{"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/Role/index.vue?vue&type=script&lang=js","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/Role/index.vue","mtime":1725944942464},{"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 {
  getRoleList,
  getRoleUserList,
  commonFileUploadApi,
  StaffDepartmentListApi,
  bacthSetEmployees,
  deleteRoleUser,
  batchImportRole,
  batchDeleteUser,
  downLoadRoleTp,
  UserDeptListApi,
} from "@/api/staffApi.js";
import UserDeptDialog from "./components/UserDeptDialog.vue";
import UserAuthDialog from "../AuthListV2/components/UserAuthDialog.vue";

import Detail from "./components/Detail.vue";

export default {
  data() {
    return {
      inputRoleVb: "",
      inputchooseVb: "",
      count: 1,
      chooseVb: false,
      roleOrMeberFlag: true /* 导入成员或角色 */,
      uploadloading: false,
      batchImportVb: false,
      batchDeleteVb: false,
      leftList: [],

      expandRow: [],
      tableData: [],
      multipleSelection: [], //全选列表
      tableColumn: [
        {
          prop: "userName",
          label: `姓名`,
          show: true,
        },
        {
          prop: "mobile",
          label: "手机号",
          align: "center",
          show: true,
        },

        {
          prop: "departName",
          label: `所在部门`,
          align: "center",
          show: true,
        },

        {
          prop: "occupationType",
          label: `职业类型`,
          align: "center",
          show: true,
        },
        // {
        //   prop: "totalMember",
        //   label: `应用权限`,
        //   width: "200",
        //   align: "center",
        //   show: true,
        // },
        {
          prop: "addRoleTime",
          label: `添加时间`,
          align: "center",
          show: true,
        },
      ],
      showdialog: false,
      showdialogImport: false,
      rowOne: {},

      isAllSelect: false, //是否全选,

      type: 0,
      params: {
        //搜索条件
        pageIndex: 1,
        pageSize: 10,
        keyword: "",
        roleId: [],
      },
      roleMainListmultipleSelection: [],
      organizationId: localStorage.domainId,
      activeRole: {},

      dpTreeData: [],
      loadingcheckedData: false,
      chooseData: [],
      showdialogUser: false,
    };
  },
  components: {
    Detail,
    UserDeptDialog,
    UserAuthDialog
  },
  mounted() {
    this.search(); //表格列表
  },

  watch: {
    inputchooseVb(val) {
      this.$refs.tree.filter(val);
    },
  },
  methods: {
    downloadTemp() {
      downLoadRoleTp(this.organizationId).then((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);
        }
      });

      //
    },
    filterChooseData(data = []) {
      let resArr = [];
      let resID = new Set(this.chooseData.map((item) => item.id));
      data.forEach((item) => {
        if (!resID.has(item.id)) {
          resArr.push(item);
        }
        resID.add(item.id);
      });
      if (resArr.length) {
        this.chooseData = this.chooseData.concat(resArr);
      }
    },
    filterNode(value, data) {
      if (!value) return true;
      return data.name.indexOf(value) !== -1;
    },
    //排序
    sortRole() {
      if (this.leftList.length > 1) {
        if (this.leftList[0].seq >= this.leftList[1].seq) {
          this.$message.success("已按排序值升序排列");
          this.leftList.sort((a, b) => {
            return a.seq - b.seq;
          });
        } else {
          this.$message.success("已按排序值降序排列");
          this.leftList.sort((a, b) => {
            return b.seq - a.seq;
          });
        }
      }
    },
    setPt(list){

      this.$refs.userauthdialog.open(list, 'single',true);
    },
    sureAdd() {
      bacthSetEmployees(
        {
          employeeIdList: this.chooseData.map((e) => e.id),
          roleIdList: [this.activeRole.id],
        },
        this.organizationId
      ).then((response) => {
        if (response.status == 200) {
          this.$message.success("添加成功");
          this.chooseVb = false;
          this.getRoleUserList(this.activeRole);
        }
      });
    },
    deleteAllTag() {
      this.chooseData = [];
    },
    deleteTag(tagIndex) {
      this.chooseData.splice(this.chooseData.indexOf(tagIndex), 1);
    },

    getMeberList({ data }) {
      //点击部门成员数弹窗
      this.showdialogUser = true;
      this.$refs.UserpopChildren.getTableRow(data, 0);
    },
    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);
          }
        });
      }
    },

    async getDepartmentList() {
      this.chooseData = [];
      if (this.dpTreeData.length) return (this.chooseVb = true);
      const { data } = await StaffDepartmentListApi({
        domainId: localStorage.domainId,
      });

      this.sortTableData(data);
      this.dpTreeData = data;
      this.chooseVb = true;
    },

    batchRemoveMeber() {
      if (!this.multipleSelection.length) {
        return this.$message.error("请选择要删除的成员");
      }
      this.$confirm(
        `<div>
          <div style='color:red;font-weight:bold; font-size:18px;margin-bottom:8px;'>注意</div>
          <div >
          删除为不可逆操作，被移除的成员将会被移除对应权限。</div>

          
         </div>`,
        "提示",
        {
          dangerouslyUseHTMLString: true,
          confirmButtonText: "确定删除",
          cancelButtonText: "取消",
          confirmButtonClass: "el-button--danger",
          type: "warning",
        }
      )
        .then(() => {
          batchDeleteUser(
            {
              employeeIdList: this.multipleSelection.map((e) => e.employeeId),
              roleId: this.activeRole.id,
            },
            this.organizationId
          ).then((response) => {
            if (response.status == 200) {
              this.getRoleUserList(this.activeRole); //表格列表
            }
          });
        })
        .catch(() => {
          // this.radio = ""; //清空选中
        });
    },
    batchImportVbAction(v) {
      this.roleOrMeberFlag = v;
      this.batchImportVb = true;
    },
    sureDelete() {
      this.batchDeleteVb = false;
    },
    beforeUpload(file) {
      if (file.size / 1024 / 1024 > 5) {
        return this.$message.error("上传文件不能超过5MB!");
      }
      return true;
    },
    uploadImg(e) {
      this.uploadloading = true;
      //文件上传
      if (__network__) {
        this.obsFile(e); //obs文件上传
        return;
      } else {
        this.InFileUpload(e); //内网文件上传
      }
    },
    finalUpload(path) {
      batchImportRole({ path }, this.organizationId, this.activeRole.id)
        .then((response) => {
          if (response) {
            const content = response;
            const blob = new Blob([content]);
            const fileName = `批量导入成员结果.xlsx`;
            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);
              this.$message.info("导入结果，请查阅批量导入成员结果文件");
              elink.click();
              URL.revokeObjectURL(elink.href); // 释放URL 对象
            } else {
              // IE10+下载
              navigator.msSaveBlob(blob, fileName);
            }
            this.batchImportVb = false;
          }
        })
        .finally(() => {
          this.uploadloading = false;
          this.$refs.upload.clearFiles();
          this.getRoleUserList(this.activeRole);
        });
    },
    obsFile(e) {
      //obs文件上传
      console.log(e);
      var that = this;
      var domainId = this.$route.query.domainId || "default"; //保存本地企业id
      // var objectKey="uploads/"+domainId+"/"+new Date().getFullYear()+"/"+new Date().getTime()+e.file.name
      let now = new Date();
      let y = now.getFullYear();
      let m =
        now.getMonth() + 1 < 10
          ? "0" + (now.getMonth() + 1)
          : now.getMonth() + 1;
      let d = now.getDate() < 10 ? "0" + now.getDate() : now.getDate();
      let md = m + "-" + d;
      var objectKey = `uploads/${y}/${md}/${domainId}/${now.getTime()}/${
        e.file.name
      }`;

      var obs = new ObsClient({
        access_key_id: ak,
        secret_access_key: sk,
        server: urlserver,
        timeout: 60 * 5,
      });
      obs
        .putObject({
          Bucket: BucketName,
          Key: objectKey,
          SourceFile: e.file, //获取file文件
        })
        .then(function (result) {
          if (result.CommonMsg.Status < 300) {
            console.log("Create object:" + objectKey + " successfully!\n");
            var httpurl = `https://${BucketName}.${urlserver}/${objectKey}`;
            httpurl = convertCdnPath(httpurl);
            that.finalUpload(httpurl);

            // that.fileList=[{name:e.file.name,url:httpurl}]
          }
        });
    },
    InFileUpload(e) {
      this.uploadloading = true;
      let fd = new FormData();
      fd.append("file", e.file);

      commonFileUploadApi(fd).then((response) => {
        let blobReader = new Response(response).json();
        blobReader.then((res) => {
          if (res.data) {
            this.finalUpload(res.data);
          }
        });
      });
    },

    batchD() {
      /* 批量删除 */
    },
    batchI() {
      /* 批量导入 */
    },
    search() {
      this.activeRole = {};
      this.tableDatalist();
      //查询
    },
    tableDatalist() {
      //表格列表
      let obj = { employeeId: "", roleName: this.inputRoleVb };
      getRoleList(obj, this.organizationId).then((response) => {
        if (Array.isArray(response.data) && response.data[0]) {
          this.leftList = response.data;

          this.getRoleUserList(response.data[0]);
        }
      });
    },

    getRoleUserList(role) {
      if (role) {
        this.activeRole = role;
        this.params = { ...this.params, roleId: role.id };
        getRoleUserList(this.params, this.organizationId).then(({ data }) => {
          if (Array.isArray(data.data)) {
            this.tableData = data.data;
            this.params = { ...this.params, total: data.total };
          }
        });
      }
    },
    handleCurrentChange(val) {
      this.params.pageIndex = val;
      this.getRoleUserList(this.activeRole);
    },
    handleSizeChange(val) {
      //切换每页条数
      this.params.pageIndex = 1; //重置第一页
      this.params.pageSize = val;
      this.getRoleUserList(this.activeRole);
    },
    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);
          }
        }
      });
    },

    roleMainListhandleSelectionChange(val) {
      //选中全选
      console.log(val);
      this.roleMainListmultipleSelection = val;
    },

    roleMainListhandleSelectionAllChange(val) {
      //选中全选
      console.log(val);
      this.roleMainListmultipleSelection = val;
    },
    toggleSelection(row, select) {
      //全选选中与取消选中
      if (select) {
        this.$refs.districtTable.toggleRowSelection(row, select); //全选选中
      } else {
        this.$refs.districtTable.clearSelection(); //取消选中
      }
    },
    patchDel() {},

    editDept(row, type) {
      this.type = type;
      //编辑
      this.rowOne = { ...row };
      this.showdialogImport = true;
    },
    delDept(row) {
      console.log(this.roleMainListmultipleSelection);
      //删除
      //删除选中表格数据
      //当有row的时候就是单条 没有的时候就是批量删除
      let rows = row ? [row] : this.roleMainListmultipleSelection;

      const idList = rows.map((e) => e.id);
      const nameList = rows.map((e) => e.roleName);

      if (Object.keys(rows).length) {
        const tips = row
          ? `<div>
          <div>确认删除【<span style='color:red'>${row.roleName}</span>】角色？</div>

删除前请确认该属于该角色的成员 <span style='color:red'>已全部移除。 </span>
          
         </div>`
          : `<div>
          <div>确认删除【<span style='color:red'>${nameList.join(
            ","
          )}</span>】角色？</div>

删除前请确认所选角色下的成员 <span style='color:red'>已全部移除。 </span>
          
         </div>`;
        this.$confirm(tips, "提示", {
          dangerouslyUseHTMLString: true,
          confirmButtonText: "确定删除",
          cancelButtonText: "取消",
          confirmButtonClass: "el-button--danger",
          type: "warning",
        })
          .then(() => {
            deleteRoleUser({ idList }, this.organizationId).then((response) => {
              if (response.status == 200) {
                this.$message.success("删除成功");
                this.batchDeleteVb = false;
                this.search(); //表格列表
              } else {
                this.$message.error(response.message || "操作失败");
              }
            });
          })
          .catch(() => {
            // this.radio = ""; //清空选中
          });
      }
    },
  },
};
"},null]}