| | |
| | | <el-scrollbar style="height: auto;border-bottom-right-radius:8px "> |
| | | <basic-container> |
| | | <div class="abox"> |
| | | <avue-tree :data="treeData" :option="treeOption" @node-click="nodeClick"/> |
| | | <avue-tree ref="tree" :data="treeData" :option="treeOption" @node-click="nodeClick"/> |
| | | </div> |
| | | </basic-container> |
| | | </el-scrollbar> |
| | |
| | | <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-button> |
| | | <el-button v-if="userInfo.role_name.includes('admin')" |
| | | icon="el-icon-coordinate" |
| | | plain |
| | | size="small" |
| | | type="info" |
| | | @click="handleLock">账号解封 |
| | | icon="el-icon-coordinate" |
| | | plain |
| | | size="small" |
| | | type="info" |
| | | @click="handleLock">账号解封 |
| | | </el-button> |
| | | <el-button v-if="userInfo.role_name.includes('admin')" |
| | | icon="el-icon-upload2" |
| | | plain |
| | | size="small" |
| | | type="success" |
| | | @click="handleImport">导入 |
| | | icon="el-icon-upload2" |
| | | plain |
| | | size="small" |
| | | type="success" |
| | | @click="handleImport">导入 |
| | | </el-button> |
| | | <el-button v-if="userInfo.role_name.includes('admin')" |
| | | icon="el-icon-download" |
| | | plain |
| | | size="small" |
| | | type="warning" |
| | | @click="handleExport">导出 |
| | | icon="el-icon-download" |
| | | plain |
| | | size="small" |
| | | type="warning" |
| | | @click="handleExport">导出 |
| | | </el-button> |
| | | <el-button size="small" |
| | | type="warning" |
| | | icon="el-icon-setting" |
| | | @click="updateUserStatus"> |
| | | 账号停/启用 |
| | | </el-button> |
| | | </template> |
| | | <template slot="tenantName" |
| | |
| | | </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"> |
| | | <el-button @click="roleBox = false">取 消</el-button> |
| | | <el-button type="primary" |
| | |
| | | </el-dialog> |
| | | <!-- 设置密码策略弹出框--> |
| | | <el-dialog |
| | | :before-close="handleClose" |
| | | :visible.sync="passVisible" |
| | | 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> |
| | | </basic-container> |
| | | </el-col> |
| | |
| | | updatePlatform, |
| | | add, |
| | | grant, |
| | | resetPassword, unlock |
| | | resetPassword, |
| | | unlock, |
| | | updateUserStatus |
| | | } from "@/api/system/user"; |
| | | import {exportBlob} from "@/api/common"; |
| | | import {getDeptTree, getDeptLazyTree} from "@/api/system/dept"; |
| | |
| | | } |
| | | }; |
| | | return { |
| | | tenantId:'', |
| | | form: {}, |
| | | seoptions: [], |
| | | sevalue:"", |
| | |
| | | tip: false, |
| | | searchShow: true, |
| | | searchMenuSpan: 6, |
| | | columnBtn:false, |
| | | border: true, |
| | | index: true, |
| | | selection: true, |
| | | viewBtn: true, |
| | | dialogType: 'drawer', |
| | | dialogClickModal: false, |
| | | highlightCurrentRow: true, //行选中时高亮 |
| | | column: [ |
| | | { |
| | | label: "登录账号", |
| | |
| | | required: true, |
| | | message: "请选择用户平台", |
| | | trigger: "blur" |
| | | }] |
| | | }], |
| | | }, |
| | | { |
| | | label: "状态", |
| | | display: false, |
| | | sortable:true, |
| | | html:true, |
| | | prop: "userStatus", |
| | | formatter : function (row, column) { |
| | | return row.userStatus == 0 ? '<i class="el-icon-check" style="color: #32cd32;font-size: 20px;font-weight: 800"></i>' : '<i class="el-icon-close" style="color: #ff0000;font-size: 20px;font-weight: 800"></i>' |
| | | } |
| | | }, |
| | | ], |
| | | group: [ |
| | |
| | | trigger: "click" |
| | | }], |
| | | span: 24, |
| | | value:"" |
| | | }, |
| | | { |
| | | label: "登录账号", |
| | |
| | | label: "dictValue", |
| | | value: "dictKey" |
| | | }, |
| | | value:'1', |
| | | dataType: "number", |
| | | slot: true, |
| | | prop: "userType", |
| | |
| | | { |
| | | 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'}] |
| | |
| | | value: "id" |
| | | }, |
| | | rules: [{ |
| | | required: true, |
| | | required: false, |
| | | message: "请选择所属岗位", |
| | | trigger: "click" |
| | | }], |
| | |
| | | 'form.tenantId'() { |
| | | if (this.form.tenantId !== '' && this.initFlag) { |
| | | this.initData(this.form.tenantId); |
| | | console.log('this.form.tenantId',this.form.tenantId) |
| | | } |
| | | }, |
| | | 'excelForm.isCovered'() { |
| | |
| | | } |
| | | }, |
| | | methods: { |
| | | |
| | | // beOpen(done,type){ |
| | | // console.log(done,type) |
| | | // }, |
| | | // 用户停用启用状态 |
| | | /** 修改用户状态 */ |
| | | updateUserStatus(){ |
| | | let list = this.selectionList; |
| | | if(func.isEmpty(list)){ |
| | | this.$message({ |
| | | type: "warning", |
| | | message: "请至少选择一条用户数据!" |
| | | }); |
| | | return; |
| | | } |
| | | if(func.isAttrInconsistent(list,"userStatus")){ |
| | | this.$message({ |
| | | type: "warning", |
| | | message: "批量操作用户状态时,请选择用户状态一致的数据!" |
| | | }); |
| | | return; |
| | | } |
| | | let userIds = func.joinedString(list,"id"); |
| | | let status = list[0].userStatus == 1 ? true:false; |
| | | updateUserStatus(userIds,status).then(res=>{ |
| | | this.$message({ |
| | | type: "success", |
| | | message: "操作成功!" |
| | | }); |
| | | this.onLoad(this.page); |
| | | }) |
| | | }, |
| | | //esc取消键操作 |
| | | handleClose(done) { |
| | | /*handleClose(done) { |
| | | this.$confirm('确认关闭?') |
| | | .then(() => { |
| | | done(); |
| | |
| | | done(); |
| | | }); |
| | | |
| | | }, |
| | | },*/ |
| | | //点击配置密码策略 |
| | | handlepass(){ |
| | | if (this.selectionList.length === 0) { |
| | |
| | | }else { |
| | | this.passVisible=true; |
| | | } |
| | | console.log("selectionList",this.selectionList) |
| | | console.log(this.UserPwdstrategyVO) |
| | | }, |
| | | // 设置密码策略,传递下拉框的id和多选框的id |
| | | passhandle(){ |
| | |
| | | //要传递的id,一个是数组另一个是字符串 |
| | | this.UserPwdstrategyVO.userIds=this.selid; |
| | | this.UserPwdstrategyVO.pwdstrategyId=this.id |
| | | console.log("1",this.UserPwdstrategyVO) |
| | | console.log("2",this.UserPwdstrategyVO.userIds) |
| | | |
| | | //请求 |
| | | insert(this.UserPwdstrategyVO.userIds).then(()=>{ |
| | | insert(this.UserPwdstrategyVO).then(()=>{ |
| | | this.passVisible=false |
| | | this.$message({ |
| | | type: "success", |
| | |
| | | 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; |
| | | |
| | |
| | | }) |
| | | }, |
| | | 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; |
| | |
| | | } |
| | | }); |
| | | } |
| | | 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; |
| | |
| | | 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; |