yuxc
2025-01-15 2bea732496b4f5051233ed94e206160992351596
Source/plt-web/plt-web-ui/src/views/systemModel/businessModel/index.vue
@@ -7,7 +7,8 @@
                     @node-click="nodeClick">
          <span slot-scope="{ node, data }" class="el-tree-node__label">
            <span style="display: flex">
              <icon-show :name="data.icon"></icon-show>
              <icon-show v-if="data.iconType=='svg'" :name="data.icon"></icon-show>
              <i v-else :class="data.icon"></i>
                {{ (node || {}).label }}
            </span>
          </span>
@@ -72,32 +73,18 @@
        <el-form ref="form" :model="form" label-width="100px" size="small"
                 style="max-height: calc(100vh - 200px);overflow: auto;">
          <span v-if="form.category !== 1">
            <el-form-item>
               <span slot="label" style="display:inline-block;">
                菜单标识:
                 <el-tooltip class="item" content="请输入英文字符,并保证唯一性!" effect="dark" placement="top-start">
                   <i class='el-icon-star-on' style="color: #F56C6C"/>
                </el-tooltip>
               </span>
              <el-input v-model="form.alias" :disabled="!editStatus && !addStatus"
                        placeholder="请输入英文字符,并保证唯一性!"></el-input>
            <el-form-item class="is-required">
              <span slot="label">模块名:</span>
              <el-input v-model="form.name" :disabled="!editStatus && !addStatus" placeholder="请输入模块名"></el-input>
            </el-form-item>
               <el-form-item>
               <span slot="label" style="display:inline-block;">
                模块名:
                 <i class='el-icon-star-on' style="color: #F56C6C"/>
               </span>
            <el-input v-model="form.name" :disabled="!editStatus && !addStatus" placeholder="请输入模块名"></el-input>
            <el-form-item class="is-required">
              <span slot="label">模块别名:</span>
              <el-input v-model="form.alias" :disabled="!editStatus && !addStatus"  placeholder="请输入模块别名"></el-input>
            </el-form-item>
            <el-form-item>
               <span slot="label" style="display:inline-block;">
                序号:
                  <el-tooltip class="item" content="数字,描述该模块在其父模块下的显示顺序" effect="dark" placement="top-start">
                   <i class='el-icon-star-on' style="color: #F56C6C"/>
                </el-tooltip>
               </span>
            <el-input v-model="form.sort" :disabled="!editStatus && !addStatus"
                      placeholder="数字,描述该模块在其父模块下的显示顺序"></el-input>
           <el-form-item class="is-required">
              <span slot="label">序号:</span>
              <el-input-number v-model="form.sort" :disabled="!editStatus && !addStatus"></el-input-number>
              <el-link :underline="false" style="margin-left: 20px" type="danger">数字,描述该模块在其父模块下的显示顺序</el-link>
            </el-form-item>
            <el-form-item v-if="form.functionType === 0" label="C/S:">
            <el-input v-model="form.pathC" :disabled="!editStatus && !addStatus" :rows="2" placeholder="请输入C/S路径"
@@ -140,28 +127,31 @@
          </el-form-item>
          </span>
          <span v-if="form.category === 1">
            <el-form-item label="名称:">
            <el-input v-model="form.name" :disabled="form.category === 1" placeholder="请输入名称"></el-input>
            <el-form-item label="名称:" class="is-required">
              <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.category === 1" placeholder="请输入标识"></el-input>
            <el-form-item label="标识:" class="is-required">
              <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 label="别名:" class="is-required">
              <el-input v-model="form.alias" placeholder="请输入别名"></el-input>
            </el-form-item>
            <el-form-item label="编号:">
            <el-input v-model="form.sort" :disabled="form.category === 1" placeholder="请输入编号"></el-input>
            <el-form-item label="图标:">
              <input-icon v-model="form.source" placeholder="请选择图标">
              </input-icon>
            </el-form-item>
            <el-form-item label="编号:" class="is-required">
              <el-input-number v-model="form.sort" :disabled="form.category === 1" :max="63" :min="1"></el-input-number>
            </el-form-item>
            <el-form-item label="描述:">
            <el-input v-model="form.remark" :disabled="form.category === 1" 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
              v-model="form.isValid"
              active-color="#13ce66"
              inactive-color="#ff4949">
            </el-switch>
              <el-switch
                v-model="form.isValid"
                active-color="#13ce66"
                inactive-color="#ff4949">
              </el-switch>
          </el-form-item>
          </span>
        </el-form>
@@ -173,7 +163,7 @@
      append-to-body="true"
      class="avue-dialog"
      title="操作分类"
      width="500px"
      width="900px"
    >
      <avue-crud
        ref="methodsCrud"
@@ -227,13 +217,19 @@
        menu: false,
        height: 500,
        header: false,
        column: [
          {
            label: '操作分类',
            prop: 'name',
            sortable: true,
          }
        ]
        column: [{
          label: '名称',
          prop: 'name',
          width:180,
          sortable: true,
        }, {
          label: '标识',
          prop: 'code',
          width:180,
        }, {
          label: '描述',
          prop: 'remark'
        }]
      },
      methodsLoading: false,
      methodsVisble: false,
@@ -250,8 +246,9 @@
        menu: false,
        addBtn: false,
        defaultExpandAll: false,
        defaultExpandedKeys:['business'],
        props: {
          label: 'name',
          label: 'label',
          value: 'id',
          children: 'children',
        },
@@ -265,10 +262,10 @@
            resolve(res.data.data.map(item => {
              return {
                ...item,
                id: item.id,
                name: item.name,
                label: item.category!=1?item.name:item.alias,
                leaf: !item.hasChildren,
                icon: item.source || 'iconoir:home'
                icon: item.source || (node.level === 0?'el-icon-s-home':'el-icon-s-tools'),
                iconType:item.source?'svg':'iconfont'
              }
            }))
          })
@@ -495,7 +492,7 @@
          this.lastIndex = newIndex;
        },
        () => {
          this.methodsList = [];
          this.methodsList = [row];
        }
      );
    },
@@ -505,6 +502,7 @@
      const params = {
        id: this.form.id,
        isValid: this.form.isValid,
        source:this.form.source,
        alias: this.form.alias
      }
      updateAlias(params).then(res => {
@@ -566,7 +564,9 @@
          let node = this.currentClickNode.parent;
          node.loaded = false;
          node.expand();
          this.$refs.tree.setCurrentNode(this.currentClickNode);
          this.$nextTick(()=>{
            this.$refs.tree.setCurrentKey(this.currentClickNode.data.id);
          });
        } else {
          this.refresh = Math.random(); // 刷新左侧树
        }