管道基础大数据平台系统开发-【前端】-新系統界面
Surpriseplus
2023-04-13 797992cf12451dc64070ec63b6b1917aa5cc9b2e
src/views/datamanage/dictionaryManage.vue
@@ -11,7 +11,27 @@
        class="dictionary_leftTree subpage_Div"
        style="border: 1px solid #dcdfe6;"
      >
        <ul>
        <el-input
          size="small"
          v-model="filterInput"
          style="width: 200px"
          :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"
          @node-click="getTableDesc"
          :filter-node-method="filterNode"
          ref="tree"
        ></el-tree>
        <!-- <ul>
          <li
            @click="getTableDesc(item)"
            v-for="(item, i) in optionCount"
@@ -20,7 +40,7 @@
          >
            {{ item.tabDesc }}
          </li>
        </ul>
        </ul> -->
      </div>
      <div class="right subpage_Div">
@@ -38,9 +58,17 @@
                v-model="formInline.tab"
                :placeholder="$t('shuJuGuanLi.lable3')"
                style="width: 200px"
              ><i slot="suffix" class="el-icon-search"  @click="getSelectDictTab" style="padding-right: 8px"></i></el-input>
              ><i
                  slot="suffix"
                  class="el-icon-search"
                  @click="getSelectDictTab"
                  style="padding-right: 8px"
                ></i></el-input>
            </el-form-item>
            <el-form-item style="float: right" size="small">
            <el-form-item
              style="float: right"
              size="small"
            >
              <el-button
                v-if="btnStatus.insert"
                icon="el-icon-edit"
@@ -55,7 +83,7 @@
                @click="DelFormData"
                type="danger"
              >{{ $t("common.delete") }}</el-button>
<!--              <el-button
              <!--              <el-button
                icon="el-icon-search"
                size="small"
                @click="getSelectDictTab"
@@ -78,6 +106,7 @@
          <el-table
            :data="tableData"
            style="width: 100%"
            border
            @selection-change="handleSelectionChange"
            height="calc(100% - 57px)"
          >
@@ -139,7 +168,7 @@
            />
            <el-table-column
              min-width="100"
              prop="createUser"
              prop="createName"
              :label="$t('dataManage.dictionaryManageObj.createPersonnel')"
            />
            <el-table-column
@@ -150,7 +179,7 @@
            />
            <el-table-column
              min-width="100"
              prop="updateUser"
              prop="updateName"
              :label="$t('dataManage.dictionaryManageObj.updatePersonnel')"
            />
@@ -294,6 +323,7 @@
      top="2vh"
      :title="$t('dataManage.dictionaryManageObj.revamp')"
      :visible.sync="dialogFormVisible"
      :before-close="handleClose"
    >
      <div style="height: 500px; overflow: auto">
        <el-form
@@ -401,7 +431,7 @@
        <el-button
          type="info"
          size="small"
          @click="dialogFormVisible = false"
          @click="handleClose"
        >{{ $t("dataManage.dictionaryManageObj.cancel") }}</el-button>
        <el-button
          class="primary"
@@ -416,6 +446,7 @@
      :title="$t('dataManage.dictionaryManageObj.add')"
      top="2vh"
      :visible.sync="InsertFormdialog"
      :before-close="handleCloseadd"
    >
      <div style="height: 500px; overflow: auto">
        <el-form
@@ -523,7 +554,7 @@
        <el-button
          type="info"
          size="small"
          @click="InsertFormdialog = false"
          @click="handleCloseadd"
        >{{
          $t("dataManage.dictionaryManageObj.cancel")
        }}</el-button>
@@ -548,11 +579,16 @@
  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 },
  data() {
    return {
      filterInput: "",
      activeName: "",
      formInline: [],
      listData: {
@@ -581,13 +617,29 @@
        insert: false,
        update: false,
      },
      domainData: [],
      defaultProps: {
        children: "children",
        label: "label",
      },
    };
  },
  watch: {
    filterInput(val) {
      this.$refs.tree.filter(val);
    },
  },
  created() {
    this.getSelectDictTab();
    this.showPermsBtn();
  },
  methods: {
    filterNode(value, data) {
      if (!value) return true;
      return data.val.indexOf(value) !== -1;
    },
    //新增
    async insertFromData() {
      const data = await insertDict(this.insertform);
@@ -609,6 +661,9 @@
    },
    //获取表格字段信息
    getTableDesc(res) {
      if (res.children) {
        return
      }
      this.insertform.tab = res.tab;
      this.insertform.tabDesc = res.tabDesc;
      this.insertform.ns = res.ns;
@@ -635,7 +690,7 @@
    },
    handleSizeChange(val) {
      thihs.listData.pageIndex = 1;
      this.listData.pageIndex = 1;
      this.listData.pageSize = val;
      this.startQueryNameData();
    },
@@ -714,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);
    },
@@ -726,21 +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 = 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) {
      this.optionCount = data.result;
      this.insertform.tab = data.result[0].tab;
      this.insertform.tabDesc = data.result[0].tabDesc;
      this.insertform.ns = data.result[0].ns;
      this.listData.tab = data.result[0].tab;
      this.listData.ns = data.result[0].ns;
      this.activeName = data.result[0].tab;
      this.startQueryNameData();
      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
        })
        .catch((_) => { });
    },
    handleCloseadd() {
      this.$confirm("关闭后无法保存,是否关闭?")
        .then((_) => {
          this.InsertFormdialog = false
        })
        .catch((_) => { });
    },
  },
};
@@ -814,7 +929,7 @@
    border: 1px solid #dcdfe6;
    .inquire {
      // margin-bottom: 10px;
      //padding: 8px;
      padding: 8px;
      // margin-top: 10px;
      border-radius: 5px;
      //border: 1px solid #dcdfe6;