refactor(系统设置): 系统菜单用户列表批量操作

This commit is contained in:
shiziyuan9527 2021-06-25 18:57:40 +08:00 committed by 刘瑞斌
parent 6743dac777
commit f562d3eb25
10 changed files with 570 additions and 110 deletions

View File

@ -1,5 +1,5 @@
package io.metersphere.commons.constants;
public enum BatchProcessUserInfoType {
ADD_WORKSPACE,ADD_USER_ROLE
ADD_WORKSPACE,ADD_USER_ROLE, ADD_PROJECT, ADD_USER_GROUP
}

View File

@ -31,6 +31,11 @@ public class GroupController {
return groupService.getGroupList(request);
}
@GetMapping("/get/all")
public List<Group> getAllGroup() {
return groupService.getAllGroup();
}
@PostMapping("/get")
@RequiresPermissions(PermissionConstants.SYSTEM_GROUP_READ)
public List<Group> getGroupByType(@RequestBody EditGroupRequest request) {
@ -96,4 +101,9 @@ public class GroupController {
public List<Organization> getOrganization(@PathVariable String userId) {
return groupService.getOrganization(userId);
}
@GetMapping("/{type}/{id}")
public List<?> getResource(@PathVariable String type, @PathVariable String id) {
return groupService.getResource(type, id);
}
}

View File

@ -102,4 +102,11 @@ public class WorkspaceController {
public void updateOrgMember(@RequestBody WorkspaceMemberDTO memberDTO) {
workspaceService.updateWorkspaceMember(memberDTO);
}
@GetMapping("/list/{orgId}")
public List<Workspace> getWorkspaceByOrgId(@PathVariable String orgId) {
WorkspaceRequest request = new WorkspaceRequest();
request.setOrganizationId(orgId);
return workspaceService.getWorkspaceList(request);
}
}

View File

@ -4,10 +4,7 @@ import com.alibaba.fastjson.JSON;
import com.github.pagehelper.Page;
import com.github.pagehelper.PageHelper;
import io.metersphere.base.domain.*;
import io.metersphere.base.mapper.GroupMapper;
import io.metersphere.base.mapper.OrganizationMapper;
import io.metersphere.base.mapper.UserGroupMapper;
import io.metersphere.base.mapper.UserGroupPermissionMapper;
import io.metersphere.base.mapper.*;
import io.metersphere.base.mapper.ext.ExtGroupMapper;
import io.metersphere.base.mapper.ext.ExtUserGroupMapper;
import io.metersphere.commons.constants.UserGroupConstants;
@ -24,6 +21,7 @@ import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.session.ExecutorType;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.poi.ss.formula.functions.T;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@ -54,6 +52,10 @@ public class GroupService {
private OrganizationService organizationService;
@Resource
private OrganizationMapper organizationMapper;
@Resource
private WorkspaceMapper workspaceMapper;
@Resource
private ProjectMapper projectMapper;
private static final Map<String, List<String>> map = new HashMap<String, List<String>>(4){{
put(UserGroupType.SYSTEM, Arrays.asList(UserGroupType.SYSTEM, UserGroupType.ORGANIZATION, UserGroupType.WORKSPACE, UserGroupType.PROJECT));
@ -341,4 +343,54 @@ public class GroupService {
public List<Group> getProjectMemberGroups(String projectId, String userId) {
return extUserGroupMapper.getProjectMemberGroups(projectId, userId);
}
public List<Group> getAllGroup() {
return groupMapper.selectByExample(new GroupExample());
}
public List<? extends Object> getResource(String type, String groupId) {
List<T> resource = new ArrayList<>();
Group group = groupMapper.selectByPrimaryKey(groupId);
String orgId = group.getScopeId();
if (!StringUtils.equals("global", orgId)) {
Organization organization = organizationMapper.selectByPrimaryKey(orgId);
if (organization == null) {
return resource;
}
}
if (StringUtils.equals(UserGroupType.ORGANIZATION, type)) {
OrganizationExample organizationExample = new OrganizationExample();
OrganizationExample.Criteria criteria = organizationExample.createCriteria();
if (!StringUtils.equals(orgId, "global")) {
criteria.andIdEqualTo(orgId);
}
return organizationMapper.selectByExample(organizationExample);
}
if (StringUtils.equals(UserGroupType.WORKSPACE, type)) {
WorkspaceExample workspaceExample = new WorkspaceExample();
WorkspaceExample.Criteria criteria = workspaceExample.createCriteria();
if (!StringUtils.equals(orgId, "global")) {
criteria.andOrganizationIdEqualTo(orgId);
}
return workspaceMapper.selectByExample(workspaceExample);
}
if (StringUtils.equals(UserGroupType.PROJECT, type)) {
ProjectExample projectExample = new ProjectExample();
ProjectExample.Criteria pc = projectExample.createCriteria();
WorkspaceExample workspaceExample = new WorkspaceExample();
WorkspaceExample.Criteria criteria = workspaceExample.createCriteria();
if (!StringUtils.equals(orgId, "global")) {
criteria.andOrganizationIdEqualTo(orgId);
List<Workspace> workspaces = workspaceMapper.selectByExample(workspaceExample);
List<String> list = workspaces.stream().map(Workspace::getId).collect(Collectors.toList());
pc.andWorkspaceIdIn(list);
}
return projectMapper.selectByExample(projectExample);
}
return resource;
}
}

View File

@ -909,28 +909,105 @@ public class UserService {
* @param request
*/
public void batchProcessUserInfo(UserBatchProcessRequest request) {
List<String> userIdList = this.selectIdByUserRequest(request);
String batchType = request.getBatchType();
for (String userID : userIdList) {
Map<String, List<String>> roleResourceIdMap = new HashMap<>();
if (StringUtils.equals(BatchProcessUserInfoType.ADD_WORKSPACE.name(), batchType)) {
//添加工作空间时默认赋予只读用户权限
String userRole = RoleConstants.TEST_VIEWER;
List<String> workspaceID = request.getBatchProcessValue();
if (workspaceID != null && !workspaceID.isEmpty()) {
roleResourceIdMap.put(userRole, workspaceID);
if (StringUtils.equals(BatchProcessUserInfoType.ADD_PROJECT.name(), batchType)) {
batchAddUserToProject(request);
} else {
batchAddUserGroup(request);
}
} else if (StringUtils.equals(BatchProcessUserInfoType.ADD_USER_ROLE.name(), batchType)) {
roleResourceIdMap = this.genRoleResourceMap(request.getBatchProcessValue());
}
if (!roleResourceIdMap.isEmpty()) {
UserRoleExample userRoleExample = new UserRoleExample();
userRoleExample.createCriteria().andUserIdEqualTo(userID);
List<UserRole> userRoles = userRoleMapper.selectByExample(userRoleExample);
UserRequest user = this.convert2UserRequest(userID, roleResourceIdMap, userRoles);
this.addUserWorkspaceAndRole(user, userRoles);
private void batchAddUserGroup(UserBatchProcessRequest request) {
List<String> userIds = this.selectIdByUserRequest(request);
// groupId+resourceId e.g. admin+none
List<String> groupResources = request.getBatchProcessValue();
Map<String, List<String>> sourceMap = new HashMap<>();
for (String groupResource : groupResources) {
String[] split = groupResource.split("\\+");
String groupId = split[0];
String sourceId = split[1];
if (sourceMap.get(groupId) == null) {
List<String> list = new ArrayList<>();
list.add(sourceId);
sourceMap.put(groupId, list);
} else {
sourceMap.get(groupId).add(sourceId);
}
}
for (String userId : userIds) {
Set<String> set = sourceMap.keySet();
for (String group : set) {
Group gp = groupMapper.selectByPrimaryKey(group);
if (gp != null) {
if (StringUtils.equals(UserGroupType.SYSTEM, gp.getType())) {
UserGroupExample userGroupExample = new UserGroupExample();
userGroupExample.createCriteria().andGroupIdEqualTo(group).andUserIdEqualTo(userId);
List<UserGroup> userGroups = userGroupMapper.selectByExample(userGroupExample);
if (CollectionUtils.isEmpty(userGroups)) {
UserGroup userGroup = new UserGroup();
userGroup.setId(UUID.randomUUID().toString());
userGroup.setGroupId(group);
userGroup.setSourceId("system");
userGroup.setUserId(userId);
userGroup.setUpdateTime(System.currentTimeMillis());
userGroup.setCreateTime(System.currentTimeMillis());
userGroupMapper.insertSelective(userGroup);
}
} else {
// 组织工作空间项目
UserGroupExample userGroupExample = new UserGroupExample();
userGroupExample.createCriteria().andGroupIdEqualTo(group).andUserIdEqualTo(userId);
List<UserGroup> userGroups = userGroupMapper.selectByExample(userGroupExample);
List<String> sourceIds = userGroups.stream().map(UserGroup::getSourceId).collect(Collectors.toList());
List<String> list = sourceMap.get(group);
list.removeAll(sourceIds);
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
UserGroupMapper mapper = sqlSession.getMapper(UserGroupMapper.class);
for (String sourceId : list) {
UserGroup userGroup = new UserGroup();
userGroup.setId(UUID.randomUUID().toString());
userGroup.setUserId(userId);
userGroup.setGroupId(group);
userGroup.setSourceId(sourceId);
userGroup.setCreateTime(System.currentTimeMillis());
userGroup.setUpdateTime(System.currentTimeMillis());
mapper.insertSelective(userGroup);
}
sqlSession.flushStatements();
}
}
}
}
}
private void batchAddUserToProject(UserBatchProcessRequest request) {
List<String> userIds = this.selectIdByUserRequest(request);
String toSetGroup = UserGroupConstants.READ_ONLY;
List<String> projectIds = request.getBatchProcessValue();
for (String userId : userIds) {
UserGroupExample userGroupExample = new UserGroupExample();
userGroupExample
.createCriteria()
.andUserIdEqualTo(userId)
.andGroupIdEqualTo(toSetGroup);
List<UserGroup> userGroups = userGroupMapper.selectByExample(userGroupExample);
List<String> exist = userGroups.stream().map(UserGroup::getSourceId).collect(Collectors.toList());
projectIds.removeAll(exist);
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
UserGroupMapper mapper = sqlSession.getMapper(UserGroupMapper.class);
for (String projectId : projectIds) {
UserGroup userGroup = new UserGroup();
userGroup.setId(UUID.randomUUID().toString());
userGroup.setUserId(userId);
userGroup.setGroupId(toSetGroup);
userGroup.setSourceId(projectId);
userGroup.setCreateTime(System.currentTimeMillis());
userGroup.setUpdateTime(System.currentTimeMillis());
mapper.insertSelective(userGroup);
}
sqlSession.flushStatements();
}
}
private List<String> selectIdByUserRequest(UserBatchProcessRequest request) {

View File

@ -5,24 +5,24 @@
<ms-table-header :create-permission="['ORGANIZATION_USER:READ+CREATE']" :condition.sync="condition" @search="initTableData" @create="create"
:create-tip="$t('member.create')" :title="$t('commons.member')"/>
</template>
<el-table border class="adjust-table ms-select-all-fixed" :data="tableData" style="width: 100%"
<el-table border class="adjust-table" :data="tableData" style="width: 100%"
@select-all="handleSelectAll"
@select="handleSelect"
:height="screenHeight"
ref="userTable">
<el-table-column type="selection" width="50"/>
<ms-table-header-select-popover v-show="total>0"
:page-size="pageSize>total?total:pageSize"
:total="total"
:select-data-counts="selectDataCounts"
:table-data-count-in-page="tableData.length"
@selectPageAll="isSelectDataAll(false)"
@selectAll="isSelectDataAll(true)"/>
<el-table-column v-if="!referenced" width="30" min-width="30" :resizable="false" align="center">
<template v-slot:default="scope">
<show-more-btn :is-show="scope.row.showMore" :buttons="buttons" :size="selectDataCounts"/>
</template>
</el-table-column>
<!-- <ms-table-header-select-popover v-show="total>0"-->
<!-- :page-size="pageSize>total?total:pageSize"-->
<!-- :total="total"-->
<!-- :select-data-counts="selectDataCounts"-->
<!-- :table-data-count-in-page="tableData.length"-->
<!-- @selectPageAll="isSelectDataAll(false)"-->
<!-- @selectAll="isSelectDataAll(true)"/>-->
<!-- <el-table-column v-if="!referenced" width="30" min-width="30" :resizable="false" align="center">-->
<!-- <template v-slot:default="scope">-->
<!-- <show-more-btn :is-show="scope.row.showMore" :buttons="buttons" :size="selectDataCounts"/>-->
<!-- </template>-->
<!-- </el-table-column>-->
<el-table-column prop="id" label="ID"/>
<el-table-column prop="name" :label="$t('commons.username')"/>

View File

@ -98,7 +98,8 @@
</span>
</el-dialog>
<user-import ref="userImportDialog" @refreshAll="search"></user-import>
<user-cascader :lable="batchAddLable" :title="batchAddTitle" @confirm="cascaderConfirm" ref="cascaderDialog"></user-cascader>
<project-cascader :title="batchAddTitle" @confirm="cascaderConfirm" ref="cascaderDialog"></project-cascader>
<group-cascader :title="'批量添加用户组'" @confirm="cascaderConfirm" ref="groupCascaderDialog"></group-cascader>
<edit-user ref="editUser" @refresh="search"/>
</div>
</template>
@ -112,7 +113,7 @@ import MsDialogFooter from "../../common/components/MsDialogFooter";
import MsTableOperatorButton from "../../common/components/MsTableOperatorButton";
import {getCurrentProjectID, listenGoBack, removeGoBackListener} from "@/common/js/utils";
import MsRolesTag from "../../common/components/MsRolesTag";
import {getCurrentUser} from "../../../../common/js/utils";
import {getCurrentUser} from "@/common/js/utils";
import {PHONE_REGEX} from "@/common/js/regex";
import UserImport from "@/business/components/settings/system/components/UserImport";
import MsTableHeaderSelectPopover from "@/business/components/common/components/table/MsTableHeaderSelectPopover";
@ -126,10 +127,13 @@ import {
import UserCascader from "@/business/components/settings/system/components/UserCascader";
import ShowMoreBtn from "@/business/components/track/case/components/ShowMoreBtn";
import EditUser from "@/business/components/settings/system/EditUser";
import ProjectCascader from "@/business/components/settings/system/components/ProjectCascader";
import GroupCascader from "@/business/components/settings/system/components/GroupCascader";
export default {
name: "MsUser",
components: {
GroupCascader,
EditUser,
MsCreateBox,
MsTablePagination,
@ -141,6 +145,7 @@ export default {
UserImport,
MsTableHeaderSelectPopover,
UserCascader,
ProjectCascader,
ShowMoreBtn
},
inject: [
@ -163,9 +168,8 @@ export default {
createPath: '/user/special/add',
updatePath: '/user/special/update',
editPasswordPath: '/user/special/password',
batchAddLable: this.$t('project.please_choose_workspace'),
batchAddTitle: this.$t('project.batch_choose_workspace'),
batchAddWorkspaceOptions:[],
batchAddTitle: "批量选择项目",
batchAddProjectOptions:[],
batchAddUserRoleOptions:[],
result: {},
currentUserId: '',
@ -191,12 +195,12 @@ export default {
checkPasswordForm: {},
ruleForm: {},
buttons: [
// {
// name: this.$t('user.button.add_workspace_batch'), handleClick: this.addWorkspaceBatch
// },
// {
// name: this.$t('user.button.add_user_role_batch'), handleClick: this.addUserRoleBatch
// }
{
name: "批量添加到项目", handleClick: this.addToProjectBatch
},
{
name: "批量添加用户组", handleClick: this.addUserGroupBatch
}
],
rule: {
id: [
@ -338,7 +342,7 @@ export default {
},
search() {
this.selectRows = new Set();
// this.condition.selectAll = false;
this.condition.selectAll = false;
this.result = this.$post(this.buildPagePath(this.queryPath), this.condition, response => {
let data = response.data;
this.total = data.itemCount;
@ -418,41 +422,6 @@ export default {
importUserDialogOpen(){
this.$refs.userImportDialog.open();
},
addRole(validForm) {
this.$refs[validForm].validate(valid => {
if (valid) {
let roleInfo = {};
roleInfo.selects = [];
let ids = this.form.roles.map(r => r.id);
ids.forEach(id => {
roleInfo.selects.push(id);
})
let roles = this.form.roles;
roles.push(roleInfo);
if (this.form.roles.length > this.userRole.length - 1) {
this.btnAddRole = true;
}
} else {
return false;
}
})
},
initWorkspaceBatchProcessDataStruct(isShow){
this.$get("/user/getWorkspaceDataStruct/All", response => {
this.batchAddWorkspaceOptions = response.data;
if(isShow){
this.$refs.cascaderDialog.open('ADD_WORKSPACE',this.batchAddWorkspaceOptions);
}
});
},
initRoleBatchProcessDataStruct(isShow){
this.$get("/user/getUserRoleDataStruct/All", response => {
this.batchAddUserRoleOptions = response.data;
if(isShow){
this.$refs.cascaderDialog.open('ADD_USER_ROLE',this.batchAddUserRoleOptions);
}
});
},
handleSelectAll(selection) {
_handleSelectAll(this, selection, this.tableData, this.selectRows, this.condition);
setUnSelectIds(this.tableData, this.condition, this.selectRows);
@ -468,25 +437,18 @@ export default {
isSelectDataAll(data) {
this.condition.selectAll = data;
setUnSelectIds(this.tableData, this.condition, this.selectRows);
this.condition.unSelectIds = [];
this.selectDataCounts = getSelectDataCounts(this.condition, this.total, this.selectRows);
toggleAllSelection(this.$refs.userTable, this.tableData, this.selectRows);
},
addWorkspaceBatch(){
if(this.batchAddWorkspaceOptions.length == 0){
this.initWorkspaceBatchProcessDataStruct(true);
}else{
this.$refs.cascaderDialog.open('ADD_WORKSPACE',this.batchAddWorkspaceOptions);
}
addToProjectBatch(){
this.$refs.cascaderDialog.open('ADD_PROJECT',this.batchAddProjectOptions);
},
addUserRoleBatch(){
if(this.batchAddUserRoleOptions.length == 0){
this.initRoleBatchProcessDataStruct(true);
}else{
this.$refs.cascaderDialog.open('ADD_USER_ROLE',this.batchAddUserRoleOptions);
}
addUserGroupBatch(){
this.$refs.groupCascaderDialog.open('ADD_USER_GROUP',this.batchAddUserRoleOptions);
},
cascaderConfirm(batchProcessTypeParam,selectValueArr){
if(selectValueArr.length == 0){
cascaderConfirm(batchProcessTypeParam, selectValueArr){
if(selectValueArr.length === 0){
this.$success(this.$t('commons.modify_success'));
}
let params = {};
@ -496,7 +458,8 @@ export default {
this.$post('/user/special/batchProcessUserInfo', params, () => {
this.$success(this.$t('commons.modify_success'));
this.search();
this.$refs.cascaderDialog.close();
batchProcessTypeParam === "ADD_PROJECT" ? this.$refs.cascaderDialog.close() :
this.$refs.groupCascaderDialog.close();
});
},
buildBatchParam(param) {

View File

@ -0,0 +1,174 @@
<template>
<el-dialog class="user-cascade" :title="title" :visible.sync="dialogVisible"
@close="close">
<div class="block">
<el-form :model="ruleForm" :rules="rules" ref="ruleForm">
<el-form-item prop="project" label-width="0px">
<el-cascader-panel :props="props"
popper-class="ms-cascade"
:emitPath="true"
ref="cascadeSelector"
:key="isResourceShow"
clearable>
</el-cascader-panel>
</el-form-item>
</el-form>
</div>
<span slot="footer" class="dialog-footer">
<ms-dialog-footer
@cancel="close()"
@confirm="confirm()"/>
</span>
</el-dialog>
</template>
<script>
import ElUploadList from "element-ui/packages/upload/src/upload-list";
import MsTableButton from '../../../../components/common/components/MsTableButton';
import {listenGoBack, removeGoBackListener} from "@/common/js/utils";
import MsDialogFooter from "@/business/components/common/components/MsDialogFooter";
import {GROUP_SYSTEM} from "@/common/js/constants";
import {USER_GROUP_SCOPE} from "@/common/js/table-constants";
export default {
name: "GroupCascader",
components: {ElUploadList, MsTableButton, MsDialogFooter},
data() {
let validateSelect = (rule, value, callback) => {
let checkNodes = this.$refs.cascadeSelector.getCheckedNodes(true);
if (checkNodes.length === 0) {
callback(new Error("请选择项目"));
}
callback();
};
const self = this
return {
ruleForm: {
project: '',
},
rules: {
project: [
{validator: validateSelect, message: "请选择项目", trigger: 'change'}
],
},
selectedIds: [],
isResourceShow: 0,
props: {
multiple: true,
lazy: true,
value: 'id',
label: 'showLabel',
lazyLoad(node, resolve) {
const {level} = node;
if (level === 0) {
self.getGroup(resolve);
} else if (level === 1) {
self.getResource(node, resolve);
} else {
resolve([]);
}
}
},
dialogVisible: false,
isLoading: false,
batchProcessType: '',
options: [],
};
},
props: {
title: {
type: String,
default: ''
}
},
methods: {
close() {
removeGoBackListener(this.close);
this.dialogVisible = false;
this.selectedIds = [];
++this.isResourceShow;
this.options = [];
this.$refs['ruleForm'].resetFields();
},
open(batchProcessType, optionsParam) {
listenGoBack(this.close);
this.dialogVisible = true;
this.batchProcessType = batchProcessType;
this.options = optionsParam;
if (this.batchProcessType === 'ADD_PROJECT') {
this.rules.project[0].message = "请选择项目";
} else {
this.rules.project[0].message = "请选择用户组";
}
},
confirm() {
this.$refs.ruleForm.validate((valid) => {
if (valid) {
let checkNodes = this.$refs.cascadeSelector.getCheckedNodes(true);
let selectValueArr = [];
for (let node of checkNodes) {
let idString = "";
if (node.parent) {
idString = node.parent.value + "+" + node.value;
} else {
idString = node.value + "+none";
}
selectValueArr.push(idString);
}
this.$emit('confirm', this.batchProcessType, selectValueArr)
} else {
return false;
}
});
},
getGroup(resolve) {
this.$get("user/group/get/all", res => {
let data = res.data ? res.data : [];
if (data.length > 0) {
data.forEach(d => {
d.leaf = d.type === GROUP_SYSTEM;
d.showLabel = "[" + USER_GROUP_SCOPE[d.type] + "] " + d.name;
});
}
resolve(data);
})
},
getResource(node, resolve) {
let type = node.data.type;
let {value} = node;
this.$get("user/group/" + type + "/" + value, res => {
let data = res.data ? res.data : [];
if (data.length > 0) {
data.forEach(d => {
d.leaf = true;
d.showLabel = d.name;
});
}
resolve(data);
})
}
}
}
</script>
<style>
</style>
<style scoped>
.user-cascade >>> .el-dialog {
width: 700px;
}
.user-cascade >>> .el-dialog__body {
padding: 5px 20px;
}
/deep/ .el-form-item__content {
margin-left: 0;
}
/deep/ .el-cascader-menu__wrap {
height: 300px;
width: 340px;
}
</style>

View File

@ -0,0 +1,177 @@
<template>
<el-dialog class="user-cascade" :title="title" :visible.sync="dialogVisible"
@close="close">
<div class="block">
<el-alert
title="默认为成员添加只读用户组(系统)"
type="info"
show-icon
:closable="false"
style="margin-bottom: 10px;"
>
</el-alert>
<el-form :model="ruleForm" :rules="rules" ref="ruleForm">
<el-form-item prop="project" label-width="0px">
<el-cascader-panel :props="props"
popper-class="ms-cascade"
v-model="selectedIds"
ref="cascadeSelector"
:key="isResourceShow"
clearable>
</el-cascader-panel>
</el-form-item>
</el-form>
</div>
<span slot="footer" class="dialog-footer">
<ms-dialog-footer
@cancel="close()"
@confirm="confirm()"/>
</span>
</el-dialog>
</template>
<script>
import ElUploadList from "element-ui/packages/upload/src/upload-list";
import MsTableButton from '../../../../components/common/components/MsTableButton';
import {listenGoBack, removeGoBackListener} from "@/common/js/utils";
import MsDialogFooter from "@/business/components/common/components/MsDialogFooter";
export default {
name: "User2ProjectCascader",
components: {ElUploadList, MsTableButton, MsDialogFooter},
data() {
let validateSelect = (rule, value, callback) => {
let checkNodes = this.$refs.cascadeSelector.getCheckedNodes(true);
if (checkNodes.length === 0) {
callback(new Error("请选择项目"));
}
callback();
};
const self = this
return {
ruleForm: {
project: '',
},
rules: {
project: [
{validator: validateSelect, message: "请选择项目", trigger: 'change'}
],
},
selectedIds: [],
isResourceShow: 0,
props: {
multiple: true,
lazy: true,
value: 'id',
label: 'name',
lazyLoad(node, resolve) {
const {level, value} = node;
if (level === 0) {
self.getOrganization(resolve);
} else if (level === 1) {
self.getWorkspace(value, resolve);
} else if (level === 2) {
self.getProject(value, resolve);
} else {
resolve([]);
}
}
},
dialogVisible: false,
isLoading: false,
batchProcessType: '',
options: [],
};
},
props: {
title: {
type: String,
default: ''
}
},
methods: {
close() {
removeGoBackListener(this.close);
this.dialogVisible = false;
this.selectedIds = [];
++this.isResourceShow;
this.options = [];
this.$refs['ruleForm'].resetFields();
},
open(batchProcessType, optionsParam) {
listenGoBack(this.close);
this.dialogVisible = true;
this.batchProcessType = batchProcessType;
this.options = optionsParam;
if (this.batchProcessType === 'ADD_PROJECT') {
this.rules.project[0].message = "请选择项目";
} else {
this.rules.project[0].message = "请选择用户组";
}
},
confirm() {
this.$refs.ruleForm.validate((valid) => {
if (valid) {
let checkNodes = this.$refs.cascadeSelector.getCheckedNodes(true);
let selectValueArr = [];
for (let i = 0; i < checkNodes.length; i++) {
selectValueArr.push(checkNodes[i].value);
}
this.$emit('confirm', this.batchProcessType, selectValueArr)
} else {
return false;
}
});
},
getOrganization(resolve) {
this.$get("organization/list", res => {
let data = res.data ? res.data : [];
if (data.length > 0) {
data.forEach(d => d.leaf = false);
}
resolve(data);
})
},
getWorkspace(condition, resolve) {
this.$get("workspace/list/" + condition, res => {
let data = res.data ? res.data : [];
if (data.length > 0) {
data.forEach(d => d.leaf = false);
}
resolve(data);
})
},
getProject(condition, resolve) {
this.$get("project/listAll/" + condition, res => {
let data = res.data ? res.data : [];
if (data.length > 0) {
data.forEach(d => d.leaf = true);
}
resolve(data);
})
}
}
}
</script>
<style>
</style>
<style scoped>
.user-cascade >>> .el-dialog {
width: 750px;
}
.user-cascade >>> .el-dialog__body {
padding: 5px 20px;
}
/deep/ .el-form-item__content {
margin-left: 0;
}
/deep/ .el-cascader-menu__wrap {
height: 300px;
width: 250px;
}
</style>

View File

@ -5,25 +5,25 @@
<ms-table-header :create-permission="['WORKSPACE_USER:READ+CREATE']" :condition.sync="condition" @search="initTableData" @create="create"
:create-tip="$t('member.create')" :title="$t('commons.member')"/>
</template>
<el-table border class="adjust-table ms-select-all-fixed" :data="tableData" style="width: 100%"
<el-table border class="adjust-table" :data="tableData" style="width: 100%"
@select-all="handleSelectAll"
@select="handleSelect"
:height="screenHeight"
ref="userTable">
<el-table-column type="selection" width="50"/>
<ms-table-header-select-popover v-show="total>0"
:page-size="pageSize>total?total:pageSize"
:total="total"
:select-data-counts="selectDataCounts"
:table-data-count-in-page="tableData.length"
@selectPageAll="isSelectDataAll(false)"
@selectAll="isSelectDataAll(true)"/>
<el-table-column v-if="!referenced" width="30" min-width="30" :resizable="false" align="center">
<template v-slot:default="scope">
<show-more-btn :is-show="scope.row.showMore" :buttons="buttons" :size="selectDataCounts"/>
</template>
</el-table-column>
<!-- <ms-table-header-select-popover v-show="total>0"-->
<!-- :page-size="pageSize>total?total:pageSize"-->
<!-- :total="total"-->
<!-- :select-data-counts="selectDataCounts"-->
<!-- :table-data-count-in-page="tableData.length"-->
<!-- @selectPageAll="isSelectDataAll(false)"-->
<!-- @selectAll="isSelectDataAll(true)"/>-->
<!-- <el-table-column v-if="!referenced" width="30" min-width="30" :resizable="false" align="center">-->
<!-- <template v-slot:default="scope">-->
<!-- <show-more-btn :is-show="scope.row.showMore" :buttons="buttons" :size="selectDataCounts"/>-->
<!-- </template>-->
<!-- </el-table-column>-->
<el-table-column prop="id" label="ID"/>
<el-table-column prop="name" :label="$t('commons.username')"/>