Skip to content
Toggle navigation
Projects
Groups
Snippets
Help
Toggle navigation
This project
Loading...
Sign in
罗鑫霖
/
vion-tools
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Settings
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit 076ce683
authored
Jan 25, 2022
by
李金轩
Browse Files
Options
Browse Files
Tag
Download
Email Patches
Plain Diff
ljx
1 parent
430b72bd
Hide whitespace changes
Inline
Side-by-side
Showing
18 changed files
with
804 additions
and
519 deletions
public/config.js
src/Request/PublicAxiosInstance.js
src/router/index.js
src/views/DataRepair/DataRepair.less
src/views/DataRepair/DataRepair.vue
src/views/DataRepair/DataRepairApi.js
src/views/DataRepair/FaceData/FaceData.js
src/views/DataRepair/FaceData/FaceData.less
src/views/DataRepair/FaceData/FaceData.vue
src/views/DataRepair/PassengerFlowData/PassengerFlowData.less
src/views/DataRepair/PassengerFlowData/PassengerFlowData.vue
src/views/EquipmentTimeErrorVerification/EquipmentTimeErrorVerification.vue
src/views/DataRepair/PassengerFlowData/PassengerFlowData.js → src/views/EquipmentTimeErrorVerification/EquipmentTimeErrorVerificationApi.js
src/views/Main/Icons/logo.svg
src/views/Main/Main.vue
src/views/SnapshotCluster/ClusterResult/ClusterResult.vue
src/views/SnapshotCluster/SnapshotRecord/SnapshotRecord.vue
src/views/Test/Test.vue
public/config.js
View file @
076ce68
window
.
_baseUrl
=
[
'localhost'
,
'192.168.1.104'
].
includes
(
window
.
location
.
hostname
)
?
'http://store.keliuyun.com:9998'
:
''
// window._baseUrl = ['localhost', '192.168.1.104'].includes(window.location.hostname) ? 'http://store.keliuyun.com:9998' : ''
window
.
_baseUrl
=
'http://36.112.68.214:9999'
const
log
=
console
.
log
.
bind
(
console
)
const
log
=
console
.
log
.
bind
(
console
)
src/Request/PublicAxiosInstance.js
View file @
076ce68
...
@@ -15,7 +15,7 @@ axiosInstance.interceptors.request.use(
...
@@ -15,7 +15,7 @@ axiosInstance.interceptors.request.use(
config
=>
{
config
=>
{
if
([
'localhost'
,
'192.168.1.104'
].
includes
(
window
.
location
.
hostname
))
if
([
'localhost'
,
'192.168.1.104'
].
includes
(
window
.
location
.
hostname
))
{
{
config
.
headers
.
Authorization
=
'
a1c28c12-cb12-439a-ae1e-e816e3f8f809
'
config
.
headers
.
Authorization
=
'
2c74d6cb-e060-4fbf-9ebe-60f67313de91
'
}
}
else
else
{
{
...
...
src/router/index.js
View file @
076ce68
...
@@ -42,6 +42,10 @@ const route = [
...
@@ -42,6 +42,10 @@ const route = [
path
:
'/'
,
path
:
'/'
,
redirect
:
'/Main/DataRerun'
,
redirect
:
'/Main/DataRerun'
,
},
},
{
path
:
'/test'
,
component
:
()
=>
import
(
"@/views/Test/Test.vue"
),
},
...
menuRoute
...
menuRoute
]
]
...
...
src/views/DataRepair/DataRepair.less
View file @
076ce68
.success {
color: #26ff29;
}
.failed {
color: red;
}
src/views/DataRepair/DataRepair.vue
View file @
076ce68
<
template
>
<
template
>
<a-menu
v-model:selectedKeys=
"currentMenu"
mode=
"horizontal"
>
<a-form
:model=
"queryForm"
layout=
"inline"
:label-col=
"
{ style: { width: '100px' } }">
<a-menu-item
:key=
"'客流数据'"
>
<a-form-item
label=
"集团:"
style=
"padding: 5px 0"
>
客流数据
<a-select
v-model:value=
"queryForm.account_id"
</a-menu-item>
style=
"width: 280px"
<a-menu-item
:key=
"'人脸数据'"
>
mode=
"multiple"
人脸数据
:maxTagCount=
"1"
</a-menu-item>
@
change=
"onAccountChange"
</a-menu>
>
<div
v-show=
"currentMenu[0] === '客流数据'"
>
<a-select-option
<PassengerFlowData></PassengerFlowData>
v-for=
"item in accountList"
</div>
:value=
"item.id"
<div
v-show=
"currentMenu[0] === '人脸数据'"
>
>
<FaceData></FaceData>
{{
item
.
name
}}
</div>
</a-select-option>
</a-select>
</a-form-item>
<a-form-item
label=
"广场:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.plaza_id"
style=
"width: 280px"
mode=
"multiple"
:maxTagCount=
"1"
@
change=
"onPlazaChange"
>
<a-select-option
v-for=
"item in plazaList"
:value=
"item.id"
>
{{
item
.
name
}}
</a-select-option>
</a-select>
</a-form-item>
<a-form-item
label=
"监控点名称:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.gate_id"
style=
"width: 280px"
mode=
"multiple"
:maxTagCount=
"1"
@
change=
"onGateChange"
>
<a-select-option
v-for=
"item in gateList"
:value=
"item.id"
>
{{
item
.
name
}}
</a-select-option>
</a-select>
</a-form-item>
<a-form-item
label=
"设备通道号:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.channel_id"
style=
"width: 280px"
mode=
"multiple"
:maxTagCount=
"1"
>
<a-select-option
v-for=
"item in channelList"
:value=
"item"
>
{{
item
}}
</a-select-option>
</a-select>
</a-form-item>
<a-form-item
label=
"修补日期:"
style=
"padding: 5px 0"
>
<a-date-picker
v-model:value=
"queryForm.repairDate"
style=
"width: 280px"
/>
</a-form-item>
<a-form-item
label=
"参考日期:"
style=
"padding: 5px 0"
>
<a-date-picker
v-model:value=
"queryForm.referenceDate"
style=
"width: 280px"
/>
</a-form-item>
<a-form-item
label=
"开始时间:"
style=
"padding: 5px 0"
>
<a-time-picker
v-model:value=
"queryForm.startTime"
style=
"width: 280px"
/>
</a-form-item>
<a-form-item
label=
"结束时间:"
style=
"padding: 5px 0"
>
<a-time-picker
v-model:value=
"queryForm.endTime"
style=
"width: 280px"
/>
</a-form-item>
<a-form-item
label=
"数据波动比例:"
style=
"padding: 5px 0"
>
<a-input
v-model:value=
"queryForm.minFactor"
style=
"width: 129px"
/>
至
<a-input
v-model:value=
"queryForm.maxFactor"
style=
"width: 129px"
/>
</a-form-item>
<a-form-item
style=
"padding: 5px 0"
>
<a-button
type=
"primary"
@
click=
"preview"
>
预览
</a-button>
</a-form-item>
<a-form-item
style=
"padding: 5px 0"
>
<a-button
type=
"primary"
@
click=
"repair"
>
修补
</a-button>
</a-form-item>
</a-form>
<a-table
:dataSource=
"dataList"
v-loading=
"isLoading"
:columns=
"[
{
title: '监控点名称',
dataIndex: 'gatename',
align:'center',
},
{
title: '设备号',
dataIndex: 'deviceSerialnum',
align:'center',
},
{
title: '通道号',
dataIndex: 'channelSerialnum',
align:'center',
},
{
title: '参考数据条数',
dataIndex: 'sourceCount',
align:'center',
},
{
title: '实际数据条数',
dataIndex: 'targetCount',
align:'center',
},
{
title: '参考数据量',
dataIndex: 'sourceInnum',
align:'center',
},
{
title: '实际数据量',
dataIndex: 'targetInnum',
align:'center',
},
{
title: '状态',
dataIndex: 'status',
align:'center',
slots: {
customRender: 'status',
},
},
{
title: '操作',
dataIndex: 'address',
align:'center',
},
]" :pagination="false">
<template
#
status=
"
{ text }">
<span
:class=
"getClass(text)"
>
{{
text
}}
</span>
</
template
>
</a-table>
</template>
</template>
<
script
>
<
script
>
import
{
ref
}
from
'vue'
import
featureLibraryRebuildApi
from
'@/views/FeatureLibraryRebuild/FeatureLibraryRebuildApi'
import
FaceData
from
'./FaceData/FaceData.vue'
import
{
reactive
,
ref
,
toRaw
}
from
'vue'
import
PassengerFlowData
from
'./PassengerFlowData/PassengerFlowData.vue'
import
moment
from
'moment'
import
snapshotRecordApi
from
'@/views/SnapshotCluster/SnapshotRecord/SnapshotRecordApi'
import
{
isArray
}
from
'@/PublicUtil/Judgment'
import
{
filterEmptyValueInObject
,
formatDate
,
formatTime
}
from
'@/PublicUtil/PublicUtil'
import
peopleReContrastApi
from
'@/views/PeopleReContrast/PeopleReContrastApi'
import
dataRepairApi
from
'@/views/DataRepair/DataRepairApi'
import
clusterResultApi
from
'@/views/SnapshotCluster/ClusterResult/ClusterResultApi'
export
default
{
export
default
{
components
:
{
FaceData
,
PassengerFlowData
,
},
setup
()
{
setup
()
{
// scalar
const
isLoading
=
ref
(
false
)
const
currentMenu
=
ref
([
'客流数据'
])
const
resultList
=
ref
([
])
// sequence
// sequence
// mapping
const
accountList
=
ref
([])
// function
const
plazaList
=
ref
([])
const
zoneList
=
ref
([])
const
gateList
=
ref
([])
const
channelList
=
ref
([])
const
dataList
=
ref
([])
const
queryForm
=
reactive
(
{
account_id
:
[],
plaza_id
:
[],
gate_id
:
[],
channel_id
:
[],
repairDate
:
moment
(
moment
().
format
(
'YYYY-MM-DD'
),
'YYYY-MM-DD'
),
referenceDate
:
moment
(
moment
().
format
(
'YYYY-MM-DD'
),
'YYYY-MM-DD'
),
startTime
:
moment
(
'00:00:00'
,
'HH:mm:ss'
),
endTime
:
moment
(
'23:59:59'
,
'HH:mm:ss'
),
minFactor
:
0
,
maxFactor
:
1
,
}
)
const
onAccountChange
=
function
()
{
getPlazaList
()
queryForm
.
gate_id
=
[]
gateList
.
value
=
[]
queryForm
.
channel_id
=
[]
channelList
.
value
=
[]
}
const
onPlazaChange
=
function
()
{
getGateList
()
queryForm
.
channel_id
=
[]
channelList
.
value
=
[]
}
const
onGateChange
=
function
()
{
getChannelList
()
}
const
getPlazaList
=
function
()
{
queryForm
.
plaza_id
=
[]
plazaList
.
value
=
[]
snapshotRecordApi
.
getPlazaList
(
{
account_id
:
queryForm
.
account_id
.
toString
()
}
).
then
(
(
r
)
=>
{
if
(
isArray
(
r
))
{
plazaList
.
value
=
r
}
}
)
}
const
getAccountList
=
function
()
{
queryForm
.
account_id
=
[]
accountList
.
value
=
[]
snapshotRecordApi
.
getAccountList
().
then
(
(
r
)
=>
{
if
(
isArray
(
r
))
{
accountList
.
value
=
r
}
}
)
}
const
getGateList
=
async
function
()
{
queryForm
.
gate_id
=
[]
gateList
.
value
=
[]
let
tempList
=
[]
for
(
const
account
of
queryForm
.
account_id
)
{
for
(
const
plaza
of
queryForm
.
plaza_id
)
{
const
r
=
await
dataRepairApi
.
getGateList
(
{
accountIds
:
account
,
mallIds
:
plaza
,
}
)
if
(
isArray
(
r
))
{
tempList
.
push
(...
r
)
}
}
}
gateList
.
value
=
[...
new
Set
(
tempList
)]
}
const
getChannelList
=
async
function
()
{
queryForm
.
channel_id
=
[]
channelList
.
value
=
[]
let
tempList
=
[]
for
(
const
gate
of
queryForm
.
gate_id
)
{
const
r
=
await
dataRepairApi
.
getChannelList
(
{
gateId
:
gate
,
}
)
if
(
isArray
(
r
))
{
tempList
.
push
(...
r
)
}
}
channelList
.
value
=
tempList
}
const
floatToPercent
=
function
(
floatNum
)
{
if
(
!
floatNum
)
{
return
0
}
let
formatNum
=
Math
.
floor
(
floatNum
*
100
)
return
formatNum
>=
100
?
100
:
formatNum
}
const
dealMessage
=
function
(
message
)
{
// scheduleType
const
{
dates
,
mallIds
,
mallNames
,
status
,
stepCount
,
scheduleType
,
counter
}
=
message
let
resObj
=
{}
resObj
.
dates
=
dates
resObj
.
mallIds
=
mallIds
resObj
.
mallNames
=
mallNames
resObj
.
status
=
status
resObj
.
progress
=
floatToPercent
(
stepCount
)
resObj
.
totalNum
=
0
resObj
.
totalPage
=
0
resObj
.
current
=
0
resObj
.
curPageSize
=
0
resObj
.
currentPage
=
0
resObj
.
scheduleType
=
scheduleType
if
(
counter
)
{
// dataNum dateMallNum step totalData totalDate totalMall totalMallDateProduct allDataCount
resObj
.
totalNum
=
counter
.
allDataCount
resObj
.
totalPage
=
counter
.
totalMallDateProduct
resObj
.
current
=
counter
.
dataNum
resObj
.
curPageSize
=
counter
.
totalData
resObj
.
currentPage
=
counter
.
dateMallNum
}
if
(
resultList
.
value
.
length
)
{
const
isSameScheduleType
=
resultList
.
value
.
some
(
item
=>
item
.
scheduleType
===
scheduleType
)
isSameScheduleType
?
resultList
.
value
.
forEach
(
item
=>
{
//
item
.
progress
=
floatToPercent
(
stepCount
)
if
(
counter
)
{
item
.
totalNum
=
counter
.
allDataCount
item
.
totalPage
=
counter
.
totalMallDateProduct
item
.
current
=
counter
.
dataNum
item
.
curPageSize
=
counter
.
totalData
item
.
currentPage
=
counter
.
dateMallNum
}
})
:
resultList
.
value
.
push
(
resObj
)
resObj
=
{}
}
else
{
resultList
.
value
.
push
(
resObj
)
resObj
=
{}
}
}
const
preview
=
async
function
()
{
isLoading
.
value
=
true
dataList
.
value
=
[]
const
rawData
=
toRaw
(
queryForm
)
for
(
const
channelId
of
rawData
.
channel_id
)
{
const
data
=
filterEmptyValueInObject
(
{
channelSerialnum
:
channelId
,
maxFactor
:
rawData
.
maxFactor
,
minFactor
:
rawData
.
minFactor
,
targetStartDate
:
formatDate
(
rawData
.
repairDate
)
+
' '
+
formatTime
(
rawData
.
startTime
),
targetEndDate
:
formatDate
(
rawData
.
repairDate
)
+
' '
+
formatTime
(
rawData
.
endTime
),
sourceStartDate
:
formatDate
(
rawData
.
referenceDate
)
+
' '
+
formatTime
(
rawData
.
startTime
),
sourceEndDate
:
formatDate
(
rawData
.
referenceDate
)
+
' '
+
formatTime
(
rawData
.
endTime
),
}
)
const
r
=
await
dataRepairApi
.
preview
(
data
)
if
(
r
.
msg_code
===
200
)
{
r
.
data
.
status
=
'已修复'
}
else
{
r
.
data
.
status
=
'未执行'
}
dataList
.
value
.
push
(
r
.
data
)
}
isLoading
.
value
=
false
}
const
repair
=
async
function
()
{
isLoading
.
value
=
true
dataList
.
value
=
[]
const
rawData
=
toRaw
(
queryForm
)
for
(
const
channelId
of
rawData
.
channel_id
)
{
const
data
=
filterEmptyValueInObject
(
{
channelSerialnum
:
channelId
,
maxFactor
:
rawData
.
maxFactor
,
minFactor
:
rawData
.
minFactor
,
targetStartDate
:
formatDate
(
rawData
.
repairDate
)
+
' '
+
formatTime
(
rawData
.
startTime
),
targetEndDate
:
formatDate
(
rawData
.
repairDate
)
+
' '
+
formatTime
(
rawData
.
endTime
),
sourceStartDate
:
formatDate
(
rawData
.
referenceDate
)
+
' '
+
formatTime
(
rawData
.
startTime
),
sourceEndDate
:
formatDate
(
rawData
.
referenceDate
)
+
' '
+
formatTime
(
rawData
.
endTime
),
}
)
const
r
=
await
dataRepairApi
.
repair
(
data
)
if
(
r
.
msg_code
===
200
)
{
r
.
data
.
status
=
'已修复'
}
else
{
r
.
data
.
status
=
'未执行'
}
dataList
.
value
.
push
(
r
.
data
)
}
isLoading
.
value
=
false
}
const
getClass
=
function
(
text
)
{
switch
(
text
)
{
case
'已修复'
:
{
return
'success'
}
case
'未执行'
:
{
return
'failed'
}
default
:
{
break
}
}
}
const
__main
=
function
()
{
getAccountList
()
}
__main
()
return
{
return
{
// scalar
// scalar
currentMenu
,
isLoading
,
// sequence
// sequence
// mapping
accountList
,
plazaList
,
zoneList
,
gateList
,
channelList
,
resultList
,
dataList
,
queryForm
,
// function
// function
onAccountChange
,
onPlazaChange
,
onGateChange
,
preview
,
repair
,
getClass
,
}
}
}
}
}
}
</
script
>
</
script
>
<
style
scoped
>
<
style
lang=
"less"
scoped
>
@import
"./DataRepair.less"
;
</
style
>
</
style
>
src/views/DataRepair/DataRepairApi.js
0 → 100644
View file @
076ce68
import
axiosInstance
from
"@/Request/PublicAxiosInstance"
import
{
filterEmptyValueInObject
}
from
"@/PublicUtil/PublicUtil"
class
DataRepairApi
{
getGateList
(
data
)
{
return
axiosInstance
.
request
(
{
method
:
'GET'
,
url
:
`/gates`
,
params
:
data
}
)
}
getChannelList
(
data
)
{
return
axiosInstance
.
request
(
{
method
:
'GET'
,
url
:
`/channels`
,
params
:
data
}
)
}
preview
(
data
)
{
return
axiosInstance
.
request
(
{
method
:
'POST'
,
url
:
`/preview/viewCountData`
,
data
:
data
}
)
}
repair
(
data
)
{
return
axiosInstance
.
request
(
{
method
:
'POST'
,
url
:
`/preview/updateCountData`
,
data
:
data
}
)
}
}
const
dataRepairApi
=
new
DataRepairApi
()
export
default
dataRepairApi
src/views/DataRepair/FaceData/FaceData.js
deleted
100644 → 0
View file @
430b72b
import
axiosInstance
from
"@/Request/PublicAxiosInstance"
import
{
filterEmptyValueInObject
}
from
"@/PublicUtil/PublicUtil"
class
SnapshotRecordApi
{
getGateList
(
data
)
{
return
axiosInstance
.
request
(
{
method
:
'GET'
,
url
:
`/gates/gateByInfo`
,
params
:
filterEmptyValueInObject
(
{
account_id
:
data
.
account_id
,
plaza_id
:
data
.
plaza_id
,
zone_id
:
data
.
zone_id
,
type
:
data
.
type
,
},
)
}
)
}
}
const
snapshotRecordApi
=
new
SnapshotRecordApi
()
export
default
snapshotRecordApi
src/views/DataRepair/FaceData/FaceData.less
deleted
100644 → 0
View file @
430b72b
.single-image {
height: 300px;
width: 100%;
}
src/views/DataRepair/FaceData/FaceData.vue
deleted
100644 → 0
View file @
430b72b
<
template
>
</
template
>
<
script
>
export
default
{
setup
()
{
return
{}
}
}
</
script
>
<
style
lang=
"less"
scoped
>
@import
"./FaceData"
;
</
style
>
src/views/DataRepair/PassengerFlowData/PassengerFlowData.less
deleted
100644 → 0
View file @
430b72b
.single-image {
height: 300px;
width: 100%;
}
src/views/DataRepair/PassengerFlowData/PassengerFlowData.vue
deleted
100644 → 0
View file @
430b72b
<
template
>
<a-form
:model=
"queryForm"
layout=
"inline"
>
<a-form-item
label=
"集团:"
>
<a-select
v-model:value=
"queryForm.account_id"
style=
"width: 200px"
mode=
"multiple"
:maxTagCount=
"1"
@
change=
"onAccountChange"
>
<a-select-option
v-for=
"item in accountList"
:value=
"item.id"
>
{{
item
.
name
}}
</a-select-option>
</a-select>
</a-form-item>
<a-form-item
label=
"广场:"
>
<a-select
v-model:value=
"queryForm.plaza_id"
style=
"width: 200px"
mode=
"multiple"
:maxTagCount=
"1"
@
change=
"onPlazaChange"
>
<a-select-option
v-for=
"item in plazaList"
:value=
"item.id"
>
{{
item
.
name
}}
</a-select-option>
</a-select>
</a-form-item>
<a-form-item
label=
"监控点:"
>
<a-select
v-model:value=
"queryForm.gate_id"
style=
"width: 200px"
mode=
"multiple"
:maxTagCount=
"1"
>
<a-select-option
v-for=
"item in gateList"
:value=
"item.id"
>
{{
item
.
name
}}
</a-select-option>
</a-select>
</a-form-item>
<a-form-item
label=
"开始日期:"
>
<a-date-picker
v-model:value=
"queryForm.startDate"
/>
</a-form-item>
<a-form-item
label=
"结束日期:"
>
<a-date-picker
v-model:value=
"queryForm.endDate"
/>
</a-form-item>
<a-form-item>
<a-button
type=
"primary"
@
click=
"confirmSearch"
>
开始
</a-button>
</a-form-item>
</a-form>
</
template
>
<
script
>
import
{
reactive
,
ref
,
toRaw
}
from
'vue'
import
moment
from
'moment'
import
snapshotRecordApi
from
'@/views/SnapshotCluster/SnapshotRecord/SnapshotRecordApi'
import
{
isArray
}
from
'@/PublicUtil/Judgment'
import
{
formatDate
,
formatTime
}
from
'@/PublicUtil/PublicUtil'
import
InformationDisplay
from
'@/component/InformationDisplay/InformationDisplay'
import
dataRerunApi
from
'@/views/DataRerun/DataRerunApi'
import
passengerFlowDataApi
from
'@/views/DataRepair/PassengerFlowData/PassengerFlowData'
export
default
{
components
:
{
InformationDisplay
,
},
setup
()
{
const
resultList
=
ref
([])
const
informationList
=
ref
([])
// sequence
const
accountList
=
ref
([])
const
plazaList
=
ref
([])
const
zoneList
=
ref
([])
const
gateList
=
ref
([])
let
webSocketMap
=
{
mallcountData
:
undefined
,
floorcountData
:
undefined
,
zonecountData
:
undefined
,
gatecountData
:
undefined
,
mallfaceSta
:
undefined
,
floorfaceSta
:
undefined
,
zonefaceSta
:
undefined
,
gatefaceSta
:
undefined
,
}
// mapping
const
progressMap
=
{
mallcountData
:
"商场客流"
,
floorcountData
:
"楼层客流"
,
zonecountData
:
"店铺客流"
,
gatecountData
:
"监控点客流"
,
mallfaceSta
:
"商场人脸"
,
floorfaceSta
:
"楼层人脸"
,
zonefaceSta
:
"店铺人脸"
,
gatefaceSta
:
"监控点人脸"
}
const
queryForm
=
reactive
(
{
account_id
:
[],
plaza_id
:
[],
gate_id
:
[],
channel
:
[],
startDate
:
moment
(
moment
().
format
(
'YYYY-MM-DD'
),
'YYYY-MM-DD'
),
endDate
:
moment
(
moment
().
format
(
'YYYY-MM-DD'
),
'YYYY-MM-DD'
),
}
)
const
onAccountChange
=
function
()
{
getPlazaList
()
}
const
onPlazaChange
=
function
()
{
getGateList
()
}
const
getGateList
=
function
()
{
queryForm
.
gate_id
=
[]
gateList
.
value
=
[]
passengerFlowDataApi
.
getGateList
(
{
accountIds
:
queryForm
.
account_id
.
toString
(),
mallIds
:
queryForm
.
plaza_id
.
toString
(),
}
).
then
(
(
r
)
=>
{
if
(
isArray
(
r
))
{
gateList
.
value
=
r
}
}
)
}
const
getPlazaList
=
function
()
{
queryForm
.
plaza_id
=
[]
plazaList
.
value
=
[]
snapshotRecordApi
.
getPlazaList
(
{
account_id
:
queryForm
.
account_id
.
toString
()
}
).
then
(
(
r
)
=>
{
if
(
isArray
(
r
))
{
plazaList
.
value
=
r
}
}
)
}
const
getAccountList
=
function
()
{
queryForm
.
account_id
=
[]
accountList
.
value
=
[]
snapshotRecordApi
.
getAccountList
().
then
(
(
r
)
=>
{
if
(
isArray
(
r
))
{
accountList
.
value
=
r
}
}
)
}
const
floatToPercent
=
function
(
floatNum
)
{
if
(
!
floatNum
)
{
return
0
}
let
formatNum
=
Math
.
floor
(
floatNum
*
100
)
return
formatNum
>=
100
?
100
:
formatNum
}
const
dealMessage
=
function
(
message
)
{
// scheduleType
const
{
dates
,
mallIds
,
mallNames
,
status
,
stepCount
,
scheduleType
,
counter
}
=
message
let
resObj
=
{}
resObj
.
dates
=
dates
resObj
.
mallIds
=
mallIds
resObj
.
mallNames
=
mallNames
resObj
.
status
=
status
resObj
.
progress
=
floatToPercent
(
stepCount
)
resObj
.
totalNum
=
0
resObj
.
totalPage
=
0
resObj
.
current
=
0
resObj
.
curPageSize
=
0
resObj
.
currentPage
=
0
resObj
.
scheduleType
=
scheduleType
if
(
counter
)
{
// dataNum dateMallNum step totalData totalDate totalMall totalMallDateProduct allDataCount
resObj
.
totalNum
=
counter
.
allDataCount
resObj
.
totalPage
=
counter
.
totalMallDateProduct
resObj
.
current
=
counter
.
dataNum
resObj
.
curPageSize
=
counter
.
totalData
resObj
.
currentPage
=
counter
.
dateMallNum
}
if
(
resultList
.
value
.
length
)
{
const
isSameScheduleType
=
resultList
.
value
.
some
(
item
=>
item
.
scheduleType
===
scheduleType
)
isSameScheduleType
?
resultList
.
value
.
forEach
(
item
=>
{
//
item
.
progress
=
floatToPercent
(
stepCount
)
if
(
counter
)
{
item
.
totalNum
=
counter
.
allDataCount
item
.
totalPage
=
counter
.
totalMallDateProduct
item
.
current
=
counter
.
dataNum
item
.
curPageSize
=
counter
.
totalData
item
.
currentPage
=
counter
.
dateMallNum
}
})
:
resultList
.
value
.
push
(
resObj
)
resObj
=
{}
}
else
{
resultList
.
value
.
push
(
resObj
)
resObj
=
{}
}
}
const
initializeWebSocket
=
function
(
scheduleType
)
{
if
(
webSocketMap
[
scheduleType
]
!==
undefined
)
{
webSocketMap
[
scheduleType
].
close
()
}
webSocketMap
[
scheduleType
]
=
new
WebSocket
(
`ws://store.keliuyun.com:9998/recal/schedule/
${
scheduleType
}
`
)
webSocketMap
[
scheduleType
].
onopen
=
()
=>
{
queryData
(
scheduleType
)
}
webSocketMap
[
scheduleType
].
onmessage
=
function
(
event
)
{
let
message
=
JSON
.
parse
(
event
.
data
)
dealMessage
(
message
)
if
(
message
.
stepCount
===
1
)
{
webSocketMap
[
scheduleType
].
close
()
}
}
}
const
queryData
=
function
(
scheduleType
)
{
const
rawData
=
toRaw
(
queryForm
)
const
data
=
{
mallIds
:
rawData
.
plaza_id
,
scheduleType
:
scheduleType
,
startDate
:
formatDate
(
rawData
.
startDate
)
+
' '
+
'00:00:00'
,
endDate
:
formatDate
(
rawData
.
endDate
)
+
' '
+
'00:00:00'
,
}
dataRerunApi
.
getResult
(
data
,
scheduleType
).
then
(
(
r
)
=>
{
informationList
.
value
.
push
(
r
)
}
)
}
const
confirmSearch
=
function
()
{
passengerFlowDataApi
.
preview
()
}
const
__main
=
function
()
{
getAccountList
()
}
__main
()
return
{
// sequence
accountList
,
plazaList
,
zoneList
,
gateList
,
resultList
,
informationList
,
// mapping
progressMap
,
queryForm
,
onAccountChange
,
initializeWebSocket
,
confirmSearch
,
onPlazaChange
,
}
}
}
</
script
>
<
style
lang=
"less"
scoped
>
@import
"./PassengerFlowData.less"
;
</
style
>
src/views/EquipmentTimeErrorVerification/EquipmentTimeErrorVerification.vue
View file @
076ce68
<
template
>
<
template
>
132231
<a-table
:dataSource=
"dataList"
v-loading=
"isLoading"
:columns=
"[
</
template
>
{
title: '集团名称',
dataIndex: 'accountname',
align:'center',
slots: {
customRender: 'accountname',
},
},
{
title: '商场名称',
dataIndex: 'mallname',
align:'center',
},
{
title: '监控点名称',
dataIndex: 'gatename',
align:'center',
},
{
title: '设备号',
dataIndex: 'serialnum',
align:'center',
},
{
title: 'IP',
dataIndex: 'local_ip',
align:'center',
},
{
title: 'mac地址',
dataIndex: 'mac',
align:'center',
},
{
title: '发送的错误的数据日期',
dataIndex: 'errordate',
align:'center',
},
{
title: '统计日期',
dataIndex: 'countdate',
align:'center',
}
]" :pagination="false">
</a-table>
</
template
>
<
script
>
<
script
>
export
default
{
import
{
defineComponent
,
ref
}
from
'vue'
import
equipmentTimeErrorVerificationApi
from
'@/views/EquipmentTimeErrorVerification/EquipmentTimeErrorVerificationApi'
export
default
defineComponent
({
setup
()
{
setup
()
{
return
{}
const
dataList
=
ref
([])
}
const
isLoading
=
ref
(
false
)
}
</
script
>
<
style
scoped
>
const
__main
=
function
()
{
equipmentTimeErrorVerificationApi
.
getList
().
then
(
(
r
)
=>
{
dataList
.
value
=
r
.
data
}
)
}
</
style
>
__main
()
return
{
isLoading
,
dataList
,
}
},
})
</
script
>
src/views/
DataRepair/PassengerFlowData/PassengerFlowData
.js
→
src/views/
EquipmentTimeErrorVerification/EquipmentTimeErrorVerificationApi
.js
View file @
076ce68
import
axiosInstance
from
"@/Request/PublicAxiosInstance"
import
axiosInstance
from
"@/Request/PublicAxiosInstance"
import
{
filterEmptyValueInObject
}
from
"@/PublicUtil/PublicUtil"
import
{
filterEmptyValueInObject
}
from
"@/PublicUtil/PublicUtil"
class
PassengerFlowData
Api
{
class
EquipmentTimeErrorVerification
Api
{
preview
(
data
)
{
getList
(
data
)
{
return
axiosInstance
.
request
(
return
axiosInstance
.
request
(
{
{
method
:
'
POS
T'
,
method
:
'
GE
T'
,
url
:
`/
preview/viewCountData
`
,
url
:
`/
devices/deviceInfo
`
,
}
}
)
)
}
}
}
}
const
passengerFlowDataApi
=
new
PassengerFlowData
Api
()
const
equipmentTimeErrorVerificationApi
=
new
EquipmentTimeErrorVerification
Api
()
export
default
passengerFlowData
Api
export
default
equipmentTimeErrorVerification
Api
src/views/Main/Icons/logo.svg
0 → 100644
View file @
076ce68
<?xml version="1.0" encoding="UTF-8"?>
<svg
width=
"135px"
height=
"32px"
viewBox=
"0 0 135 32"
version=
"1.1"
xmlns=
"http://www.w3.org/2000/svg"
xmlns:xlink=
"http://www.w3.org/1999/xlink"
>
<title>
文安logo
</title>
<g
id=
"控件"
stroke=
"none"
stroke-width=
"1"
fill=
"none"
fill-rule=
"evenodd"
>
<g
id=
"header"
transform=
"translate(-40.000000, -17.000000)"
>
<image
id=
"文安logo"
x=
"32"
y=
"10"
width=
"152"
height=
"44"
xlink:href=
""
></image>
</g>
</g>
</svg>
\ No newline at end of file
\ No newline at end of file
src/views/Main/Main.vue
View file @
076ce68
<
template
>
<
template
>
<el-container>
<el-container>
<el-aside
style=
"background: black"
width=
"200px"
>
<el-header
style=
"background: black"
>
<a-menu
mode=
"inline"
theme=
"dark"
@
click=
"onClick"
>
<el-row
style=
"height: 100%"
>
<a-menu-item
:key=
"'/Main/DataRerun'"
>
<el-col
:span=
"2"
>
<span>
数据重跑
</span>
<div
class=
"flex-vertical-center"
style=
"height: 100%"
>
</a-menu-item>
<img
:src=
"require('./Icons/logo.svg')"
style=
"height: auto;width:210px"
/>
<a-menu-item
:key=
"'/Main/DataRepair'"
>
</div>
<span>
数据修补
</span>
</el-col>
</a-menu-item>
<el-col
:span=
"22"
>
<a-menu-item
:key=
"'/Main/FeatureReExtract'"
>
<div
class=
"flex-vertical-center"
style=
"font-size: 17px;display: flex;height: 100%;color: white; justify-content: flex-end"
>
<span>
特征重提
</span>
<span
style=
"margin: 0 20px"
>
{{
currentTime
}}
</span>
</a-menu-item>
<span>
{{
getWeek
()
}}
</span>
<a-menu-item
:key=
"'/Main/FeatureLibraryRebuild'"
>
</div>
<span>
特征库重建
</span>
</el-col>
</a-menu-item>
</el-row>
<a-menu-item
:key=
"'/Main/PeopleReContrast'"
>
</el-header>
<span>
人员重新比对
</span>
<el-main
style=
"padding: 0"
>
</a-menu-item>
<el-container>
<a-menu-item
:key=
"'/Main/SnapshotCluster'"
>
<el-aside
style=
"background: black"
width=
"190px"
>
<span>
抓拍聚类
</span>
<a-menu
mode=
"inline"
theme=
"dark"
@
click=
"onClick"
>
</a-menu-item>
<a-menu-item
:key=
"'/Main/DataRerun'"
>
<a-menu-item
:key=
"'/Main/EquipmentTimeErrorVerification'"
>
<span>
数据重跑
</span>
<span>
设备时间错误校验
</span>
</a-menu-item>
</a-menu-item>
<a-menu-item
:key=
"'/Main/DataRepair'"
>
</a-menu>
<span>
数据修补
</span>
</el-aside>
</a-menu-item>
<el-main>
<a-menu-item
:key=
"'/Main/FeatureReExtract'"
>
<router-view
:key=
"$route.fullPath"
></router-view>
<span>
特征重提
</span>
</a-menu-item>
<a-menu-item
:key=
"'/Main/FeatureLibraryRebuild'"
>
<span>
特征库重建
</span>
</a-menu-item>
<a-menu-item
:key=
"'/Main/PeopleReContrast'"
>
<span>
人员重新比对
</span>
</a-menu-item>
<a-menu-item
:key=
"'/Main/SnapshotCluster'"
>
<span>
抓拍聚类
</span>
</a-menu-item>
<a-menu-item
:key=
"'/Main/EquipmentTimeErrorVerification'"
>
<span>
设备时间错误校验
</span>
</a-menu-item>
</a-menu>
</el-aside>
<el-main>
<router-view
:key=
"$route.fullPath"
></router-view>
</el-main>
</el-container>
</el-main>
</el-main>
</el-container>
</el-container>
</
template
>
</
template
>
<
script
>
<
script
>
import
{
defineComponent
,
ref
}
from
'vue'
import
{
defineComponent
,
ref
}
from
'vue'
import
{
useRouter
}
from
'vue-router'
import
{
useRouter
}
from
'vue-router'
import
moment
from
"moment"
export
default
defineComponent
({
export
default
defineComponent
({
setup
()
{
setup
()
{
const
router
=
useRouter
()
const
router
=
useRouter
()
const
currentTime
=
ref
(
moment
().
format
(
"YYYY-MM-DD HH:mm:ss"
))
const
goto
=
function
(
path
)
{
const
goto
=
function
(
path
)
{
router
.
push
(
path
)
router
.
push
(
path
)
...
@@ -57,20 +78,45 @@ export default defineComponent({
...
@@ -57,20 +78,45 @@ export default defineComponent({
)
)
}
}
const
getWeek
=
function
(
date
)
{
let
week
=
moment
(
date
).
day
()
switch
(
week
)
{
case
1
:
return
'星期一'
case
2
:
return
'星期二'
case
3
:
return
'星期三'
case
4
:
return
'星期四'
case
5
:
return
'星期五'
case
6
:
return
'星期六'
case
0
:
return
'星期天'
}
}
const
__main
=
function
()
{
const
__main
=
function
()
{
// log(accessedMenu)
setInterval
(()
=>
{
currentTime
.
value
=
moment
().
format
(
"YYYY-MM-DD HH:mm:ss"
)
},
1000
)
}
}
__main
()
__main
()
return
{
return
{
// scalar
// scalar
currentTime
,
// sequence
// sequence
// mapping
// mapping
// function
// function
goto
,
goto
,
getOpeneds
,
getOpeneds
,
onClick
,
onClick
,
getWeek
,
}
}
},
},
})
})
...
...
src/views/SnapshotCluster/ClusterResult/ClusterResult.vue
View file @
076ce68
<
template
>
<
template
>
<a-form
:model=
"queryForm"
layout=
"inline"
:label-col=
"
{
span: 4}" :wrapper-col="{span: 14
}">
<a-form
:model=
"queryForm"
layout=
"inline"
:label-col=
"
{
style: { width: '70px' }
}">
<a-form-item
label=
"集团:"
>
<a-form-item
label=
"集团:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.account_id"
<a-select
v-model:value=
"queryForm.account_id"
style=
"width: 2
0
0px"
style=
"width: 2
8
0px"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
@
change=
"onAccountChange"
@
change=
"onAccountChange"
...
@@ -15,9 +15,9 @@
...
@@ -15,9 +15,9 @@
</a-select-option>
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"广场:"
>
<a-form-item
label=
"广场:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.plaza_id"
<a-select
v-model:value=
"queryForm.plaza_id"
style=
"width: 2
0
0px"
style=
"width: 2
8
0px"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
@
change=
"onPlazaChange"
@
change=
"onPlazaChange"
...
@@ -29,8 +29,8 @@
...
@@ -29,8 +29,8 @@
</a-select-option>
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"出入类型:"
>
<a-form-item
label=
"出入类型:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.type"
style=
"width: 2
0
0px"
>
<a-select
v-model:value=
"queryForm.type"
style=
"width: 2
8
0px"
>
<a-select-option
:value=
"0"
>
全场
</a-select-option>
<a-select-option
:value=
"0"
>
全场
</a-select-option>
<a-select-option
:value=
"1"
>
广场出入口
</a-select-option>
<a-select-option
:value=
"1"
>
广场出入口
</a-select-option>
<a-select-option
:value=
"2"
>
楼层出入口
</a-select-option>
<a-select-option
:value=
"2"
>
楼层出入口
</a-select-option>
...
@@ -38,9 +38,9 @@
...
@@ -38,9 +38,9 @@
<a-select-option
:value=
"4"
>
其他
</a-select-option>
<a-select-option
:value=
"4"
>
其他
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"区域信息:"
>
<a-form-item
label=
"区域信息:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.zone_id"
<a-select
v-model:value=
"queryForm.zone_id"
style=
"width: 2
0
0px"
style=
"width: 2
8
0px"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
@
change=
"onZoneChange"
>
@
change=
"onZoneChange"
>
...
@@ -52,9 +52,9 @@
...
@@ -52,9 +52,9 @@
</a-select-option>
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"监控点:"
>
<a-form-item
label=
"监控点:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.gate_id"
<a-select
v-model:value=
"queryForm.gate_id"
style=
"width: 2
0
0px"
style=
"width: 2
8
0px"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
>
:maxTagCount=
"1"
>
<a-select-option
<a-select-option
...
@@ -65,44 +65,44 @@
...
@@ -65,44 +65,44 @@
</a-select-option>
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"方向:"
>
<a-form-item
label=
"方向:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.direction"
<a-select
v-model:value=
"queryForm.direction"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
style=
"width: 2
0
0px"
>
style=
"width: 2
8
0px"
>
<a-select-option
:value=
"1"
>
进
</a-select-option>
<a-select-option
:value=
"1"
>
进
</a-select-option>
<a-select-option
:value=
"-1"
>
出
</a-select-option>
<a-select-option
:value=
"-1"
>
出
</a-select-option>
<a-select-option
:value=
"0"
>
横穿
</a-select-option>
<a-select-option
:value=
"0"
>
横穿
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"抓怕类型:"
>
<a-form-item
label=
"抓怕类型:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.picType"
style=
"width: 2
0
0px"
>
<a-select
v-model:value=
"queryForm.picType"
style=
"width: 2
8
0px"
>
<a-select-option
:value=
"1"
>
半身照
</a-select-option>
<a-select-option
:value=
"1"
>
半身照
</a-select-option>
<a-select-option
:value=
"2"
>
全身照
</a-select-option>
<a-select-option
:value=
"2"
>
全身照
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"人员类型:"
>
<a-form-item
label=
"人员类型:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.personType"
<a-select
v-model:value=
"queryForm.personType"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
style=
"width: 2
0
0px"
>
style=
"width: 2
8
0px"
>
<a-select-option
:value=
"1"
>
店员
</a-select-option>
<a-select-option
:value=
"1"
>
店员
</a-select-option>
<a-select-option
:value=
"2"
>
顾客
</a-select-option>
<a-select-option
:value=
"2"
>
顾客
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"选择日期:"
>
<a-form-item
label=
"选择日期:"
style=
"padding: 5px 0"
>
<a-date-picker
v-model:value=
"queryForm.date"
:format=
"'YYYY-MM-DD'"
/>
<a-date-picker
v-model:value=
"queryForm.date"
:format=
"'YYYY-MM-DD'"
style=
"width: 280px"
/>
</a-form-item>
</a-form-item>
<a-form-item
label=
"选择时间:"
>
<a-form-item
label=
"选择时间:"
style=
"padding: 5px 0"
>
<a-time-picker
v-model:value=
"queryForm.startTime"
/>
<a-time-picker
v-model:value=
"queryForm.startTime"
style=
"width: 140px"
/>
<a-time-picker
v-model:value=
"queryForm.endTime"
/>
<a-time-picker
v-model:value=
"queryForm.endTime"
style=
"width: 140px"
/>
</a-form-item>
</a-form-item>
<a-form-item
label=
"图片数量:"
>
<a-form-item
label=
"图片数量:"
style=
"padding: 5px 0"
>
<a-input
v-model:value=
"queryForm.minPic"
style=
"width: 1
00
px"
/>
<a-input
v-model:value=
"queryForm.minPic"
style=
"width: 1
29
px"
/>
至
至
<a-input
v-model:value=
"queryForm.maxPic"
style=
"width: 1
00
px"
/>
<a-input
v-model:value=
"queryForm.maxPic"
style=
"width: 1
29
px"
/>
</a-form-item>
</a-form-item>
<a-form-item>
<a-form-item
style=
"padding: 5px 0"
>
<a-button
type=
"primary"
@
click=
"confirmSearch"
:loading=
"isLoading"
>
查询
</a-button>
<a-button
type=
"primary"
@
click=
"confirmSearch"
:loading=
"isLoading"
>
查询
</a-button>
</a-form-item>
</a-form-item>
</a-form>
</a-form>
...
...
src/views/SnapshotCluster/SnapshotRecord/SnapshotRecord.vue
View file @
076ce68
<
template
>
<
template
>
<a-form
:model=
"queryForm"
layout=
"inline"
>
<a-form
:model=
"queryForm"
layout=
"inline"
:label-col=
"
{ style: { width: '70px' } }"
>
<a-form-item
label=
"集团:"
>
<a-form-item
label=
"集团:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.account_id"
<a-select
v-model:value=
"queryForm.account_id"
style=
"width: 2
0
0px"
style=
"width: 2
8
0px"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
@
change=
"onAccountChange"
@
change=
"onAccountChange"
...
@@ -15,9 +15,9 @@
...
@@ -15,9 +15,9 @@
</a-select-option>
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"广场:"
>
<a-form-item
label=
"广场:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.plaza_id"
<a-select
v-model:value=
"queryForm.plaza_id"
style=
"width: 2
0
0px"
style=
"width: 2
8
0px"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
@
change=
"onPlazaChange"
@
change=
"onPlazaChange"
...
@@ -29,8 +29,8 @@
...
@@ -29,8 +29,8 @@
</a-select-option>
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"出入类型:"
>
<a-form-item
label=
"出入类型:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.type"
style=
"width: 2
0
0px"
>
<a-select
v-model:value=
"queryForm.type"
style=
"width: 2
8
0px"
>
<a-select-option
:value=
"0"
>
全场
</a-select-option>
<a-select-option
:value=
"0"
>
全场
</a-select-option>
<a-select-option
:value=
"1"
>
广场出入口
</a-select-option>
<a-select-option
:value=
"1"
>
广场出入口
</a-select-option>
<a-select-option
:value=
"2"
>
楼层出入口
</a-select-option>
<a-select-option
:value=
"2"
>
楼层出入口
</a-select-option>
...
@@ -38,9 +38,9 @@
...
@@ -38,9 +38,9 @@
<a-select-option
:value=
"4"
>
其他
</a-select-option>
<a-select-option
:value=
"4"
>
其他
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"区域信息:"
>
<a-form-item
label=
"区域信息:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.zone_id"
<a-select
v-model:value=
"queryForm.zone_id"
style=
"width: 2
0
0px"
style=
"width: 2
8
0px"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
@
change=
"onZoneChange"
>
@
change=
"onZoneChange"
>
...
@@ -52,9 +52,9 @@
...
@@ -52,9 +52,9 @@
</a-select-option>
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"监控点:"
>
<a-form-item
label=
"监控点:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.gate_id"
<a-select
v-model:value=
"queryForm.gate_id"
style=
"width: 2
0
0px"
style=
"width: 2
8
0px"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
>
:maxTagCount=
"1"
>
<a-select-option
<a-select-option
...
@@ -65,39 +65,39 @@
...
@@ -65,39 +65,39 @@
</a-select-option>
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"方向:"
>
<a-form-item
label=
"方向:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.direction"
<a-select
v-model:value=
"queryForm.direction"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
style=
"width: 2
0
0px"
>
style=
"width: 2
8
0px"
>
<a-select-option
:value=
"1"
>
进
</a-select-option>
<a-select-option
:value=
"1"
>
进
</a-select-option>
<a-select-option
:value=
"-1"
>
出
</a-select-option>
<a-select-option
:value=
"-1"
>
出
</a-select-option>
<a-select-option
:value=
"0"
>
横穿
</a-select-option>
<a-select-option
:value=
"0"
>
横穿
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"抓怕类型:"
>
<a-form-item
label=
"抓怕类型:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.picType"
style=
"width: 2
0
0px"
>
<a-select
v-model:value=
"queryForm.picType"
style=
"width: 2
8
0px"
>
<a-select-option
:value=
"1"
>
半身照
</a-select-option>
<a-select-option
:value=
"1"
>
半身照
</a-select-option>
<a-select-option
:value=
"2"
>
全身照
</a-select-option>
<a-select-option
:value=
"2"
>
全身照
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"人员类型:"
>
<a-form-item
label=
"人员类型:"
style=
"padding: 5px 0"
>
<a-select
v-model:value=
"queryForm.personType"
<a-select
v-model:value=
"queryForm.personType"
mode=
"multiple"
mode=
"multiple"
:maxTagCount=
"1"
:maxTagCount=
"1"
style=
"width: 2
0
0px"
>
style=
"width: 2
8
0px"
>
<a-select-option
:value=
"1"
>
店员
</a-select-option>
<a-select-option
:value=
"1"
>
店员
</a-select-option>
<a-select-option
:value=
"2"
>
顾客
</a-select-option>
<a-select-option
:value=
"2"
>
顾客
</a-select-option>
</a-select>
</a-select>
</a-form-item>
</a-form-item>
<a-form-item
label=
"选择日期:"
>
<a-form-item
label=
"选择日期:"
style=
"padding: 5px 0"
>
<a-date-picker
v-model:value=
"queryForm.date"
:format=
"'YYYY-MM-DD'"
/>
<a-date-picker
v-model:value=
"queryForm.date"
:format=
"'YYYY-MM-DD'"
style=
"width: 280px"
/>
</a-form-item>
</a-form-item>
<a-form-item
label=
"选择时间:"
>
<a-form-item
label=
"选择时间:"
style=
"padding: 5px 0"
>
<a-time-picker
v-model:value=
"queryForm.startTime"
/>
<a-time-picker
v-model:value=
"queryForm.startTime"
style=
"width: 140px"
/>
<a-time-picker
v-model:value=
"queryForm.endTime"
/>
<a-time-picker
v-model:value=
"queryForm.endTime"
style=
"width: 140px"
/>
</a-form-item>
</a-form-item>
<a-form-item>
<a-form-item
style=
"padding: 5px 0"
>
<a-button
type=
"primary"
@
click=
"confirmSearch"
:loading=
"isLoading"
>
查询
</a-button>
<a-button
type=
"primary"
@
click=
"confirmSearch"
:loading=
"isLoading"
>
查询
</a-button>
</a-form-item>
</a-form-item>
</a-form>
</a-form>
...
...
src/views/Test/Test.vue
View file @
076ce68
<
template
>
<
template
>
<div
class=
"container"
ref=
"container"
:style=
"
{ height: containerHeight }">
<a-table
:columns=
"columns"
:data-source=
"data"
>
<div
class=
"empty"
:style=
"
{ height: emptyHeight }">
</div>
<template
#
name=
"
{ text }">
<ul
class=
"list"
:style=
"
{ transform: `translateY(${translateY})` }">
<a>
{{
text
}}
</a>
<li
v-for=
"item in listData"
:key=
"item"
class=
"item"
:style=
"
{ height: itemHeight }">
{{
item
}}
</li>
</
template
>
</ul>
<
template
#
customTitle
>
</div>
<span>
<smile-outlined/>
Name
</span>
</
template
>
<
template
#
tags=
"{ text: tags }"
>
<span>
<a-tag
v-for=
"tag in tags"
:key=
"tag"
:color=
"tag === 'loser' ? 'volcano' : tag.length > 5 ? 'geekblue' : 'green'"
>
{{
tag
.
toUpperCase
()
}}
</a-tag>
</span>
</
template
>
<
template
#
action=
"{ record }"
>
<span>
<a>
Invite 一
{{
record
.
name
}}
</a>
<a-divider
type=
"vertical"
/>
<a>
Delete
</a>
<a-divider
type=
"vertical"
/>
<a
class=
"ant-dropdown-link"
>
More actions
<down-outlined/>
</a>
</span>
</
template
>
</a-table>
</template>
</template>
<
script
>
<
script
>
import
{
computed
,
onMounted
,
ref
}
from
'vue'
import
{
SmileOutlined
,
DownOutlined
}
from
'@ant-design/icons-vue'
import
{
defineComponent
}
from
'vue'
export
default
{
const
columns
=
[
{
dataIndex
:
'name'
,
key
:
'name'
,
slots
:
{
title
:
'customTitle'
,
customRender
:
'name'
,
},
},
{
title
:
'Age'
,
dataIndex
:
'age'
,
key
:
'age'
,
},
{
title
:
'Address'
,
dataIndex
:
'address'
,
key
:
'address'
,
},
{
title
:
'Tags'
,
key
:
'tags'
,
dataIndex
:
'tags'
,
slots
:
{
customRender
:
'tags'
,
},
},
{
title
:
'Action'
,
key
:
'action'
,
slots
:
{
customRender
:
'action'
,
},
},
]
const
data
=
[
{
key
:
'1'
,
name
:
'John Brown'
,
age
:
32
,
address
:
'New York No. 1 Lake Park'
,
tags
:
[
'nice'
,
'developer'
],
},
{
key
:
'2'
,
name
:
'Jim Green'
,
age
:
42
,
address
:
'London No. 1 Lake Park'
,
tags
:
[
'loser'
],
},
{
key
:
'3'
,
name
:
'Joe Black'
,
age
:
32
,
address
:
'Sidney No. 1 Lake Park'
,
tags
:
[
'cool'
,
'teacher'
],
},
]
export
default
defineComponent
({
setup
()
{
setup
()
{
const
oriData
=
Array
.
from
({
length
:
100
},
(
v
,
k
)
=>
k
)
const
itemHeight
=
20
const
emptyHeight
=
itemHeight
*
oriData
.
length
const
containerHeight
=
window
.
innerHeight
const
itemCount
=
Math
.
ceil
(
containerHeight
/
itemHeight
)
const
container
=
ref
(
null
)
const
start
=
ref
(
0
)
const
translateY
=
ref
(
0
)
const
listData
=
computed
(()
=>
{
return
oriData
.
slice
(
start
.
value
,
start
.
value
+
itemCount
+
1
)
})
onMounted
(
()
=>
{
container
.
value
.
addEventListener
(
'scroll'
,
e
=>
{
const
{
scrollTop
}
=
e
.
target
start
.
value
=
Math
.
floor
(
scrollTop
/
itemHeight
)
translateY
.
value
=
scrollTop
+
'px'
}
)
}
)
return
{
return
{
listData
,
data
,
container
,
columns
,
translateY
,
containerHeight
:
containerHeight
+
'px'
,
itemHeight
:
itemHeight
+
'px'
,
emptyHeight
:
emptyHeight
+
'px'
}
}
}
},
}
components
:
{
SmileOutlined
,
DownOutlined
,
},
})
</
script
>
</
script
>
<
style
lang=
"less"
scoped
>
.container
{
overflow
:
auto
;
display
:
flex
;
}
</
style
>
Write
Preview
Markdown
is supported
Attach a file
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to post a comment