Selaa lähdekoodia

月报:节点树 添加图标

洪海涛 4 vuotta sitten
vanhempi
sitoutus
c6816860a8
1 muutettua tiedostoa jossa 252 lisäystä ja 209 poistoa
  1. 252 209
      src/views/monthlyReport/childrenPage/setReport/components/nodeTreeSet.vue

+ 252 - 209
src/views/monthlyReport/childrenPage/setReport/components/nodeTreeSet.vue

@@ -1,209 +1,252 @@
-<template>
-  <div class="nodeTree">
-    <div class="sreach-header">
-      <el-input v-model="filterText" class="node-input" suffix-icon="el-icon-search" placeholder="输入关键字进行过滤" @blur="expandAll = true, getOdinTree(filterText)" />
-      <el-button class="teamDeleteText" type="text" @click="() => append('add')">添加根节点</el-button>
-    </div>
-    <el-tree v-if="tree" ref="tree" v-loading="loading" class="filter-tree" :data="treeNodeData" :props="defaultProps" :default-expand-all="expandAll" :expand-on-click-node="false" :filter-node-method="filterNode">
-      <span slot-scope="{ node, data }" class="custom-tree-node">
-        <span>
-          {{ node.label }}
-          <el-tag v-for="item in data.deptSetting" :key="item.id" closable type="info" size="small" style="margin-left: 20px;" @close="handleClose(item, data, 'tag')">{{ item.value }}</el-tag>
-        </span>
-      <span>
-          <el-button class="teamDeleteText" type="text" @click="() => append(data)">设置</el-button>
-        </span>
-      </span>
-    </el-tree>
-    <normal-dialog :show-dialog="showTreeNodeDialog" :title="typeVal === 'add' ? '添加根节点' : '设置'" :width="'35%'" @confirm="createOdinDeptRel" @cancel="showTreeNodeDialog = false, $set(setTeam, 'value', [])">
-      <el-form :model="setTeam" label-width="65px">
-        <el-form-item v-if="typeVal === 'add'" label="根节点">
-          <el-select v-model="setTeam.odinIds" multiple filterable remote style="width: 100%" reserve-keyword placeholder="请选择">
-            <el-option v-for="item in treeOption" :key="item.odinId" :label="item.odinNs" :value="item.odinId" />
-          </el-select>
-        </el-form-item>
-        <el-form-item v-else label="团队">
-          <el-select v-model="setTeam.value" filterable remote style="width: 100%" reserve-keyword placeholder="请选择" :remote-method="remoteMethod">
-            <el-option v-for="item in options" :key="item.deptCode" :label="item.deptName" :value="item.deptCode">
-              {{ item.deptLevel }} {{ item.deptName }}
-            </el-option>
-          </el-select>
-        </el-form-item>
-      </el-form>
-    </normal-dialog>
-    <!-- 删除 -->
-    <normal-dialog :show-dialog="deleteTeamBizDialog" :title="'删除'" :width="'35%'" @confirm="deleteDeptBizRel()" @cancel="deleteTeamBizDialog = false">
-      <div class="teamDeleteText">
-        是否清除节点 <span style="font-weight: 600;">{{ deleteData.data.name }}</span> 的设置信息?
-      </div>
-    </normal-dialog>
-  </div>
-</template>
-
-<script>
-import normalDialog from '@/components/dialog/normalDialog'
-import { getDeptByKeyWord, createOdinDeptRel, deleteOdinBizRel, getOdinTree, getOdinNodeByParentId, addShowOdinNode } from '@/api/qualityMonthlyReport'
-export default {
-  components: { normalDialog },
-  data() {
-    return {
-      deleteTeamBizDialog: false, // 删除
-      showTreeNodeDialog: false, // 节点树设置
-      filterText: '',
-      typeVal: 'add',
-      expandAll: false,
-      setTeam: {
-        value: ''
-      },
-      loading: false,
-      options: [], // 团队option
-      nodeData: {}, // 点击设置的节点
-      dataList: [],
-      deleteData: {
-        data: {},
-        node: {}
-      },
-      tree: true,
-      treeNodeData: [],
-      treeOption: [],
-      defaultProps: {
-        value: 'id',
-        children: 'children',
-        label: 'name'
-      }
-    }
-  },
-  watch: {
-    filterText(val) {
-      this.$refs.tree.filter(val)
-    }
-  },
-  created() {
-    this.getOdinTree(null)
-    this.getOdinNodeByParentId(138396)
-  },
-  methods: {
-    getOdinTree(e) {
-      this.treeNodeData = []
-      this.loading = true
-      getOdinTree(e).then(res => { // 获取节点树list
-        if (res.code === 200) {
-          setTimeout(() => {
-            this.loading = false
-            this.treeNodeData = res.data
-          }, 1000)
-        }
-      })
-    },
-    getOdinNodeByParentId(e) {
-      getOdinNodeByParentId(e).then(res => {
-        if (res.code === 200) this.treeOption = res.data
-      })
-    },
-    async remoteMethod(query) { // 获取部门option
-      if (query !== '') {
-        const res = await getDeptByKeyWord(query)
-        if (res.code === 200) {
-          this.options = res.data
-          this.dataList = [...res.data]
-        }
-      }
-    },
-    async deleteDeptBizRel() {
-      const res = await deleteOdinBizRel({ odinId: this.deleteData.data.id, deptId: this.deleteData.node.id })
-      if (res.code === 200) {
-        this.getOdinTree(null)
-        this.deleteTeamBizDialog = false
-        this.$message({ type: 'success', message: '已删除' })
-        window.log({ c: 'report_setting', d: 'report_setting_delSector' })
-      }
-    },
-    handleClose(node, data) { // 点击删除的数据
-      this.deleteTeamBizDialog = true
-      this.deleteData = { data: data, node: node }
-    },
-    async createOdinDeptRel(val) {
-      if (this.typeVal === 'add') {
-        addShowOdinNode({ odinIds: this.setTeam.odinIds }).then(res => {
-          if (res.code === 200) {
-            this.getOdinTree(null)
-            window.log({ c: 'report_setting', d: 'report_setting_addRootNode' })
-          }
-        })
-        return
-      }
-      const list = []
-      this.dataList.map(item => {
-        if (item.deptCode === this.setTeam.value) {
-          list.push({ deptId: item.deptCode, deptName: item.deptName })
-        }
-      })
-      const obj = { ...this.nodeData, depts: list, odinNsName: this.typeVal.ns }
-      const res = await createOdinDeptRel(obj)
-      if (res.code === 200) {
-        this.$set(this.setTeam, 'value', '')
-        this.getOdinTree(null)
-        this.$message({ type: 'success', message: '添加成功' })
-        this.showTreeNodeDialog = false
-        window.log({ c: 'report_setting', d: 'report_setting_addSector' })
-      }
-    },
-    filterNode(value, data) { // 筛选
-      if (!value) return true
-      return data.name.indexOf(value) !== -1
-    },
-    append(val) { // 设置
-      this.setTeam = {}
-      this.typeVal = val
-      this.showTreeNodeDialog = true
-      if (val === 'add') return
-      this.nodeData = { odinId: val.id, odinNs: val.name, odinNsName: val.ns }
-    }
-  }
-}
-</script>
-
-<style lang='less' scoped>
-  .custom-tree-node {
-    flex: 1;
-    display: flex;
-    align-items: center;
-    justify-content: space-between;
-    font-size: 14px;
-    padding-right: 8px;
-    line-height: 40px;
-  }
-
-  .nodeTree {
-    width: 500px;
-
-    /deep/label {
-      font-weight: 400;
-    }
-
-    .node-input {
-      margin: 20px 20px 20px 0;
-    }
-
-    .sreach-header {
-      margin-top: -5px;
-      display: flex;
-      align-items: center;
-      justify-content: space-between;
-    }
-
-    .filter-tree {
-      /deep/.el-tree-node {
-        margin-top: 10px;
-        color: #444444;
-        font-weight: 400;
-      }
-    }
-
-    .teamDeleteText {
-      text-align: center;
-      font-weight: 400;
-    }
-  }
-
-</style>
+<template>
+  <div class="nodeTree">
+    <div class="sreach-header">
+      <el-input v-model="filterText" class="node-input" suffix-icon="el-icon-search" placeholder="输入关键字进行过滤" @blur="expandAll = true, getOdinTree(filterText)" />
+      <el-button class="teamDeleteText" type="text" @click="() => append('add')">添加根节点</el-button>
+    </div>
+    <el-tree v-if="tree" ref="tree" v-loading="loading" class="filter-tree" :data="treeNodeData" :props="defaultProps" :default-expand-all="expandAll" :expand-on-click-node="false" :filter-node-method="filterNode">
+      <span slot-scope="{ node, data }" class="custom-tree-node">
+        <span>
+          <span v-if="node.label === 'offline'" style="background-image: url();background-size: 18px;margin-right: 2px;background-repeat: no-repeat;background-size: 21px 21px;vertical-align: middle;width: 21px;height: 21px;display: inline-block;position: relative;left: -1px" /><span v-else style="border-radius: 50%;display: inline-block;padding: 2px 4px;line-height: 1;font-size: 12px;color: #fff;position: relative;margin-right: 5px;top: 0px;" :style="{backgroundColor: setOdinColor(data.category ? data.category[0] : 'p')}">{{ data.category ? data.category[0].toUpperCase() : 'P' }}</span>{{ node.label }}
+          <el-tag v-for="item in data.deptSetting" :key="item.id" closable type="info" size="small" style="margin-left: 20px;" @close="handleClose(item, data, 'tag')">
+            <el-tooltip class="item" effect="dark" :content="find(item.id).deptPath" placement="top"><span>{{ item.value }}</span></el-tooltip></el-tag>
+        </span>
+      <span>
+          <el-button class="teamDeleteText" type="text" @click="() => append(data)">设置</el-button>
+        </span>
+      </span>
+    </el-tree>
+    <normal-dialog :show-dialog="showTreeNodeDialog" :title="typeVal === 'add' ? '添加根节点' : '设置'" :width="'35%'" @confirm="createOdinDeptRel" @cancel="showTreeNodeDialog = false, $set(setTeam, 'value', [])">
+      <el-form :model="setTeam" label-width="65px">
+        <el-form-item v-if="typeVal === 'add'" label="根节点">
+          <el-select v-model="setTeam.odinIds" multiple filterable remote style="width: 100%" reserve-keyword placeholder="请选择">
+            <el-option v-for="item in treeOption" :key="item.odinId" :label="item.odinNs" :value="item.odinId" />
+          </el-select>
+        </el-form-item>
+        <el-form-item v-else label="团队">
+          <Cascader ref="Cascader" v-model="setTeam.value" :multiple="false" />
+          <!--          <el-select v-model="setTeam.value" filterable remote style="width: 100%" reserve-keyword placeholder="请选择" :remote-method="remoteMethod">-->
+          <!--            <el-option v-for="item in options" :key="item.deptCode" :label="item.deptName" :value="item.deptCode">-->
+          <!--              {{ item.deptLevel }} {{ item.deptName }}-->
+          <!--            </el-option>-->
+          <!--          </el-select>-->
+        </el-form-item>
+      </el-form>
+    </normal-dialog>
+    <!-- 删除 -->
+    <normal-dialog :show-dialog="deleteTeamBizDialog" :title="'删除'" :width="'35%'" @confirm="deleteDeptBizRel()" @cancel="deleteTeamBizDialog = false">
+      <div class="teamDeleteText">
+        是否清除节点 <span style="font-weight: 600;">{{ deleteData.data.name }}</span> 的设置信息?
+      </div>
+    </normal-dialog>
+  </div>
+</template>
+
+<script>
+import normalDialog from '@/components/dialog/normalDialog'
+import Cascader from '@/views/monthlyReport/childrenPage/editReport/components/Cascader'
+import { getDeptByKeyWord, createOdinDeptRel, deleteOdinBizRel, getOdinTree, getOdinNodeByParentId, addShowOdinNode } from '@/api/qualityMonthlyReport'
+export default {
+  components: { normalDialog, Cascader },
+  data() {
+    return {
+      deleteTeamBizDialog: false, // 删除
+      showTreeNodeDialog: false, // 节点树设置
+      filterText: '',
+      typeVal: 'add',
+      expandAll: false,
+      setTeam: {
+        value: []
+      },
+      loading: false,
+      options: [], // 团队option
+      nodeData: {}, // 点击设置的节点
+      dataList: [],
+      deleteData: {
+        data: {},
+        node: {}
+      },
+      tree: true,
+      treeNodeData: [],
+      treeOption: [],
+      defaultProps: {
+        value: 'id',
+        children: 'children',
+        label: 'name'
+      }
+    }
+  },
+  computed: {
+    selectEnum() {
+      return this.$store.state.monthlyReportEdit.selectEnum
+    }
+  },
+  watch: {
+    filterText(val) {
+      this.$refs.tree.filter(val)
+    }
+  },
+  created() {
+    this.getOdinTree(null)
+    this.getOdinNodeByParentId(138396)
+    // 获取部门数据
+    this.$store.dispatch('monthlyReportEdit/setSelectEnum')
+  },
+  methods: {
+    getOdinTree(e) {
+      this.treeNodeData = []
+      this.loading = true
+      getOdinTree(e).then(res => { // 获取节点树list
+        if (res.code === 200) {
+          setTimeout(() => {
+            this.loading = false
+            this.treeNodeData = res.data
+          }, 1000)
+        }
+      })
+    },
+    getOdinNodeByParentId(e) {
+      getOdinNodeByParentId(e).then(res => {
+        if (res.code === 200) this.treeOption = res.data
+      })
+    },
+    async remoteMethod(query) { // 获取部门option
+      if (query !== '') {
+        const res = await getDeptByKeyWord(query)
+        if (res.code === 200) {
+          this.options = res.data
+          this.dataList = [...res.data]
+        }
+      }
+    },
+    async deleteDeptBizRel() {
+      const res = await deleteOdinBizRel({ odinId: this.deleteData.data.id, deptId: this.deleteData.node.id })
+      if (res.code === 200) {
+        this.getOdinTree(null)
+        this.deleteTeamBizDialog = false
+        this.$message({ type: 'success', message: '已删除' })
+        window.log({ c: 'report_setting', d: 'report_setting_delSector' })
+      }
+    },
+    handleClose(node, data) { // 点击删除的数据
+      this.deleteTeamBizDialog = true
+      this.deleteData = { data: data, node: node }
+    },
+    async createOdinDeptRel(val) {
+      if (this.typeVal === 'add') {
+        addShowOdinNode({ odinIds: this.setTeam.odinIds }).then(res => {
+          if (res.code === 200) {
+            this.getOdinTree(null)
+            window.log({ c: 'report_setting', d: 'report_setting_addRootNode' })
+          }
+        })
+        return
+      }
+      const list = []
+      this.dataList.map(item => {
+        if (item.deptCode === this.setTeam.value) {
+          list.push({ deptId: item.deptCode, deptName: item.deptName })
+        }
+      })
+      const setTeam = this.find(this.setTeam.value)
+      list.push({ deptId: setTeam.value, deptName: setTeam.label })
+      // find()
+      const obj = { ...this.nodeData, depts: list, odinNsName: this.typeVal.ns }
+      const res = await createOdinDeptRel(obj)
+      if (res.code === 200) {
+        this.$set(this.setTeam, 'value', '')
+        this.getOdinTree(null)
+        this.$message({ type: 'success', message: '添加成功' })
+        this.showTreeNodeDialog = false
+        window.log({ c: 'report_setting', d: 'report_setting_addSector' })
+      }
+    },
+    filterNode(value, data) { // 筛选
+      if (!value) return true
+      return data.name.indexOf(value) !== -1
+    },
+    append(val) { // 设置
+      this.setTeam = {}
+      setTimeout(() => {
+        this.$refs.Cascader.selectValue = ''
+      })
+      this.typeVal = val
+      this.showTreeNodeDialog = true
+      if (val === 'add') return
+      this.nodeData = { odinId: val.id, odinNs: val.name, odinNsName: val.ns }
+      this.$forceUpdate()
+    },
+    // 设置odin节点前置图标颜色
+    setOdinColor(keyword) {
+      if (keyword === 'p') return '#8CBDDD'
+      if (keyword === 'g') return '#AB91E5'
+      if (keyword === 's') return 'rgba(14,180,0,0.65)'
+      if (keyword === 'c') return '#E09D6C'
+      return ''
+    },
+    // 查找对应的部门数据
+    find(id) {
+      let name = ''
+      const run = (arr) => {
+        for (let i = 0; i < arr.length; i++) {
+          const elm = arr[i]
+          if (`${elm.value}` === `${id}`) {
+            name = elm
+            return
+          }
+          if (elm.children) {
+            run(elm.children)
+          }
+        }
+      }
+      run(this.selectEnum)
+      return name
+    }
+  }
+}
+</script>
+
+<style lang='scss' scoped>
+.custom-tree-node {
+  flex: 1;
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  font-size: 14px;
+  padding-right: 8px;
+  line-height: 40px;
+}
+
+.nodeTree {
+  width: 500px;
+
+  >>>label {
+    font-weight: 400;
+  }
+
+  .node-input {
+    margin: 20px 20px 20px 0;
+  }
+
+  .sreach-header {
+    margin-top: -5px;
+    display: flex;
+    align-items: center;
+    justify-content: space-between;
+  }
+
+  .filter-tree {
+    >>>.el-tree-node {
+      margin-top: 10px;
+      color: #444444;
+      font-weight: 400;
+    }
+  }
+
+  .teamDeleteText {
+    text-align: center;
+    font-weight: 400;
+  }
+}
+
+</style>