From 49b46688641b7a4ba074dedccbcc5547f879ec0a Mon Sep 17 00:00:00 2001
From: 祖安之光 <11848914+light-of-zuan@user.noreply.gitee.com>
Date: Tue, 02 Jun 2026 14:50:14 +0800
Subject: [PATCH] 修改专业对应部门处室
---
src/views/safetyReview/expertManage/fillForm/index.vue | 59 +++++++++++++++++++++++++++++++++++++++++++++++++----------
1 files changed, 49 insertions(+), 10 deletions(-)
diff --git a/src/views/safetyReview/expertManage/fillForm/index.vue b/src/views/safetyReview/expertManage/fillForm/index.vue
index d133eb8..fbcb06c 100644
--- a/src/views/safetyReview/expertManage/fillForm/index.vue
+++ b/src/views/safetyReview/expertManage/fillForm/index.vue
@@ -5,13 +5,14 @@
<el-form :model="state.form" :rules="state.rules" ref="ruleFormRef" label-width="200px">
<el-row>
<el-col :span="20">
- <el-form-item label="专业类别" prop="domain">
+ <el-form-item label="专业类别" prop="profession">
<el-cascader
style="width: 100%"
clearable
- v-model="state.form.domain"
+ :disabled="state.disable"
+ v-model="state.form.profession"
:options="state.expertsType"
- :props="{ expandTrigger: 'hover',value: 'classifyName',label: 'classifyName',emitPath: false }"
+ :props="{ expandTrigger: 'hover', value: 'id',label: 'classifyName'}"
@change="professionChange"></el-cascader>
</el-form-item>
</el-col>
@@ -22,6 +23,7 @@
<el-cascader
style="width: 100%"
clearable
+ :disabled="state.findDept"
v-model="state.form.deptId"
:options="state.deptList"
:props="{ expandTrigger: 'hover', value: 'deptId',label: 'deptName',emitPath: false}"></el-cascader>
@@ -395,6 +397,9 @@
form:{
name:'',
sex:'',
+ profession: [],
+ bigClassify: null,
+ smallClassify: null,
domain: '',
deptId: null,
birthday: '',
@@ -427,6 +432,7 @@
remark: '',
source: 1
},
+ findDept: true,
expertsType: [],
deptList: [],
directionList: [
@@ -467,7 +473,7 @@
rules:{
name:[{ required: true, message: '请填写姓名', trigger: 'blur' }],
sex:[{ required: true, message: '请选择性别', trigger: 'blur' }],
- domain: [{ required: true, message: '请选择专业类别', trigger: 'blur' }],
+ profession: [{ required: true, message: '请选择专业类别', trigger: 'blur' }],
deptId: [{ required: true, message: '请选择业务处室', trigger: 'blur' }],
birthday: [{ required: true, message: '请选择出生日期', trigger: 'blur' }],
phone:[{ required: true, validator: validatePhone, trigger: 'blur' }],
@@ -500,17 +506,43 @@
}
}
+const professionChange = (value) => {
+ if (!value) {
+ state.form.profession = []
+ state.form.bigClassify = null
+ state.form.smallClassify = null
+ }
+ const foundType = findNodeById(state.expertsType,value[1])
+ if(foundType.deptId){
+ state.form.deptId = foundType.deptId
+ state.findDept = true
+ }else{
+ ElMessage.warning('该专业未找到对应的业务处室,请手动选择')
+ state.form.deptId = null
+ state.findDept = false
+ }
+}
+
+const findNodeById = (data,value)=> {
+ for (const node of data) {
+ if (node.id === value) {
+ return node;
+ }
+ if (node.children) {
+ const foundNode = findNodeById(node.children, value);
+ if (foundNode) {
+ return foundNode;
+ }
+ }
+ }
+ return null;
+}
+
function getDepList() {
listOutDept({}).then(response => {
state.deptList = proxy.handleTree(response.data, "deptId",'parentId','children');
});
}
-
- const professionChange=(value)=> {
- console.log(value,'val')
- }
-
-
// 图片上传
const showTip =()=>{
@@ -588,6 +620,9 @@
await formEl.validate(async (valid, fields) => {
if (valid) {
let data = JSON.parse(JSON.stringify(state.form))
+ data.bigClassify = data.profession[0]
+ data.smallClassify = data.profession[1]
+ data.domain = findNodeById(state.expertsType,data.smallClassify)?.classifyName
data.supportDirectionSafety = Array.isArray(data.supportDirectionSafety)?data.supportDirectionSafety.join(','):''
data.supportDirectionPrevention = Array.isArray(data.supportDirectionPrevention)?data.supportDirectionPrevention.join(','):''
data.supportDirectionEmergency = Array.isArray(data.supportDirectionEmergency)?data.supportDirectionEmergency.join(','):''
@@ -598,6 +633,7 @@
data.achievementKey = state.achievementList.map(i=>i.name).join(',')
data.personalOpinionKey = state.proAdviceList.map(i=>i.name).join(',')
data.recommendUnitOpinionKey = state.adviceList.map(i=>i.name).join(',')
+ delete data.profession
delete data.id
const res= await addExpertInfo(data)
if(res.code == 200){
@@ -605,6 +641,9 @@
state.form = {
name:'',
sex:'',
+ profession: [],
+ bigClassify: null,
+ smallClassify: null,
domain: '',
birthday: '',
phone:'',
--
Gitblit v1.9.2