田源
2023-10-18 59c9fdfeecda48c774660b04fe84f5992caa1893
Source/UBCS-WEB/src/views/system/user.vue
@@ -1,35 +1,39 @@
<template>
  <el-row>
    <el-col :span="5">
    <el-col :span="5" v-if="userflag">
      <div class="box">
        <el-scrollbar>
        <el-scrollbar style="height: auto;border-bottom-right-radius:8px ">
          <basic-container>
            <avue-tree :data="treeData" :option="treeOption" @node-click="nodeClick"/>
            <div class="abox">
              <avue-tree ref="tree" :data="treeData" :option="treeOption" @node-click="nodeClick"/>
            </div>
          </basic-container>
        </el-scrollbar>
      </div>
    </el-col>
    <el-col :span="19">
    <el-col :span="usernumber">
      <basic-container>
        <div class="bbox">
        <avue-crud ref="crud"
                   v-model="form"
                   :before-open="beforeOpen"
                   :data="data"
                   :option="option"
                   :page.sync="page"
                   :permission="permissionList"
                   :search.sync="search"
                   :table-loading="loading"
                   @row-del="rowDel"
                   @row-update="rowUpdate"
                   @row-save="rowSave"
                   @search-change="searchChange"
                   @search-reset="searchReset"
                   @selection-change="selectionChange"
                   @current-change="currentChange"
                   @size-change="sizeChange"
                   @refresh-change="refreshChange"
                   @on-load="onLoad">
          v-model="form"
          :before-open="beforeOpen"
          :data="data"
          :option="option"
          :page.sync="page"
          :permission="permissionList"
          :search.sync="search"
          :table-loading="loading"
          @row-del="rowDel"
          @row-update="rowUpdate"
          @row-save="rowSave"
          @search-change="searchChange"
          @search-reset="searchReset"
          @row-click="clickRowChange"
          @selection-change="selectionChange"
          @current-change="currentChange"
          @size-change="sizeChange"
          @refresh-change="refreshChange"
          @on-load="onLoad">
          <template slot="menuLeft">
            <el-button v-if="permission.user_delete"
                       icon="el-icon-delete"
@@ -98,19 +102,19 @@
            <el-tag>{{ row.userTypeName }}</el-tag>
          </template>
        </avue-crud>
        </div>
        <el-dialog :visible.sync="roleBox"
                   append-to-body
                   title="用户角色配置"
                   width="345px">
            append-to-body
            title="用户角色配置"
            width="345px">
          <el-tree ref="treeRole"
                   :data="roleGrantList"
                   :default-checked-keys="roleTreeObj"
                   :props="props"
                   check-strictly
                   default-expand-all
                   node-key="id"
                   show-checkbox>
              :data="roleGrantList"
              :default-checked-keys="roleTreeObj"
              :props="props"
              check-strictly
              default-expand-all
              node-key="id"
              show-checkbox>
          </el-tree>
          <span slot="footer" class="dialog-footer">
@@ -138,8 +142,7 @@
          class="passdialog"
          append-to-body
          title="设置密码策略"
          width="30%"
        >
          width="30%">
          <el-select v-model="sevalue" placeholder="请选择"  class="selects" @change="selChange" >
            <el-option
              v-for="item in seoptions"
@@ -148,44 +151,13 @@
              :value="item.id"
              class="seloption"
              >
            </el-option>
          </el-select>
            <span slot="footer" class="dialog-footer">
            <el-button @click="passVisible = false">取 消</el-button>
            <el-button type="primary" @click="passhandle">确 定</el-button>
  </span>
              <el-button @click="passVisible = false">取 消</el-button>
              <el-button type="primary" @click="passhandle">确 定</el-button>
            </span>
        </el-dialog>
        <!--        <el-dialog title="用户平台配置"-->
        <!--                   append-to-body-->
        <!--                   :visible.sync="platformBox">-->
        <!--          <avue-crud :option="platformOption"-->
        <!--                     :table-loading="platformLoading"-->
        <!--                     :data="platformData"-->
        <!--                     ref="platformCrud"-->
        <!--                     v-model="platformForm"-->
        <!--                     :before-open="platformBeforeOpen"-->
        <!--                     :page.sync="platformPage"-->
        <!--                     :permission="platformPermissionList"-->
        <!--                     @row-update="platformRowUpdate"-->
        <!--                     @search-change="platformSearchChange"-->
        <!--                     @search-reset="platformSearchReset"-->
        <!--                     @selection-change="platformSelectionChange"-->
        <!--                     @current-change="platformCurrentChange"-->
        <!--                     @size-change="platformSizeChange"-->
        <!--                     @refresh-change="platformRefreshChange"-->
        <!--                     @on-load="platformOnLoad">-->
        <!--            <template slot-scope="{row}"-->
        <!--                      slot="tenantName">-->
        <!--              <el-tag>{{row.tenantName}}</el-tag>-->
        <!--            </template>-->
        <!--            <template slot-scope="{row}"-->
        <!--                      slot="userTypeName">-->
        <!--              <el-tag>{{row.userTypeName}}</el-tag>-->
        <!--            </template>-->
        <!--            -->
        <!--          </avue-crud>-->
        <!--        </el-dialog>-->
      </basic-container>
    </el-col>
  </el-row>
@@ -205,7 +177,7 @@
  resetPassword, unlock
} from "@/api/system/user";
import {exportBlob} from "@/api/common";
import {getDeptTree, getDeptLazyTree} from "@/api/system/dept";
import {getDeptTree, getDeptLazyTree, updateUserStatus} from "@/api/system/dept";
import {getRoleTree} from "@/api/system/role";
import {getPostList} from "@/api/system/post";
import {mapGetters} from "vuex";
@@ -237,6 +209,7 @@
      }
    };
    return {
      tenantId:'',
      form: {},
      seoptions: [],
      sevalue:"",
@@ -274,7 +247,9 @@
      treeDeptId: '',
      treeData: [],
      treeOption: {
        height:"auto",
        nodeKey: 'id',
        border: true,
        lazy: true,
        treeLoad: function (node, resolve) {
          const parentId = (node.level === 0) ? 0 : node.data.id;
@@ -298,17 +273,19 @@
        }
      },
      option: {
        height: 'auto',
        height:'auto',
        calcHeight: 80,
        tip: false,
        searchShow: true,
        searchMenuSpan: 6,
        columnBtn:false,
        border: true,
        index: true,
        selection: true,
        viewBtn: true,
        dialogType: 'drawer',
        dialogClickModal: false,
        highlightCurrentRow: true, //行选中时高亮
        column: [
          {
            label: "登录账号",
@@ -355,7 +332,7 @@
          {
            label: "用户平台",
            type: "select",
            dicUrl: "/api/blade-system/dict/dictionary?code=user_type",
            dicUrl: "/api/ubcs-system/dict/dictionary?code=user_type",
            props: {
              label: "dictValue",
              value: "dictKey"
@@ -369,7 +346,7 @@
              required: true,
              message: "请选择用户平台",
              trigger: "blur"
            }]
            }],
          },
        ],
        group: [
@@ -382,7 +359,7 @@
                label: "所属租户",
                prop: "tenantId",
                type: "tree",
                dicUrl: "/api/blade-system/tenant/select",
                dicUrl: "/api/ubcs-system/tenant/select",
                props: {
                  label: "tenantName",
                  value: "tenantId"
@@ -397,6 +374,7 @@
                  trigger: "click"
                }],
                span: 24,
                value:""
              },
              {
                label: "登录账号",
@@ -410,11 +388,12 @@
              {
                label: "用户平台",
                type: "select",
                dicUrl: "/api/blade-system/dict/dictionary?code=user_type",
                dicUrl: "/api/ubcs-system/dict/dictionary?code=user_type",
                props: {
                  label: "dictValue",
                  value: "dictKey"
                },
                value:'1',
                dataType: "number",
                slot: true,
                prop: "userType",
@@ -427,6 +406,7 @@
              {
                label: '密码',
                prop: 'password',
                type: "password",
                hide: true,
                editDisplay: false,
                viewDisplay: false,
@@ -436,6 +416,7 @@
                label: '确认密码',
                prop: 'password2',
                hide: true,
                type: "password",
                editDisplay: false,
                viewDisplay: false,
                rules: [{required: true, validator: validatePass2, trigger: 'blur'}]
@@ -571,7 +552,7 @@
                  value: "id"
                },
                rules: [{
                  required: true,
                  required: false,
                  message: "请选择所属岗位",
                  trigger: "click"
                }],
@@ -625,7 +606,7 @@
          {
            label: "用户平台",
            type: "select",
            dicUrl: "/api/blade-system/dict/dictionary?code=user_type",
            dicUrl: "/api/ubcs-system/dict/dictionary?code=user_type",
            props: {
              label: "dictValue",
              value: "dictKey"
@@ -669,7 +650,7 @@
              res: 'data'
            },
            tip: '请上传 .xls,.xlsx 标准格式文件',
            action: "/api/blade-user/import-user"
            action: "/api/ubcs-user/import-user"
          },
          {
            label: "数据覆盖",
@@ -709,19 +690,22 @@
      UserPwdstrategyVO:{
        userIds:[],
        pwdstrategyId:''
      }
      },
      userflag:true,
      usernumber:0
    };
  },
  watch: {
    'form.tenantId'() {
      if (this.form.tenantId !== '' && this.initFlag) {
        this.initData(this.form.tenantId);
        console.log('this.form.tenantId',this.form.tenantId)
      }
    },
    'excelForm.isCovered'() {
      if (this.excelForm.isCovered !== '') {
        const column = this.findObject(this.excelOption.column, "excelFile");
        column.action = `/api/blade-user/import-user?isCovered=${this.excelForm.isCovered}`;
        column.action = `/api/ubcs-user/import-user?isCovered=${this.excelForm.isCovered}`;
      }
    }
  },
@@ -758,9 +742,23 @@
    }
  },
  created() {
    updateUserStatus({userid:'1702600796324032513',status:true}).then(res=>{
      console.log(res)
    })
    this.selecload()
    const arr=JSON.parse(localStorage.getItem("updataid"))
    if(arr.user_id != '0' && arr.tenant_id !== '000000'){
      this.userflag=false
      this.usernumber=24
    }else {
      this.userflag=true
      this.usernumber=19
    }
  },
  methods: {
    beOpen(done,type){
      console.log(done,type)
    },
    //esc取消键操作
    handleClose(done) {
      this.$confirm('确认关闭?')
@@ -780,7 +778,6 @@
      }else {
        this.passVisible=true;
      }
      console.log("selectionList",this.selectionList)
    },
    // 设置密码策略,传递下拉框的id和多选框的id
    passhandle(){
@@ -791,7 +788,7 @@
       //要传递的id,一个是数组另一个是字符串
       this.UserPwdstrategyVO.userIds=this.selid;
       this.UserPwdstrategyVO.pwdstrategyId=this.id
      console.log(this.UserPwdstrategyVO)
      //请求
      insert(this.UserPwdstrategyVO).then(()=>{
        this.passVisible=false
@@ -799,10 +796,10 @@
          type: "success",
          message: "配置成功!"
        });
        this.selectionList=[]
        this.onLoad(this.page)
        console.log("selectionList",this.selectionList)
        this.selid=[]
      }).catch(res=>{
        this.selid=[]
        this.$message({
          type: "warning",
          message: res
@@ -814,13 +811,15 @@
    selChange(row){
      this.id=row
    },
    selecload(page, params = {}) {
      getPage(this.page.currentPage, this.page.pageSize, Object.assign(params, this.query)).then(res => {
        console.log(res)
        this.seoptions=res.data.data.content
    selecload() {
      getPage(1, -1).then(res => {
        // console.log(res)
        this.seoptions=res.data.data.records
      });
    },
    nodeClick(data) {
      console.log(data)
      console.log(this.form.tenantId)
      this.treeDeptId = data.id;
      this.page.currentPage = 1;
      this.onLoad(this.page);
@@ -853,21 +852,22 @@
      });
    },
    rowSave(row, done, loading) {
      row.deptId = row.deptId.join(",");
      row.roleId = row.roleId.join(",");
      row.postId = row.postId.join(",");
      add(row).then(() => {
        this.initFlag = false;
        this.onLoad(this.page);
        this.$message({
          type: "success",
          message: "操作成功!"
        row.deptId = row.deptId.join(",");
        row.roleId = row.roleId.join(",");
        row.postId = row.postId.join(",");
        console.log('3',row)
        add(row).then(() => {
          this.initFlag = false;
          this.onLoad(this.page);
          this.$message({
            type: "success",
            message: "操作成功!"
          });
          done();
        }, error => {
          window.console.log(error);
          loading();
        });
        done();
      }, error => {
        window.console.log(error);
        loading();
      });
    },
    rowUpdate(row, index, done, loading) {
      row.deptId = row.deptId.join(",");
@@ -914,8 +914,15 @@
      this.onLoad(this.page, params);
      done();
    },
    clickRowChange(row){
      this.$refs.crud.toggleSelection();
      this.selectionList = row;
      this.$refs.crud.setCurrentRow(row);
      this.$refs.crud.toggleRowSelection(row); //选中当前行
    },
    selectionChange(list) {
      this.selectionList = list;
      this.$refs.crud.setCurrentRow(this.selectionList[list.length-1]);
    },
    selectionClear() {
      this.selectionList = [];
@@ -973,7 +980,7 @@
      if (this.selectionList.length === 1) {
        this.roleTreeObj = this.selectionList[0].roleId.split(",");
      }
      getRoleTree().then(res => {
      getRoleTree(this.selectionList[0].tenantId).then(res => {
        this.roleGrantList = res.data.data;
        this.roleBox = true;
@@ -1020,18 +1027,24 @@
        type: "warning"
      }).then(() => {
        NProgress.start();
        exportBlob(`/api/blade-user/export-user?${this.website.tokenHeader}=${getToken()}&account=${account}&realName=${realName}`).then(res => {
        exportBlob(`/api/ubcs-user/export-user?${this.website.tokenHeader}=${getToken()}&account=${account}&realName=${realName}`).then(res => {
          downloadXls(res.data, `用户数据表${dateNow()}.xlsx`);
          NProgress.done();
        })
      });
    },
    handleTemplate() {
      exportBlob(`/api/blade-user/export-template?${this.website.tokenHeader}=${getToken()}`).then(res => {
      exportBlob(`/api/ubcs-user/export-template?${this.website.tokenHeader}=${getToken()}`).then(res => {
        downloadXls(res.data, "用户数据模板.xlsx");
      })
    },
    beforeOpen(done, type) {
      //console.log(type)
      // console.log('this.tenantId',this.tenantId)
      // const column = this.findObject(this.option.group,'tenantId');
      // column.value=this.tenantId;
      // console.log('column',column)
      // if(this.treeDeptId){
      if (["edit", "view"].includes(type)) {
        getUser(this.form.id).then(res => {
          this.form = res.data.data;
@@ -1046,8 +1059,13 @@
          }
        });
      }
      const prop = this.findObject(this.option.group, 'tenantId');
      //console.log('1',prop)
      this.initFlag = true;
      done();
      // }else {
      //   this.$message.warning('请选择一条所属租户')
      // }
    },
    currentChange(currentPage) {
      this.page.currentPage = currentPage;
@@ -1065,6 +1083,7 @@
        this.page.total = data.total;
        this.data = data.records;
        this.loading = false;
        this.tenantId=data.records[0].tenantId
        this.selectionClear();
      });
    },
@@ -1142,10 +1161,13 @@
  overflow: scroll;
}
.selects{
  width: 400px;
  margin-left: 92px;
  width: 100%;
}
.seloption{
  margin-left: 10px;
}
.abox{
  height: 771px;
}
</style>