lukeyan #33

Merged
lukeyan merged 6 commits from lukeyan into master 2 years ago

@ -48,3 +48,35 @@ export function addVideoList(params) {
params params
}) })
} }
// 新增智能感应
export function addPerceptionList(params) {
return request({
url: '/safety/tbDevicePerceptionInfo/insert',
method: 'get',
params
})
}
// 修改智能感应
export function changePerceptionList(params) {
return request({
url: '/safety/tbDevicePerceptionInfo/update',
method: 'post',
params
})
}
// 导出视频监控
export function exportVideo(params) {
return request({
url: '/safety/tbDeviceVideoInfo/export',
method: 'post',
params
})
}
// 导出智能感应
export function exportPerception(params) {
return request({
url: '/safety/tbDevicePerceptionInfo/export',
method: 'post',
params
})
}

@ -0,0 +1,26 @@
// 平安指数模块接口
import request from '@/utils/request'
// 请求综合指数
export function safeCalculation(params) {
return request({
url: '/safety/system/tbSafeCalculationRule/getCalculationRule',
method: 'post',
params
})
}
// 修改综合指数
export function saveSafeCalculation(data) {
return request({
url: '/safety/system/tbSafeCalculationRule',
method: 'put',
data
})
}
// 指标表格数据
export function getIndexTable(params) {
return request({
url: '/safety/system/tbSafeRule/getRuleTree',
method: 'post',
params
})
}

@ -392,7 +392,7 @@ export default {
/* 图片鼠标经过按钮 */ /* 图片鼠标经过按钮 */
.btn { .btn {
margin-left: 25%; margin-left: 20%;
margin-top: 25%; margin-top: 25%;
button { button {

@ -4,6 +4,7 @@
class="dialog" class="dialog"
:title="dialogTitle" :title="dialogTitle"
:visible.sync="visible" :visible.sync="visible"
@close="close()"
:close-on-click-modal="false" :close-on-click-modal="false"
width="970px" width="970px"
> >
@ -11,183 +12,447 @@
<!-- 设备基础信息表单 --> <!-- 设备基础信息表单 -->
<div class="equipment_form"> <div class="equipment_form">
<p>设备基础信息</p> <p>设备基础信息</p>
<el-form ref="equipmentForm" :model="equipmentForm"> <el-form
<el-form-item label="企业名称"> ref="equipmentForm"
<el-select :model="form"
v-model="equipmentForm.company.villageName" :rules="rules"
placeholder="请选择企业" :disabled="disabled"
> >
<el-form-item label="企业名称" prop="companyName">
<el-select v-model="form.companyName" placeholder="请选择企业">
<el-option <el-option
v-for="item in equipmentForm.company" v-for="item in list.company"
:key="item.villageCode" @click.native="companyNameselected(item.companyName, item.id)"
:label="item.villageName" :key="item.id"
:value="item.villageCode" :label="item.companyName"
:value="item.id"
> >
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="设备名称"> <el-form-item> </el-form-item>
<el-input v-model="equipmentForm.name"></el-input> <el-form-item label="设备名称" prop="deviceName">
<el-input v-model="form.deviceName"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备IP"> <el-form-item label="设备IP" prop="deviceIp">
<el-input v-model="equipmentForm.ip"></el-input> <el-input v-model="form.deviceIp"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="登录账号"> <el-form-item label="登录账号" prop="account">
<el-input v-model="equipmentForm.passUser"></el-input> <el-input v-model="form.account"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="登录密码"> <el-form-item label="登录密码" prop="password">
<el-input v-model="equipmentForm.passNum"></el-input> <el-input v-model="form.password"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备大类"> <el-form-item label="设备大类" prop="devicePerceptionParentTypeCn">
<el-input v-model="equipmentForm.big"></el-input> <el-select
v-model="form.devicePerceptionParentTypeCn"
placeholder="请选择设备大类"
>
<el-option
v-for="item in list.perception_type"
@click.native="parent_selected(item.dictLabel,item.dictValue)"
:key="item.dictValue"
:label="item.dictLabel"
:value="item.dictValue"
>
</el-option>
</el-select>
</el-form-item> </el-form-item>
<el-form-item label="是否卡口"> <el-form-item label="是否卡口" prop="isDoorwayVideoCn">
<el-input v-model="equipmentForm.mouse"></el-input> <el-select
ref="isDoorwayVideoCn"
v-model="form.isDoorwayVideoCn"
placeholder="请选择是否卡口"
>
<el-option
v-for="item in list.isDoorwayVideoList"
@click.native="isDoorselected(item.id)"
:key="item.id"
:label="item.label"
:value="item.id"
>
</el-option>
</el-select>
</el-form-item> </el-form-item>
<el-form-item label="设备小类"> <el-form-item label="设备小类" prop="devicePerceptionSubTypeCn">
<el-input v-model="equipmentForm.small"></el-input> <el-select
v-model="form.devicePerceptionSubTypeCn"
placeholder="请选择设备小类"
>
<el-option
v-for="item in list.video_type"
@click.native="perception_selected(item.dictLabel,item.dictValue)"
:key="item.dictValue"
:label="item.dictLabel"
:value="item.dictValue"
>
</el-option>
</el-select>
</el-form-item> </el-form-item>
</el-form> </el-form>
</div> </div>
<!-- 视频通道信息表单 --> <!-- 视频通道信息表单 -->
<div class="video_form"> <div class="video_form">
<p>视频通道信息</p> <p>视频通道信息</p>
<el-form ref="videoForm" :model="videoForm"> <el-form
<el-form-item label="通道编码"> ref="videoForm"
<el-input v-model="videoForm.channelCode"></el-input> :model="form"
:rules="rules"
:disabled="disabled"
>
<el-form-item label="通道编码" prop="gbsChannelNo">
<el-input v-model="form.gbsChannelNo"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="NVR编码"> <el-form-item label="NVR编码" prop="gbsNvrNo">
<el-input v-model="videoForm.NVRCode"></el-input> <el-input v-model="form.gbsNvrNo"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="通道号"> <el-form-item label="通道号" prop="channelNo">
<el-input v-model="videoForm.channelNum"></el-input> <el-input v-model="form.channelNo"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="RTSP流地址"> <el-form-item label="RTSP流地址" prop="rtspAddress">
<el-input v-model="videoForm.address"></el-input> <el-input v-model="form.rtspAddress"></el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>
</div> </div>
<!-- 设备位置信息表单 --> <!-- 设备位置信息表单 -->
<div class="equipment_address_form"> <div class="equipment_address_form">
<p>设备位置信息</p> <p>设备位置信息</p>
<el-form ref="addressForm" :model="addressForm"> <el-form
<el-form-item label="设备经度"> ref="addressForm"
<el-input v-model="addressForm.longitude"></el-input> :model="form"
:rules="rules"
:disabled="disabled"
>
<el-form-item label="设备经度" prop="longitude">
<el-input v-model="form.longitude"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备纬度"> <el-form-item label="设备纬度" prop="latitude">
<el-input v-model="addressForm.latitude"></el-input> <el-input v-model="form.latitude"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="U3D经度"> <el-form-item label="U3D经度" prop="u3dLongitude">
<el-input v-model="addressForm.U3D_longitude"></el-input> <el-input v-model="form.u3dLongitude"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="U3D纬度"> <el-form-item label="U3D纬度" prop="u3dLatitude">
<el-input v-model="addressForm.U3D_latitude"></el-input> <el-input v-model="form.u3dLatitude"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备高度"> <el-form-item label="设备高度" prop="deviceHeight">
<el-input v-model="addressForm.equipemnt_hight"></el-input> <el-input v-model="form.deviceHeight"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="U3D高度"> <el-form-item label="U3D高度" prop="u3dHeight">
<el-input v-model="addressForm.U3D_hight"></el-input> <el-input v-model="form.u3dHeight"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备方位"> <el-form-item label="进出方向" prop="directionCn">
<el-select v-model="form.directionCn" placeholder="请选择进出方向">
<el-option
v-for="item in list.directionList"
:key="item.id"
:label="item.label"
:value="item.label"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="设备方位" prop="orientationCn">
<el-select <el-select
v-model="addressForm.equipment_orientation.orientationCode" v-model="form.orientationCn"
placeholder="请选择设备方位" placeholder="请选择设备方位"
> >
<el-option <el-option
v-for="item in addressForm.equipment_orientation" v-for="item in list.orientation_types"
:key="item.orientationCode" :key="item.dictValue"
:label="item.orientation" :label="item.dictLabel"
:value="item.orientationCode" :value="item.dictValue"
> >
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="安装位置"> <el-form-item
<el-input v-model="addressForm.equipment_position"></el-input> label="安装位置"
prop="deviceAddress"
class="deviceAddress_text"
>
<el-input v-model="form.deviceAddress"></el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>
</div> </div>
<!-- 设备其他信息表单 --> <!-- 设备其他信息表单 -->
<div class="other_form"> <div class="other_form">
<p>设备其他信息</p> <p>设备其他信息</p>
<el-form ref="otherForm" :model="otherForm"> <el-form ref="otherForm" :model="form" :disabled="disabled">
<el-form-item label="设备品牌"> <el-form-item label="设备品牌" prop="deviceBrand">
<el-input v-model="otherForm.brand"></el-input> <el-input v-model="form.deviceBrand"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备厂家"> <el-form-item label="设备厂家" prop="manufactor">
<el-input v-model="otherForm.manufacturer"></el-input> <el-input v-model="form.manufactor"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="厂家联系电话"> <el-form-item label="厂家联系电话" prop="manufactorPhone">
<el-input v-model="otherForm.manufacturer_phone"></el-input> <el-input v-model="form.manufactorPhone"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="SN号"> <el-form-item label="SN号" prop="deviceSn">
<el-input v-model="otherForm.SN_num"></el-input> <el-input v-model="form.deviceSn"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备MAC"> <el-form-item label="设备MAC" prop="deviceMac">
<el-input v-model="otherForm.MAC"></el-input> <el-input v-model="form.deviceMac"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备端口"> <el-form-item label="设备端口" prop="devicePort">
<el-input v-model="otherForm.port"></el-input> <el-input v-model="form.devicePort"></el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>
</div> </div>
</div> </div>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
<el-button @click="saveFormData"> </el-button> <el-button
<el-button> </el-button> @click="saveFormData('equipmentForm', 'videoForm', 'addressForm')"
> </el-button
>
<!-- <el-button @click="save()"></el-button> -->
<el-button @click="close()"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
</template> </template>
<script> <script>
import { debounce } from "@/utils/publicMethod_lxy/debounce.js"; import {
commonDict,
getCompanyList,
addPerceptionList,
changePerceptionList,
} from "@/api/correlationEquipment";
// import { debounce } from "@/utils/publicMethod_lxy/debounce.js";
export default { export default {
name: "addPerceptionDialog", name: "addPerceptionDialog",
data() { data() {
return { return {
visible: false, visible: false,
dialogTitle: "新建", dialogTitle: "",
equipmentForm: { list: {
//
company: [], company: [],
mouse:'', video_type: [],
perception_type: [],
isDoorwayVideoList: [
{ label: "是", id: "1" },
{ label: "否", id: "2" },
],
directionList: [
{ label: "进", id: "1" },
{ label: "出", id: "2" },
],
orientation_types: [],
}, },
form: {
//
companyId: "",
companyName: "",
deviceName: "",
deviceIp: "",
// deviceVideoParentType: "",
devicePerceptionSubType: "", //
devicePerceptionSubTypeCn: "", //
devicePerceptionParentType: "", //
devicePerceptionParentTypeCn: "", //
isDoorwayVideoCn: "",
isDoorwayVideo: "",
account: "",
password: "",
// //
videoForm: { gbsChannelNo: "",
channelCode: "", gbsNvrNo: "",
NVRCode: "", channelNo: "",
channelNum: "", rtspAddress: "",
address: "",
},
// //
addressForm: {
longitude: "", longitude: "",
latitude: "", latitude: "",
U3D_longitude: "", u3dLongitude: "",
U3D_latitude: "", u3dLatitude: "",
equipemnt_hight: "", deviceHeight: "",
U3D_hight: "", u3dHeight: "",
equipment_orientation: [], directionCn: "",
equipment_position: "", orientation: "",
}, orientationCn: "",
deviceAddress: "",
// //
otherForm: { deviceBrand: "",
brand: "", manufactor: "",
manufacturer: "", manufactorPhone: "",
manufacturer_phone: "", deviceSn: "",
SN_num: "", deviceMac: "",
MAC: "", devicePort: "",
port: "", },
disabled: false, //
rules: {
companyName: [
{ required: true, message: "请选择企业", trigger: "change" },
],
deviceName: [
{ required: true, message: "请填写设备名称", trigger: "blur" },
],
deviceIp: [
{ required: true, message: "请填写设备ip", trigger: "blur" },
],
devicePerceptionParentTypeCn: [
{ required: true, message: "请选择设备大类", trigger: "change" },
],
devicePerceptionSubTypeCn: [
{ required: true, message: "请选择设备小类", trigger: "change" },
],
gbsChannelNo: [
{ required: true, message: "请输入通道编码", trigger: "blur" },
],
gbsNvrNo: [
{ required: true, message: "请输入NVR编码", trigger: "blur" },
],
longitude: [
{ required: true, message: "请输入设备经度", trigger: "blur" },
],
latitude: [
{ required: true, message: "请输入设备经度", trigger: "blur" },
],
deviceAddress: [
{ required: true, message: "请输入安装位置", trigger: "blur" },
],
}, },
}; };
}, },
created() {},
methods: { methods: {
open() { open(num, row) {
if (num === "1") {
this.dialogTitle = "新建";
this.disabled = false;
} else if (num === "2") {
this.dialogTitle = "编辑";
this.form = row;
this.disabled = false;
console.log("row12345", row);
} else if (num === "5") {
this.dialogTitle = "详情";
this.form = row;
this.disabled = true;
}
this.visible = true; this.visible = true;
//
const params = {
dictType: "device_video_sub_type",
};
commonDict(params).then((res) => {
this.list.video_type = res.data;
});
//
const val = {
dictType: "device_perception_sub_type",
};
commonDict(val).then((res) => {
this.list.perception_type = res.data;
});
//
const param_op = {
dictType: "orientation",
};
commonDict(param_op).then((res) => {
this.list.orientation_types = res.data;
});
//
getCompanyList().then((res) => {
this.list.company = res.data;
});
},
isDoorselected(value) {
this.form.isDoorwayVideo = value; //
},
companyNameselected(name, value) {
this.form.companyName = name;
this.form.companyId = value; //
},
parent_selected(label,value) {
this.form.devicePerceptionParentTypeCn = label
this.form.devicePerceptionParentType = value; //
console.log("this.form3333", this.form);
},
perception_selected(label,value) {
this.form.devicePerceptionSubTypeCn = label
this.form.devicePerceptionSubType = value; //
console.log("this.form2222", this.form);
},
//
saveFormData(formName1,formName2,formName3) {
if (this.dialogTitle === "新建") {
this.$refs[formName1].validate((valid1) => {
if (valid1) {
this.$refs[formName2].validate((valid2) => {
if (valid2) {
this.$refs[formName3].validate((valid3) => {
if (valid3) {
const params = this.form;
addPerceptionList(params)
.then((res) => {
this.visible = false;
this.$message({
message: res.msg,
type: "success",
});
})
.catch((err) => {
console.log(err); //
});
}
}); //
} else {
this.$message.warning("请填入必填项");
}
}); //
} else {
this.$message.warning("请填入必填项");
}
}); //
} else if (this.dialogTitle === "编辑") {
this.$refs[formName1].validate((valid) => {
if (valid) {
this.$refs[formName2].validate((valid) => {
if (valid) {
this.$refs[formName3].validate((valid) => {
if (valid) {
console.log('this.form123', JSON.stringify(this.form))
console.log('this.form124', JSON.parse(JSON.stringify(this.form)))
changePerceptionList(JSON.parse(JSON.stringify(this.form)))
.then((res) => {
console.log(res);
console.log('this.form125', JSON.parse(JSON.stringify(this.form)))
this.visible = false;
this.$message.success("编辑成功");
})
.catch((err) => {
console.log(err); //
this.$message.warning("编辑失败");
});
} else {
this.$message.warning("请填入必填项");
}
}); //
} else {
this.$message.warning("请填入必填项");
}
}); //
} else {
this.$message.warning("请填入必填项");
}
});
}
},
// save() {
// console.log('this.form7777',this.form);
// },
//
close() {
this.visible = false;
//
//
this.$refs["equipmentForm"].resetFields();
//
this.$refs["videoForm"].resetFields();
//
this.$refs["addressForm"].resetFields();
//
this.$refs["otherForm"].resetFields();
}, },
saveFormData: debounce(function () {
this.$message.success("232324234");
}, 300),
}, },
}; };
</script> </script>
@ -195,12 +460,12 @@ export default {
/deep/.el-dialog { /deep/.el-dialog {
.el-dialog__title { .el-dialog__title {
color: #fff; color: #fff;
text-shadow: 0 0 9px rgba(21, 255, 198, 0.64);
} }
background-image: url("~@/assets/companyFile/dialogBack.png"); background-image: url("~@/assets/companyFile/dialogBack.png");
background-size: 100% 100%; background-size: 100% 100%;
background-repeat: no-repeat; background-repeat: no-repeat;
height: 720px; height: 750px;
/* 关闭弹窗叉号 */ /* 关闭弹窗叉号 */
.el-dialog__headerbtn { .el-dialog__headerbtn {
@ -237,6 +502,7 @@ export default {
} }
.form_body { .form_body {
margin-top: 3%;
height: 600px; height: 600px;
overflow-y: scroll; overflow-y: scroll;
p { p {
@ -254,7 +520,9 @@ export default {
background: url("~@/assets/companyFile/242112.png") no-repeat !important; background: url("~@/assets/companyFile/242112.png") no-repeat !important;
background-size: 100% 100% !important; background-size: 100% 100% !important;
} }
.equipment_form {
margin-top: -2%;
}
.form_body::-webkit-scrollbar { .form_body::-webkit-scrollbar {
width: 6px; width: 6px;
background-color: #5e666a; background-color: #5e666a;
@ -302,5 +570,13 @@ export default {
} }
} }
} }
.el-form-item.deviceAddress_text {
width: 900px !important;
.el-form-item__content {
.el-input__inner {
width: 750px;
}
}
}
} }
</style> </style>

@ -4,6 +4,7 @@
class="dialog" class="dialog"
:title="dialogTitle" :title="dialogTitle"
:visible.sync="visible" :visible.sync="visible"
@close="close()"
:close-on-click-modal="false" :close-on-click-modal="false"
width="970px" width="970px"
> >
@ -18,7 +19,11 @@
:disabled="disabled" :disabled="disabled"
> >
<el-form-item label="企业名称" prop="companyName"> <el-form-item label="企业名称" prop="companyName">
<el-select ref="companySelect" v-model="form.companyName" placeholder="请选择企业"> <el-select
ref="companySelect"
v-model="form.companyName"
placeholder="请选择企业"
>
<el-option <el-option
v-for="item in form.company" v-for="item in form.company"
:key="item.id" :key="item.id"
@ -28,6 +33,8 @@
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item>
</el-form-item>
<el-form-item label="设备名称" prop="deviceName"> <el-form-item label="设备名称" prop="deviceName">
<el-input v-model="form.deviceName"></el-input> <el-input v-model="form.deviceName"></el-input>
</el-form-item> </el-form-item>
@ -62,10 +69,10 @@
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="登录账号"> <el-form-item label="登录账号" prop="account">
<el-input v-model="form.account"></el-input> <el-input v-model="form.account"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="登录密码"> <el-form-item label="登录密码" prop="password">
<el-input v-model="form.password"></el-input> <el-input v-model="form.password"></el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -85,10 +92,10 @@
<el-form-item label="NVR编码" prop="gbsNvrNo"> <el-form-item label="NVR编码" prop="gbsNvrNo">
<el-input v-model="form.gbsNvrNo"></el-input> <el-input v-model="form.gbsNvrNo"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="通道号"> <el-form-item label="通道号" prop="channelNo">
<el-input v-model="form.channelNo"></el-input> <el-input v-model="form.channelNo"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="RTSP流地址"> <el-form-item label="RTSP流地址" prop="rtspAddress">
<el-input v-model="form.rtspAddress"></el-input> <el-input v-model="form.rtspAddress"></el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -108,19 +115,19 @@
<el-form-item label="设备纬度" prop="latitude"> <el-form-item label="设备纬度" prop="latitude">
<el-input v-model="form.latitude"></el-input> <el-input v-model="form.latitude"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="U3D经度"> <el-form-item label="U3D经度" prop="u3dLongitude">
<el-input v-model="form.u3dLongitude"></el-input> <el-input v-model="form.u3dLongitude"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="U3D纬度"> <el-form-item label="U3D纬度" prop="u3dLatitude">
<el-input v-model="form.u3dLatitude"></el-input> <el-input v-model="form.u3dLatitude"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备高度"> <el-form-item label="设备高度" prop="deviceHeight">
<el-input v-model="form.deviceHeight"></el-input> <el-input v-model="form.deviceHeight"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="U3D高度"> <el-form-item label="U3D高度" prop="u3dHeight">
<el-input v-model="form.u3dHeight"></el-input> <el-input v-model="form.u3dHeight"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备方位"> <el-form-item label="设备方位" prop="orientation">
<el-select v-model="form.orientation" placeholder="请选择设备方位"> <el-select v-model="form.orientation" placeholder="请选择设备方位">
<el-option <el-option
v-for="item in form.orientation_types" v-for="item in form.orientation_types"
@ -140,22 +147,22 @@
<div class="other_form"> <div class="other_form">
<p>设备其他信息</p> <p>设备其他信息</p>
<el-form ref="otherForm" :model="form" :disabled="disabled"> <el-form ref="otherForm" :model="form" :disabled="disabled">
<el-form-item label="设备品牌"> <el-form-item label="设备品牌" prop="deviceBrand">
<el-input v-model="form.deviceBrand"></el-input> <el-input v-model="form.deviceBrand"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备厂家"> <el-form-item label="设备厂家" prop="manufactor">
<el-input v-model="form.manufactor"></el-input> <el-input v-model="form.manufactor"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="厂家联系电话"> <el-form-item label="厂家联系电话" prop="manufactorPhone">
<el-input v-model="form.manufactorPhone"></el-input> <el-input v-model="form.manufactorPhone"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="SN号"> <el-form-item label="SN号" prop="deviceSn">
<el-input v-model="form.deviceSn"></el-input> <el-input v-model="form.deviceSn"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备MAC"> <el-form-item label="设备MAC" prop="deviceMac">
<el-input v-model="form.deviceMac"></el-input> <el-input v-model="form.deviceMac"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="设备端口"> <el-form-item label="设备端口" prop="devicePort">
<el-input v-model="form.devicePort"></el-input> <el-input v-model="form.devicePort"></el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -168,7 +175,7 @@
" "
> </el-button > </el-button
> >
<el-button> </el-button> <el-button @click="close()"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
</template> </template>
@ -260,6 +267,7 @@ export default {
}; };
}, },
created() { created() {
//
const params = { const params = {
dictType: "device_video_sub_type", dictType: "device_video_sub_type",
}; };
@ -269,15 +277,18 @@ export default {
const val = { const val = {
dictType: "device_perception_sub_type", dictType: "device_perception_sub_type",
}; };
//
commonDict(val).then((res) => { commonDict(val).then((res) => {
this.form.perception_type = res.data; this.form.perception_type = res.data;
}); });
//
const param_op = { const param_op = {
dictType: "orientation", dictType: "orientation",
}; };
commonDict(param_op).then((res) => { commonDict(param_op).then((res) => {
this.form.orientation_types = res.data; this.form.orientation_types = res.data;
}); });
//
getCompanyList().then((res) => { getCompanyList().then((res) => {
this.form.company = res.data; this.form.company = res.data;
}); });
@ -296,6 +307,7 @@ export default {
this.disabled = true; this.disabled = true;
} }
}, },
//
saveFormData: debounce(function (formName1, formName2, formName3) { saveFormData: debounce(function (formName1, formName2, formName3) {
this.$refs[formName1].validate((valid1) => { this.$refs[formName1].validate((valid1) => {
if (valid1) { if (valid1) {
@ -307,7 +319,7 @@ export default {
delete this.form.video_type; delete this.form.video_type;
delete this.form.perception_type; delete this.form.perception_type;
delete this.form.orientation_types; delete this.form.orientation_types;
this.form.companyId = this.$refs.companySelect.selected.value // id this.form.companyId = this.$refs.companySelect.selected.value; // id
const params = this.form; const params = this.form;
console.log("this.form", this.form); console.log("this.form", this.form);
if (this.dialogTitle === "新建") { if (this.dialogTitle === "新建") {
@ -336,6 +348,19 @@ export default {
} }
}); // }); //
}, 300), }, 300),
//
close() {
this.visible = false;
//
//
this.$refs['equipmentForm'].resetFields()
//
this.$refs['videoForm'].resetFields()
//
this.$refs['addressForm'].resetFields()
//
this.$refs['otherForm'].resetFields()
},
}, },
}; };
</script> </script>
@ -348,7 +373,7 @@ export default {
background-image: url("~@/assets/companyFile/dialogBack.png"); background-image: url("~@/assets/companyFile/dialogBack.png");
background-size: 100% 100%; background-size: 100% 100%;
background-repeat: no-repeat; background-repeat: no-repeat;
height: 720px; height: 750px;
/* 关闭弹窗叉号 */ /* 关闭弹窗叉号 */
.el-dialog__headerbtn { .el-dialog__headerbtn {
@ -385,6 +410,7 @@ export default {
} }
.form_body { .form_body {
margin-top: 3%;
height: 600px; height: 600px;
overflow-y: scroll; overflow-y: scroll;
p { p {
@ -402,7 +428,9 @@ export default {
background: url("~@/assets/companyFile/242112.png") no-repeat !important; background: url("~@/assets/companyFile/242112.png") no-repeat !important;
background-size: 100% 100% !important; background-size: 100% 100% !important;
} }
.equipment_form {
margin-top: -2%;
}
.form_body::-webkit-scrollbar { .form_body::-webkit-scrollbar {
width: 6px; width: 6px;
background-color: #5e666a; background-color: #5e666a;

@ -18,8 +18,15 @@
</template> </template>
<script> <script>
import { debounce } from "@/utils/publicMethod_lxy/debounce.js"; import { debounce } from "@/utils/publicMethod_lxy/debounce.js";
import { exportVideo,exportPerception } from "@/api/correlationEquipment";
export default { export default {
name: "DeriveDialog", name: "DeriveDialog",
props: {
table_title: {
type: String,
default: "",
},
},
data() { data() {
return { return {
visible: false, visible: false,
@ -30,7 +37,29 @@ export default {
this.visible = true; this.visible = true;
}, },
confrim: debounce(function () { confrim: debounce(function () {
this.$message.success("232324234"); if (this.table_title === "视频监控设备列表") {
//
exportVideo().then((res) => {
console.log(123);
console.log(res);
this.$message.success('导出成功')
this.visible = false
}).catch(err=>{
console.log(err);
this.$message.warning('导出失败')
})
} else if (this.table_title === "智能感知设备列表") {
//
exportPerception().then((res) => {
console.log(456);
console.log(res);
this.$message.success('导出成功')
this.visible = false
}).catch(err=>{
console.log(err);
this.$message.warning('导出失败')
})
}
}, 300), }, 300),
}, },
}; };

@ -117,7 +117,7 @@
<AddVideoDialog ref="addVideoDialog"></AddVideoDialog> <AddVideoDialog ref="addVideoDialog"></AddVideoDialog>
<AddPerceptionDialog ref="addPerceptionDialog"></AddPerceptionDialog> <AddPerceptionDialog ref="addPerceptionDialog"></AddPerceptionDialog>
<UploadDialog ref="uploadDialog"></UploadDialog> <UploadDialog ref="uploadDialog"></UploadDialog>
<DeriveDialog ref="deriveDialog"></DeriveDialog> <DeriveDialog ref="deriveDialog" :table_title="table_title"></DeriveDialog>
</div> </div>
</template> </template>
<script> <script>
@ -375,7 +375,7 @@ export default {
width: calc(100% - 30px); width: calc(100% - 30px);
margin-top: 12px; margin-top: 12px;
margin-left: 12px; margin-left: 12px;
height: 27vh; height: 30vh;
.el-table, .el-table,
.el-table__expanded-cell { .el-table__expanded-cell {
@ -384,7 +384,7 @@ export default {
} }
/deep/.el-table { /deep/.el-table {
height: 35vh; height: 27vh;
thead { thead {
text-align: center; text-align: center;
color: #fff; color: #fff;

@ -266,7 +266,7 @@ export default {
/* 左侧 */ /* 左侧 */
.cardBodyLeft { .cardBodyLeft {
width: 25%; width: 25%;
height: 100%; height: 75vh;
background: rgba(23, 36, 36, 0.4); background: rgba(23, 36, 36, 0.4);
border: 0.5px solid #485f6c; border: 0.5px solid #485f6c;
border-radius: 4px; border-radius: 4px;
@ -316,7 +316,7 @@ export default {
height: 69vh; height: 69vh;
.el-tree { .el-tree {
/* 树形数据过长添加滚动条 */ /* 树形数据过长添加滚动条 */
height: 95%; height: 65vh;
overflow: auto; overflow: auto;
// box-shadow: 5px 5px 10px #126a58; // box-shadow: 5px 5px 10px #126a58;
border-radius: 4px; border-radius: 4px;
@ -399,6 +399,7 @@ export default {
} }
/* 竖分割线 */ /* 竖分割线 */
.el-divider.el-divider--vertical { .el-divider.el-divider--vertical {
opacity: 0;
margin-left: 13px; margin-left: 13px;
height: 100%; height: 100%;
} }
@ -411,8 +412,8 @@ export default {
font-size: 18px; font-size: 18px;
text-shadow: 0 0 9px rgba(21, 255, 198, 0.64); text-shadow: 0 0 9px rgba(21, 255, 198, 0.64);
} }
width: 75%; width: 74%;
height: 100%; height: 75vh;
border-radius: 4px; border-radius: 4px;
background: rgba(31, 45, 49, 0.4); background: rgba(31, 45, 49, 0.4);
border: 0.5px solid #485f6c; border: 0.5px solid #485f6c;

@ -0,0 +1,565 @@
<!-- 指标表格 -->
<template>
<div class="display">
<table>
<tr class="table_title">
<th class="table_title_one">一级指标</th>
<th class="table_title_two">二级指标</th>
<th class="table_title_three">三级指标</th>
</tr>
<!-- 防疫安全 -->
<tr class="table_body">
<td rowspan="5" @click="click_onelevel('3')"></td>
<td @click="click_twolevel"></td>
<td>疫苗接种数</td>
</tr>
<tr class="table_body">
<td @click="click_twolevel"></td>
<td>核算检测率</td>
</tr>
<tr class="table_body">
<td @click="click_twolevel"></td>
<td>场所码异常数</td>
</tr>
<tr class="table_body">
<td @click="click_twolevel" rowspan="2">中高风险返企数</td>
<td>境外人员</td>
</tr>
<tr class="table_body">
<td>境内人员</td>
</tr>
<!-- 人员安全 -->
<tr class="table_body">
<td rowspan="14" @click="click_onelevel('14')"></td>
<td rowspan="4" @click="click_twolevel"></td>
<td>未登记人员</td>
</tr>
<tr class="table_body">
<td>未注销人员</td>
</tr>
<tr class="table_body">
<td>未变更人员</td>
</tr>
<tr class="table_body">
<td>高危人员</td>
</tr>
<tr class="table_body">
<td rowspan="7" @click="click_twolevel"></td>
<td>重性精神病人</td>
</tr>
<tr class="table_body">
<td>非访人员</td>
</tr>
<tr class="table_body">
<td>退役重点人员</td>
</tr>
<tr class="table_body">
<td>个人极端人员</td>
</tr>
<tr class="table_body">
<td>前科人员</td>
</tr>
<tr class="table_body">
<td>家暴人员</td>
</tr>
<tr class="table_body">
<td>酗酒人员</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>危险品领用保管使用人员</td>
</tr>
<tr class="table_body">
<td>危险品技术资质人员</td>
</tr>
<tr class="table_body">
<td>专家人员</td>
<td>领域内有较高专业知识技术的专家人才</td>
</tr>
<!-- 消防安全 -->
<tr class="table_body">
<td rowspan="13" @click="click_onelevel('33')"></td>
<td rowspan="3" @click="click_twolevel"></td>
<td>设备录入率</td>
</tr>
<tr class="table_body">
<td>配置合理性</td>
</tr>
<tr class="table_body">
<td>日常保养及时率</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>必要资质</td>
</tr>
<tr class="table_body">
<td>验收许可或建设许可</td>
</tr>
<tr class="table_body">
<td>日常检查表</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>人员培训率</td>
</tr>
<tr class="table_body">
<td>演习举办情况</td>
</tr>
<tr class="table_body">
<td>管理层专业知晓程度</td>
</tr>
<tr class="table_body">
<td rowspan="4" @click="click_twolevel"></td>
<td>火灾事故</td>
</tr>
<tr class="table_body">
<td>其他事故</td>
</tr>
<tr class="table_body">
<td>消防违建</td>
</tr>
<tr class="table_body">
<td>协助扑救</td>
</tr>
<!-- 危化运输安全 -->
<tr class="table_body">
<td rowspan="15" @click="click_onelevel('51')"></td>
<td rowspan="2" @click="click_twolevel"></td>
<td>区内企业评分</td>
</tr>
<tr class="table_body">
<td>区外企业评分</td>
</tr>
<tr class="table_body">
<td rowspan="5" @click="click_twolevel"></td>
<td>违停</td>
</tr>
<tr class="table_body">
<td>闯禁</td>
</tr>
<tr class="table_body">
<td>超速</td>
</tr>
<tr class="table_body">
<td>疲劳驾驶</td>
</tr>
<tr class="table_body">
<td>未按车道行驶</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>经损事故</td>
</tr>
<tr class="table_body">
<td>伤亡事故</td>
</tr>
<tr class="table_body">
<td>泄漏事故</td>
</tr>
<tr class="table_body">
<td>行政/刑事案件</td>
<td>有无拘留判刑</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>反馈整改完成</td>
</tr>
<tr class="table_body">
<td>整改反馈未完成</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>企业演习</td>
</tr>
<tr class="table_body">
<td>集中培训学习</td>
</tr>
<!-- 列管物品安全 -->
<tr class="table_body">
<td rowspan="10" @click="click_onelevel('73')"></td>
<td rowspan="2" @click="click_twolevel"></td>
<td>易制爆物品生产购买销售储存使用</td>
</tr>
<tr class="table_body">
<td>剧毒物品生产购买销售储存使用</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>放射源储存</td>
</tr>
<tr class="table_body">
<td>放射源运输</td>
</tr>
<tr class="table_body">
<td>放射源使用</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>烟花爆竹运输销售燃放</td>
</tr>
<tr class="table_body">
<td>炸药雷管保管运输使用</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>猎枪</td>
</tr>
<tr class="table_body">
<td>竞技体育用枪</td>
</tr>
<tr class="table_body">
<td>商业射击馆枪支</td>
</tr>
<!-- 内部治安安全 -->
<tr class="table_body">
<td rowspan="15" @click="click_onelevel('88')"></td>
<td rowspan="4" @click="click_twolevel"></td>
<td>企业保卫人员名单</td>
</tr>
<tr class="table_body">
<td>企业物防设施清单</td>
</tr>
<tr class="table_body">
<td>企业技防前端感知(人脸车脸重要部位视频监控)建设</td>
</tr>
<tr class="table_body">
<td>企业技防设施连入平台情况</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>规章制度</td>
</tr>
<tr class="table_body">
<td>应急预案</td>
</tr>
<tr class="table_body">
<td>应急演练</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>部门检查合格进行评分</td>
</tr>
<tr class="table_body">
<td>部门检查不合格及有缺陷的要求企业整改</td>
</tr>
<tr class="table_body">
<td>应系统研判(设施过期及设施故障)</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>企业反馈整改完成</td>
</tr>
<tr class="table_body">
<td>企业反馈整改未完成</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>企业发生被盗被骗等各类案件</td>
</tr>
<tr class="table_body">
<td>企业员工涉及的各类案件</td>
</tr>
<tr class="table_body">
<td>企业员工涉及的信访等案件</td>
</tr>
<!-- 道路安全 -->
<tr class="table_body">
<td rowspan="13" @click="click_onelevel('109')"></td>
<td rowspan="2" @click="click_twolevel"></td>
<td>区内企业评分</td>
</tr>
<tr class="table_body">
<td>区外企业评分</td>
</tr>
<tr class="table_body">
<td rowspan="5" @click="click_twolevel"></td>
<td>违停</td>
</tr>
<tr class="table_body">
<td>闯禁</td>
</tr>
<tr class="table_body">
<td>超速</td>
</tr>
<tr class="table_body">
<td>未按车道行驶</td>
</tr>
<tr class="table_body">
<td>闯红灯</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>经损事故</td>
</tr>
<tr class="table_body">
<td>伤亡事故</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>反馈整改完成</td>
</tr>
<tr class="table_body">
<td>反馈整改未完成</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>设施完善</td>
</tr>
<tr class="table_body">
<td>设施缺失</td>
</tr>
<!-- 防攻击安全 -->
<tr class="table_body">
<td rowspan="16" @click="click_onelevel('128')"></td>
<td rowspan="6" @click="click_twolevel"></td>
<td>重要岗位人员是否进行安全背景调查</td>
</tr>
<tr class="table_body">
<td>应急力量是否配备</td>
</tr>
<tr class="table_body">
<td>是否安排人员24小时值班</td>
</tr>
<tr class="table_body">
<td>是否安排巡逻防控力量</td>
</tr>
<tr class="table_body">
<td>是否建立联防联动联治机制</td>
</tr>
<tr class="table_body">
<td>是否定期开展实战演练</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>是否有实体防护设施</td>
</tr>
<tr class="table_body">
<td>是否配备必要的防爆器械</td>
</tr>
<tr class="table_body">
<td>车辆进出口是否安装车辆冲撞设施</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>是否全方位安装视频监控系统</td>
</tr>
<tr class="table_body">
<td>是否安装访客登记系统</td>
</tr>
<tr class="table_body">
<td>是否安装入侵和紧急报警系统</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>企业反馈完成整改</td>
</tr>
<tr class="table_body">
<td>企业反馈未完成整改</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>是否定期开展反恐实战演练</td>
</tr>
<tr class="table_body">
<td>是否定期开展反恐培训</td>
</tr>
<!-- 网络安全 -->
<tr class="table_body">
<td rowspan="10" @click="click_onelevel('150')"></td>
<td rowspan="2" @click="click_twolevel"></td>
<td>反馈整改完成</td>
</tr>
<tr class="table_body">
<td>反馈整改未完成</td>
</tr>
<tr class="table_body">
<td @click="click_twolevel"></td>
<td>是否有过行政处罚</td>
</tr>
<tr class="table_body">
<td @click="click_twolevel"></td>
<td>是否发生过</td>
</tr>
<tr class="table_body">
<td rowspan="3" @click="click_twolevel"></td>
<td>网站备案</td>
</tr>
<tr class="table_body">
<td>应用备案</td>
</tr>
<tr class="table_body">
<td>应用评估</td>
</tr>
<tr class="table_body">
<td @click="click_twolevel"></td>
<td>等保定级评审完成/未完成</td>
</tr>
<tr class="table_body">
<td rowspan="2" @click="click_twolevel"></td>
<td>应急演练</td>
</tr>
<tr class="table_body">
<td>集中培训学习</td>
</tr>
</table>
</div>
</template>
<script>
import { getIndexTable } from "@/api/systemManagement/safeIndex";
import bus from "@/assets/js/eventBus.js";
export default {
name: "IndexTable",
data() {
return {
display_data: {},
one_index_three_level: [
{ id: 5, levelIndexThree: "疫苗接种数" },
{ id: 8, levelIndexThree: "核算检测率" },
{ id: 10, levelIndexThree: "场所码异常数" },
{ id: 12, levelIndexThree: "境外人员" },
{ id: 13, levelIndexThree: "境内人员" },
],
};
},
created() {
this.getData();
},
methods: {
// table_header() {
// return {
// "text-align": "center", //
// color: "#fff",
// };
// },
//
getData() {
getIndexTable().then((res) => {
console.log("res", res);
this.display_data = res.data;
});
},
//
click_onelevel(id) {
const massage= {
safeRuleId:id,
level:'1',
}
this.$emit("back", massage);
bus.$emit('send', massage) //
},
//
click_twolevel() {
const level = "2";
this.$emit("backLevel", level);
},
//
click_threelevel() {
const level = "3";
this.$emit("backLevel", level);
},
},
};
</script>
<style lang="less" scoped>
.display {
margin-top: 2vh;
width: 40.3vw;
height: 52vh;
overflow-y: scroll;
border: 0.1px solid #4d8f89;
}
.display::-webkit-scrollbar {
width: 6px;
background-color: #5e666a;
border-radius: 4px;
}
.display::-webkit-scrollbar-thumb {
width: 5px;
background-color: #3c4b4a;
border-radius: 4px;
}
table {
width: 40vw;
height: 50vh;
border: 0.1px solid #4d8f89;
.table_title {
color: #fff;
background: linear-gradient(to right, #284f49, #2f6363, #233b38);
height: 4vh;
.table_title_one {
width: 9vw;
}
.table_title_two {
width: 14vw;
}
.table_title_three {
width: 17vw;
}
}
.table_body {
color: #fff;
font-size: 18px;
text-align: center;
td {
border: 0.1px solid #4d8f89;
height: 4vh !important;
cursor: pointer;
}
td:hover{
background: #3c4b4a;
color: #54FFBE ;
}
}
}
.display_title {
display: flex;
width: 40vw;
height: 4vh;
background: linear-gradient(to right, #284f49, #2f6363, #233b38);
font-size: 18px;
color: #fff;
text-align: center;
line-height: 4vh;
.title_one {
width: 9vw;
}
.title_two {
width: 14vw;
}
.title_three {
width: 17vw;
}
}
.parent {
display: flex;
text-align: center;
font-size: 18px;
color: #fff;
border-bottom: 0.2px solid #4d8f89;
// background: #243333;
.son_one {
width: 9vw;
height: 20vh;
line-height: 20vh;
}
.son_two {
width: 14vw;
display: flex;
flex-direction: column;
div {
height: 5vh;
line-height: 5vh;
}
}
.son_three {
width: 17vw;
display: flex;
flex-direction: column;
div {
height: 4vh;
line-height: 4vh;
}
}
}
</style>

@ -0,0 +1,180 @@
<!-- 一级指标详细信息展示 -->
<template>
<div class="massage_body">
<div class="massage_form">
<div class="form_title">
{{ this.form_data.sumTitle }}&nbsp;&nbsp;&nbsp;=
</div>
<div class="form_space"></div>
<el-form ref="form" :model="form" class="levelform">
<el-form-item>
<label slot="label"
>{{
this.form_data.calculation[0].indexName
}}&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="this.form_data.calculation[0].rate"></el-input>
</el-form-item>
<el-form-item v-for="item in this.form_data_for" :key="item.sort">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;{{ item.indexName }}&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="item.rate"></el-input>
</el-form-item>
</el-form>
<div v-if="btn_flag" class="massage_btn">
<el-button @click="change_form"></el-button>
</div>
<div v-else class="massage_btn_two">
<el-button> </el-button>
<el-button @click="cancel_form"> </el-button>
</div>
</div>
</div>
</template>
<script>
import bus from "@/assets/js/eventBus.js";
import { safeCalculation } from "@/api/systemManagement/safeIndex";
export default {
name: "IndexmassageOne",
data() {
return {
btn_flag: true,
form: {},
form_data: {}, // form-item
form_data_for: [], // form-item
};
},
created() {
safeCalculation({ safeRuleId: 3, levelIndex: 1 }).then((res) => {
this.form_data = res.data.ruleDetail;
this.form_data_for = res.data.ruleDetail.calculation.filter(
(element, index) => index > 0
);
});
},
mounted() {
bus.$on("send", (data) => {
console.log(data, "data");
const params = {
safeRuleId: data.safeRuleId,
levelIndex: data.level,
};
safeCalculation(params).then((res) => {
console.log("res1", res);
this.form_data = res.data.ruleDetail;
this.form_data_for = res.data.ruleDetail.calculation.filter(
(element, index) => index > 0
);
});
});
},
methods: {
//
change_form() {
this.btn_flag = false;
},
//
cancel_form() {
this.btn_flag = true;
},
},
};
</script>
<style lang="less" scoped>
/deep/.levelform.el-form {
width: 27vw;
height: 20vh;
display: flex;
flex-wrap: wrap;
.el-form-item {
display: flex;
.el-form-item__label {
font-size: 18px;
color: #fff;
}
}
}
// /deep/.text_form.el-form {
// height: 10vh;
// margin-top: 3vh;
// display: flex;
// flex-wrap: wrap;
// .el-form-item {
// display: flex;
// .el-form-item__label {
// font-size: 18px;
// color: #fff;
// }
// }
// }
/deep/.el-input__inner {
width: 3vw;
border-radius: 0px;
font-size: 16px;
background: #3c4b4a;
color: #fff;
}
/deep/.text_form {
.el-form-item {
.el-form-item__content {
.el-input {
.el-input__inner {
width: 3vw;
border: 0px;
border-radius: 0px;
background: rgba(165, 42, 42, 0);
color: #fff;
}
}
}
}
}
.massage_body {
margin-top: 2vh;
width: 43.3vw;
height: 52vh;
border: 0.1px solid #4d8f89;
.massage_form {
display: flex;
margin-top: 1vh;
margin-left: 0.6vw;
width: 42vw;
height: 22vh;
color: #fff;
border-radius: 4px;
background: rgba(31, 45, 49, 0.4);
border: 0.5px solid #485f6c;
.form_title {
width: 5vw;
height: 22vh;
line-height: 3.8vh;
font-size: 18px;
text-align: right;
}
.form_space {
width: 1vw;
height: 22vh;
}
}
.massage_btn,
.massage_btn_two {
width: 10vw;
height: 14vh;
text-align: center;
line-height: 14vh;
.el-button {
width: 4vw;
border: 1px solid #4a6072;
color: #fff;
border-radius: 0px !important;
background: #323f43;
}
.el-button:focus,
.el-button:hover {
color: #34e1b3;
filter: brightness(150%);
}
}
}
</style>

@ -0,0 +1,14 @@
<!-- 三级指标详细信息展示 -->
<template>
<div>789</div>
</template>
<script>
export default {
name: "indexmassageThree",
data() {
return {};
},
};
</script>
<style lang="less" scoped>
</style>

@ -0,0 +1,14 @@
<!-- 二级指标详细信息展示 -->
<template>
<div>456</div>
</template>
<script>
export default {
name: "indexmassageTwo",
data() {
return {};
},
};
</script>
<style lang="less" scoped>
</style>

@ -0,0 +1,463 @@
<template>
<!-- 平安指数 -->
<el-card class="box-card">
<div class="topZS"></div>
<div class="bottomZS"></div>
<div slot="header" class="clearfix">
<span>平安指数</span>
</div>
<div class="cardBody">
<div class="synthesize_index">
<span>企业综合指数</span>
<div class="index">
<div class="index_title">综合指数算法 =</div>
<div class="index_space"></div>
<!-- 综合指数算法表单 -->
<div class="index_form">
<el-form v-if="!btn_flag" ref="form" :model="form" class="form">
<el-form-item label="内部治安管理 ×" prop="rate_one">
<label slot="label"
>内部治安管理&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_one"></el-input>
</el-form-item>
<el-form-item label="+ 防疫安全 ×" prop="rate_two">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;防疫安全&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_two"></el-input>
</el-form-item>
<el-form-item label="+ 人员安全 ×" prop="rate_three">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;人员安全&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_three"></el-input>
</el-form-item>
<el-form-item label="+ 道路交通安全秩序管理 ×" prop="rate_four">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;道路交通安全秩序管理&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_four"></el-input>
</el-form-item>
<el-form-item label="+ 防攻击安全管理 ×" prop="rate_five">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;防攻击安全管理&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_five"></el-input>
</el-form-item>
<el-form-item label="+ 网络安全管理 ×" prop="rate_six">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;网络安全管理&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_six"></el-input>
</el-form-item>
<el-form-item label="+ 消防安全 ×" prop="rate_seven">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;消防安全&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_seven"></el-input>
</el-form-item>
<el-form-item label="+ 危化运输安全 ×" prop="rate_eight">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;危化运输安全&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_eight"></el-input>
</el-form-item>
<el-form-item label="+ 列管物品 ×" prop="rate_nine">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;列管物品&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_nine"></el-input>
</el-form-item>
</el-form>
<el-form
v-else
ref="text_form"
:model="form"
class="text_form"
:disabled="disabled"
>
<el-form-item label="内部治安管理 ×" prop="rate_one">
<label slot="label"
>内部治安管理&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_one"></el-input>
</el-form-item>
<el-form-item label="+ 防疫安全 ×" prop="rate_two">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;防疫安全&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_two"></el-input>
</el-form-item>
<el-form-item label="+ 人员安全 ×" prop="rate_three">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;人员安全&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_three"></el-input>
</el-form-item>
<el-form-item label="+ 道路交通安全秩序管理 ×" prop="rate_four">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;道路交通安全秩序管理&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_four"></el-input>
</el-form-item>
<el-form-item label="+ 防攻击安全管理 ×" prop="rate_five">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;防攻击安全管理&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_five"></el-input>
</el-form-item>
<el-form-item label="+ 网络安全管理 ×" prop="rate_six">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;网络安全管理&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_six"></el-input>
</el-form-item>
<el-form-item label="+ 消防安全 ×" prop="rate_seven">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;消防安全&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_seven"></el-input>
</el-form-item>
<el-form-item label="+ 危化运输安全 ×" prop="rate_eight">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;危化运输安全&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_eight"></el-input>
</el-form-item>
<el-form-item label="+ 列管物品 ×" prop="rate_nine">
<label slot="label"
>+&nbsp;&nbsp;&nbsp;&nbsp;列管物品&nbsp;&nbsp;&nbsp;&nbsp;×</label
>
<el-input v-model="form.rate_nine"></el-input>
</el-form-item>
</el-form>
</div>
<div class="index_btn">
<div class="btn_one" v-if="btn_flag">
<el-button @click="change_form"> </el-button>
</div>
<div v-else class="btn_two">
<el-button :loading="btn_loading" @click="save_form"
> </el-button
>
<el-button @click="cancel_form"> </el-button>
</div>
</div>
</div>
</div>
<div class="index_all">
<div class="index_table">
<div class="table_title">指标分值配置</div>
<IndexTable @back="back" ref="indexTable"></IndexTable>
</div>
<div class="index_massage">
<div class="table_title"></div>
<IndexmassageOne v-if="this.level ==='1'" ref="indexmassageOne"></IndexmassageOne>
<IndexmassageTwo v-else-if="this.level === '2'" ref="indexmassageTwo"></IndexmassageTwo>
<IndexmassageThree v-else-if="this.level === '3'" ref="indexmassageThree"></IndexmassageThree>
</div>
</div>
</div>
</el-card>
</template>
<script>
import {
safeCalculation,
saveSafeCalculation,
} from "@/api/systemManagement/safeIndex";
import IndexTable from "./components/indexTable";
import IndexmassageOne from "./components/indexmassageOne";
import IndexmassageTwo from "./components/indexmassageTwo";
import IndexmassageThree from "./components/indexmassageThree";
export default {
name: "SafeIndex",
components: {
IndexTable,
IndexmassageOne,
IndexmassageTwo,
IndexmassageThree
},
data() {
return {
btn_flag: true,
btn_loading: false,
id: "",
level: "1", //
safeRuleId: "",
form: {
rate_one: "",
rate_two: "",
rate_three: "",
rate_four: "",
rate_five: "",
rate_six: "",
rate_seven: "",
rate_eight: "",
rate_nine: "",
}, //
disabled: true,
};
},
created() {
this.get_data();
},
methods: {
//
change_form() {
this.btn_flag = false;
},
//
save_form() {
//
this.btn_loading = true;
const all_data =
Number(this.form.rate_one) +
Number(this.form.rate_two) +
Number(this.form.rate_three) +
Number(this.form.rate_four) +
Number(this.form.rate_five) +
Number(this.form.rate_six) +
Number(this.form.rate_seven) +
Number(this.form.rate_eight) +
Number(this.form.rate_nine);
console.log("all_data", all_data);
if (
Number(this.form.rate_one) > 0 &&
Number(this.form.rate_two) > 0 &&
Number(this.form.rate_three) > 0 &&
Number(this.form.rate_four) > 0 &&
Number(this.form.rate_five) > 0 &&
Number(this.form.rate_six) > 0 &&
Number(this.form.rate_seven) > 0 &&
Number(this.form.rate_eight) > 0 &&
Number(this.form.rate_nine) > 0 &&
all_data === 1
) {
const obj = {
calculation: [
{ indexName: "内部治安管理", rate: this.form.rate_one, sort: "1" },
{ indexName: "防疫安全", rate: this.form.rate_two, sort: "2" },
{ indexName: "人员安全", rate: this.form.rate_three, sort: "3" },
{
indexName: "道路交通安全秩序管理",
rate: this.form.rate_four,
sort: "4",
},
{
indexName: "防攻击安全管理",
rate: this.form.rate_five,
sort: "5",
},
{ indexName: "网络安全管理", rate: this.form.rate_six, sort: "6" },
{ indexName: "消防安全", rate: this.form.rate_seven, sort: "7" },
{
indexName: "危化运输安全",
rate: this.form.rate_eight,
sort: "8",
},
{ indexName: "列管物品", rate: this.form.rate_nine, sort: "9" },
],
sumTitle: "综合指数算法",
};
const params = {
calculationRule: JSON.stringify(obj),
id: this.id,
safeRuleId: this.safeRuleId,
};
console.log("params", params);
saveSafeCalculation(params)
.then((res) => {
console.log(res);
this.btn_loading = false;
this.btn_flag = true;
})
.catch((err) => {
console.log(err);
});
} else {
this.$message.warning("保存失败,各指标占比应大于等于0且总和应等于1");
}
},
// text_form
cancel_form() {
//
this.get_data();
this.btn_flag = true;
},
get_data() {
//
safeCalculation({ safeRuleId: 1, levelIndex: 0 }).then((res) => {
console.log("res", res.data.calculationRule);
console.log("res", JSON.parse(res.data.calculationRule));
this.form.rate_one = res.data.ruleDetail.calculation[0].rate;
this.form.rate_two = res.data.ruleDetail.calculation[1].rate;
this.form.rate_three = res.data.ruleDetail.calculation[2].rate;
this.form.rate_four = res.data.ruleDetail.calculation[3].rate;
this.form.rate_five = res.data.ruleDetail.calculation[4].rate;
this.form.rate_six = res.data.ruleDetail.calculation[5].rate;
this.form.rate_seven = res.data.ruleDetail.calculation[6].rate;
this.form.rate_eight = res.data.ruleDetail.calculation[7].rate;
this.form.rate_nine = res.data.ruleDetail.calculation[8].rate;
this.id = res.data.id;
this.safeRuleId = res.data.safeRuleId;
});
},
back(back) {
this.level = back.level
},
},
};
</script>
<style lang="less" scoped>
/* card统一样式 */
.el-card.box-card.is-always-shadow {
border: 0px;
height: 89vh; /* 控制card布局高度,用于适配 */
position: relative;
background: url("~@/assets/companyFile/22136.png") no-repeat !important;
background-size: 100% 100% !important;
}
/* card统一样式 */
/deep/.el-card__header {
border-bottom: 1px solid #a1a1a1 !important;
.clearfix {
span {
font-size: 17px;
font-weight: 400;
color: #fff;
text-shadow: 0 0 9px rgba(21, 255, 198, 0.64);
}
}
}
/deep/.form.el-form {
height: 10vh;
margin-top: 3vh;
display: flex;
flex-wrap: wrap;
.el-form-item {
display: flex;
.el-form-item__label {
font-size: 18px;
color: #fff;
}
}
}
/deep/.text_form.el-form {
height: 10vh;
margin-top: 3vh;
display: flex;
flex-wrap: wrap;
.el-form-item {
display: flex;
.el-form-item__label {
font-size: 18px;
color: #fff;
}
}
}
/deep/.el-input__inner {
width: 3vw;
border-radius: 0px;
font-size: 16px;
background: #3c4b4a;
color: #fff;
}
/deep/.text_form {
.el-form-item {
.el-form-item__content {
.el-input {
.el-input__inner {
width: 3vw;
border: 0px;
border-radius: 0px;
background: rgba(165, 42, 42, 0);
color: #fff;
}
}
}
}
}
/* 综合指数算法 */
.synthesize_index {
span {
font-size: 18px;
color: #fff;
}
width: 85vw;
height: 19vh;
.index {
display: flex;
margin-top: 1.5vh;
width: 85vw;
height: 16vh;
color: #fff;
border-radius: 4px;
background: rgba(31, 45, 49, 0.4);
border: 0.5px solid #485f6c;
.index_title {
text-align: right;
line-height: 9.8vh;
font-size: 18px;
width: 10vw;
height: 14vh;
}
.index_space {
width: 1vw;
height: 14vh;
}
.index_form {
width: 64vw;
height: 14vh;
}
.index_btn {
width: 10vw;
height: 14vh;
text-align: center;
line-height: 14vh;
.el-button {
width: 4vw;
border: 1px solid #4a6072;
color: #fff;
border-radius: 0px !important;
background: #323f43;
}
.el-button:focus,
.el-button:hover {
color: #34e1b3;
filter: brightness(150%);
}
}
}
}
.index_all {
display: flex;
width: 85vw;
/* 表格区域 */
.index_table {
margin-top: 2vh;
width: 41vw;
height: 58.5vh;
// background: #fff;
.table_title {
height: 4vh;
line-height: 4vh;
font-size: 18px;
color: #fff;
}
}
.index_massage {
margin-top: 2vh;
margin-left: 0.5vw;
width: 43.5vw;
height: 58.5vh;
// background: #fff;
.table_title {
height: 4vh;
line-height: 4vh;
font-size: 18px;
color: rgb(19, 12, 12);
}
}
}
</style>
Loading…
Cancel
Save