{"remainingRequest":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/index.js??vue-loader-options!/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/DepartmentsList/index.vue?vue&type=script&lang=js","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/DepartmentsList/index.vue","mtime":1734079750102},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/thread-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/babel-loader/lib/index.js","mtime":456789000000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:
import {
  StaffDepartmentListApi,
  delDepartmentsApi,
  displayOrderApi,
  exportDepartListExcelApi
} from "@/api/staffApi.js";
import DeptDialog from "./components/DeptDialog.vue";
import ImportDeptDialog from "./components/ImportDeptDialog.vue";
import MoveDeptDialog from "./components/MoveDeptDialog.vue";
import ImDeptDialog from "./components/ImDeptDialog.vue";
import UserDeptDialog from "./components/UserDeptDialog.vue";
export default {
  data() {
    return {
      search:"",
      expandRow: [],
      tableData: [],
      multipleSelection: [], //全选列表
      tableColumn: [
        {
          prop: "name",
          label: `${$SuperviseStr.depart}名称`,
          width: "400",
          align: "left",
          show: true,
        },
        {
          prop: "displayOrder",
          label: "排序",
          width: "80",
          align: "center",
          show: true,
        },
        {
          prop: "totalMember",
          label: `${$SuperviseStr.depart}成员数`,
          width: "180",
          align: "center",
          show: true,
        },
        {
          prop: "permissionType",
          label: `${$SuperviseStr.depart}成员通讯录权限`,
          width: "",
          align: "center",
          show: true,
        },
      ],
      showdialog: false,
      showdialogImport: false,
      showdialogMove: false,
      showdialogIm: false,
      showdialogUser: false,
      disabled: true, //默认禁用
      isAllSelect: false, //是否全选
      displayOrderShow: false,
      homeTemplateBoradType:localStorage.getItem("homeTemplateBoradType") || "",
    };
  },
  components: {
    DeptDialog,
    ImportDeptDialog,
    MoveDeptDialog,
    ImDeptDialog,
    UserDeptDialog,
  },
  mounted() {
    this.tableDatalist(); //表格列表
  },
  computed:{
     treeTable(){
       let searchValue=this.search
       if(searchValue){
        //  return this.tableData.filter(item=>{
        //    return Object.keys(item).some(its=>{
        //      return String(item[its]).toLowerCase().indexOf(searchValue)>-1
        //    })
        //  })
        let treeData=this.tableData
        let handleTreeData=this.handleTreeData(treeData,searchValue)
        console.log(handleTreeData)
        this.setExpandRow(handleTreeData)
        console.log(this.expandRow)
        this.expandRow=this.expandRow.join(",").split(",")//返回数组id ['id1','id2']
        return handleTreeData  //匹配返回过滤查询到的父子树数据
       }
       console.log(this.tableData)
       return this.tableData //没匹配返回全部
     }
  },
  watch: {
    multipleSelection() {
      //复选框选中启用按钮
      if (this.multipleSelection.length) {
        this.disabled = false;
      } else {
        this.disabled = true;
      }
    },
  },
  methods: {
    //树形表格过滤
    handleTreeData(treeData, searchValue){
      // debugger
      if(!treeData||treeData.length==0) return [];
      const array=[];
      for(let i=0;i<treeData.length;i++){
              let match=false;
              for(let pro in treeData[i]){
                if(typeof(treeData[i][pro])=='string'){
                  match |=treeData[i][pro].includes(searchValue);
                  if(match) break;
                }
              }
              if(this.handleTreeData(treeData[i].children,searchValue).length>0||match){
                array.push({...treeData[i],children:this.handleTreeData(treeData[i].children,searchValue)})                
              }              
      } 
      console.log(array)
      return array;
    },
     //将过滤好的树形数据展开
    setExpandRow(handleTreeData){
       if(handleTreeData.length){
          for(let i of handleTreeData){
             this.expandRow.push(i.id)
             if(i.children.length){
               this.setExpandRow(i.children)
             }
          }
       }
    }, 
    exportExcel() {
      //导出
      let obj2 = { domainId: this.$route.query.domainId };
      exportDepartListExcelApi(this.params, obj2).then((response) => {
        console.log(response);
        const content = response;
        const blob = new Blob([content]);
        const fileName = `导出.xls`;
        if ("download" in document.createElement("a")) {
          // 非IE下载
          const elink = document.createElement("a");
          elink.download = fileName;
          elink.style.display = "none";
          elink.href = URL.createObjectURL(blob);
          document.body.appendChild(elink);
          elink.click();
          URL.revokeObjectURL(elink.href); // 释放URL 对象
          document.body.removeChild(elink);
        } else {
          // IE10+下载
          navigator.msSaveBlob(blob, fileName);
        }
      });
    },
    tableDatalist() {
      //表格列表
      let obj = { domainId: this.$route.query.domainId }; //获取url域domainId
      StaffDepartmentListApi(obj).then((response) => {
        if (response.data) {
          this.tableData = response.data;
          this.sortTableData(this.tableData);
        }
      });
    },
    sortTableData(arr) {
      //递归排序
      if (arr.length) {
        arr.forEach((item) => {
          item.displayOrderNumber = item.displayOrder;
          let allowedDepartsStr = [];
          if (item.allowedDeparts && item.allowedDeparts.length) {
            item.allowedDeparts.forEach((its) => {
              allowedDepartsStr.push(its.name);
            });
            item.allowedDepartsStr = allowedDepartsStr.join(",");
          }
          if (item.children.length) {
            this.sortTableData(item.children);
          }
        });
      }
    },
    handleSelectionChange(val) {
      //选中全选
      console.log(val);
      this.multipleSelection = val;
    },
    handleSelectionAllChange(selection, first) {
      //全选
      if (!first) {
        this.isAllSelect = !this.isAllSelect;
      }
      selection.map((el) => {
        if (el.children) {
          el.children.map((j) => {
            this.toggleSelection(j, this.isAllSelect);
          });
          if (el.children.length > 0) {
            this.handleSelectionAllChange(el.children, true);
          }
        }
      });
    },
    toggleSelection(row, select) {
      //全选选中与取消选中
      if (select) {
        this.$refs.districtTable.toggleRowSelection(row, select); //全选选中
      } else {
        this.$refs.districtTable.clearSelection(); //取消选中
      }
    },
    addDept() {
      //新增
      this.showdialog = true;
      this.$refs.popChildren.getTableRow({}, 0);
    },
    editDept(row) {
      console.log(row)
      //编辑
      this.showdialog = true;
      this.$refs.popChildren.getTableRow(row, 1);
    },
    delDept(row) {
      //删除
      //删除选中表格数据
      let ids = [row.id];
      let obj2 = { domainId: this.$route.query.domainId }; //获取url域domainId
      if (Object.keys(row) != "") {
        this.$confirm("此操作将永久删除此对应数据, 是否继续?", "提示", {
          confirmButtonText: "确定",
          cancelButtonText: "取消",
          type: "warning",
        })
          .then(() => {
            delDepartmentsApi(ids, obj2).then((response) => {
              if (response.status == 200) {
                this.tableDatalist(); //表格列表
              }
            });
          })
          .catch(() => {
            // this.radio = ""; //清空选中
          });
      }
    },
    patchDel() {
      //批量删除
      let obj2 = { domainId: this.$route.query.domainId }; //获取url域domainId
      if (this.multipleSelection.length) {
        this.$confirm("此操作将永久删除此对应数据, 是否继续?", "提示", {
          confirmButtonText: "确定",
          cancelButtonText: "取消",
          type: "warning",
        })
          .then(() => {
            let ids = [];
            this.multipleSelection.forEach((item) => {
              ids.push(item.id);
            });
            delDepartmentsApi(ids, obj2).then((response) => {
              if (response.status == 200) {
                this.tableDatalist(); //表格列表
              }
            });
          })
          .catch(() => {
            // this.radio = ""; //清空选中
          });
      }
    },
    importDept() {
      this.showdialogImport = true;
    },
    moveDept() {
      this.showdialogMove = true;
      this.$refs.MovepopChildren.getTableRow(this.multipleSelection, 0);
    },
    ImDept() {
      this.showdialogIm = true;
      this.$refs.ImpopChildren.getTableRow(this.multipleSelection, 0);
    },
    saveok(row, scope) {
      //保存排序
      console.log(row);
      console.log(scope);
      let obj2 = { domainId: this.$route.query.domainId };
      displayOrderApi(row, obj2).then((response) => {
        if (response.status == 200) {
          this.tableDatalist(); //表格列表
          scope._self.$refs[`popover-${scope.$index}`][0].doClose();
        }
      });
    },
    close(row, scope) {
      //关闭排序
      this.tableDatalist(); //表格列表
      scope._self.$refs[`popover-${scope.$index}`][0].doClose();
    },
    totalMemberClick(row) {
      //点击部门成员数弹窗
      this.showdialogUser = true;
      this.$refs.UserpopChildren.getTableRow(row, 0);
    },
    refurlist() {
      //弹窗后刷新列表
      this.tableDatalist(); //表格列表
    },
  },
};
"},null]}