From fcdc4ef3b6ad8bb6b85333325387b4fcce417167 Mon Sep 17 00:00:00 2001
From: 田源 <tianyuan@vci-tech.com>
Date: 星期五, 27 十二月 2024 17:05:42 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 Source/plt-web/plt-web-ui/src/App.vue                                |    8 +++
 Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Icons/index.vue  |    3 +
 Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Aciton/index.vue |   75 ++++++++++++++++++++++++-------------
 3 files changed, 57 insertions(+), 29 deletions(-)

diff --git a/Source/plt-web/plt-web-ui/src/App.vue b/Source/plt-web/plt-web-ui/src/App.vue
index 20bdc54..e32eb14 100644
--- a/Source/plt-web/plt-web-ui/src/App.vue
+++ b/Source/plt-web/plt-web-ui/src/App.vue
@@ -5,6 +5,9 @@
   </div>
 </template>
 <script>
+import {getIcons} from "@/api/UI/Icons";
+import store from "@/store";
+
 export default {
   name: "app",
   data() {
@@ -12,7 +15,10 @@
   },
   watch: {},
   created() {
-
+    //鑾峰彇鎵�鏈夊浘鏍囷紝瀛樺湪session
+    getIcons().then(res => {
+      store.dispatch("setIcons", res.data.data);
+    })
   },
   methods: {},
   computed: {}
diff --git a/Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Aciton/index.vue b/Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Aciton/index.vue
index 19d7f72..3586e44 100644
--- a/Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Aciton/index.vue
+++ b/Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Aciton/index.vue
@@ -23,28 +23,34 @@
 
     <el-main>
       <basic-container v-if="treeNodeRow.id === 'root' ">
-        <div class="headerCon">
-          <el-button v-if="permissionList.addBtn" icon="el-icon-plus" plain size="small" type="primary" @click="addTreeClickHandler">鍒涘缓
-          </el-button>
-          <!--<el-button v-if="permissionList.editBtn" icon="el-icon-edit" plain size="small" type="primary" @click="editTreeClickHandler">淇敼
-          </el-button>
-          <el-button v-if="permissionList.delBtn" icon="el-icon-delete" plain size="small" type="danger" @click="delTreeClickHandler">鍒犻櫎
-          </el-button>-->
-          <el-button v-if="permissionList.importBtn" icon="el-icon-upload2" plain size="small" type="primary" @click="uploadClickHandler">瀵煎叆
-          </el-button>
-          <el-button v-if="permissionList.exportBtn" icon="el-icon-download" plain size="small" type="primary" @click="exportClickHandler">瀵煎嚭
-          </el-button>
-        </div>
         <div>
           <avue-crud
             ref="treeCrud"
             v-model="treeForm"
-            :data="treeData[0].childs"
+            :data="treeData[0].children"
             :option="treeCrudOption"
             @row-del="rowTreeDelHandler"
             @row-save="rowTreeSaveHandler"
             @row-update="rowTreeUpdataHandler"
             @refresh-change="handleRefresh">
+            <template slot="menuLeft">
+              <el-button v-if="permissionList.addBtn" icon="el-icon-plus" plain size="small" type="primary" @click="addTreeClickHandler(treeNodeRow)">鍒涘缓
+              </el-button>
+              <!--<el-button v-if="permissionList.editBtn" icon="el-icon-edit" plain size="small" type="primary" @click="editTreeClickHandler">淇敼
+              </el-button>
+              <el-button v-if="permissionList.delBtn" icon="el-icon-delete" plain size="small" type="danger" @click="delTreeClickHandler">鍒犻櫎
+              </el-button>-->
+              <el-button v-if="permissionList.importBtn" icon="el-icon-upload2" plain size="small" type="primary" @click="uploadClickHandler">瀵煎叆
+              </el-button>
+              <el-button v-if="permissionList.exportBtn" icon="el-icon-download" plain size="small" type="primary" @click="exportClickHandler">瀵煎嚭
+              </el-button>
+            </template>
+            <template #menu="{ row, size }">
+              <el-button v-if="permissionList.addBtn" :size="size" icon="el-icon-plus"
+                         text
+                         type="text"
+                         @click="addTreeClickHandler(row)">鏂板瀛愮骇</el-button>
+            </template>
           </avue-crud>
         </div>
       </basic-container>
@@ -174,7 +180,7 @@
         props: {
           label: 'name',
           value: 'id',
-          children: 'childs'
+          children: 'children'
         }
       },
       treeData: []
@@ -206,7 +212,9 @@
         addBtn: false,
         calcHeight: -50,
         highlightCurrentRow: true,
-        menuWidth: 160,
+        rowKey: 'id',
+        rowParentKey: 'pid',
+        menuWidth: 360,
         span: 24,
         labelWidth: 100,
         dialogWidth: '800',
@@ -229,11 +237,6 @@
         }, {
           label: '鐖朵富绫�',
           prop: 'pidName',
-          formatter:function(row){
-            if(row.pid=='root'){
-              return 'Action鍒嗙被'
-            }
-          },
           disabled: true,
           span: 24
         }, {
@@ -396,7 +399,7 @@
       }
       getActionTree(params).then(res => {
         const data = res.data.obj;
-        this.treeData = [data];
+        this.treeData = this.treeDataFormAtter([data],'Action鍒嗙被');
         const selectTreeData = this.option.column.find(item => item.prop === 'plActionCls'); // 鎵惧埌action娣诲姞鍒嗙被鏍�
         const dicData=[data];
         dicData[0].disabled=true;//鏍硅妭鐐逛笉鑳介��
@@ -404,11 +407,25 @@
       })
     },
 
+    treeDataFormAtter(items,pidName) {
+      return items.map(item => {
+        // 杞崲褰撳墠鑺傜偣鐨勫睘鎬�
+        const formList = {
+          ...item,
+          pidName:pidName,
+          children: item.childs && item.childs.length > 0 ? this.treeDataFormAtter(item.childs,item.name) : undefined
+        };
+        return formList;
+      });
+    },
+
     // 宸︿晶鏍戣鐐瑰嚮
     nodeClick(row) {
       this.treeNodeRow = row;
-      this.getRightTableList(row);
-      this.bottomData = [];
+      if(this.treeNodeRow.id !== 'root'){
+        this.getRightTableList(row);
+        this.bottomData = [];
+      }
     },
 
     // 澶撮儴鍒锋柊鎸夐挳
@@ -675,16 +692,20 @@
     },
 
     // 宸︿晶鏍戝垱寤�
-    addTreeClickHandler() {
-      if (func.isEmptyObject(this.treeNodeRow)) {
+    addTreeClickHandler(row) {
+      let parentRow=row;
+      if(!row || !row.id){
+        parentRow=this.treeNodeRow
+      }
+      if (func.isEmptyObject(parentRow)) {
         this.$message.error('璇烽�夋嫨涓�鏉″垎绫昏繘琛屾坊鍔�');
         return;
       }
-      if (!this.treeNodeRow.id && this.treeNodeRow.name=='鏈垎绫�') {
+      if (!parentRow.id && parentRow.name=='鏈垎绫�') {
         this.$message.error('鏈垎绫讳笅涓嶈兘鍒涘缓瀛愬垎绫�');
         return;
       }
-      const {createTime, creator, name, id, description} = this.treeNodeRow;
+      const {createTime, creator, name, id, description} = parentRow;
       this.$set(this.treeForm, 'createTime', func.formattedDate(createTime));
       this.$set(this.treeForm, 'creator', creator);
       this.$set(this.treeForm, 'pid', id);
diff --git a/Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Icons/index.vue b/Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Icons/index.vue
index 6836e8e..13c1cf5 100644
--- a/Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Icons/index.vue
+++ b/Source/plt-web/plt-web-ui/src/views/modelingMenu/ui/Icons/index.vue
@@ -226,7 +226,8 @@
   },
   created() {
     this.getGroups();
-    this.initList();  },
+    this.initList();
+  },
   methods:{
     getGroups() {
       getDicts('EnumIconGroups').then(res => {

--
Gitblit v1.9.3