|
@@ -52,6 +52,7 @@ import javax.servlet.http.HttpServletResponse;
|
|
|
import javax.validation.ConstraintViolationException;
|
|
|
import javax.validation.Valid;
|
|
|
import javax.validation.Validator;
|
|
|
+import javax.validation.constraints.NotNull;
|
|
|
import java.io.File;
|
|
|
import java.io.IOException;
|
|
|
import java.util.*;
|
|
@@ -167,44 +168,52 @@ public class UserController {
|
|
|
queryWrapper.isNull("a.is_admin");
|
|
|
if (ObjectUtil.isNotEmpty(userDTO)){
|
|
|
if (ObjectUtil.isNotEmpty(userDTO.getCompanyDTO()) && ObjectUtil.isNotEmpty(userDTO.getOfficeDTO())) {
|
|
|
- // 当不是精确的部门查询时,再添加下面的筛选条件
|
|
|
- if ((StringUtils.isNotBlank(userDTO.getCompanyDTO().getId()) && StringUtils.isBlank(userDTO.getOfficeDTO().getId()))
|
|
|
- || "true".equals(userDTO.getSelectAll())) {
|
|
|
- // officeDTO.id是空,companyDTO.id不是空的话,说明前端组件点击的集团来进行查询
|
|
|
- // selectAll为‘true’的话,说明前端没有选择集团或者部门查询,这个时候要展示全部人员
|
|
|
- // 根据当前用户的部门id找到此部门的ids
|
|
|
- String ids = officeService.getById(UserUtils.getCurrentUserDTO().getOfficeDTO().getId()).getParentIds();
|
|
|
- // 根据ids分隔后的index[2],找到当前用户的所属公司id
|
|
|
- String companyId = null;
|
|
|
- String[] split = ids.split(",");
|
|
|
- // split.length大于2,说明当前登录人所属部门是普通部门,展示部分人员信息
|
|
|
- // 否则,当前登录人所属公共类部门(忘了叫什么类部门了,就是总经办那种部门),展示全部人员信息
|
|
|
- if(split.length>2){
|
|
|
- companyId = split[2];
|
|
|
- // 根据公司id,找到此公司下的所有部门
|
|
|
- List<Office> officeList = officeService.list(new QueryWrapper<Office>().lambda().eq(Office::getParentId, companyId));
|
|
|
- Set officeIdSet = new HashSet();
|
|
|
- for (Office office : officeList) {
|
|
|
- if(StringUtils.isNotBlank(office.getId())){
|
|
|
- officeIdSet.add(office.getId());
|
|
|
+ OfficeDTO officeDTO = UserUtils.getCurrentUserDTO().getOfficeDTO();
|
|
|
+ if (StringUtils.isNotBlank(userDTO.getCertType())) {
|
|
|
+ //获取当前登陆人是否事中审公司人员
|
|
|
+ if(officeDTO.getParentIds().contains("1615171302381182978")){
|
|
|
+
|
|
|
+ }
|
|
|
+ }else{
|
|
|
+ // 当不是精确的部门查询时,再添加下面的筛选条件
|
|
|
+ if ((StringUtils.isNotBlank(userDTO.getCompanyDTO().getId()) && StringUtils.isBlank(userDTO.getOfficeDTO().getId()))
|
|
|
+ || "true".equals(userDTO.getSelectAll())) {
|
|
|
+ // officeDTO.id是空,companyDTO.id不是空的话,说明前端组件点击的集团来进行查询
|
|
|
+ // selectAll为‘true’的话,说明前端没有选择集团或者部门查询,这个时候要展示全部人员
|
|
|
+ // 根据当前用户的部门id找到此部门的ids
|
|
|
+ String ids = officeService.getById(UserUtils.getCurrentUserDTO().getOfficeDTO().getId()).getParentIds();
|
|
|
+ // 根据ids分隔后的index[2],找到当前用户的所属公司id
|
|
|
+ String companyId = null;
|
|
|
+ String[] split = ids.split(",");
|
|
|
+ // split.length大于2,说明当前登录人所属部门是普通部门,展示部分人员信息
|
|
|
+ // 否则,当前登录人所属公共类部门(忘了叫什么类部门了,就是总经办那种部门),展示全部人员信息
|
|
|
+ if(split.length>2){
|
|
|
+ companyId = split[2];
|
|
|
+ // 根据公司id,找到此公司下的所有部门
|
|
|
+ List<Office> officeList = officeService.list(new QueryWrapper<Office>().lambda().eq(Office::getParentId, companyId));
|
|
|
+ Set officeIdSet = new HashSet();
|
|
|
+ for (Office office : officeList) {
|
|
|
+ if(StringUtils.isNotBlank(office.getId())){
|
|
|
+ officeIdSet.add(office.getId());
|
|
|
+ }
|
|
|
}
|
|
|
+ List<String> officeIdList = Lists.newArrayList(officeIdSet);
|
|
|
+ // 拿到这些部门的id
|
|
|
+ //List<String> officeIdList = officeList.stream().distinct().map(Office::getId).collect(Collectors.toList());
|
|
|
+ // 拿到所有公有部门的id
|
|
|
+ List<String> officePublicIdList = officeService.list(new LambdaQueryWrapper<Office>().eq(Office::getIsPublic,"1")).stream().map(Office::getId).collect(Collectors.toList());
|
|
|
+ // 拿到直属公司的id
|
|
|
+ officeIdList.add(companyId);
|
|
|
+ // 最后得到的所有部门的id
|
|
|
+ officeIdList.addAll(officePublicIdList);
|
|
|
+ List<String> lastIds = officeIdList.stream().distinct().collect(Collectors.toList());
|
|
|
+ // 添加筛选条件为这些部门的id
|
|
|
+ queryWrapper.in("a.office_id",lastIds);
|
|
|
}
|
|
|
- List<String> officeIdList = Lists.newArrayList(officeIdSet);
|
|
|
- // 拿到这些部门的id
|
|
|
- //List<String> officeIdList = officeList.stream().distinct().map(Office::getId).collect(Collectors.toList());
|
|
|
- // 拿到所有公有部门的id
|
|
|
- List<String> officePublicIdList = officeService.list(new LambdaQueryWrapper<Office>().eq(Office::getIsPublic,"1")).stream().map(Office::getId).collect(Collectors.toList());
|
|
|
- // 拿到直属公司的id
|
|
|
- officeIdList.add(companyId);
|
|
|
- // 最后得到的所有部门的id
|
|
|
- officeIdList.addAll(officePublicIdList);
|
|
|
- List<String> lastIds = officeIdList.stream().distinct().collect(Collectors.toList());
|
|
|
- // 添加筛选条件为这些部门的id
|
|
|
- queryWrapper.in("a.office_id",lastIds);
|
|
|
+ } else if(StringUtils.isBlank(userDTO.getCompanyDTO().getId()) && StringUtils.isNotBlank(userDTO.getOfficeDTO().getId())) {
|
|
|
+ // officeDTO.id不是空,companyDTO.id是空的话,说明前端组件点击的部门查询
|
|
|
+ queryWrapper.eq("a.office_id",userDTO.getOfficeDTO().getId());
|
|
|
}
|
|
|
- } else if(StringUtils.isBlank(userDTO.getCompanyDTO().getId()) && StringUtils.isNotBlank(userDTO.getOfficeDTO().getId())) {
|
|
|
- // officeDTO.id不是空,companyDTO.id是空的话,说明前端组件点击的部门查询
|
|
|
- queryWrapper.eq("a.office_id",userDTO.getOfficeDTO().getId());
|
|
|
}
|
|
|
}
|
|
|
}
|