管道基础大数据平台系统开发-【前端】-新系統界面
Surpriseplus
2023-04-18 a7d306cb0fe6482251f9d4acdc29674ffc13a032
src/views/datamanage/dictionaryManage.vue
@@ -18,11 +18,15 @@
          :placeholder="$t('shuJuGuanLi.shuJuJianSuo.valueone')"
          suffix-icon="el-icon-search"
        ></el-input>
        <!-- <el-tree
          :data="domainData"
          :props="defaultProps"
        >
        </el-tree> -->
        <el-tree
          :data="domainData"
          :props="defaultProps"
          :default-expand-all="true"
          @node-click="getTableDesc"
          :filter-node-method="filterNode"
          ref="tree"
@@ -164,7 +168,7 @@
            />
            <el-table-column
              min-width="100"
              prop="createUser"
              prop="createName"
              :label="$t('dataManage.dictionaryManageObj.createPersonnel')"
            />
            <el-table-column
@@ -175,7 +179,7 @@
            />
            <el-table-column
              min-width="100"
              prop="updateUser"
              prop="updateName"
              :label="$t('dataManage.dictionaryManageObj.updatePersonnel')"
            />
@@ -210,7 +214,7 @@
              @size-change="handleSizeChange"
              @current-change="handleCurrentChange"
              :current-page="listData.pageIndex"
              :page-sizes="[10, 20, 50, 100]"
              :page-sizes="[10, 50, 100, 200]"
              :page-size="listData.pageSize"
              layout="total, sizes, prev, pager, next, jumper"
              :total="count"
@@ -319,6 +323,7 @@
      top="2vh"
      :title="$t('dataManage.dictionaryManageObj.revamp')"
      :visible.sync="dialogFormVisible"
      :before-close="handleClose"
    >
      <div style="height: 500px; overflow: auto">
        <el-form
@@ -426,7 +431,7 @@
        <el-button
          type="info"
          size="small"
          @click="dialogFormVisible = false"
          @click="handleClose"
        >{{ $t("dataManage.dictionaryManageObj.cancel") }}</el-button>
        <el-button
          class="primary"
@@ -441,6 +446,7 @@
      :title="$t('dataManage.dictionaryManageObj.add')"
      top="2vh"
      :visible.sync="InsertFormdialog"
      :before-close="handleCloseadd"
    >
      <div style="height: 500px; overflow: auto">
        <el-form
@@ -548,7 +554,7 @@
        <el-button
          type="info"
          size="small"
          @click="InsertFormdialog = false"
          @click="handleCloseadd"
        >{{
          $t("dataManage.dictionaryManageObj.cancel")
        }}</el-button>
@@ -573,6 +579,10 @@
  insertDict,
} from "../../api/api";
import MyBread from "../../components/MyBread.vue";
import { conditions } from '../Archive/Archive';
import {
  getTreeData
} from "../../utils/treeData.js"
export default {
  name: "dictionaryManage",
  components: { MyBread },
@@ -610,7 +620,7 @@
      domainData: [],
      defaultProps: {
        children: "children",
        label: "val",
        label: "label",
      },
    };
  },
@@ -651,6 +661,9 @@
    },
    //获取表格字段信息
    getTableDesc(res) {
      if (res.children) {
        return
      }
      this.insertform.tab = res.tab;
      this.insertform.tabDesc = res.tabDesc;
      this.insertform.ns = res.ns;
@@ -677,7 +690,7 @@
    },
    handleSizeChange(val) {
      thihs.listData.pageIndex = 1;
      this.listData.pageIndex = 1;
      this.listData.pageSize = val;
      this.startQueryNameData();
    },
@@ -718,7 +731,7 @@
            this.$message.error("删除失败");
          }
          this.listData.pageIndex = 1;
          this.listData.pageSize = 10;
          this.startQueryNameData();
          this.$message({
            type: "success",
@@ -756,7 +769,7 @@
      var m = time.getMonth() + 1;
      var d = time.getDate();
      var h = time.getHours();
      var mm = time.getMinutes();
      var mm = time.getMvinutes();
      var s = time.getSeconds();
      return y + "-" + this.add0(m) + "-" + this.add0(d);
    },
@@ -768,59 +781,81 @@
      this.formInline.tab = null;
      this.getSelectDictTab();
    },
    treeData(source) {
      let cloneData = JSON.parse(JSON.stringify(source));// 对源数据深度克隆
      if (cloneData.length != 0) {
        return cloneData.filter((father) => {
          // 循环所有项
          let branchArr = cloneData.filter((child) => father.label == child.pname); // 对比ID,分别上下级菜单,并返回数据
          branchArr.length > 0 ? (father.children = branchArr) : ''; // 给父级添加一个children属性,并赋值
          // 属于同一对象问题,例如:令 a=b、c=1 ,然后再令 b.c=c , 那么 a.c=b.c=c=1 ;同理,后续令 c.d=2 ,那么 a.c.d 也是=2;
          // 由此循环多次后,就能形成相应的树形数据结构
          return father.pname == -1; // 返回一级菜单
        });
      }
    },
    //目录树获取
    async getSelectDictTab() {
      const data = await selectDictTab({ name: this.formInline.tab });
      if (data.code != 200) {
        this.$message.error("下拉调用失败");
        this.$message.error("列表调用失败");
      }
      var val = data.result;
      var std = [];
      val.filter((item) => {
        if (std.indexOf(item.bak) == -1) {
          std.push(item.bak);
          this.domainData.push(
            {
              val: item.bak,
              children: [],
            }
          )
        }
      });
      this.domainData.filter((item) => {
        val.filter((res) => {
          if (item.val === res.bak) {
            res.val = res.tabDesc
            item.children.push(res)
      var val = JSON.parse(JSON.stringify(data.result));
      var tree = getTreeData(data.result);
      this.domainData = tree
      this.getQueryNameData(tree[0]);
      // var = this.domainData[0].children;
      //
    },
    getQueryNameData(res) {
      if (res.children) {
        this.getQueryNameData(res.children);
      } else {
        if (res.length != 1) {
          if (res[0].children) {
            this.getQueryNameData(res[0].children);
          } else {
            var result = res[0]
            this.insertform.tab = result.tab;
            this.insertform.tabDesc = result.tabDesc;
            this.insertform.ns = result.ns;
            this.listData.tab = result.tab;
            this.listData.ns = result.ns;
            this.activeName = result.tab;
            this.startQueryNameData();
          }
        } else {
          if (res.children) {
            this.getQueryNameData(res.children);
          } else {
            var result = res
            this.insertform.tab = result.tab;
            this.insertform.tabDesc = result.tabDesc;
            this.insertform.ns = result.ns;
            this.listData.tab = result.tab;
            this.listData.ns = result.ns;
            this.activeName = result.tab;
            this.startQueryNameData();
          }
        }
      }
    },
    handleClose() {
      this.$confirm("关闭后无法保存,是否关闭?")
        .then((_) => {
          this.dialogFormVisible = false
        })
      })
      // let bdres = data.result.filter((item) => item.ns == "bd");
      // let bsres = data.result.filter((item) => item.ns == "bs");
      // let mdres = data.result.filter((item) => item.ns == "md");
      // for (var i in bdres) {
      //   // bdres[i].val = bdres[i].tabDesc + '(' + bdres[i].tab + ')';
      //   bdres[i].val = bdres[i].tabDesc;
      // }
      // for (var i in bsres) {
      //   // bsres[i].val = bsres[i].tabDesc + '(' + bsres[i].tab + ')';
      //   bsres[i].val = bsres[i].tabDesc;
      // }
      // for (var i in mdres) {
      //   // bsres[i].val = bsres[i].tabDesc + '(' + bsres[i].tab + ')';
      //   mdres[i].val = mdres[i].tabDesc;
      // }
      // this.domainData[0].children = bdres;
      // this.domainData[1].children = bsres;
      // this.domainData[2].children = mdres;
      var result = this.domainData[0].children;
      this.insertform.tab = result[0].tab;
      this.insertform.tabDesc = result[0].tabDesc;
      this.insertform.ns = result[0].ns;
      this.listData.tab = result[0].tab;
      this.listData.ns = result[0].ns;
      this.activeName = result[0].tab;
      this.startQueryNameData();
        .catch((_) => { });
    },
    handleCloseadd() {
      this.$confirm("关闭后无法保存,是否关闭?")
        .then((_) => {
          this.InsertFormdialog = false
        })
        .catch((_) => { });
    },
  },
};