飞天云平台-国产化
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

172 lines
6.0 KiB

<template>
<div style="height: calc(100vh - 232px);">
<div class="head-container">
<div class="head-search">
<el-select v-model="query.doorCodes" clearable size="small" placeholder="门禁列表选择" class="filter-item" style="width: 140px;" @change="crud.toQuery">
<i slot="prefix" class="iconfont icon-zhuangtai" />
<el-option v-for="item in doorOptions" :key="item.key" :label="item.display_name" :value="item.key" />
</el-select>
<date-range-picker v-model="blurryTime" class="date-item" />
<rrOperation>
<template v-slot:right>
<el-button class="filter-item filter-refresh" size="mini" type="warning" icon="el-icon-refresh-left" @click="resetQuery()">重置</el-button>
</template>
</rrOperation>
</div>
<crudOperation :permission="permission">
<template v-slot:right>
<el-button :loading="crud.downloadLoading" size="mini" @click="doExport">
<i class="iconfont icon-daochu" />
导出
</el-button>
</template>
</crudOperation>
</div>
<div class="container-wrap">
<span class="right-top-line" />
<span class="left-bottom-line" />
<el-table ref="table" v-loading="crud.loading" highlight-current-row style="width: 100%;" height="calc(100vh - 330px)" :data="crud.data" @selection-change="crud.selectionChangeHandler">
<el-table-column type="index" label="序号" width="55" align="center" />
<el-table-column prop="dev_sn" label="门禁设备" />
<el-table-column prop="person_name" label="通行人员" />
<el-table-column prop="pass_direction" label="进出方向">
<template slot-scope="scope">
<div>{{ scope.row.pass_direction === 1?'进':'出' }}</div>
</template>
</el-table-column>
<el-table-column prop="pass_type" label="进出凭证类型">
<template slot-scope="scope">
<div>{{ scope.row.pass_type === 1 ? '证号':'身份证/一卡通/读者证' }}</div>
</template>
</el-table-column>
<el-table-column prop="pass_card" label="卡号" />
<el-table-column prop="pass_time" label="时间">
<template slot-scope="scope">
<div>{{ scope.row.pass_time | parseTime }}</div>
</template>
</el-table-column>
</el-table>
<!--分页组件-->
<pagination v-if="crud.data.length !== 0" />
</div>
</div>
</template>
<script>
import crudFace from '@/api/faceRecognition/index'
import { FetchDeviceTreeByType } from '@/api/deviceVI/index'
import CRUD, { presenter, header, crud } from '@crud/crud'
import rrOperation from '@crud/RR.operation'
import crudOperation from '@crud/CRUD.operation'
import pagination from '@crud/Pagination'
import DateRangePicker from '@/components/DateRangePicker'
import { exportFile } from '@/utils/index'
import qs from 'qs'
import { mapGetters } from 'vuex'
export default {
name: 'PersonInfoManage',
components: { pagination, crudOperation, rrOperation, DateRangePicker },
cruds() {
return CRUD({ title: '门禁日志', url: 'api/accessLog/initAccessControlLog', crudMethod: { ...crudFace }, optShow: {
add: false,
edit: false,
del: false,
reset: false,
download: false,
group: false
}})
},
mixins: [presenter(), header(), crud()],
data() {
return {
permission: {
add: ['admin', 'column:add'],
edit: ['admin', 'column:edit'],
del: ['admin', 'column:del']
},
doorOptions: [
],
blurryTime: []
}
},
computed: {
...mapGetters([
'baseApi',
'user'
])
},
created() {
this.getDeviceTreeByType()
},
mounted() {
},
methods: {
getDeviceTreeByType() {
const params = {
'libcode': this.user.fonds.fondsNo,
'deviceType': 3
}
FetchDeviceTreeByType(params).then(res => {
this.doorOptions = res
}).catch(() => {
})
},
[CRUD.HOOK.beforeRefresh]() {
this.crud.query.libcode = this.user.fonds.fondsNo
if (this.blurryTime) {
this.crud.query.startTime = this.blurryTime[0]
this.crud.query.endTime = this.blurryTime[1]
} else {
this.crud.query.startTime = null
this.crud.query.endTime = null
}
},
[CRUD.HOOK.afterRefresh]() {
},
resetQuery() {
this.blurryTime = null
this.crud.query.startTime = null
this.crud.query.endTime = null
this.crud.query.doorCodes = null
this.crud.toQuery()
},
doExport() {
console.log('doExport', this.crud.page.total)
if (this.crud.page.total >= 10000) {
this.handleExport('导出数据大于10000条,时间可能较长')
} else {
this.handleExport('此操作将导出所有数据')
}
},
handleExport(message) {
this.crud.downloadLoading = true
this.$confirm(message + '<span>你是否还要继续?</span>', '提示', {
confirmButtonText: '继续',
cancelButtonText: '取消',
type: 'warning',
dangerouslyUseHTMLString: true
}).then(() => {
const params = {
'libcode': this.user.fonds.fondsNo,
'doorCodes': this.crud.query.doorCodes,
'startTime': this.blurryTime.length !== 0 ? this.blurryTime[0].split(' ')[0] : null,
'endTime': this.blurryTime.length !== 0 ? this.blurryTime[1].split(' ')[0] : null
}
console.log('exportFile', params)
exportFile(this.baseApi + '/api/accessLog/downloadAccessControlLog?' + qs.stringify(params, { indices: false, allowDots: true, skipNulls: false }))
this.crud.downloadLoading = false
}).catch(() => {
console.log('取消')
this.crud.downloadLoading = false
})
}
}
}
</script>
<style lang="scss" scoped>
::v-deep .el-pagination{
margin: 24px 0 10px 0 !important
}
</style>