| | |
| | | |
| | | <el-row type="flex" justify="start" v-for="(items, index) in groupData(videoData)"> |
| | | <el-col :span="4" v-for="item in items" :key="item.id"> |
| | | <el-card :style="{ borderBottomColor: getStatusColor(item.auditStatus) }"style="width:150px;height: 150px;text-align: center;border-bottom-width: 3px;"> |
| | | <el-card style="width:150px;height: 150px;text-align: center;border-bottom-width: 3px;"> |
| | | <i style="font-size: 40px;padding: 15px;" :class="item.icon"></i> |
| | | <div style="font-size:12px; text-align: center; height: 25px;">{{ item.name }} </div> |
| | | <div style="font-size:12px; text-align: center; height: 25px;">{{ item.ruleName }} </div> |
| | | <div class="bottom clearfix"> |
| | | <el-button type="text" class="button" @click="handleUpdate(item)">修改</el-button> |
| | | </div> |
| | |
| | | |
| | | <el-row type="flex" justify="start" v-for="(items, index) in groupData(carData)"> |
| | | <el-col :span="4" v-for="item in items" :key="item.id"> |
| | | <el-card :style="{ borderBottomColor: getStatusColor(item.auditStatus) }"style="width:150px;height: 150px;text-align: center;border-bottom-width: 3px;"> |
| | | <el-card style="width:150px;height: 150px;text-align: center;border-bottom-width: 3px;"> |
| | | <i style="font-size: 40px;padding: 15px;" :class="item.icon"></i> |
| | | <div style="font-size:12px; text-align: center; height: 25px;">{{ item.name }} </div> |
| | | <div style="font-size:12px; text-align: center; height: 25px;">{{ item.ruleName }} </div> |
| | | <div class="bottom clearfix"> |
| | | <el-button type="text" class="button" @click="handleUpdate(item)">修改</el-button> |
| | | </div> |
| | |
| | | |
| | | <el-row type="flex" justify="start" v-for="(items, index) in groupData(faceData)"> |
| | | <el-col :span="4" v-for="item in items" :key="item.id"> |
| | | <el-card :style="{ borderBottomColor: getStatusColor(item.auditStatus) }"style="width:150px;height: 150px;text-align: center;border-bottom-width: 3px;"> |
| | | <el-card style="width:150px;height: 150px;text-align: center;border-bottom-width: 3px;"> |
| | | <i style="font-size: 40px;padding: 15px;" :class="item.icon"></i> |
| | | <div style="font-size:12px; text-align: center; height: 25px;">{{ item.name }} </div> |
| | | <div style="font-size:12px; text-align: center; height: 25px;">{{ item.ruleName }} </div> |
| | | <div class="bottom clearfix"> |
| | | <el-button type="text" class="button" @click="handleUpdate(item)">修改</el-button> |
| | | </div> |
| | |
| | | <el-dialog :title="title" :visible.sync="open" width="600px" append-to-body> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |
| | | <el-form-item label="规则名称" prop="ruleName"> |
| | | <el-input v-model="form.name" placeholder="请输入规则名称"/> |
| | | </el-form-item> |
| | | <el-form-item label="考核类型" prop="examineCategory"> |
| | | <el-select v-model="form.examineCategory" placeholder="考核类型"> |
| | | <el-option |
| | | v-for="dict in dict.type.platform_examine_category" |
| | | :key="dict.value" |
| | | :label="dict.label" |
| | | :value="parseInt(dict.value)" |
| | | /> |
| | | </el-select> |
| | | <el-input v-model="form.ruleName" placeholder="请输入规则名称"/> |
| | | </el-form-item> |
| | | <el-form-item label="规则类型" prop="ruleCategory"> |
| | | <el-select v-model="form.ruleCategory" placeholder="规则类型"> |
| | |
| | | v-for="dict in dict.type.platform_rule_category" |
| | | :key="dict.value" |
| | | :label="dict.label" |
| | | :value="dict.value" |
| | | :value="parseInt(dict.value)" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | |
| | | |
| | | <script> |
| | | import { listCheckRule, getCheckRule, delCheckRule, addCheckRule, updateCheckRule } from "@/api/platform/check-rule"; |
| | | import { templateSelect} from "@/api/platform/check-template" |
| | | export default { |
| | | name: "CheckRule", |
| | | dicts: ['platform_audit_state','platform_rule_category'], |
| | |
| | | ruleCategory: null, |
| | | templateId: null, |
| | | }, |
| | | videoData: [ |
| | | { name: '平台在线率', icon: 'el-icon-connection', ruleDescription: '省厅对市级共享和联网平台进行实时监测,市级共享/联网平台每月离线总时长在30分钟以内的平台在线率为100%,每超过30分钟扣10个百分点,扣完为止。' + |
| | | '每个月底最后4个工作日为预留的调试时间,可进行平台对接调试或者升级改造,平台对接调试或者升级改造须提前向省厅报备。除' + |
| | | '每月底4个工作日,其余时间报备每次扣10个百分点,每次报备不超过24小时,每月不超过3次。(重大特殊情况,如重大自然灾害等报厅领导批示)', examineCategory:0,ruleCategory:'0', auditStatus: 'approved'}, |
| | | { name: '一机一档合格率', icon: 'el-icon-folder', ruleDescription: '运维平台每月初对各地上传至联网平台的“一机一档”数据库中的摄像机档案数据进行质量校验,对必填项填报准确、规范的档案数据视为合格。\n' + |
| | | '一机一档合格率=合格的档案数据条数/档案数据总条数', examineCategory:0,ruleCategory:'0', auditStatus: 'pending' }, |
| | | { name: '一机一档注册率', icon: 'el-icon-folder', ruleDescription: '运维平台每月对省厅视图库的前端摄像机点位数量和一机一档的数据匹配。(上月底最后一天确认一机一档车辆、人脸点位数,1号由视图库侧进行考核)\n' + |
| | | '人脸卡口资产注册率=资产库登记在用的人脸卡口数量/(未注册的在线人脸卡口数量+资产库登记在用的人脸卡口数量)\n' + |
| | | '车辆卡口资产注册率=资产库登记在用的人脸卡口数量/(未注册的在线人脸卡口数量+资产库登记在用的人脸卡口数量)', examineCategory:0,ruleCategory:'0', auditStatus: 'rejected' }, |
| | | { name: '档案考核比', icon: 'el-icon-folder', ruleDescription: '描述信息', examineCategory:0,ruleCategory:'0',auditStatus: 'approved' }, |
| | | { name: '点位在线率', icon: 'el-icon-search', ruleDescription: '描述信息', examineCategory:0,ruleCategory:'0',auditStatus: 'approved'}, |
| | | { name: '录像可用率', icon: 'el-icon-turn-off', ruleDescription: '描述信息',examineCategory:0,ruleCategory:'0',auditStatus: 'approved'}, |
| | | { name: '标注正确率', icon: 'el-icon-place', ruleDescription: '描述信息', examineCategory:0,ruleCategory:'0',auditStatus: 'approved' }, |
| | | { name: '校时正确率', icon: 'el-icon-place', ruleDescription: '描述信息', examineCategory:0,ruleCategory:'0',auditStatus: 'approved' }, |
| | | { name: '重点点位在线率', icon: 'el-icon-place', ruleDescription: '描述信息', examineCategory:0,ruleCategory:'0',auditStatus: 'approved'}, |
| | | { name: '重点点位校时正确率', icon: 'el-icon-place', ruleDescription: '描述信息', examineCategory:0,ruleCategory:'0',auditStatus: 'approved' }, |
| | | { name: '重点指挥图像在线率', icon: 'el-icon-place', ruleDescription: '描述信息', examineCategory:0,ruleCategory:'0',auditStatus: 'approved' }, |
| | | { name: '视频图像资源安全管理', icon: 'el-icon-place', ruleDescription: '描述信息', examineCategory:0,ruleCategory:'0',auditStatus: 'approved' }, |
| | | ], |
| | | carData: [ |
| | | { name: '视图库对接稳定性', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '点位在线率', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '联网卡口设备目录一致率', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '车辆卡口信息采集准确率', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '车辆卡口设备抓拍数据完整性', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '车辆卡口设备抓拍数据准确性', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '车辆卡口设备时钟准确性', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '车辆卡口设备抓拍数据上传及时性', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '车辆卡口设备url可用性', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '车辆卡口设备抓拍数据大图可用性', icon: 'el-icon-truck', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | ], |
| | | faceData: [ |
| | | { name: '视图库对接稳定性', icon: 'el-icon-alarm-clock', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '点位在线率', icon: 'el-icon-user', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '目录一致率', icon: 'el-icon-data-line', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '人脸卡口信息采集准确率', icon: 'el-icon-timer', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '设备抓拍图片合格性', icon: 'el-icon-money', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '设备抓拍图片时钟准确性', icon: 'el-icon-data-analysis', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '抓拍人脸数据上传及时性', icon: 'el-icon-data-analysis', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | { name: '人脸卡口设备抓拍数据大图可用性', icon: 'el-icon-data-analysis', ruleDescription: '描述信息', auditStatus: 'approved' }, |
| | | ], |
| | | videoData: [], |
| | | carData: [], |
| | | faceData: [], |
| | | activeIndex: '0', |
| | | // 表单参数 |
| | | form: {}, |
| | |
| | | this.queryParams["end"] = this.daterangeCreateTime[1]; |
| | | } |
| | | listCheckRule(this.queryParams).then(response => { |
| | | this.checkRuleList = response.rows; |
| | | this.videoData = response.data.videoRules; |
| | | this.faceData = response.data.faceRules; |
| | | this.carData = response.data.carRules; |
| | | this.total = response.total; |
| | | this.loading = false; |
| | | }); |
| | |
| | | .el-menu{ |
| | | margin: 10px auto; |
| | | } |
| | | |
| | | </style> |