From bd19a941293d124d7c58c6d351e7e86c1fa15559 Mon Sep 17 00:00:00 2001 From: 马宇豪 <978517621@qq.com> Date: 星期二, 26 十一月 2024 11:18:50 +0800 Subject: [PATCH] 新增数据上报修改 --- src/views/newSpecialWorkSystem/workTicket/zysq/components/power.vue | 148 +++++++++++++++++++++++++++++-------------------- 1 files changed, 87 insertions(+), 61 deletions(-) diff --git a/src/views/newSpecialWorkSystem/workTicket/zysq/components/power.vue b/src/views/newSpecialWorkSystem/workTicket/zysq/components/power.vue index 031d931..77f8d65 100644 --- a/src/views/newSpecialWorkSystem/workTicket/zysq/components/power.vue +++ b/src/views/newSpecialWorkSystem/workTicket/zysq/components/power.vue @@ -79,15 +79,15 @@ <el-row> <el-col :span="12"> <el-form-item label="作业负责人" prop="headUids"> - <el-select v-model="form.headUids" multiple :multiple-limit="1" filterable @change="getStartEndIds" clearable> - <el-option - v-for="item in lists.workerList" - :key="item.uid" - :label="item.username" - :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-select v-model="form.headUids" multiple :multiple-limit="1" filterable @change="getStartEndIds" clearable>--> +<!-- <el-option--> +<!-- v-for="item in lists.workerList"--> +<!-- :key="item.uid"--> +<!-- :label="item.username"--> +<!-- :value="item.uid"--> +<!-- />--> +<!-- </el-select>--> + <el-cascader style="width: 100%" v-model="form.headUids" :options="lists.workerList" :props="cas3Props" @change="singleSelect($event,'负责人')" filterable :show-all-levels="false"/> </el-form-item> </el-col> </el-row> @@ -99,15 +99,15 @@ </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-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="zyList?zyList:lists.spList.opList" :props="cas2Props" @change="singleSelect($event,'作业人')" filterable :show-all-levels="false"/> </el-form-item> </el-col> </el-row> @@ -472,41 +472,16 @@ } }, cas2Props: { - expandTrigger: 'hover', value: 'uid', label: 'realName', multiple: true, - checkStrictly: false, - lazy: true, - async lazyLoad(node, resolve){ - const { value, level } = node - let nodes = [] - if(level == 0){ - nodes = props.lists.spList.opList - }else{ - let res = await userApi().getCtf({uid: value}) - if(res.data.code == 200){ - nodes = res.data.data - }else{ - ElMessage({ - type: 'warning', - message: res.data.msg - }) - } - } - nodes=nodes.map(item => ({ - uid: item.certNo +','+ item.certExpiredAt+','+item.certTypeName, - realName: node.label + '(' +item.certTypeName +' ' + item.certExpiredAt + ')', - leaf: level >= 1 - })) - resolve(nodes) - } + checkStrictly: true, + children: 'certList' }, cas3Props: { - expandTrigger: 'hover', value: 'uid', label: 'realName', - multiple: true, + checkStrictly: true, lazy: true, async lazyLoad(node, resolve){ const { value, level } = node @@ -525,7 +500,7 @@ } } nodes=nodes.map(item => ({ - uid: item.certNo +','+ item.certExpiredAt+','+item.certTypeName, + uid: item.certNo +','+ item.certExpiredAt, realName: node.label + '(' +item.certTypeName +' ' + item.certExpiredAt + ')', leaf: level >= 1 })) @@ -595,13 +570,44 @@ const openWorkSelect = ()=>{ workSelectRef.value.openDialog(state.form.involveOtherWork) } - const getWorkerList = (val)=>{ - const filteredList = props.lists.spList.opList.filter(i => state.form.workDepIds.includes(i.depId)); + const getWorkerList = ()=>{ + let idList:Array<any> = [] + for(let i of state.form.workDepIds){ + idList = idList.concat(getListFromDep(getIdListsFormDepId(props.lists.departList,i))) + } + const depLists = [...new Set(idList)] + const filteredList = props.lists.spList.opList.filter(i => depLists.includes(i.depId)); if(filteredList && filteredList.length>0){ state.zyList = filteredList }else{ state.zyList = props.lists.spList.opList } + } + + const getListFromDep = (dep) =>{ + let depIds = [] + depIds.push(dep.depId) + if (Array.isArray(dep.children)) { + for (let child of dep.children) { + depIds = depIds.concat(getListFromDep(child)); + } + } + return depIds; + } + + const getIdListsFormDepId=(DepList:Array<any>,id:number)=>{ + for(const i of DepList){ + if(i.depId === id){ + return i + } + if(Array.isArray(i.children)){ + const node:any = getIdListsFormDepId(i.children,id) + if(node){ + return node + } + } + } + return null } const getSelected = ()=>{ state.form.involveOtherWork = workSelectRef.value.selected @@ -664,15 +670,24 @@ return index === 0; } - const transformArr = (arr: Array<any>)=>{ - return arr.map((i)=>{ - return { - uid: i[0], - certificate: i[1].split(',')[0], - certExpiredAt: i[1].split(',')[1], - certTypeName: i[1].split(',')[2] - } - }) + const transformArr = (arr: Array<any>,type: string)=>{ + if(type == '作业人'){ + return arr.map((i)=>{ + return { + uid: i[0], + certificate: i[1]?i[1].split(',')[0]:'', + certExpiredAt: i[1]?i[1].split(',')[1]:'', + certTypeName: '' + } + }) + }else{ + return [{ + uid: arr[0], + certificate: arr[1]?arr[1].split(',')[0]:'', + certExpiredAt: arr[1]?arr[1].split(',')[1]:'', + certTypeName: '' + }] + } } const transform2Arr = (arr: Array<any>)=>{ @@ -708,10 +723,20 @@ } } if(type == '作业人'){state.form.operatorUids = temp} - // if(type == '分析人'){state.form.analystUids = temp} + if(type == '负责人'){ + state.form.headUids = temp + state.form.startOrEndUids = [state.form.headUids[0]] + state.form.approvalDepBasicList[0].approvalUids = [state.form.headUids[0]] + } if(type == '监护人'){state.form.guardianUids = temp} if(type == '确认人'){state.form.safetyMeasureUids = temp} if(type == '结束人'){state.form.startOrEndUids = temp} + }else{ + if(type == '负责人'){ + state.form.headUids = selected + state.form.startOrEndUids = state.form.headUids + state.form.approvalDepBasicList[0].approvalUids = state.form.headUids + } } } @@ -734,8 +759,8 @@ state.form.workDetail.electricityUids = state.form.workDetail.electricityUids.join(',') state.form.riskIdentification = state.form.riskIdentification.join(',') const {depIdList,...data} = state.form - data.operatorUids = transform2Arr(data.operatorUids) - data.headUids = transform2Arr(data.headUids) + data.operatorUids = transformArr(data.operatorUids,'作业人') + data.headUids = transformArr(data.headUids,'负责人') // data.analystUids = transformArr(data.analystUids) data.guardianUids = transform2Arr(data.guardianUids) data.safetyMeasureUids = transform2Arr(data.safetyMeasureUids) @@ -751,6 +776,7 @@ formEl.resetFields() state.form.guardianUids = [] state.form.involveOtherWork = [] + state.form.headUids = [] getBasicData() } else { ElMessage({ -- Gitblit v1.9.2