【7.3.3】用户下拉列表选择-根据当前用户权限获取管理的用户信息

pull/47/head
ye_star 2023-02-21 21:40:08 +08:00
parent 9d4c5511b6
commit 2eca3b47ed
3 changed files with 59 additions and 2 deletions

View File

@ -272,6 +272,21 @@ public class SysUserController {
return new SuccessResponseData<>(sysUserService.selector(sysUserRequest));
}
/**
*
* <p>
*
*
* @param sysUserRequest name ()
* @return
* @author yx
* @date 2023/02/21 09:49
*/
@GetResource(name = "系统用户_选择器(权限)", path = "/sysUser/selectorByAuthority", requiredPermission = false)
public ResponseData<List<SimpleDict>> selectorByAuthority(SysUserRequest sysUserRequest) {
return new SuccessResponseData<>(sysUserService.selectorByAuthority(sysUserRequest));
}
/**
*
* <p>

View File

@ -230,6 +230,13 @@ public interface SysUserService extends IService<SysUser>, UserServiceApi {
*/
List<SimpleDict> selector(SysUserRequest sysUserRequest);
/**
* -
*
*
*/
List<SimpleDict> selectorByAuthority(SysUserRequest request);
/**
*
*

View File

@ -91,6 +91,7 @@ import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections4.CollectionUtils;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@ -601,6 +602,34 @@ public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser> impl
return this.selectUserList(sysUserRequest, false);
}
@Override
public List<SimpleDict> selectorByAuthority(SysUserRequest request) {
//获取用户数据权限
Long userId = ObjectUtil.isNull(request.getUserId()) ? LoginContext.me().getLoginUser().getUserId() : request.getUserId();
DataScopeDTO dataScope = dataScopeApi.getDataScope(userId);
// 塞入用户数据范围
request.setUserScopeIds(dataScope.getUserIds());
LambdaQueryWrapper<SysUser> wrapper = this.createWrapper(request);
// 排除超级管理员
wrapper.ne(SysUser::getSuperAdminFlag, YesOrNotEnum.Y.getCode());
// 查询id name account
wrapper.select(SysUser::getRealName, SysUser::getUserId, SysUser::getAccount);
List<SysUser> list = this.list(wrapper);
ArrayList<SimpleDict> results = new ArrayList<>();
for (SysUser sysUser : list) {
SimpleDict simpleDict = new SimpleDict();
simpleDict.setId(sysUser.getUserId());
simpleDict.setName(sysUser.getRealName());
simpleDict.setCode(sysUser.getAccount());
results.add(simpleDict);
}
return results;
}
@Override
public List<SimpleDict> selectorWithAdmin(SysUserRequest sysUserRequest) {
return this.selectUserList(sysUserRequest, true);
@ -1046,11 +1075,17 @@ public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser> impl
queryWrapper.eq(ObjectUtil.isNotEmpty(sysUserRequest.getUserId()), SysUser::getUserId, sysUserRequest.getUserId());
queryWrapper.like(ObjectUtil.isNotEmpty(sysUserRequest.getAccount()), SysUser::getAccount, sysUserRequest.getAccount());
queryWrapper.like(ObjectUtil.isNotEmpty(sysUserRequest.getRealName()), SysUser::getRealName, sysUserRequest.getRealName());
queryWrapper.in(CollectionUtils.isNotEmpty(sysUserRequest.getUserScopeIds()), SysUser::getUserId, sysUserRequest.getUserScopeIds());
// 根据text查询
if (ObjectUtil.isNotEmpty(sysUserRequest.getSearchText())) {
queryWrapper.like(SysUser::getAccount, sysUserRequest.getSearchText()).or().like(SysUser::getRealName, sysUserRequest.getSearchText()).or()
.like(SysUser::getNickName, sysUserRequest.getSearchText());
queryWrapper.and(wrapper -> wrapper.like(SysUser::getAccount, sysUserRequest.getSearchText())
// 姓名
.or().like(SysUser::getRealName, sysUserRequest.getSearchText())
// 昵称
.or().like(SysUser::getNickName, sysUserRequest.getSearchText())
// 手机号
.or().like(SysUser::getPhone, sysUserRequest.getSearchText()));
}
return queryWrapper;