From 5c45db7c1be28da293b3583c16834ee97e8bac47 Mon Sep 17 00:00:00 2001 From: 马宇豪 <978517621@qq.com> Date: 星期三, 02 四月 2025 13:43:06 +0800 Subject: [PATCH] 修改 --- src/views/experiment/project/components/projectDialog.vue | 650 ++++++++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 485 insertions(+), 165 deletions(-) diff --git a/src/views/experiment/project/components/projectDialog.vue b/src/views/experiment/project/components/projectDialog.vue index 102bdeb..34fc950 100644 --- a/src/views/experiment/project/components/projectDialog.vue +++ b/src/views/experiment/project/components/projectDialog.vue @@ -1,11 +1,11 @@ <template> <div class="system-menu-dialog-container"> - <el-dialog :title="projectDialogState.title" v-model="projectDialogState.projectDialogVisible" width="70%"> + <el-dialog :title="projectDialogState.title" v-model="projectDialogState.projectDialogVisible" width="80%" :before-close="handleClose"> <el-form ref="ProjectFormRef" :rules="projectDialogState.projectFormRules" :model="projectDialogState.projectForm" size="default" label-width="0"> <table class="report-table"> - <th class="m-color b-font" style="text-align: center">***研究所/***大学<br />科学研究实验项目安全风险基础信息录入表(已开展B)</th> + <th class="m-color b-font" style="text-align: center">材料科学姑苏实验室<br/>科学研究实验项目安全风险基础信息录入表(新立项)(带<span style="color: red">*</span>为必填项)</th> <tr> - <td class="w-25 m-color">实验名称</td> + <td class="w-25 m-color required">实验名称</td> <td class="w-75 m-color"> <el-form-item prop="experimentName"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.experimentName" placeholder="请输入实验名称" /> @@ -13,148 +13,203 @@ </td> </tr> <tr> - <td class="w-25 m-color">实验类型</td> + <td class="w-25 m-color required">实验类型</td> <td class="w-75 m-color"> - - <el-radio-group style="text-align: center" :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.experimentType"> - <el-radio :label="1">化学类</el-radio> - <el-radio :label="2">生物类</el-radio> - <el-radio :label="3">辐射类</el-radio> - <el-radio :label="4">机电类</el-radio> - <el-radio :label="5">特种设备类</el-radio> - <el-radio :label="6">其他类</el-radio> - </el-radio-group> - - + <el-form-item prop="typeValue" style="display: flex;justify-content: center"> +<!-- <el-radio-group style="text-align: center" :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.experimentType">--> +<!-- <el-radio :label="1">化学类</el-radio>--> +<!-- <el-radio :label="2">生物类</el-radio>--> +<!-- <el-radio :label="3">辐射类</el-radio>--> +<!-- <el-radio :label="4">机电类</el-radio>--> +<!-- <el-radio :label="5">特种设备类</el-radio>--> +<!-- <el-radio :label="6">其他类</el-radio>--> +<!-- </el-radio-group>--> + <el-checkbox-group style="text-align: center" v-model="typeValue" :disabled="projectDialogState.disabled" @change="changeList"> + <el-checkbox v-for="item in projectDialogState.experimentTypeList" :label="item.typeId" :key="item.typeId" >{{item.typeName}}</el-checkbox> + </el-checkbox-group> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">部门</td> + <td class="w-25 m-color required">部门</td> <td class="w-25 m-color"> - <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.dep" /> +<!-- <el-form-item prop="dep">--> +<!-- <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.dep" />--> +<!-- </el-form-item>--> + <el-form-item prop="dep"> + <el-select style="width: 100%" v-model="projectDialogState.projectForm.dep" clearable filterable> + <el-option + v-for="item in projectDialogState.deptList" + :key="item.id" + :value="item.depName" + :label="item.depName" + ></el-option> + </el-select> + </el-form-item> </td> - <td class="w-25 m-color">负责人</td> - <td class="w-16 m-color"> - <el-select :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.liabilityUserId" clearable filterable> - <el-option - v-for="item in projectDialogState.systemPersonList" - :key="item.id" - :value="item.id" - :label="item.realName" - ></el-option> - </el-select> + <td class="w-25 m-color required">立项时间</td> + <td class="w-25 m-color"> + <el-form-item prop="createExperimentTime"> + <el-date-picker :disabled="projectDialogState.disabled" type="datetime" format="YYYY/MM/DD HH:mm:ss" value-format="YYYY-MM-DD HH:mm:ss" v-model="projectDialogState.projectForm.createExperimentTime" /> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">立项时间</td> - <td class="w-25 m-color"> - <el-date-picker :disabled="projectDialogState.disabled" type="datetime" format="YYYY/MM/DD HH:mm:ss" value-format="YYYY-MM-DD HH:mm:ss" v-model="projectDialogState.projectForm.expectStartTime" /> - </td> -<!-- <td class="w-16 m-color">开展时间</td>--> -<!-- <td class="w-16 m-color">--> -<!-- <el-date-picker v-model="projectDialogState.projectForm.startTime" />--> -<!-- </td>--> - <td class="w-25 m-color">安全负责人</td> - <td class="w-16 m-color"> - <el-select :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.safeLiabilityUserId" clearable filterable> - <el-option - v-for="item in projectDialogState.allPersonList" + <td class="w-25 m-color required">负责人</td> + <td class="w-25 m-color"> + <el-form-item prop="liabilityUserId"> + <el-select style="width: 100%" v-model="projectDialogState.projectForm.liabilityUserId" clearable filterable @change="getLiabilityUserPhone($event)"> + <el-option + v-for="item in projectDialogState.systemPersonList" :key="item.id" :value="item.id" - :label="item.personName" - ></el-option> - </el-select> - </td> + :label="item.realName" + ></el-option> + </el-select> +<!-- <el-select style="width: 100%" disabled v-model="projectDialogState.projectForm.liabilityUserId" clearable filterable>--> +<!-- <el-option :key="userInfos.uid" :value="userInfos.uid" :label="userInfos.userName"></el-option>--> +<!-- </el-select>--> + </el-form-item> +<!-- <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.liabilityUserId"/>--> + </td> + <td class="w-25 m-color required">电话</td> + <td class="w-25 m-color"> + <el-form-item prop="liabilityUserPhone"> + <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.liabilityUserPhone" /> + </el-form-item> + </td> </tr> - <tr class="m-color b-font" style="text-align: center">实验场所</tr> -<!-- <tr>--> -<!-- <td class="w-25 m-color">楼宇</td>--> -<!-- <td class="w-75 m-color">--> -<!-- <el-input v-model="projectDialogState.projectForm.building" placeholder="请输入楼栋名称" />--> -<!-- </td>--> -<!-- </tr>--> <tr> - <td class="w-25 m-color">房间号</td> -<!-- <td class="w-75 m-color">--> - <td class="w-16 m-color"> - <el-select :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.siteId" placeholder="请输入房间号" > - <el-option - v-for="item in projectDialogState.allRoomList" - :key="item.id" - :value="item.id" - :label="item.room" - ></el-option> - </el-select> - </td> + <td class="w-25 m-color required">安全负责人</td> + <td class="w-25 m-color"> +<!-- <el-select style="width: 100%" :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.safeLiabilityUser" @change="getSafeLiabilityUserPhone($event)" clearable filterable>--> +<!-- <el-option--> +<!-- v-for="item in projectDialogState.allPersonList"--> +<!-- :key="item.id"--> +<!-- :value="item.id"--> +<!-- :label="item.personName"--> +<!-- ></el-option>--> +<!-- </el-select>--> + <el-form-item prop="safeLiabilityUser"> + <el-select style="width: 100%" v-model="projectDialogState.projectForm.safeLiabilityUser" clearable filterable @change="getSafeLiabilityUserPhone($event)"> + <el-option + v-for="item in projectDialogState.systemPersonList" + :key="item.id" + :value="item.realName" + :label="item.realName" + ></el-option> + </el-select> + </el-form-item> +<!-- <el-form-item prop="safeLiabilityUser">--> +<!-- <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.safeLiabilityUser" />--> +<!-- </el-form-item>--> + </td> + <td class="w-25 m-color required">电话</td> + <td class="w-25 m-color"> + <el-form-item prop="safeLiabilityUserPhone"> + <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.safeLiabilityUserPhone" /> + </el-form-item> + </td> </tr> + <select-room ref="selectRoomRef" v-model:disabled="projectDialogState.disabled" v-model:data="projectDialogState.projectForm.siteList"></select-room> <select-material ref="selectMaterialRef" v-model:disabled="projectDialogState.disabled" v-model:data="projectDialogState.projectForm.stuffList"></select-material> <select-equipment ref="selectEquipmentRef" v-model:disabled="projectDialogState.disabled" v-model:data="projectDialogState.projectForm.deviceList"></select-equipment> <tr> - <td class="w-25 m-color">实验步骤</td> + <td class="w-25 m-color required">实验步骤</td> <td class="w-75 m-color"> + <el-form-item prop="experimentStep"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.experimentStep" placeholder="请输入实验步骤" /> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">操作方法</td> + <td class="w-25 m-color required">操作方法</td> <td class="w-75 m-color"> + <el-form-item prop="experimentMethod"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.experimentMethod" placeholder="请输入操作方法" /> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">工艺过程</td> + <td class="w-25 m-color required">工艺过程</td> <td class="w-75 m-color"> + <el-form-item prop="process"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.process" placeholder="请输入工艺过程" /> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">特殊/关键过程</td> + <td class="w-25 m-color required">特殊/关键过程</td> <td class="w-75 m-color"> + <el-form-item prop="keyProcess"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.keyProcess" placeholder="请输入特殊/关键过程" /> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">是否存在过夜、老化实验</td> + <td class="w-25 m-color required">预防措施</td> + <td class="w-75 m-color"> + <el-form-item prop="measure"> + <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.measure" placeholder="请输入预防措施" /> + </el-form-item> + </td> + </tr> + <tr> + <td class="w-25 m-color required">是否存在过夜、老化实验</td> <td class="w-25 m-color"> + <el-form-item prop="timeout"> <el-radio-group :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.timeout"> <el-radio :label="1">存在</el-radio> <el-radio :label="2">不存在</el-radio> </el-radio-group> + </el-form-item> </td> - <td class="w-25 m-color">过夜、老化保障措施</td> - <td class="w-25 m-color"> + <td class="w-25 m-color required" v-if="projectDialogState.projectForm.timeout === 1">过夜、老化保障措施</td> + <td class="w-25 m-color" v-if="projectDialogState.projectForm.timeout === 1"> + <el-form-item prop="timeoutManager"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.timeoutManager" /> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">是否在封闭条件下</td> + <td class="w-25 m-color required">是否在封闭条件下</td> <td class="w-25 m-color"> + <el-form-item prop="closed"> <el-radio-group :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.closed"> <el-radio :label="1">存在</el-radio> <el-radio :label="2">不存在</el-radio> </el-radio-group> + </el-form-item> </td> - <td class="w-25 m-color">封闭条件保障措施</td> - <td class="w-25 m-color"> - <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.unclosedManager" /> + <td class="w-25 m-color required" v-if="projectDialogState.projectForm.closed === 1">封闭条件保障措施</td> + <td class="w-25 m-color" v-if="projectDialogState.projectForm.closed === 1"> + <el-form-item prop="unclosedManager"> + <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.unclosedManager"/> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">实验场所防爆措施条件和设施情况</td> + <td class="w-25 m-color required">实验场所防爆措施条件和设施情况</td> <td class="w-75 m-color"> + <el-form-item prop="explosionProof"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.explosionProof" placeholder="请输入" /> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">实验场所防火措施条件和设施情况</td> + <td class="w-25 m-color required">实验场所防火措施条件和设施情况</td> <td class="w-75 m-color"> + <el-form-item prop="fireProof"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.fireProof" placeholder="请输入" /> + </el-form-item> </td> </tr> <tr> - <td class="w-25 m-color">实验场所防中毒措施条件和设施情况</td> + <td class="w-25 m-color required">实验场所防中毒措施条件和设施情况</td> <td class="w-75 m-color"> + <el-form-item prop="poisonProof"> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.poisonProof" placeholder="请输入" /> + </el-form-item> </td> </tr> @@ -176,48 +231,63 @@ <!-- <el-input v-model="projectDialogState.projectForm.systemName" placeholder="请输入" />--> <!-- </td>--> <!-- </tr>--> +<!-- <tr class="m-color b-font" style="text-align: center">应急预案/应急演练</tr>--> +<!-- <tr>--> +<!-- <td class="w-25 m-color required">有无预案</td>--> +<!-- <td class="w-25 m-color required">预案名称</td>--> +<!-- <td class="w-25 m-color required">是否演练</td>--> +<!-- <td class="w-25 m-color required">演练情况</td>--> +<!-- </tr>--> +<!-- <tr>--> +<!-- <td class="w-25 m-color">--> +<!-- <el-form-item prop="emergencyPlan">--> +<!-- <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.emergencyPlan" />--> +<!-- </el-form-item>--> +<!-- </td>--> +<!-- <td class="w-25 m-color">--> +<!-- <el-form-item prop="emergencyPlanName">--> +<!-- <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.emergencyPlanName" />--> +<!-- </el-form-item>--> +<!-- </td>--> +<!-- <td class="w-25 m-color">--> +<!-- <el-form-item prop="emergencyDrillStatus">--> +<!-- <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.emergencyDrillStatus" />--> +<!-- </el-form-item>--> +<!-- </td>--> +<!-- <td class="w-25 m-color">--> +<!-- <el-form-item prop="emergencyDrill">--> +<!-- <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.emergencyDrill" />--> +<!-- </el-form-item>--> +<!-- </td>--> +<!-- </tr>--> + <select-emergency ref="selectEmergencyRef" v-model:disabled="projectDialogState.disabled" v-model:data="projectDialogState.projectForm.emergencyList"></select-emergency> <tr> - <td class="w-25 m-color">安全管理制度</td> + <td class="w-25 m-color required">安全管理制度</td> + <td class="w-75 m-color"> + <el-form-item prop="safeManagerMethod"> + <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.safeManagerMethod" placeholder="请输入" /> + </el-form-item> + </td> + </tr> + <tr class="m-color b-font" style=" text-align: center">其他信息</tr> + <tr> + <td class="w-25 m-color required">实验场所是否需要分区隔断</td> <td class="w-75 m-color"> - <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.safeManagerMethod" placeholder="请输入" /> - </td> - </tr> - <tr class="m-color b-font" style="text-align: center">应急预案/应急演练</tr> - <tr> - <td class="w-25 m-color">有无预案</td> - <td class="w-25 m-color"> - 预案名称 - </td> - <td class="w-25 m-color">是否演练</td> - <td class="w-25 m-color"> - 演练情况 - </td> - </tr> - <tr> - <td class="w-25 m-color"> - <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.emergencyPlan" /> - </td> - <td class="w-25 m-color"> - <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.emergencyPlanName" /> - </td> - <td class="w-25 m-color"> - <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.emergencyDrillStatus" /> - </td> - <td class="w-25 m-color"> - <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.emergencyDrill" /> - </td> - </tr> - <tr class="m-color b-font" style=" text-align: center">实验人员</tr> - <tr> - <td class="w-25 m-color">实验场所是否需要分区隔断</td> - <td class="w-75 m-color"> - <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.partitionCondition" placeholder="请输入" /> + <el-form-item prop="partitionCondition"> +<!-- <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.partitionCondition" placeholder="请输入" />--> + <el-radio-group :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.partitionCondition"> + <el-radio :label="0">是</el-radio> + <el-radio :label="1">否</el-radio> + </el-radio-group> + </el-form-item> </td> </tr> <tr> <td class="w-25 m-color">其它基础信息(详细描述)</td> <td class="w-75 m-color"> + <el-form-item> <el-input :disabled="projectDialogState.disabled" v-model="projectDialogState.projectForm.note" placeholder="请输入" /> + </el-form-item> </td> </tr> </table> @@ -225,7 +295,8 @@ <template #footer> <span class="dialog-footer" style="padding-top:10px;text-align: center !important;"> <el-button @click="projectDialogState.projectDialogVisible = !projectDialogState.projectDialogVisible" size="default">取 消</el-button> - <el-button type="primary" v-if="!projectDialogState.disabled" @click="onSubmitProject" size="default">确定</el-button> + <el-button type="primary" v-if="!projectDialogState.disabled && projectDialogState.title!= '编辑'" @click="onSubmitProject" size="default">确定</el-button> + <el-button type="primary" v-if="!projectDialogState.disabled" @click="scratchProject" plain size="default">暂存</el-button> </span> </template> </el-dialog> @@ -238,16 +309,27 @@ import {projectApi} from "/@/api/experiment/project"; import {personApi} from "/@/api/basic/person"; import {userApi} from "/@/api/systemManage/user"; +import {useUserInfo} from "/@/stores/userInfo"; +import {storeToRefs} from "pinia"; +import {checkChineseName, verifyPhone} from "/@/utils/toolsValidate"; +import {departmentApi} from "/@/api/systemManage/department"; const SelectEquipment = defineAsyncComponent(() => import('./selectEquipment.vue')) const SelectMaterial = defineAsyncComponent(() => import('./selectMaterial.vue')) +const SelectEmergency = defineAsyncComponent(() => import('./selectEmergency.vue')) const SelectDanger = defineAsyncComponent(() => import('./selectDanger.vue')) const SelectPerson = defineAsyncComponent(() => import('./selectPerson.vue')) +const SelectRoom = defineAsyncComponent(() => import('./selectRoom.vue')) const ProjectFormRef = ref() const selectPersonRef = ref() const selectEquipmentRef = ref() +const selectRoomRef = ref() const selectMaterialRef = ref() +const selectEmergencyRef = ref() const selectDangerRef = ref() +const typeValue = ref([]) +const userInfo = useUserInfo(); +const { userInfos } = storeToRefs(userInfo); const projectDialogState = reactive<ProjectDialogType>({ title: '', @@ -257,14 +339,17 @@ id: null, experimentName: "", experimentType: null, + typeList: [], liabilityUserId: null, - safeLiabilityUserId: null, + liabilityUserPhone: '', + safeLiabilityUser: '', + safeLiabilityUserPhone: '', dep: "", - siteId: null, experimentStep: "", experimentMethod: "", process: "", keyProcess: "", + measure: "", timeout: null, timeoutManager: "", closed: null, @@ -272,35 +357,97 @@ explosionProof: "", fireProof: "", poisonProof: "", - hazardousWaste: null, safeManagerMethod: "", - emergencyPlan: "", - emergencyDrill: "", - emergencyPlanName: "", - emergencyDrillStatus: "", - partitionCondition: "", + emergencyList: [], + partitionCondition: null, note: "", - expectStartTime: null, - persons: [ - ], - deviceList: [ - ], - stuffList: [ - ], - hazardousWasteList: [ - ] + createExperimentTime: '', + persons: [], + siteList: [], + deviceList: [], + stuffList: [], + hazardousWasteList: [] }, + experimentTypeList: [ + {typeId: 1, typeName: '化学类'}, + {typeId: 2, typeName: '生物类'}, + {typeId: 3, typeName: '辐射类'}, + {typeId: 4, typeName: '机电类'}, + {typeId: 5, typeName: '特种设备类'}, + {typeId: 6, typeName: '其它类'}, + ], projectFormRules: { - experimentName: [{ required: true, message: '请填写设备编号', trigger: 'blur' }], - deviceName: [{ required: true, message: '请填写设备名称', trigger: 'blur' }], - devicePower: [{ required: true, message: '请填写设备功率', trigger: 'blur' }], - deviceUnit: [{ required: true, message: '请选择计量单位', trigger: 'change' }] + experimentName: [{ required: true, message: '', trigger: 'blur' }], + experimentType: [{ required: true, message: '', trigger: 'blur' }], + typeList: [{ required: true, message: '', trigger: 'blur' }], + liabilityUserId: [{ required: true, message: '', trigger: 'blur' }], + liabilityUserPhone: [{ required: true, message: '', trigger: 'blur' }], + safeLiabilityUser: [{ required: true, message: '', trigger: 'blur' }], + safeLiabilityUserPhone: [{ required: true, message: '', trigger: 'blur' }], + dep: [{ required: true, message: '', trigger: 'blur' }], + experimentStep: [{ required: true, message: '', trigger: 'blur' }], + experimentMethod: [{ required: true, message: '', trigger: 'blur' }], + process: [{ required: true, message: '', trigger: 'blur' }], + keyProcess: [{ required: true, message: '', trigger: 'blur' }], + measure: [{ required: true, message: '', trigger: 'blur' }], + timeout: [{ required: true, message: '', trigger: 'blur' }], + timeoutManager: [{ required: true, message: '', trigger: 'blur' }], + closed: [{ required: true, message: '', trigger: 'blur' }], + unclosedManager: [{ required: true, message: '', trigger: 'blur' }], + explosionProof: [{ required: true, message: '', trigger: 'blur' }], + fireProof: [{ required: true, message: '', trigger: 'blur' }], + poisonProof: [{ required: true, message: '', trigger: 'blur' }], + safeManagerMethod: [{ required: true, message: '', trigger: 'blur' }], + emergencyList: [{ required: true, message: '', trigger: 'blur' }], + partitionCondition: [{ required: true, message: '', trigger: 'blur' }], + createExperimentTime: [{ required: true, message: '', trigger: 'blur' }] }, allPersonList: [], allRoomList: [], systemPersonList: [], + deptList: [] }) +const getLiabilityUserPhone = (value: number)=>{ + const data = projectDialogState.systemPersonList.find(item => item.id === value) as AllPersonListType + projectDialogState.projectForm.liabilityUserPhone = data.phone +} + +const getSafeLiabilityUserPhone = (value: number)=>{ + const data = projectDialogState.systemPersonList.find(item => item.realName === value) as AllPersonListType + projectDialogState.projectForm.safeLiabilityUserPhone = data.phone +} + +// const getSafeLiabilityUserPhone = (value: number)=>{ +// const data = projectDialogState.allPersonList.find(item => item.id === value) as AllPersonListType +// projectDialogState.projectForm.safeLiabilityUserPhone = data.phone +// } + +const scratchProject = async() => { + projectDialogState.projectForm.emergencyList = projectDialogState.projectForm.emergencyList ? projectDialogState.projectForm.emergencyList.map(obj => ({emergencyDrill : + obj.emergencyDrill, emergencyDrillStatus : obj.emergencyDrillStatus, emergencyPlan : obj.emergencyPlan, emergencyPlanName : obj.emergencyPlanName})): [] + // projectDialogState.projectForm.emergencyList = projectDialogState.projectForm.emergencyList ? projectDialogState.projectForm.emergencyList: [] + projectDialogState.projectForm.persons = projectDialogState.projectForm.persons ? projectDialogState.projectForm.persons: [] + // projectDialogState.projectForm.hazardousWasteList = projectDialogState.projectForm.hazardousWasteList ? projectDialogState.projectForm.hazardousWasteList: [] + projectDialogState.projectForm.hazardousWasteList = projectDialogState.projectForm.hazardousWasteList ? projectDialogState.projectForm.hazardousWasteList.map(obj => ({classify:obj.classify,wasteStorage:obj.wasteStorage,handAmount:obj.handAmount})): [] + // const roomList = selectRoomRef.value.dataList ? selectRoomRef.value.dataList: [] + projectDialogState.projectForm.siteList = projectDialogState.projectForm.siteList ?projectDialogState.projectForm.siteList.map(({siteId}) => ({siteId})) : [] + projectDialogState.projectForm.stuffList = projectDialogState.projectForm.stuffList ? projectDialogState.projectForm.stuffList: [] + projectDialogState.projectForm.deviceList = projectDialogState.projectForm.deviceList ? projectDialogState.projectForm.deviceList: [] + let res = await projectApi().temporaryProject(projectDialogState.projectForm); + if(res.data.code === 100){ + handleClose() + ElMessage({ + type: 'success', + message: '暂存信息成功' + }) + }else{ + ElMessage({ + type: 'warning', + message: res.data.msg, + }); + } +} const showProjectDialog = (title: string, value: ProjectType, allRoomList: RoomType []) => { projectDialogState.projectDialogVisible = true; projectDialogState.allRoomList = allRoomList @@ -314,14 +461,17 @@ id: null, experimentName: "", experimentType: null, + typeList: [], liabilityUserId: null, - safeLiabilityUserId: null, + liabilityUserPhone: '', + safeLiabilityUser: '', + safeLiabilityUserPhone: '', dep: "", - siteId: null, experimentStep: "", experimentMethod: "", process: "", keyProcess: "", + measure: "", timeout: null, timeoutManager: "", closed: null, @@ -329,24 +479,26 @@ explosionProof: "", fireProof: "", poisonProof: "", - hazardousWaste: 1, safeManagerMethod: "", - emergencyPlan: "", - emergencyDrill: "", - emergencyPlanName: "", - emergencyDrillStatus: "", - partitionCondition: "", + emergencyList: [], + partitionCondition: null, note: "", - expectStartTime: null, - persons: [ - ], - deviceList: [ - ], - stuffList: [ - ], - hazardousWasteList: [ - ] + createExperimentTime: '', + persons: [], + siteList: [], + deviceList: [], + stuffList: [], + hazardousWasteList: [], }; + }else if(title === '整改' || title === '编辑'){ + projectDialogState.title = title; + projectDialogState.disabled = false + for(let i in projectDialogState.projectForm) { + if(isValidKey(i, projectDialogState.projectForm)) { + projectDialogState.projectForm[i] = value[i]; + } + } + typeValue.value = projectDialogState.projectForm.typeList.map(item => item.typeId) }else{ projectDialogState.title = '查看'; projectDialogState.disabled = true @@ -355,29 +507,121 @@ projectDialogState.projectForm[i] = value[i]; } } + typeValue.value = projectDialogState.projectForm.typeList.map(item => item.typeId) } }; + +const handleClose = () => { + typeValue.value = [] + emit('refresh') + projectDialogState.projectDialogVisible = false; +} const isValidKey = (key: string | number | symbol, object:object): key is keyof typeof object =>{ return key in object; }; +const changeList = (val: any) => { + const filteredNames = projectDialogState.experimentTypeList + .filter((obj) => val.includes(obj.typeId)).map(item => { + return { + typeId: item.typeId, + typeName: item.typeName + } + }) + projectDialogState.projectForm.typeList = filteredNames -const onSubmitProject = () => { +} + +const onSubmitProject = async() => { ProjectFormRef.value.validate(async(valid: boolean) => { if(valid){ + if(projectDialogState.projectForm.timeout === 2){ + projectDialogState.projectForm.timeoutManager = '' + }else{ + if(projectDialogState.projectForm.timeoutManager == ''){ + ElMessage({ + type: 'warning', + message: '请填写过夜、老化保障措施', + duration: 1000 + }); + return + } + } + if(projectDialogState.projectForm.closed === 2){ + projectDialogState.projectForm.unclosedManager = "" + }else{ + if(projectDialogState.projectForm.unclosedManager == ''){ + ElMessage({ + type: 'warning', + message: '请填写封闭条件保障措施', + duration: 1000 + }); + return + } + } if(projectDialogState.title === '新增'){ + // if(checkChineseName(projectDialogState.projectForm.safeLiabilityUser) == false){ + // ElMessage({ + // type: 'warning', + // message: '安全负责人姓名格式有误', + // duration: 1000 + // }); + // return + // } + if(verifyPhone(projectDialogState.projectForm.safeLiabilityUserPhone) == false || verifyPhone(projectDialogState.projectForm.liabilityUserPhone) == false){ + ElMessage({ + type: 'warning', + message: '请输入正确的手机号', + duration: 1000 + }); + return + } + if(projectDialogState.projectForm.siteList.length === 0){ + ElMessage({ + type: 'warning', + message: '请至少添加一处实验场所', + duration: 1000 + }); + return + } + if(projectDialogState.projectForm.stuffList.length === 0){ + ElMessage({ + type: 'warning', + message: '请至少选择一种试剂/材料', + duration: 1000 + }); + return + } + if(projectDialogState.projectForm.deviceList.length === 0){ + ElMessage({ + type: 'warning', + message: '请至少选择一种仪器/设备', + duration: 1000 + }); + return + } + if(projectDialogState.projectForm.persons.length === 0){ + ElMessage({ + type: 'warning', + message: '请至少添加一名实验人员', + duration: 1000 + }); + return + } + projectDialogState.projectForm.emergencyList = selectEmergencyRef.value.dataList projectDialogState.projectForm.persons = selectPersonRef.value.dataList - projectDialogState.projectForm.hazardousWasteList = selectDangerRef.value.dataList + const roomList = selectRoomRef.value.dataList + projectDialogState.projectForm.siteList = roomList.map(({siteId}) => ({siteId})) projectDialogState.projectForm.stuffList = selectMaterialRef.value.dataList projectDialogState.projectForm.deviceList = selectEquipmentRef.value.dataList - let res = await projectApi().addProject(projectDialogState.projectForm); + let res = await projectApi().addProject(projectDialogState.projectForm) if(res.data.code === 100){ - emit('refresh') - projectDialogState.projectDialogVisible = false; + handleClose() ElMessage({ type: 'success', message: '新增成功' }) + }else{ ElMessage({ type: 'warning', @@ -385,13 +629,14 @@ }); } }else{ + projectDialogState.projectForm.siteList = selectRoomRef.value.dataList.map(obj => ({siteId:obj.siteId})) + projectDialogState.projectForm.hazardousWasteList = selectDangerRef.value.dataList.map(obj => ({classify:obj.classify,wasteStorage:obj.wasteStorage,handAmount:obj.handAmount})) let res = await projectApi().modProject(projectDialogState.projectForm) if(res.data.code === 100){ - emit('refresh') - projectDialogState.projectDialogVisible = false; + handleClose() ElMessage({ type: 'success', - message: '编辑成功' + message: '整改已提交' }) }else{ ElMessage({ @@ -411,10 +656,13 @@ const getPersonList = async () => { let res = await userApi().getUserList({ - roleId: 1, - usePage: false, - pageIndex: 1, - pageSize: 10 + pageIndex: 1, + pageSize: 99999, + searchParams:{ + roleId: null, + name: '', + realName: '' + } }); if(res.data.code === 100){ projectDialogState.systemPersonList = JSON.parse(JSON.stringify(res.data.data)); @@ -438,6 +686,19 @@ } }; +const getDeptData =async () => { + let res = await departmentApi().getDepartmentList() + if (res.data.code === 100) { + projectDialogState.deptList = res.data.data + } else { + ElMessage({ + type: 'warning', + message: res.data.msg + }); + } +} + + const emit = defineEmits(['refresh']); defineExpose({ @@ -447,6 +708,7 @@ onMounted(() => { getAllPersonList(); getPersonList(); + getDeptData(); }); </script> @@ -485,9 +747,22 @@ text-align: center; line-height: 42px; + :deep(.el-input__wrapper ){ + box-shadow: none; + margin-top: 6px; + } + &:last-of-type { border-right: none; } + +&.required { + &::before { + content: "*"; + display: inline-block; + color: red; + } +} &.w-14 { width: calc((100/7)/100 * 100%); @@ -539,10 +814,55 @@ .m-color { color: #0c4995; } -:deep(.el-input__wrapper ){ - box-shadow: none; - margin-top: 6px; +::v-deep(.el-form-item){ + height: 100%; + display: flex; + justify-content: center; + .el-form-item__content{ + display: flex; + justify-content: center; + } } +.roomSelect{ + ::v-deep(.el-popper){ + .el-select-dropdown__item{ + height: auto; + padding: 0; + + .roomTable{ + width: 100%; + display: flex; + border-bottom: 1px solid #ebeef5; + + &:last-of-type{ + border-bottom: none; + } + + &>div{ + width: 25%; + border-right: 1px dashed #ebeef5; + &:last-of-type{ + border-right: none; + } + + div{ + width: 100%; + } + .roomTit{ + border-bottom: 1px solid #ebeef5; + } + } + } + } + .el-select-dropdown__item.selected{ + .roomTit{ + color: #606266; + font-weight: normal; + } + } + } +} + :deep(.el-dialog__footer){ padding-top: 20px; display: flex; -- Gitblit v1.9.2