From fe9a623b42b02e7fcd112f6a85d55b3beeb58d2e Mon Sep 17 00:00:00 2001 From: luoyisheng <yangdongji@argo-ai.cn> Date: 星期四, 27 三月 2025 17:51:45 +0800 Subject: [PATCH] bug --- medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java | 29 +++++++++++++++++++++++++---- 1 files changed, 25 insertions(+), 4 deletions(-) diff --git a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java index 5f66a4f..b3596f0 100644 --- a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java +++ b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java @@ -139,6 +139,7 @@ @NotNull private Map<Long, List<SysDepartment>> getChildrenDepartmentByOrgType(SysDepartment myDepartment, List<Integer> orgTypes) { List<SysDepartment> sysDepartmentList = this.lambdaQuery() + .in(CollUtils.isNotEmpty(orgTypes), SysDepartment::getOrgType, orgTypes) .likeRight(SysDepartment::getTreeCode, myDepartment.getTreeCode()) .orderByDesc(SysDepartment::getCreateTime) .list(); @@ -146,6 +147,18 @@ .collect(Collectors.groupingBy(SysDepartment::getParentId)); } + @NotNull + private Map<Long, List<SysDepartment>> getChildrenDepartmentMap(SysDepartment myDepartment) { + List<SysDepartment> sysDepartmentList = this.lambdaQuery() + .ne(SysDepartment::getOrgType , 4) + .ne(SysDepartment::getOrgType , 3) + .ne(SysDepartment::getOrgType , 2) + .likeRight(SysDepartment::getTreeCode, myDepartment.getTreeCode()) + .orderByDesc(SysDepartment::getCreateTime) + .list(); + return sysDepartmentList.stream() + .collect(Collectors.groupingBy(SysDepartment::getParentId)); + } @Override public SysDepartment getDepartmentByParentId(Long parentId) { return this.lambdaQuery().eq(SysDepartment::getId, parentId).one(); @@ -207,8 +220,15 @@ // if (!currentDepartment.getOrgType().equals(DepartmentEnum.REGION.getCode())) { // return root; // } - Map<Long, List<SysDepartment>> childrenMap = getChildrenDepartmentByOrgType(currentDepartment, Collections.singletonList(DepartmentEnum.REGION.getCode())); + Map<Long, List<SysDepartment>> childrenMap = getChildrenDepartmentMap(currentDepartment); SysDepartmentVO sysDepartmentVO = fillChildrenTreeModel(currentDepartment, childrenMap); + Integer orgType = sysDepartmentVO.getOrgType(); + if (sysDepartmentVO.getOrgType()==4){ + SysDepartment byId = this.getById(sysDepartmentVO.getParentId()); + childrenMap = getChildrenDepartmentMap(byId); + sysDepartmentVO = fillChildrenTreeModel(byId, childrenMap); +// sysDepartmentVO.setChildren(new ArrayList<>()); + } if (sysDepartmentVO.getTreeCode().length()==10){ SysDepartment sysDepartment = this.baseMapper.selectById(sysDepartmentVO.getParentId()); SysDepartmentVO sysDepartmentVO1 = new SysDepartmentVO(); @@ -218,12 +238,12 @@ sysDepartmentVO1.setChildren(root1); sysDepartmentVO = sysDepartmentVO1; } - if (sysDepartmentVO.getTreeCode().length()==14){ + if (sysDepartmentVO.getTreeCode().length()>=14){ SysDepartment sysDepartment = this.baseMapper.selectById(sysDepartmentVO.getParentId()); SysDepartmentVO sysDepartmentVO1 = new SysDepartmentVO(); BeanUtils.copyProperties(sysDepartment,sysDepartmentVO1); List<SysDepartmentVO> root1 = new ArrayList<>(); - root1.add(sysDepartmentVO); + root1.add(sysDepartmentVO); sysDepartmentVO1.setChildren(root1); @@ -232,7 +252,7 @@ BeanUtils.copyProperties(sysDepartment2,sysDepartmentVO2); List<SysDepartmentVO> root2 = new ArrayList<>(); root2.add(sysDepartmentVO1); - sysDepartmentVO2.setChildren(root2); + sysDepartmentVO2.setChildren(root2); sysDepartmentVO = sysDepartmentVO2; } root.add(sysDepartmentVO); @@ -773,6 +793,7 @@ .like(StringUtils.isNotBlank(query.getContactPerson()), SysDepartment::getContactPerson, query.getContactPerson()) .like(StringUtils.isNotBlank(query.getContactPhone()), SysDepartment::getContactPhone, query.getContactPhone()) .eq(SysDepartment::getOrgType, DepartmentEnum.REGULATORY_UNIT.getCode()) + .orderByDesc(SysDepartment::getCreateTime) .page(new Page<>(query.getPageCurr(), query.getPageSize())); return PageDTO.of(page, RegulatoryUnitVO.class); } -- Gitblit v1.7.1