From 7528d44d20d12b0b3044fb19e58c2f68c1cebf94 Mon Sep 17 00:00:00 2001
From: 田源 <lastanimals@163.com>
Date: 星期三, 20 十一月 2024 15:40:25 +0800
Subject: [PATCH] 系统模块配置修改树节点图标

---
 Source/plt-web/plt-web-ui/src/views/systemModel/businessModel/index.vue |   83 +++++++++++++++++++++++++----------------
 1 files changed, 50 insertions(+), 33 deletions(-)

diff --git a/Source/plt-web/plt-web-ui/src/views/systemModel/businessModel/index.vue b/Source/plt-web/plt-web-ui/src/views/systemModel/businessModel/index.vue
index ef5069c..a8dd219 100644
--- a/Source/plt-web/plt-web-ui/src/views/systemModel/businessModel/index.vue
+++ b/Source/plt-web/plt-web-ui/src/views/systemModel/businessModel/index.vue
@@ -6,7 +6,7 @@
           <avue-tree :key="refresh" node-key="id" ref="tree" :data="treeData" :option="treeOption" @node-click="nodeClick">
           <span slot-scope="{ node, data }" class="el-tree-node__label">
            <span style="font-size: 15px">
-              <i class="el-icon-s-promotion"></i>
+              <i :class="data.icon"></i>
                 {{ (node || {}).label }}
             </span>
           </span>
@@ -17,8 +17,8 @@
 
     <el-main>
       <basic-container>
-        <div v-if="form.childType && form.childType !== 0 && !addStatus && !editStatus" class="btnBox">
-          <el-button :disabled="mangeShowBtn ? false : !childTypeBtn" icon="el-icon-plus" plain
+        <div v-if="(form.childType || form.childType === 0) && !addStatus && !editStatus && form.category !== 1" class="btnBox">
+          <el-button :disabled="(mangeShowBtn || form.childType === 0) ? false : !childTypeBtn" icon="el-icon-plus" plain
                      size="small"
                      type="primary" @click="addClickHandler">澧炲姞
           </el-button>
@@ -32,11 +32,11 @@
                      size="small"
                      type="primary" @click="addMethodsClickHandler">澧炲姞鎿嶄綔绫诲瀷
           </el-button>
-          <el-button v-if="this.form.childType ? mangeShowBtn :true" icon="el-icon-circle-close" plain size="small"
+          <el-button v-if=" mangeShowBtn" icon="el-icon-circle-close" plain size="small"
                      type="danger"
                      @click="addClickHandler">鍒犻櫎闈炵郴缁熸ā鍧�
           </el-button>
-          <el-button v-if="this.form.childType ? mangeShowBtn :true" icon="el-icon-circle-close" plain size="small"
+          <el-button v-if="mangeShowBtn " icon="el-icon-circle-close" plain size="small"
                      type="danger"
                      @click="addClickHandler">鍒犻櫎涓氬姟妯″潡
           </el-button>
@@ -49,7 +49,7 @@
           <el-button icon="el-icon-upload2" plain size="small" type="primary" @click="sqlClickExportClick">瀵煎嚭sql
           </el-button>
         </div>
-        <div v-else-if="form.childType && form.childType !== 0 &&(addStatus || editStatus)" class="btnBox">
+        <div v-else-if="(form.childType || form.childType === 0) && (addStatus || editStatus)" class="btnBox">
           <el-button v-if="addStatus" icon="el-icon-check" plain size="small"
                      type="success" @click="addSaveClickHandler">淇濆瓨
           </el-button>
@@ -60,40 +60,54 @@
                       type="danger" @click="addStatus=false;editStatus=false;">鍙栨秷
           </el-button>
         </div>
-        <div v-if="form.childType === 0" class="btnBox">
+        <div v-if="form.category === 1" class="btnBox">
           <el-button icon="el-icon-edit" plain size="small" type="primary" @click="updataAliasClickHandler">淇敼鍒悕
           </el-button>
           <el-button icon="el-icon-close" plain size="small" type="danger" @click="deleteOperationClickHandler">鍒犻櫎
           </el-button>
         </div>
         <el-form ref="form" :model="form" label-width="85px" style="max-height: calc(100vh - 200px);overflow: auto;">
-          <span v-if="form.childType !== 0">
+          <span v-if="form.category !== 1">
             <el-form-item label="妯″潡鍚嶏細">
             <el-input v-model="form.name" :disabled="!editStatus && !addStatus" placeholder="璇疯緭鍏ユā鍧楀悕"></el-input>
           </el-form-item>
           <el-form-item label="妯″潡鍒悕锛�">
             <el-input v-model="form.alias" :disabled="!editStatus && !addStatus" placeholder="妯″潡鍒悕鐢ㄦ潵璁板綍鏃ュ織浣跨敤"></el-input>
           </el-form-item>
-                <el-form-item label="C/S锛�">
-            <el-input v-model="form.pathC" :disabled="!editStatus && !addStatus" :rows="2" placeholder="璇疯緭鍏/S璺緞" type="textarea"></el-input>
+                <el-form-item v-if="form.functionType === 0" label="C/S锛�">
+            <el-input v-model="form.pathC" :disabled="!editStatus && !addStatus" :rows="2" placeholder="璇疯緭鍏/S璺緞"
+                      type="textarea"></el-input>
           </el-form-item>
-          <el-form-item label="B/S锛�">
-            <el-input v-model="form.path" :disabled="!editStatus && !addStatus" :rows="2" placeholder="璇疯緭鍏/S璺緞" type="textarea"></el-input>
+          <el-form-item v-if="form.functionType === 0" label="B/S锛�">
+            <el-input v-model="form.path" :disabled="!editStatus && !addStatus" :rows="2" placeholder="璇疯緭鍏/S璺緞"
+                      type="textarea"></el-input>
           </el-form-item>
-          <el-form-item label=".NET锛�">
-            <el-input v-model="form.resourceDotNet" :disabled="!editStatus && !addStatus" :rows="2" placeholder="璇疯緭鍏�.NET" type="textarea"></el-input>
-          </el-form-item>
-          <el-form-item label="Mobile锛�">
-            <el-input v-model="form.resourceMobile" :disabled="!editStatus && !addStatus" :rows="2" placeholder="璇疯緭鍏obile" type="textarea"></el-input>
+          <el-form-item v-if="form.functionType === 0" label=".NET锛�">
+            <el-input v-model="form.resourceDotNet" :disabled="!editStatus && !addStatus" :rows="2"
+                      placeholder="璇疯緭鍏�.NET" type="textarea"></el-input>
           </el-form-item>
           <el-form-item label="搴忓彿锛�">
-            <el-input v-model="form.sort" :disabled="!editStatus && !addStatus" placeholder="鏁板瓧锛屾弿杩拌妯″潡鍦ㄥ叾鐖舵ā鍧椾笅鐨勬樉绀洪『搴�"></el-input>
+            <el-input v-model="form.sort" :disabled="!editStatus && !addStatus"
+                      placeholder="鏁板瓧锛屾弿杩拌妯″潡鍦ㄥ叾鐖舵ā鍧椾笅鐨勬樉绀洪『搴�"></el-input>
           </el-form-item>
-          <el-form-item label="绠�鍥撅細">
-            <el-input v-model="form.source" :disabled="!editStatus && !addStatus"></el-input>
+          <el-form-item label="鍥炬爣锛�">
+              <avue-input-icon v-model="form.source" :disabled="!editStatus && !addStatus" :icon-list="iconList"
+                               placeholder="璇烽�夋嫨鍥炬爣">
+              </avue-input-icon>
           </el-form-item>
           <el-form-item label="鎻忚堪锛�">
-            <el-input v-model="form.remark" :disabled="!editStatus && !addStatus" :rows="3" placeholder="璇疯緭鍏ユ弿杩�" type="textarea"></el-input>
+            <el-input v-model="form.remark" :disabled="!editStatus && !addStatus" :rows="3" placeholder="璇疯緭鍏ユ弿杩�"
+                      type="textarea"></el-input>
+          </el-form-item>
+            <el-form-item label="鏄惁鑿滃崟锛�">
+            <el-switch
+              v-model="form.functionType"
+              :active-value="0"
+              :disabled="!editStatus && !addStatus"
+              :inactive-value="1"
+              active-color="#13ce66"
+              inactive-color="#ff4949">
+            </el-switch>
           </el-form-item>
           <el-form-item label="鏄惁鏈夋晥锛�">
             <el-switch
@@ -105,21 +119,21 @@
             <el-link :underline="false" style="margin-left: 20px" type="danger">涓嶇敓鏁堬紙涓嶉�夋嫨锛夋椂锛岃妯″潡鍦ㄥ姛鑳芥ā鍧楁巿鏉冮噷涓嶆樉绀�</el-link>
           </el-form-item>
           </span>
-          <span v-if="form.childType === 0">
+          <span v-if="form.category === 1">
             <el-form-item label="鍚嶇О锛�">
-            <el-input v-model="form.name" :disabled="form.childType === 0" placeholder="璇疯緭鍏ュ悕绉�"></el-input>
+            <el-input v-model="form.name" :disabled="form.category === 1" placeholder="璇疯緭鍏ュ悕绉�"></el-input>
             </el-form-item>
             <el-form-item label="鏍囪瘑锛�">
-            <el-input v-model="form.code" :disabled="form.childType === 0" placeholder="璇疯緭鍏ユ爣璇�"></el-input>
+            <el-input v-model="form.code" :disabled="form.category === 1" placeholder="璇疯緭鍏ユ爣璇�"></el-input>
             </el-form-item>
             <el-form-item label="鍒悕锛�">
             <el-input v-model="form.alias" placeholder="璇疯緭鍏ュ埆鍚�"></el-input>
             </el-form-item>
             <el-form-item label="缂栧彿锛�">
-            <el-input v-model="form.sort" :disabled="form.childType === 0" placeholder="璇疯緭鍏ョ紪鍙�"></el-input>
+            <el-input v-model="form.sort" :disabled="form.category === 1" placeholder="璇疯緭鍏ョ紪鍙�"></el-input>
             </el-form-item>
             <el-form-item label="鎻忚堪锛�">
-            <el-input v-model="form.remark" :disabled="form.childType === 0" placeholder="璇疯緭鍏ユ弿杩�"></el-input>
+            <el-input v-model="form.remark" :disabled="form.category === 1" placeholder="璇疯緭鍏ユ弿杩�"></el-input>
             </el-form-item>
             <el-form-item label="鏄惁鏈夋晥锛�">
             <el-switch
@@ -139,7 +153,7 @@
       append-to-body="true"
       class="avue-dialog"
       title="鎿嶄綔鍒嗙被"
-      width="60%"
+      width="500px"
     >
       <avue-crud
         ref="methodsCrud"
@@ -148,11 +162,10 @@
         :table-loading="methodsLoading"
         @row-click="rowMethodsClickHandler"
         @selection-change="selectMethodsChange">
-
       </avue-crud>
       <span slot="footer" class="dialog-footer">
-         <el-button @click="methodsVisble = false">鍙� 娑�</el-button>
          <el-button type="primary" @click="methodsSaveClickHandler">淇� 瀛�</el-button>
+         <el-button @click="methodsVisble = false">鍙� 娑�</el-button>
         </span>
     </el-dialog>
     <!--瀵煎叆    -->
@@ -176,11 +189,13 @@
 } from "@/api/systemModel/mangeModel/api"
 import func from "@/util/func";
 import basicOption from "@/util/basic-option";
+import iconList from "@/config/iconList";
 
 export default {
   name: "index",
   data() {
     return {
+      iconList: iconList,
       tipList: [],
       upFileType: ['xls', 'xlsx'],
       fileUrl: 'api/hmSysModConfigController/importModule',
@@ -193,6 +208,7 @@
         addBtn: false,
         menu: false,
         height: 500,
+        header:false,
         column: [
           {
             label: '鎿嶄綔鍒嗙被',
@@ -233,7 +249,8 @@
                 ...item,
                 id: item.id,
                 name: item.name,
-                leaf: !item.hasChildren
+                leaf: !item.hasChildren,
+                icon: item.source || 'iconfont iconicon_work'
               }
             }))
           })
@@ -246,6 +263,7 @@
   computed: {
     /**
      * childType
+     * 涓�0 鍏ㄩ儴鎸夐挳灞曠ず
      * 涓�-1   鍏ㄩ儴鎸夐挳灞曠ず 绂佺敤淇敼 鍒犻櫎 澧炲姞鎿嶄綔绫诲瀷
      * 涓嶄负-1 闅愯棌 鍒犻櫎闈炵郴缁熸ā鍧� 鍒犻櫎涓氬姟妯″潡
      * 涓�1鏃� 绂佺敤鎿嶄綔绫诲瀷銆佸鍏ャ�佸鍑�
@@ -357,7 +375,6 @@
         this.$message.error('Mobile鏍囪瘑闀垮害涓嶈兘255锛�');
         return
       }
-
       updateModel(this.form).then(res => {
         if (res.data.code === 200) {
           this.$message.success(res.data.msg);
@@ -408,10 +425,10 @@
     // 澧炲姞鎿嶄綔绫诲瀷
     addMethodsClickHandler() {
       this.methodsLoading = true;
-      getSysModelTreeMenuByPID({parentId: 'sysOptionNode'}).then(res => {
+      getSysModelTreeMenuByPID({parentId: 'operateNode'}).then(res => {
         if (res.data.code === 200 && res.data.data.length>0) {
           this.methodsVisble = true;
-          const data = res.data.data[0].children;
+          const data = res.data.data;
           this.methodsData = data;
           this.methodsLoading = false;
         }else {

--
Gitblit v1.9.3