From 9ca1d8a5c10cf277d02445845bd62510bebf6989 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期四, 20 二月 2025 18:00:09 +0800
Subject: [PATCH] 项目增加项目子类型字段回显bug

---
 src/views/projectEngineering/projectLibrary/component/BasicInfo.vue |  184 ++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 160 insertions(+), 24 deletions(-)

diff --git a/src/views/projectEngineering/projectLibrary/component/BasicInfo.vue b/src/views/projectEngineering/projectLibrary/component/BasicInfo.vue
index 463e144..488b476 100644
--- a/src/views/projectEngineering/projectLibrary/component/BasicInfo.vue
+++ b/src/views/projectEngineering/projectLibrary/component/BasicInfo.vue
@@ -58,30 +58,38 @@
             </el-col>
 
             <el-col :span="6">
-              <el-col :span="6">
-                <el-form-item label="寤鸿鎬ц川" label-width="100px" prop="constructionNature" style="width: 100%; min-width: 260px">
-                  <el-select
-                    v-model="projectForm.constructionNature"
-                    clearable
-                    placeholder="璇烽�夋嫨"
-                    style="width: 100%"
-                  >
-                    <el-option v-for="item in dict.type.construction_nature" :key="item.value" :label="item.label"
-                               :value="item.value"/>
-                  </el-select>
-                </el-form-item>
-              </el-col>
+              <el-form-item label="寤鸿鎬ц川" label-width="100px" prop="constructionNature"
+                            style="width: 100%; min-width: 260px">
+                <el-select
+                  v-model="projectForm.constructionNature"
+                  clearable
+                  placeholder="璇烽�夋嫨"
+                  style="width: 100%"
+                >
+                  <el-option v-for="item in dict.type.construction_nature" :key="item.value" :label="item.label"
+                             :value="item.value"/>
+                </el-select>
+              </el-form-item>
             </el-col>
           </el-row>
           <el-row :gutter="20">
             <el-col :span="6">
               <el-form-item label="椤圭洰绫诲瀷" label-width="100px" prop="projectType" style="width: 100%">
-                <el-select v-model="projectForm.projectType" clearable placeholder="璇烽�夋嫨" style="width: 100%">
+                <el-select v-model="projectForm.projectType" @change="getChildSelect" clearable placeholder="璇烽�夋嫨" style="width: 100%">
                   <el-option v-for="item in dict.type.sys_project_type" :key="item.value" :label="item.label"
                              :value="item.value"/>
                 </el-select>
               </el-form-item>
             </el-col>
+            <el-col :span="6">
+              <el-form-item label="椤圭洰瀛愮被鍨�" label-width="100px" prop="projectSubType" style="width: 100%">
+                <el-select v-model="projectForm.projectSubType" :disabled="projectForm.projectType === ''" clearable placeholder="璇烽�夋嫨" style="width: 100%">
+                  <el-option v-for="item in projectSubTypeList" :key="item.dictCode + 'zd'" :label="item.dictLabel"
+                             :value="item.dictValue"/>
+                </el-select>
+              </el-form-item>
+            </el-col>
+
             <el-col :span="6">
               <el-form-item label="椤圭洰鐘舵��" label-width="100px" prop="projectstatus" style="width: 100%">
                 <el-select v-model="projectForm.projectStatus" clearable placeholder="璇烽�夋嫨" @change="handleProjectStatusChange" style="width: 100%">
@@ -96,12 +104,12 @@
                           placeholder="璇疯緭鍏�"/>
               </el-form-item>
             </el-col>
-            <!--        <el-col :span="6">-->
-            <!--          <el-form-item label="椤圭洰涓氫富鍗曚綅" label-width="100px" prop="projectOwnerUnit" style="width: 100%">-->
-            <!--            <el-input v-model.trim="projectForm.projectOwnerUnit" class="item" clearable maxlength="255"-->
-            <!--                      placeholder="璇疯緭鍏�"/>-->
-            <!--          </el-form-item>-->
-            <!--        </el-col>-->
+<!--                    <el-col :span="6">-->
+<!--                      <el-form-item label="椤圭洰涓氫富鍗曚綅" label-width="100px" prop="projectOwnerUnit" style="width: 100%">-->
+<!--                        <el-input v-model.trim="projectForm.projectOwnerUnit" class="item" clearable maxlength="255"-->
+<!--                                  placeholder="璇疯緭鍏�"/>-->
+<!--                      </el-form-item>-->
+<!--                    </el-col>-->
           </el-row>
           <el-row :gutter="20">
             <el-col :span="6">
@@ -239,6 +247,53 @@
               </el-form-item>
             </el-col>
           </el-row>
+          <el-row :gutter="20">
+            <el-col :span="6">
+              <el-form-item label="琛屼笟涓荤閮ㄩ棬" label-width="100px" prop="industryCompetentDepartment" style="width: 100%">
+                  <el-select
+                    v-model="projectForm.industryCompetentDepartment"
+                    clearable
+                    @change="handleDepartmentChange"
+                    placeholder="璇烽�夋嫨"
+                    style="width: 100%;"
+                  >
+                    <el-option
+                      v-for="item in approvalList"
+                      :key="item.id"
+                      :value="item.id"
+                      :label="item.value"
+                    />
+                  </el-select>
+              </el-form-item>
+            </el-col>
+            <el-col :span="6">
+              <el-form-item label="鑱旂郴浜�" label-width="100px" style="width: 100%">
+                <el-select
+                  v-model="projectForm.industryCompetentDepartmentPerson"
+                  clearable
+                  placeholder="璇烽�夋嫨"
+                  @change="handleContactChange"
+                  style="width: 100%;"
+                >
+                  <el-option
+                    v-for="person in personList"
+                    :key="person.userId"
+                    :value="person.userId"
+                    :label="person.nickName"
+                  />
+                </el-select>
+              </el-form-item>
+            </el-col>
+            <el-col :span="6">
+              <el-form-item label="鑱旂郴浜鸿仈绯绘柟寮�" label-width="100px" style="width: 100%">
+                <el-input
+                  v-model="projectForm.departmentPersonPhone"
+                  clearable
+                  placeholder="璇疯緭鍏ヨ仈绯绘柟寮�"
+                />
+              </el-form-item>
+            </el-col>
+          </el-row>
         </div>
       </div>
       <div class="label">
@@ -372,8 +427,11 @@
 // import { getList } from '@/api/engineeringLibrary/index';
 // import RemoteSelect from '@/components/RemoteSelect/index.vue';
 import Cookies from "js-cookie";
-import {addProject, getProject, updateProject, getProjectCode} from '@/api/projectEngineering/projectInfo';
+import {addProject, getProject, updateProject, getProjectCode, editProject} from '@/api/projectEngineering/projectInfo';
 import {approvalList} from "@/api/system/dept";
+import {getByDept} from "@/api/system/user";
+import {getChildList, getDicts} from "@/api/system/dict/data";
+import log from "@/views/monitor/job/log";
 
 export default {
   name: 'BasicInfo',
@@ -397,11 +455,13 @@
   },
   data() {
     return {
+      projectSubTypeList: [], // 椤圭洰瀛愮被鍨�
       projectForm: {
         id: '',
         projectName: '',
         projectCode: '',
         projectType: '',
+        projectSubType: '',
         projectStatus: 'pendding',
         fundType: '',
         investType: '',
@@ -446,8 +506,12 @@
         engineeringInfos: [],
         competentDepartmentList: [],
         managementCentralizationList: [],
-        remark: ''
+        remark: '',
+        industryCompetentDepartment: null,
+        industryCompetentDepartmentPerson: null,
+        departmentPersonPhone: null,
       },
+      personList: [],
       subclass: '',
       largeCategory: '',
       approvalList: [],
@@ -481,8 +545,26 @@
     const projectForm = localStorage.getItem("projectForm");
     //鍒濆鍖栦富绠¢儴闂ㄤ笅鎷夋
     this.getApprovalList();
+
     if (projectForm) {
       this.projectForm = JSON.parse(projectForm);
+      if (this.projectForm.industryCompetentDepartment) {
+        // 鏍规嵁閫変腑鐨勯儴闂↖D鏌ヨ浜哄憳
+        getByDept(this.projectForm.industryCompetentDepartment).then((res) => {
+          this.personList = res.data;
+        })
+      }
+      if (this.projectForm.projectType) {
+        // 鏍规嵁椤圭洰绫诲瀷鏌ュ瓙绫诲瀷
+        getDicts("sys_project_type").then(res => {
+          const projectType = res.data.find(item => item.dictValue === this.projectForm.projectType);
+          if (projectType) {
+            getChildList(projectType.dictCode).then(res => {
+              this.projectSubTypeList = res.data
+            })
+          }
+        })
+      }
       this.$emit('updateIsShow', true);
     } else {
       this.projectForm.id = this.$route.query.projectId;
@@ -497,9 +579,47 @@
     }
   },
   beforeDestroy() {
-    // localStorage.setItem("projectForm", JSON.stringify(this.projectForm));
+    localStorage.setItem("projectForm", JSON.stringify(this.projectForm));
   },
   methods: {
+    getChildSelect(select) {
+      this.projectForm.projectSubType = ''
+      if (select) {
+        getChildList(this.dict.type.sys_project_type.filter(item => item.raw.dictValue === select)[0].raw.dictCode).then(res => {
+          this.projectSubTypeList = res.data
+        })
+      }
+    },
+    // 鐩戝惉鑱旂郴浜洪�夋嫨浜嬩欢
+    handleContactChange(userId) {
+      if (userId) {
+        // 鏍规嵁閫変腑鐨剈serId鏌ユ壘瀵瑰簲鐨勮仈绯讳汉
+        const selectedPerson = this.personList.find(person => person.userId === userId);
+        if (selectedPerson) {
+          // 灏嗚仈绯讳汉鐨刾hone瀛楁鍥炲~鍒拌仈绯荤數璇濊緭鍏ユ
+          this.projectForm.departmentPersonPhone = selectedPerson.phonenumber;
+        } else {
+          // 濡傛灉鏈壘鍒拌仈绯讳汉锛屾竻绌鸿仈绯荤數璇�
+          this.projectForm.departmentPersonPhone = '';
+        }
+      } else {
+        // 濡傛灉userId涓虹┖锛屾竻绌鸿仈绯荤數璇�
+        this.projectForm.departmentPersonPhone = '';
+      }
+    },
+    handleDepartmentChange(departmentId) {
+      if (departmentId) {
+        // 鏍规嵁閫変腑鐨勯儴闂↖D鏌ヨ浜哄憳
+        getByDept(departmentId).then((res) => {
+          this.personList = res.data;
+        })
+      } else {
+        // 濡傛灉鏈�夋嫨閮ㄩ棬锛屾竻绌轰汉鍛樺垪琛�
+        this.personList = [];
+      }
+      this.$set(this.projectForm, 'industryCompetentDepartmentPerson', null);
+      this.$set(this.projectForm, 'departmentPersonPhone', '');
+    },
     addWinUnit() {
       this.projectForm.winUnitList.push({
         winUnit: '',
@@ -535,8 +655,24 @@
     getProjectInfo(id) {
       getProject(id).then(res => {
         this.projectForm = res.data;
+        if (this.projectForm.industryCompetentDepartment) {
+          // 鏍规嵁閫変腑鐨勯儴闂↖D鏌ヨ浜哄憳
+          getByDept(this.projectForm.industryCompetentDepartment).then((res) => {
+            this.personList = res.data;
+          })
+        }
+        if (this.projectForm.projectType) {
+          // 鏍规嵁椤圭洰绫诲瀷鏌ュ瓙绫诲瀷
+          getDicts("sys_project_type").then(res => {
+            const projectType = res.data.find(item => item.dictValue === this.projectForm.projectType);
+            if (projectType) {
+              getChildList(projectType.dictCode).then(res => {
+                this.projectSubTypeList = res.data
+              })
+            }
+          })
+        }
         this.$emit('updateIsShow', true);
-
       });
     },
     getApprovalList() {

--
Gitblit v1.8.0