From fd15db44e6bd9b7b9a6537b82bb90a81c009b24a Mon Sep 17 00:00:00 2001
From: wangting <675591594@qq.com>
Date: 星期五, 10 五月 2024 18:16:49 +0800
Subject: [PATCH] action

---
 Source/ProjectWeb/src/components/dynamic-components/dynamic-form.vue |  103 +++++++++++++++++++++++++++++++++------------------
 1 files changed, 67 insertions(+), 36 deletions(-)

diff --git a/Source/ProjectWeb/src/components/dynamic-components/dynamic-form.vue b/Source/ProjectWeb/src/components/dynamic-components/dynamic-form.vue
index def378e..e08c6b3 100644
--- a/Source/ProjectWeb/src/components/dynamic-components/dynamic-form.vue
+++ b/Source/ProjectWeb/src/components/dynamic-components/dynamic-form.vue
@@ -1,15 +1,21 @@
 <template>
   <div :id="'UI-dynamic-'+areasName+componentVO.oid" class="UI-dynamic">
-    <dynamic-button v-if="componentVO && componentVO.buttons" :componentVO="componentVO" :butttonList="componentVO.buttons" :dataStore="[form]" :sourceData="sourceData" type="form"></dynamic-button>
-    <basic-form :span="this.componentVO.formDefineVO.columnOneRow?(24/this.componentVO.formDefineVO.columnOneRow) : 12"
+    <dynamic-button v-if="componentVO && componentVO.buttons" :key="areasName+'buttons-'+componentVO.oid"
+                    :componentVO="componentVO" :butttonList="componentVO.buttons" :dataStore="[form]" :sourceData="sourceData"
+                    @afterMethod="handleRefresh" type="form"></dynamic-button>
+    <basic-form :key="areasName+'basicForm-'+componentVO.oid"
+                :span="this.componentVO.formDefineVO.columnOneRow?(24/this.componentVO.formDefineVO.columnOneRow) : 12"
                 :formItems="this.componentVO.formDefineVO && this.componentVO.formDefineVO.items"
-                :formData="form">
+                :disabled="!inDialog"
+                :isEdit="canEdit"
+                :formData="form"
+                :initValue="paramVOS.initvalue"
+                @getFormData="getFormData">
     </basic-form>
   </div>
 </template>
 
 <script>
-
 import {dataForm} from "@/api/base/ui";
 
 export default {
@@ -30,6 +36,15 @@
     inDialog: {
       type: Boolean,
       default: false
+    },
+    canEdit:{
+      //鍐呭鏄惁鍙紪杈�
+      type:Boolean,
+      default:false
+    },
+    actionType:{
+      //鎸夐挳鎿嶄綔绫诲瀷
+      default:""
     },
     areasName: {
       type: String,
@@ -73,14 +88,11 @@
     form:{
       handler(newval) {
         if(newval) {
-          this.$emit("setDataStore", {
-            area: this.areasName,
-            type:this.componentVO.uiComponentType,
-            btmType:this.componentVO.treeDefineVO.btmType,
-            dataStore:[newval]
-          });
+
         }
-      }
+      },
+      deep: true,
+      immediate: true
     },
     sourceData: {
       handler(newval) {
@@ -88,7 +100,9 @@
         this.sourceDataMapParams=this.sourceDataMap();
         this.getParams();
         this.handleRefresh();
-      }
+      },
+      deep: true,
+      immediate: true
     }
   },
   created() {
@@ -97,28 +111,28 @@
   methods: {
     sourceDataMap: function () {
       const sourceDataMap = {};
-      if (Object.keys(this.sourceData).length>0) {
-        if(this.sourceData.oid ) {
+      if (Object.keys(this.sourceData).length > 0) {
+        if (this.sourceData.oid) {
           if (this.sourceData.oid.indexOf('@vcitreesep@') > -1) {
             this.sourceData.oid = this.sourceData.oid.split('@vcitreesep@')[1];
           }
-          sourceDataMap.sourceBtmName = this.sourceBtmType;;
+          sourceDataMap.sourceBtmName = this.sourceBtmType;
+          ;
           sourceDataMap.sourceOid = this.sourceData.oid;
         }
         for (let i in this.sourceData) {
-          let item = this.sourceData[i]
-          if (item && item.constructor === Object) return;
-          if (i == 'type' || i == 'context' || i == 'content') return;
+          const item = this.sourceData[i]
+          if (item && item.constructor === Object) continue;
+          if (i == 'type' || i == 'context' || i == 'content') continue;
           sourceDataMap['sourceData["' + i + '"]'] = item
         }
       }
 
-      if (Object.keys(this.paramVOS).length>0) {
-        for (let i in this.paramVOS) {
-          let item = this.paramVOS[i]
-          if (item && item.constructor === Object) return;
-          if (i == 'type' || i == 'context' || i == 'content') return;
-          sourceDataMap['sourceData["' + i + '"]'] = item
+      if (Object.keys(this.paramVOS).length > 0) {
+        for (let j in this.paramVOS) {
+          if (this.paramVOS[j] && this.paramVOS[j].constructor === Object) continue;
+          if (j == 'type' || j == 'context' || j == 'content' || j == "getdataurl" || j == "getdatamethod" || j == "url" || j == "method" || j == "uploadfileurl" || j == "title") continue;
+          sourceDataMap['sourceData["' + j + '"]'] = this.paramVOS[j]
         }
       }
       return sourceDataMap;
@@ -126,32 +140,49 @@
     getParams: function () {
       const formParams = {
         btmname: this.currentDefineVO.btmType,
-        btmType:this.currentDefineVO.btmType,
+        btmType: this.currentDefineVO.btmType,
         formDefineId: this.currentDefineVO.id,
-        oid:this.currentDefineVO.oid
+        oid: this.currentDefineVO.oid
       };
-      if(this.dataStore[0] && this.dataStore[0].oid) {
+      if (this.dataStore[0] && this.dataStore[0].oid) {
         formParams.oid = this.dataStore[0].oid;
       }
       const sourceDataMapList = this.sourceDataMapParams;
 
-      this.params = Object.assign({},formParams, sourceDataMapList);
-      console.log(this.params)
+      this.params = Object.assign({}, formParams, sourceDataMapList);
     },
-    onLoad:function () {
-      if (Object.keys(this.sourceData).length>0 && this.isShow) {
+    onLoad: function () {
+      if (this.paramVOS.initvalue) {
+        this.form = this.paramVOS.initvalue;
+      }
+      if (Object.keys(this.sourceData).length > 0 && this.isShow && this.actionType != "add") {
         this.loading = true;
-        dataForm(this.params).then(res => {
-          this.form = res.data.obj;
+        dataForm(this.params, this.paramVOS.getdataurl, this.paramVOS.getdatamethod).then(res => {
+          this.form = res.data.obj.data;
           this.loading = false;
+          this.$emit("setDataStore", {
+            area: this.areasName,
+            type: this.componentVO.uiComponentType,
+            btmType: this.currentDefineVO.btmType,
+            dataStore: [this.form]
+          });
+          this.$emit("setData", {
+            area: this.areasName,
+            type: this.componentVO.uiComponentType,
+            currentDefineVO: this.currentDefineVO,
+            data: this.form
+          });
         }).catch(error => {
-          this.$message.error(error);
           this.loading = false;
         });
       }
     },
-    handleRefresh(){
-
+    handleRefresh() {
+      this.form = {}
+      this.onLoad();
+    },
+    getFormData(form) {
+      this.form = form;
     }
   }
 }

--
Gitblit v1.9.3