From 275f338495f3e694ccf6fa909fb78b949a67921c Mon Sep 17 00:00:00 2001 From: kaiyu <404897439@qq.com> Date: Mon, 10 May 2021 13:06:20 +0800 Subject: [PATCH] screen-manage 修改前台用户模块 --- screen-manage/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java | 86 ++++++++++++++++++++++++++++++++----------- 1 files changed, 64 insertions(+), 22 deletions(-) diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java index 34f5fe5..bd2db85 100644 --- a/screen-manage/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java +++ b/screen-manage/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java @@ -7,13 +7,16 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.moral.api.config.mybatis.wrapper.NullFilterWrapper; import com.moral.api.entity.Organization; +import com.moral.api.entity.User; import com.moral.api.mapper.OrganizationMapper; +import com.moral.api.mapper.UserMapper; import com.moral.api.pojo.dto.organization.OrganizationDTO; import com.moral.api.pojo.dto.organization.OrganizationQueryDTO; import com.moral.api.pojo.dto.organization.OrganizationQueryNamesDTO; import com.moral.api.pojo.form.organization.*; import com.moral.api.service.OrganizationService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.moral.api.service.UserService; import com.moral.api.util.LogUtils; import com.moral.constant.Constants; import com.moral.constant.ResponseCodeEnum; @@ -29,6 +32,7 @@ import javax.servlet.http.HttpServletRequest; import java.util.*; +import java.util.function.Predicate; /** * <p> @@ -47,6 +51,12 @@ @Autowired LogUtils logUtils; + + @Autowired + UserService userService; + + @Autowired + UserMapper userMapper; Map<String, String> organizationFormMap; @@ -206,10 +216,13 @@ deleteWrapper.set("is_delete", Constants.DELETE); organizationMapper.update(null, deleteWrapper); + //������������������ + userService.deleteUserByOrganizationId(id); + //��������������������������� - List<Organization> children = getAllChildrenOrganization(existOrganization); + List<Organization> children = getAllChildrenOrganization(existOrganization.getId()); if (!ObjectUtils.isEmpty(children)) {//��������������������� - //������������������������������������������������������������������������������������������������������������������ + //��������������������������������������������������������������������������������������������������������������������������� UpdateWrapper updateWrapper = new UpdateWrapper(); if (form.getDeleteChildren().equals(Constants.DELETE_CHILDREN_ORG)) {//��������������������� //������������������������id��������������� @@ -221,6 +234,9 @@ updateWrapper.in("id", childrenId); updateWrapper.set("is_delete", Constants.DELETE); organizationMapper.update(null, updateWrapper); + //��������������������������� + childrenId.forEach(value->userService.deleteUserByOrganizationId(value)); + } else {//��������� //���������������������������id List<Integer> childrenId = new ArrayList<>(); @@ -234,8 +250,6 @@ organizationMapper.update(null, updateWrapper); } } - - //������������������������ //������������������ dto.setOrganization(existOrganization); @@ -318,12 +332,22 @@ Page<Organization> resultPage = organizationMapper.selectPage(page, queryWrapper); List<Organization> organizations = resultPage.getRecords(); List<OrganizationDTO> organizationDTOS = new ArrayList<>(); - //������������������������������������������organization���DTO��� - for (Organization child : organizations) { + //���������������������������������admin������������������organization���DTO��� + for (Organization organization : organizations) { OrganizationDTO resultDto = new OrganizationDTO(); - Organization parent = organizationMapper.selectById(child.getParentId());//��������������� - resultDto.setOrganization(child); + //��������������� + Organization parent = organizationMapper.selectById(organization.getParentId()); + resultDto.setOrganization(organization); resultDto.setParentOrganization(parent); + //������admin������ + QueryWrapper userWrapper = new QueryWrapper(); + User adminUser = new User(); + adminUser.setIsAdmin(true); + adminUser.setOrganizationId(organization.getId()); + adminUser.setIsDelete(Constants.NOT_DELETE); + userWrapper.setEntity(adminUser); + adminUser = userMapper.selectOne(userWrapper); + resultDto.setAdminUser(adminUser); organizationDTOS.add(resultDto); } @@ -338,21 +362,40 @@ } /** - * @Description: ������������������������������Id - * @Param: [] - * @return: com.moral.api.pojo.dto.organization.OrganizationQueryNameDTO - * @Author: ��������� - * @Date: 2021/4/13 - */ + * @Description: ������form���id��������������������������������� + * ������id������������������������id������id������������������������������������ + * @Param: [from] + * @return: com.moral.api.pojo.dto.organization.OrganizationQueryNamesDTO + * @Author: ��������� + * @Date: 2021/5/7 + */ @Override - public OrganizationQueryNamesDTO queryNames(OrganizationQueryNamesForm from) { + public OrganizationQueryNamesDTO queryNames(OrganizationQueryNamesForm form) { OrganizationQueryNamesDTO dto = new OrganizationQueryNamesDTO(); + //������ + Integer id = form.getId(); //������������������ QueryWrapper<Organization> queryWrapper = new QueryWrapper(); queryWrapper.eq("is_delete", Constants.NOT_DELETE); - //������ + //������������������ List<Organization> organizations = organizationMapper.selectList(queryWrapper); - + //������form������������id,��������������������������������������� + if(!ObjectUtils.isEmpty(id)){ + List<Organization> children = getAllChildrenOrganization(id); + List<Integer> thisAndchildrenIds = new ArrayList<>();//���id���������������������������id������ + thisAndchildrenIds.add(id); + for (Organization child : children) { + thisAndchildrenIds.add(child.getId()); + } + organizations.removeIf(new Predicate<Organization>() {//������ + @Override + public boolean test(Organization organization) { + if(thisAndchildrenIds.contains(organization.getId())) + return true; + return false; + } + }); + } //������������������ dto.setCode(ResponseCodeEnum.SUCCESS.getCode()); dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg()); @@ -424,9 +467,9 @@ * @Author: ��������� * @Date: 2021/4/14 */ - private List<Organization> getAllChildrenOrganization(Organization parent) { + private List<Organization> getAllChildrenOrganization(Integer parentId) { List<Organization> children = new ArrayList<>(); - recursionQueryChildren(parent, children); + recursionQueryChildren(parentId, children); return children; } @@ -437,8 +480,7 @@ * @Author: ��������� * @Date: 2021/4/14 */ - private void recursionQueryChildren(Organization parent, List<Organization> children) { - Integer parentId = parent.getId(); + private void recursionQueryChildren(Integer parentId, List<Organization> children) { QueryWrapper<Organization> queryWrapper = new QueryWrapper(); queryWrapper.eq("is_delete", Constants.NOT_DELETE); queryWrapper.eq("parent_id", parentId); @@ -446,7 +488,7 @@ if (!ObjectUtils.isEmpty(organizations)) { children.addAll(organizations); for (Organization organization : organizations) { - recursionQueryChildren(organization, children); + recursionQueryChildren(organization.getId(), children); } } else { return; -- Gitblit v1.8.0