From 20b0ce2db27b64a60de60aee05dedd448099e330 Mon Sep 17 00:00:00 2001 From: 马宇豪 <978517621@qq.com> Date: 星期一, 08 七月 2024 10:12:16 +0800 Subject: [PATCH] xiugai --- src/views/newSpecialWorkSystem/workTicket/wdsq/components/fireDialog.vue | 182 ++++++++++++++++++++++++++++++++++++--------- 1 files changed, 144 insertions(+), 38 deletions(-) diff --git a/src/views/newSpecialWorkSystem/workTicket/wdsq/components/fireDialog.vue b/src/views/newSpecialWorkSystem/workTicket/wdsq/components/fireDialog.vue index fdf1be0..d984ea7 100644 --- a/src/views/newSpecialWorkSystem/workTicket/wdsq/components/fireDialog.vue +++ b/src/views/newSpecialWorkSystem/workTicket/wdsq/components/fireDialog.vue @@ -46,33 +46,21 @@ </el-row> <el-row> <el-col :span="12"> - <el-form-item label="动火方式" prop="workDetail.workMethod"> - <el-input - v-model="form.workDetail.workMethod" - :autosize="{ minRows: 1 }" - type="textarea" - placeholder="请输入动火方式" - /> - </el-form-item> - </el-col> - <el-col :span="12"> - <el-form-item label="作业人" prop="operatorUids"> - <el-select v-model="form.operatorUids" filterable multiple clearable> + <el-form-item label="动火方式" prop="workDetail.methodList"> +<!-- <el-input--> +<!-- v-model="form.workDetail.workMethod"--> +<!-- :autosize="{ minRows: 1 }"--> +<!-- type="textarea"--> +<!-- placeholder="请输入动火方式"--> +<!-- />--> + <el-select v-model="form.workDetail.methodList" filterable multiple clearable> <el-option - v-for="item in lists.spList.opList" - :key="item.uid" - :label="item.realName" - :value="item.uid" + v-for="item in fireWorkList" + :key="item.id" + :label="item.name" + :value="item.name" /> </el-select> -<!-- <el-cascader style="width: 100%" v-model="form.operatorUids" :options="lists.spList.opList" :props="cas2Props" @change="singleSelect($event,'作业人')" filterable :show-all-levels="false"/>--> - </el-form-item> - </el-col> - </el-row> - <el-row> - <el-col :span="12"> - <el-form-item label="作业单位" prop="workDepId"> - <el-cascader style="width: 100%" v-model="form.workDepId" :props="depProps" :options="lists.departList" :show-all-levels="false"/> </el-form-item> </el-col> <el-col :span="12"> @@ -85,7 +73,39 @@ :value="item.uid" /> </el-select> -<!-- <el-cascader style="width: 100%" v-model="form.headUids" :options="lists.workerList" :props="casProps" @change="getStartEndIds" filterable :show-all-levels="false"/>--> + <!-- <el-cascader style="width: 100%" v-model="form.headUids" :options="lists.workerList" :props="casProps" @change="getStartEndIds" filterable :show-all-levels="false"/>--> + </el-form-item> + </el-col> + </el-row> + <el-row v-if="form.workDetail.methodList.find(i=>i == '其他')"> + <el-col :span="12"> + <el-form-item label="其他方式" prop="workDetail.other"> + <el-input + v-model="form.workDetail.other" + :autosize="{ minRows: 1 }" + type="textarea" + placeholder="请输入其他动火方式" + /> + </el-form-item> + </el-col> + </el-row> + <el-row> + <el-col :span="12"> + <el-form-item label="作业单位" prop="workDepIds"> + <el-cascader style="width: 100%" v-model="form.workDepIds" :props="depProps" @change="getWorkerList" :options="lists.departList" :show-all-levels="false"/> + </el-form-item> + </el-col> + <el-col :span="12"> + <el-form-item label="作业人" prop="operatorUids"> + <el-select v-model="form.operatorUids" filterable multiple clearable> + <el-option + v-for="item in zyList" + :key="item.uid" + :label="item.realName" + :value="item.uid" + /> + </el-select> + <!-- <el-cascader style="width: 100%" v-model="form.operatorUids" :options="lists.spList.opList" :props="cas2Props" @change="singleSelect($event,'作业人')" filterable :show-all-levels="false"/>--> </el-form-item> </el-col> </el-row> @@ -347,9 +367,11 @@ interface stateType { form: Object, workLevelList: Array<any>, + fireWorkList: Array<any>, equipmentDialog: boolean, tabLoading: boolean showDialog: boolean + zyList: [] props1:{} depProps:{} safetyMeasureBasicList: [] @@ -366,6 +388,7 @@ showDialog: false, equipmentDialog: false, safetyMeasureBasicList: [], + zyList: [], form: { id: null, workType: 1, @@ -378,7 +401,7 @@ headUids: [], analystUids: [], guardianUids: [], - workDepId: null, + workDepIds: [], workContent: '', workLocation: '', riskIdentification: [], @@ -390,7 +413,9 @@ startOrEndUids: [], cameraIds: [], workDetail: { - workMethod: '' + workMethod: '', + methodList: [], + other: '' }, remark: '' }, @@ -408,6 +433,52 @@ value: 3 } ], + fireWorkList: [ + { + name: "电焊", + id: 1 + }, + { + name: "气割", + id: 2 + }, + { + name: "切割", + id: 3 + }, + { + name: "打磨", + id: 4 + }, + { + name: "钻孔", + id: 5 + }, + { + name: "喷灯", + id: 6 + }, + { + name: "烘烤", + id: 7 + }, + { + name: "喷砂", + id: 8 + }, + { + name: "破碎地面", + id: 9 + }, + { + name: "清洗机", + id: 10 + }, + { + name: "其他", + id: 11 + } + ], props1:{ expandTrigger: 'hover', label: 'depName', @@ -418,6 +489,7 @@ expandTrigger: 'hover', label: 'depName', value: 'depId', + multiple: true, checkStrictly: true, emitPath: false } @@ -429,7 +501,7 @@ workContent: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], workLocation: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], operatorUids: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], - workDepId: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], + workDepIds: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], headUids: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], analystUids: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], guardianUids: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], @@ -441,20 +513,31 @@ acceptUid: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], lastApprover: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], startOrEndUids: [{ required: true, message: '该内容不能为空', trigger: 'blur' }], - "workDetail.workMethod": [{ required: true, message: '该内容不能为空', trigger: 'blur' }] + "workDetail.methodList": [{ required: true, message: '该内容不能为空', trigger: 'blur' }], + "workDetail.other": [{ required: true, message: '该内容不能为空', trigger: 'blur' }] }); const workSelectRef = ref() // 页面载入时执行方法 onMounted(() => { - getBasicData() + // getBasicData() }) onUpdated(()=>{ console.log('false loading') }) - + const getWorkerList = ()=>{ + const filteredList = props.lists.spList.opList.filter(i => state.form.workDepIds.includes(i.depId)); + if(filteredList && filteredList.length>0){ + state.zyList = filteredList + }else{ + state.zyList = props.lists.spList.opList + } + } const openDialog = (row)=>{ + clearFile() + state.zyList = props.lists.spList.opList + getBasicData() Object.keys(state.form).forEach(key => { if (row.hasOwnProperty(key)) { state.form[key] = JSON.parse(JSON.stringify(row))[key] @@ -469,15 +552,28 @@ state.form.cameraIds = row.workApprovalDeviceList.map(i=>i.deviceId) state.form.safetyMeasureUids = row.safetyMeasureList.map(i=>i.userId) state.form.approvalDepBasicList = row.approvalDepList.map((item)=>({ - content: item.content, - approvalDepBasicId: item.approvalDepBasicId, - approvalUids: item.approvalPersonList.filter(j=>j.type == 5).map(i=>i.userId), - approvalType: item.approvalType + content: item.content, + approvalDepBasicId: item.approvalDepBasicId, + approvalUids: item.approvalPersonList.filter(j=>j.type == 5).map(i=>i.userId), + approvalType: item.approvalType })) + console.log(state.form.approvalDepBasicList,777) state.form.acceptUid = row.acceptUser.userId state.form.startOrEndUids = row.startOrEndList.map(i=>i.userId) state.form.lastApprover = row.lastApprover.userId - console.log(state.form,'form') + state.form.workDetail.methodList = state.form.workDetail.workMethod.split(',') + if(row.workDepList && row.workDepList.length>0){ + state.form.workDepIds = row.workDepList.map(i=>i.workDepId) + }else{ + state.form.workDepIds.push(row.workDepId) + } + for(let i in state.form.workDetail.methodList){ + if(!state.fireWorkList.find(item=>item.name == state.form.workDetail.methodList[i])){ + state.form.workDetail.other = state.form.workDetail.methodList[i] + state.form.workDetail.methodList[i] = '其他' + } + } + getWorkerList() state.showDialog = true } @@ -494,7 +590,7 @@ headUids: [], analystUids: [], guardianUids: [], - workDepId: null, + workDepIds: [], workContent: '', workLocation: '', riskIdentification: [], @@ -506,7 +602,9 @@ startOrEndUids: [], cameraIds: [], workDetail: { - workMethod: '' + workMethod: '', + methodList: [], + other: '' }, remark: '' } @@ -628,6 +726,13 @@ // } state.form.riskIdentification = state.form.riskIdentification.join(',') const {...data} = state.form + data.workDetail.methodList = data.workDetail.methodList.map(item=>{ + if(item == '其他'){ + item = data.workDetail.other + } + return item + }) + data.workDetail.workMethod = data.workDetail.methodList.join(',') data.operatorUids = transform2Arr(data.operatorUids) data.headUids = transform2Arr(data.headUids) // data.analystUids = transformArr(data.analystUids) @@ -697,6 +802,7 @@ renderMenu, getBasicData, getStartEndIds, + getWorkerList, getSafetyIds, isFirstRow, submitForm, -- Gitblit v1.9.2