From 007e33dd8728b4557917a2ffa2e2449865602742 Mon Sep 17 00:00:00 2001 From: xiejun <xj@2023> Date: 星期一, 04 十二月 2023 16:10:48 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- Source/UBCS-WEB/src/components/FormTemplate/index.vue | 258 +++++++++++++++++++++++++++++++++++---------------- 1 files changed, 177 insertions(+), 81 deletions(-) diff --git a/Source/UBCS-WEB/src/components/FormTemplate/index.vue b/Source/UBCS-WEB/src/components/FormTemplate/index.vue index 2ad4a80..561cb91 100644 --- a/Source/UBCS-WEB/src/components/FormTemplate/index.vue +++ b/Source/UBCS-WEB/src/components/FormTemplate/index.vue @@ -21,9 +21,9 @@ :templateOid="templateOid" :type="type" data-key="masterForm" + @dataYearCode="dataYearHandler" @getFormData="getFormData" @isShow="isShowHandler" - @dataYearValue="dataYearHandler" ></FormTemplate> <div v-if=" @@ -250,9 +250,11 @@ }, methods: { openDialog() { + //鏂板鍜屼慨鏀瑰叡鍚岃皟鐢� this.getFormTemplate(); - if (this.type === "add") { + if (this.type === "add" || (this.type !== "add" && this.status === "amend")) { this.getCodeRule(); + return; } }, close() { @@ -260,6 +262,7 @@ }, // 鎺ュ彛鑾峰彇琛ㄥ崟鏁版嵁 getFormTemplate() { + //鏂板鍜屼慨鏀瑰叡鍚岃皟鐢� getFormTemplate({ templateOid: this.templateOid, codeClassifyOid: this.codeClassifyOid, @@ -277,6 +280,7 @@ } else { this.showResembleQuery = false; } + //浼犻�掕〃鍗曚笂鏂瑰尯鍩熸暟鎹� 锛堟柊澧炲拰淇敼锛� this.$nextTick(() => { this.$refs.FormTemplate.templateRender( res.data.formDefineVO.items @@ -319,7 +323,7 @@ that.secVOList = (res.data.data.secVOList || []).filter((item) => typeList.includes(item.secType) ); - if (that.secVOList.length > 0 && that.type === "add") { + if (that.secVOList.length > 0 && that.type === "add" ||(that.type !== "add" && that.status === "amend")) { that.showCodeApply = true; that.activeName = "codeApply"; @@ -346,22 +350,32 @@ }, //绯诲垪鍙疯鍒� isShowHandler(val) { - let that = this; this.isShowStatus = val; - this.secVOList.forEach(item => { - if (item.name === "绯诲垪鍙�") { - this.$set(item, "readOnly", val) - } - }) - if(this.$refs.CodeApply.changeChildItem ){ + this.secVOList.forEach(item => { + if (item.name === "绯诲垪鍙�") { + this.$set(item, "readOnly", val) + } + }) + if (this.$refs.CodeApply) { // 娣诲姞涓�涓垽鏂鍙ワ紝妫�鏌ュ璞℃槸鍚︿负undefined this.$refs.CodeApply.changeChildItem(this.secVOList, this.TreeValue, this.type); } }, //骞翠唬鍙� - dataYearHandler(val){ - console.log("val",val) + dataYearHandler(val) { + const readOnlyValue = val && Object.values(val).every(value => value !== ''); + this.secVOList.forEach(item => { + if (item.name === "骞翠唬鍙�") { + const year = readOnlyValue ? val.value.slice(0, 4) : item.codeDateValue; + this.codeApplyForm[item.oid] = year; + this.$set(item, "readOnly", readOnlyValue); + } + }); + + if (this.$refs.CodeApply) { + this.$refs.CodeApply.changeChildItem(this.secVOList, this.TreeValue, this.type); + } }, //灞炴�х爜娈佃祴鍊� attrListForm(attrListForm) { @@ -387,7 +401,7 @@ return item; }); //this.$refs.CodeApply.templateRender(this.secVOList,this.TreeValue); - this.$refs.CodeApply.changeChildItem(childItems,this.TreeValue,this.type); + this.$refs.CodeApply.changeChildItem(childItems, this.TreeValue, this.type); }, resembleQuerySubmit() { this.activeName = "resembleQuery"; @@ -399,78 +413,160 @@ } }, async submit() { - // 杩涜琛ㄥ崟鏍¢獙 - const formValidate = await this.$refs.FormTemplate.validate(); - if (!formValidate) return; - let codeValidate = true; - // 杩涜鐮佸�肩敵璇锋牎楠� - // if (this.showCodeApply) { - // codeValidate = await this.$refs.CodeApply.validate(); - // if (!codeValidate) { - // this.activeName = "codeApply"; - // return false; - // } - // } - let resembleQueryList = []; - if (this.showResembleQuery && this.$refs.resembleQueryRef) { - // 杩涜鐩镐技椤规煡璇� - resembleQueryList = await this.$refs.resembleQueryRef.resembleQuery( + if(this.status){ + // 杩涜琛ㄥ崟鏍¢獙 + const formValidate = await this.$refs.FormTemplate.validate(); + if (!formValidate) return; + let resembleQueryList = []; + if (this.showResembleQuery && this.$refs.resembleQueryRef) { + // 杩涜鐩镐技椤规煡璇� + resembleQueryList = await this.$refs.resembleQueryRef.resembleQuery( + this.form + ); + } + if (resembleQueryList.length > 0) { + await this.$confirm( + `璇ョ墿鏂欏凡鏈�${resembleQueryList.length}鏉$浉浼兼暟鎹紝鏄惁缁х画淇濆瓨锛焋, + "闇�瑕佹偍纭", + { + confirmButtonText: "纭畾", + cancelButtonText: "鍙栨秷", + type: "warning", + } + ); + } + // 鎺掗櫎涓�浜涘瓧娈� + const noData = [ + "jiliangdwname", + "materialtypeText", + "morengongysname", + "$caigouwl", + "$xiaoshouwl", + "$shifoupihaoguanli", + "lcstatus_text", + "hesuanfenleiname", + "$kucunwl", + "lastmodifier" + ]; + + let resForm = {}; + const {defaultValue, formValue} = this.getDefaultValueAndFormValues( this.form ); - } - if (resembleQueryList.length > 0) { - await this.$confirm( - `璇ョ墿鏂欏凡鏈�${resembleQueryList.length}鏉$浉浼兼暟鎹紝鏄惁缁х画淇濆瓨锛焋, - "闇�瑕佹偍纭", - { - confirmButtonText: "纭畾", - cancelButtonText: "鍙栨秷", - type: "warning", - } - ); - } - // 鎺掗櫎涓�浜涘瓧娈� - const noData = [ - "jiliangdwname", - "materialtypeText", - "morengongysname", - "$caigouwl", - "$xiaoshouwl", - "$shifoupihaoguanli", - "lcstatus_text", - "hesuanfenleiname", - "$kucunwl", - "oldcode", - "lastmodifier" - ]; - let resForm = {}; - const {defaultValue, formValue} = this.getDefaultValueAndFormValues( - this.form - ); - noData.forEach((item) => { - this.$delete(formValue, item); - }); - const keys = Object.keys(formValue); - keys.forEach((item, index) => { - keys.forEach((itm, idx) => { - if ((item === ('$' + itm)) && idx !== index) { - this.$delete(formValue, keys[index]); - } - }) - }); + noData.forEach((item) => { + this.$delete(formValue, item); + }); + const keys = Object.keys(formValue); + keys.forEach((item, index) => { + keys.forEach((itm, idx) => { + if ((item === ('$' + itm)) && idx !== index) { + this.$delete(formValue, keys[index]); + } + }) + }); - resForm.data = formValue; - resForm = Object.assign({}, resForm, defaultValue); - resForm.secDTOList = this.secVOList.map((item) => { - return { - secOid: item.oid, - secValue: this.codeApplyForm[item.oid], + resForm.data = formValue; + resForm.data = Object.assign({}, resForm.data, defaultValue); + resForm.secDTOList = this.secVOList.map((item) => { + return { + secOid: item.oid, + secValue: this.codeApplyForm[item.oid], + }; + }); + //鏍囧噯鐗瑰畾 + const mappings = { + codeStandardEditType: 'operationType', + reviseSeries: 'series', + oldcode: 'oldCode', + releaseDate: 'releaseTime', + isSeries: 'isEditseries' }; - }); - resForm.codeClassifyOid = this.codeClassifyOid; - resForm.codeRuleOid = this.codeRuleOid; - resForm.templateOid = this.templateOid; - this.$emit("submit", resForm); + + for (const key in mappings) { + if (formValue[key]) { + resForm[mappings[key]] = formValue[key]; + } + } + // + resForm.codeClassifyOid = this.codeClassifyOid; + resForm.codeRuleOid = this.codeRuleOid; + resForm.templateOid = this.templateOid; + this.$emit("submit", resForm); + }else { + // 杩涜琛ㄥ崟鏍¢獙 + const formValidate = await this.$refs.FormTemplate.validate(); + if (!formValidate) return; + let codeValidate = true; + // 杩涜鐮佸�肩敵璇锋牎楠� + // if (this.showCodeApply) { + // codeValidate = await this.$refs.CodeApply.validate(); + // if (!codeValidate) { + // this.activeName = "codeApply"; + // return false; + // } + // } + let resembleQueryList = []; + if (this.showResembleQuery && this.$refs.resembleQueryRef) { + // 杩涜鐩镐技椤规煡璇� + resembleQueryList = await this.$refs.resembleQueryRef.resembleQuery( + this.form + ); + } + if (resembleQueryList.length > 0) { + await this.$confirm( + `璇ョ墿鏂欏凡鏈�${resembleQueryList.length}鏉$浉浼兼暟鎹紝鏄惁缁х画淇濆瓨锛焋, + "闇�瑕佹偍纭", + { + confirmButtonText: "纭畾", + cancelButtonText: "鍙栨秷", + type: "warning", + } + ); + } + // 鎺掗櫎涓�浜涘瓧娈� + const noData = [ + "jiliangdwname", + "materialtypeText", + "morengongysname", + "$caigouwl", + "$xiaoshouwl", + "$shifoupihaoguanli", + "lcstatus_text", + "hesuanfenleiname", + "$kucunwl", + "oldcode", + "lastmodifier" + ]; + + let resForm = {}; + const {defaultValue, formValue} = this.getDefaultValueAndFormValues( + this.form + ); + noData.forEach((item) => { + this.$delete(formValue, item); + }); + const keys = Object.keys(formValue); + keys.forEach((item, index) => { + keys.forEach((itm, idx) => { + if ((item === ('$' + itm)) && idx !== index) { + this.$delete(formValue, keys[index]); + } + }) + }); + + resForm.data = formValue; + resForm = Object.assign({}, resForm, defaultValue); + resForm.secDTOList = this.secVOList.map((item) => { + return { + secOid: item.oid, + secValue: this.codeApplyForm[item.oid], + }; + }); + resForm.codeClassifyOid = this.codeClassifyOid; + resForm.codeRuleOid = this.codeRuleOid; + resForm.templateOid = this.templateOid; + this.$emit("submit", resForm); + } }, getDefaultValueAndFormValues(form) { let defaultValue = {}; -- Gitblit v1.9.3