| | |
| | | <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" |
| | |
| | | <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"> |
| | |
| | | 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" |
| | |
| | | :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> |
| | |
| | | } |
| | | }; |
| | | return { |
| | | tenantId:'', |
| | | form: {}, |
| | | seoptions: [], |
| | | sevalue:"", |
| | |
| | | treeDeptId: '', |
| | | treeData: [], |
| | | treeOption: { |
| | | height:"auto", |
| | | nodeKey: 'id', |
| | | border: true, |
| | | lazy: true, |
| | | treeLoad: function (node, resolve) { |
| | | const parentId = (node.level === 0) ? 0 : node.data.id; |
| | |
| | | } |
| | | }, |
| | | option: { |
| | | height: 'auto', |
| | | height:'auto', |
| | | calcHeight: 80, |
| | | tip: false, |
| | | searchShow: true, |
| | |
| | | viewBtn: true, |
| | | dialogType: 'drawer', |
| | | dialogClickModal: false, |
| | | highlightCurrentRow: true, //行选中时高亮 |
| | | column: [ |
| | | { |
| | | label: "登录账号", |
| | |
| | | { |
| | | 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" |
| | |
| | | label: "所属租户", |
| | | prop: "tenantId", |
| | | type: "tree", |
| | | dicUrl: "/api/blade-system/tenant/select", |
| | | dicUrl: "/api/ubcs-system/tenant/select", |
| | | props: { |
| | | label: "tenantName", |
| | | value: "tenantId" |
| | |
| | | trigger: "click" |
| | | }], |
| | | span: 24, |
| | | value:"211833" |
| | | }, |
| | | { |
| | | label: "登录账号", |
| | |
| | | { |
| | | 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" |
| | |
| | | { |
| | | label: '密码', |
| | | prop: 'password', |
| | | type: "password", |
| | | hide: true, |
| | | editDisplay: false, |
| | | viewDisplay: false, |
| | |
| | | label: '确认密码', |
| | | prop: 'password2', |
| | | hide: true, |
| | | type: "password", |
| | | editDisplay: false, |
| | | viewDisplay: false, |
| | | rules: [{required: true, validator: validatePass2, trigger: 'blur'}] |
| | |
| | | { |
| | | 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" |
| | |
| | | res: 'data' |
| | | }, |
| | | tip: '请上传 .xls,.xlsx 标准格式文件', |
| | | action: "/api/blade-user/import-user" |
| | | action: "/api/ubcs-user/import-user" |
| | | }, |
| | | { |
| | | label: "数据覆盖", |
| | |
| | | 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}`; |
| | | } |
| | | } |
| | | }, |
| | |
| | | }, |
| | | created() { |
| | | 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('确认关闭?') |
| | |
| | | }else { |
| | | this.passVisible=true; |
| | | } |
| | | console.log("selectionList",this.selectionList) |
| | | }, |
| | | // 设置密码策略,传递下拉框的id和多选框的id |
| | | passhandle(){ |
| | |
| | | //要传递的id,一个是数组另一个是字符串 |
| | | this.UserPwdstrategyVO.userIds=this.selid; |
| | | this.UserPwdstrategyVO.pwdstrategyId=this.id |
| | | console.log(this.UserPwdstrategyVO) |
| | | |
| | | //请求 |
| | | insert(this.UserPwdstrategyVO).then(()=>{ |
| | | this.passVisible=false |
| | |
| | | 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 |
| | |
| | | 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); |
| | |
| | | }); |
| | | }, |
| | | 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(","); |
| | |
| | | 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 = []; |
| | |
| | | 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; |
| | | |
| | |
| | | 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) { |
| | | if (["edit", "view"].includes(type)) { |
| | | getUser(this.form.id).then(res => { |
| | | this.form = res.data.data; |
| | | if (this.form.hasOwnProperty("deptId")) { |
| | | this.form.deptId = this.form.deptId.split(","); |
| | | } |
| | | if (this.form.hasOwnProperty("roleId")) { |
| | | this.form.roleId = this.form.roleId.split(","); |
| | | } |
| | | if (this.form.hasOwnProperty("postId")) { |
| | | this.form.postId = this.form.postId.split(","); |
| | | } |
| | | }); |
| | | // 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; |
| | | if (this.form.hasOwnProperty("deptId")) { |
| | | this.form.deptId = this.form.deptId.split(","); |
| | | } |
| | | if (this.form.hasOwnProperty("roleId")) { |
| | | this.form.roleId = this.form.roleId.split(","); |
| | | } |
| | | if (this.form.hasOwnProperty("postId")) { |
| | | this.form.postId = this.form.postId.split(","); |
| | | } |
| | | }); |
| | | } |
| | | const prop = this.findObject(this.option.group, 'tenantId'); |
| | | console.log('1',prop) |
| | | this.initFlag = true; |
| | | done(); |
| | | }else { |
| | | this.$message.warning('请选择一条所属租户') |
| | | } |
| | | this.initFlag = true; |
| | | done(); |
| | | }, |
| | | currentChange(currentPage) { |
| | | this.page.currentPage = currentPage; |
| | |
| | | this.page.total = data.total; |
| | | this.data = data.records; |
| | | this.loading = false; |
| | | this.tenantId=data.records[0].tenantId |
| | | this.selectionClear(); |
| | | }); |
| | | }, |
| | |
| | | overflow: scroll; |
| | | } |
| | | .selects{ |
| | | width: 400px; |
| | | margin-left: 92px; |
| | | width: 100%; |
| | | } |
| | | .seloption{ |
| | | margin-left: 10px; |
| | | } |
| | | .abox{ |
| | | height: 771px; |
| | | } |
| | | |
| | | </style> |