From 92edb806d39c94f0cbb27cc71ec1806468925e8c Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期六, 22 二月 2025 17:23:21 +0800 Subject: [PATCH] 项目增加招商引资字段、去除项目产业政策符合情况tab --- src/views/projectEngineering/projectLibrary/component/BasicInfo.vue | 148 +++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 118 insertions(+), 30 deletions(-) diff --git a/src/views/projectEngineering/projectLibrary/component/BasicInfo.vue b/src/views/projectEngineering/projectLibrary/component/BasicInfo.vue index ba40712..fffc0a2 100644 --- a/src/views/projectEngineering/projectLibrary/component/BasicInfo.vue +++ b/src/views/projectEngineering/projectLibrary/component/BasicInfo.vue @@ -58,30 +58,53 @@ </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-col :span="6"> + <el-form-item label="鎷涘晢寮曡祫椤圭洰" label-width="100px" prop="attractInvestment" + style="width: 100%; min-width: 260px"> + <el-select + v-model="projectForm.attractInvestment" + clearable + placeholder="璇烽�夋嫨" + style="width: 100%" + > + <el-option v-for="item in dict.type.attract_investment" :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 +119,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"> @@ -117,13 +140,15 @@ </el-col> <el-col :span="6"> <!-- TODO锛氭殏鏃朵笉鍋� --> - <el-form-item label="鍏宠仈宸ョ▼" label-width="100px" prop="engineering" style="width: 100%"> + <el-form-item label="椤圭洰涓氫富鍗曚綅" label-width="100px" prop="engineering" style="width: 100%"> <!-- <el-input v-model.trim="getEngineeringName" class="item" clearable disabled maxlength="255" placeholder="璇峰湪宸ョ▼涓�夋嫨椤圭洰" />--> - <el-select v-model="projectForm.engineeringIdList" :multiple="true" collapse-tags placeholder="璇烽�夋嫨" - style="width: 100%"> - <el-option v-for="item in selectOptions" :key="item.id" :label="item.engineeringName" :value="item.id"/> +<!-- <el-select v-model="projectForm.engineeringIdList" :multiple="true" collapse-tags placeholder="璇烽�夋嫨"--> +<!-- style="width: 100%">--> +<!-- <treeselect v-model="form.parentId" :options="deptOptions" :normalizer="normalizer" placeholder="閫夋嫨涓婄骇閮ㄩ棬" />--> + + <treeselect v-model="projectForm.projectOwnerUnit" :options="selectOptions" :normalizer="normalizer" placeholder="閫夋嫨鍗曚綅" /> <!-- <RemoteSelect v-if="selectOptions.length" :hasMore="hasMore" :loading="loading" :page="page" @loadMore="handleLoadMore" />--> - </el-select> +<!-- </el-select>--> </el-form-item> </el-col> </el-row> @@ -353,7 +378,7 @@ <el-form-item label="骞村害鎶曡祫閲戦" label-width="100px" prop="company" style="width: 100%; min-width: 260px"> <el-input v-model.trim="yearPlan.yearTotalMoney" clearable maxlength="255" placeholder="璇疯緭鍏�" style="width: 90%" type="number"/> - <span style="margin-left: 2px">鍏�</span> + <span style="margin-left: 2px">涓囧厓</span> </el-form-item> </el-col> <el-col :span="10"> @@ -411,6 +436,8 @@ <script> // import Upload from '@element-plus/icons-vue/dist/Upload.vue'; +import Treeselect from '@riophae/vue-treeselect' +import "@riophae/vue-treeselect/dist/vue-treeselect.css"; import Map from '@/views/components/Map/index.vue'; import TagList from "./TagList.vue"; // import MapMouseEvent from '@/views/components/Map/types'; @@ -420,14 +447,19 @@ // import RemoteSelect from '@/components/RemoteSelect/index.vue'; import Cookies from "js-cookie"; import {addProject, getProject, updateProject, getProjectCode, editProject} from '@/api/projectEngineering/projectInfo'; -import {approvalList} from "@/api/system/dept"; +import {approvalList,listDept} 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"; +import { deptList2 } from '../../../../api/system/dept' export default { name: 'BasicInfo', dicts: ['sys_funding_type', 'sys_investment_type', 'sys_project_type', 'sys_project_status', 'sys_competent_department' - , 'sys_administrative_divisions', 'sys_centralized_management', 'sys_approval_type', 'sys_key_categories', 'sys_annual_plan', 'construction_nature'], + , 'sys_administrative_divisions', 'sys_centralized_management', 'sys_approval_type', 'sys_key_categories', 'sys_annual_plan' + , 'construction_nature', 'attract_investment'], components: { + Treeselect, Map, TagList, // UploadStandard, @@ -445,11 +477,14 @@ }, data() { return { + projectSubTypeList: [], // 椤圭洰瀛愮被鍨� projectForm: { id: '', projectName: '', + attractInvestment: '', projectCode: '', projectType: '', + projectSubType: '', projectStatus: 'pendding', fundType: '', investType: '', @@ -482,7 +517,7 @@ projectImageProgress: '', }], projectAddress: '', - engineeringIdList: [], + engineeringIdList: null, content: '', constructionNature: '', contact: '', @@ -511,6 +546,7 @@ page: 1, loading: false, hasMore: true, + deptOptions: [], selectOptions: [], accept: ['pdf', 'docx', 'xlsx', 'jpg', 'jpeg'], mapCreateInfo: {}, @@ -529,6 +565,8 @@ }, }, mounted() { + this.getDeptList(); + this.projectForm.id = this.$route.query.projectId; const projectForm = localStorage.getItem("projectForm"); //鍒濆鍖栦富绠¢儴闂ㄤ笅鎷夋 @@ -540,6 +578,17 @@ // 鏍规嵁閫変腑鐨勯儴闂↖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); @@ -556,9 +605,28 @@ } }, 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 + }) + } + }, + /** 杞崲閮ㄩ棬鏁版嵁缁撴瀯 */ + normalizer(node) { + if (node.children && !node.children.length) { + delete node.children; + } + return { + id: node.deptId, + label: node.deptName, + children: node.children + }; + }, // 鐩戝惉鑱旂郴浜洪�夋嫨浜嬩欢 handleContactChange(userId) { if (userId) { @@ -630,6 +698,17 @@ 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); }); }, @@ -638,6 +717,14 @@ this.approvalList = res.data; }); }, + getDeptList(){ + listDept().then(response => { + console.log(response.data) + + this.selectOptions = this.handleTree(response.data, "deptId"); + }); + }, + submit(usedStatus) { this.$refs["projectForm"].validate(valid => { if (valid) { @@ -682,6 +769,7 @@ // this.subclass = labels.join(','); // }, async loadDataList(newPage) { + try { this.loading = true; const res = await getList({pageNum: newPage, pageSize: 10000}); -- Gitblit v1.8.0