From c6f986ace99f512cd450159e3b005afbc0eefbf7 Mon Sep 17 00:00:00 2001 From: 张天森 <1292933220@qq.com> Date: 星期三, 12 十月 2022 19:07:04 +0800 Subject: [PATCH] 三说会堂事件流程处理 --- springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComMngPopulationHouseServiceImpl.java | 108 +++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 98 insertions(+), 10 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComMngPopulationHouseServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComMngPopulationHouseServiceImpl.java index 3863593..30b810c 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComMngPopulationHouseServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComMngPopulationHouseServiceImpl.java @@ -9,6 +9,8 @@ import javax.annotation.Resource; import com.panzhihua.common.model.dtos.community.ComMngPopulationHouseInsertAdminDTO; +import com.panzhihua.common.utlis.StringUtils; +import com.panzhihua.service_community.service.ComMngPopulationHouseUserService; import org.springframework.beans.BeanUtils; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -66,6 +68,10 @@ private ComActVillageDAO comActVillageDAO; @Resource private ComMngPopulationHouseDAO comMngPopulationHouseDAO; + @Resource + private ComMngPopulationHouseService comMngPopulationHouseService; + @Resource + private ComMngPopulationHouseUserService comMngPopulationHouseUserService; private static <T> Predicate<T> distinctByKey(Function<? super T, Object> keyExtractor) { Map<Object, Boolean> seen = new ConcurrentHashMap<>(); @@ -93,9 +99,8 @@ cascadeHouseVOList = this.baseMapper.getHouseLevelByAlley(cascadeHouseDTO.getCommunityId(), cascadeHouseDTO.getVillageId()); cascadeHouseVOList = cascadeHouseVOList.stream() - .collect(Collectors.collectingAndThen( - Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(o -> o.getAlley()))), - ArrayList::new)); + .collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>( + Comparator.comparing(ComMngCascadeHouseVO::getAlley))),ArrayList::new)); cascadeHouseVOList.forEach(cascade -> { cascade.setName(cascade.getAlley()); }); @@ -111,7 +116,7 @@ () -> new TreeSet<>(Comparator.comparing(o -> o.getAlley() + ";" + o.getHouseNum()))), ArrayList::new)); cascadeHouseVOList.forEach(cascade -> { - cascade.setName(cascade.getHouseNum()); + cascade.setName(cascade.getHouseNum()+"("+cascade.getName()+")"); }); } break; @@ -169,6 +174,11 @@ @Override public R getSecondHouseAddress(CascadeHouseDTO cascadeHouseDTO) { return R.ok(this.comMngPopulationDAO.getSecondHouseAddress(cascadeHouseDTO.getCommunityId())); + } + + @Override + public R getSecondHouse(CascadeHouseDTO cascadeHouseDTO) { + return R.ok(this.comMngPopulationDAO.getSecondHouse(cascadeHouseDTO.getCommunityId())); } /** @@ -424,8 +434,8 @@ // subordinateList = // subordinateList.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new // TreeSet<>(Comparator.comparing(o -> o.getFloor()))), ArrayList::new)); - subordinateList = subordinateList.stream().filter(distinctByKey(ComMngSubordinateVO::getFloor)) - .collect(Collectors.toList()); +// subordinateList = subordinateList.stream().filter(distinctByKey(ComMngSubordinateVO::getFloor)) +// .collect(Collectors.toList()); subordinateList.forEach(cascade -> { if (cascade.getFloor().contains("栋")) { cascade.setName(cascade.getFloor()); @@ -438,8 +448,8 @@ if (houseDO != null) { subordinateList = this.baseMapper.getHouseLevelByUnitNos(houseDO.getVillageId(), houseDO.getFloor()); - subordinateList = subordinateList.stream().filter(distinctByKey(ComMngSubordinateVO::getUnitNo)) - .collect(Collectors.toList()); +// subordinateList = subordinateList.stream().filter(distinctByKey(ComMngSubordinateVO::getUnitNo)) +// .collect(Collectors.toList()); // subordinateList = // subordinateList.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new // TreeSet<>(Comparator.comparing(o -> o.getUnitNo()))), ArrayList::new)); @@ -456,8 +466,8 @@ if (houseDO != null) { subordinateList = this.baseMapper.getHouseLevelByHouseNos(houseDO.getVillageId(), houseDO.getFloor(), houseDO.getUnitNo()); - subordinateList = subordinateList.stream().filter(distinctByKey(ComMngSubordinateVO::getHouseNo)) - .collect(Collectors.toList()); +// subordinateList = subordinateList.stream().filter(distinctByKey(ComMngSubordinateVO::getHouseNo)) +// .collect(Collectors.toList()); // subordinateList = // subordinateList.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new // TreeSet<>(Comparator.comparing(o -> o.getHouseNo()))), ArrayList::new)); @@ -472,6 +482,7 @@ return R.ok(subordinateList); } + @Override public R populationRelationHouse(ComMngPopulationRelationHouseDTO relationHouseDTO) { if (relationHouseDTO.getPopulationId().isEmpty()) { @@ -533,4 +544,81 @@ } } + /** + * 实有房屋数据修复定时任务 + * @return 实有房屋数据修复定时任务 + */ + @Override + @Transactional + public R timedTaskHouseJobHandler(){ + + //需要修改的房屋信息 + List<ComMngPopulationHouseDO> updateHouseList = new ArrayList<>(); + //需要修改的房屋人员关系信息 + List<ComMngPopulationHouseUserDO> updateHouseUserList = new ArrayList<>(); + + ComMngPopulationDO population = new ComMngPopulationDO(); + + //查询所有房屋列表信息 + List<ComMngPopulationHouseDO> houseList = comMngPopulationHouseDAO.selectList(null); + //遍历房屋信息 + for (ComMngPopulationHouseDO house : houseList) { + List<ComMngPopulationHouseUserDO> houseUserList = comMngPopulationHouseUserDAO.selectList(new QueryWrapper<ComMngPopulationHouseUserDO>() + .lambda().eq(ComMngPopulationHouseUserDO::getHouseId,house.getId())); + if(houseUserList.isEmpty()){ + house.setStatus(ComMngPopulationHouseDO.status.kongzhi); + }else{ + house.setStatus(ComMngPopulationHouseDO.status.zizhu); + + //查询该房屋下人员是否是租住状态 + List<Long> populationIds = houseUserList.stream().map(ComMngPopulationHouseUserDO::getPopulId).collect(Collectors.toList()); + Integer count = comMngPopulationHouseUserDAO.getHouseUserIsRent(populationIds); + if(count > 0){ + house.setStatus(ComMngPopulationHouseDO.status.zuzhu); + } + + //查询该房屋下人员的关联信息的关系 + for (ComMngPopulationHouseUserDO houseUser : houseUserList) { + population = comMngPopulationDAO.selectById(houseUser.getPopulId()); + if(population != null){ + if(population.getIsRent() != null && population.getIsRent().equals(ComMngPopulationDO.isOk.yes)){ + houseUser.setRelationId(ComMngPopulationHouseUserDO.relationId.zuhu); + }else { + houseUser.setRelationId(ComMngPopulationHouseUserDO.relationId.zuzhu); + } + updateHouseUserList.add(houseUser); + } + } + } + + //查看房子的楼层排序 + if(house.getFloorNum() == null && StringUtils.isNotEmpty(house.getHouseNo())){ + boolean result = house.getHouseNo().matches("[0-9]+"); + if (result) {// 该字段为纯数字 + if (house.getHouseNo().length() == 4) { + String floorNum = house.getHouseNo().substring(0, 2).replaceAll("^(0+)", ""); + if(StringUtils.isNotEmpty(floorNum)){ + house.setFloorNum(Integer.parseInt(floorNum)); + } + } else if (house.getHouseNo().length() == 3) { + String floorNum = house.getHouseNo().substring(0, 1).replaceAll("^(0+)", ""); + if(StringUtils.isNotEmpty(floorNum)){ + house.setFloorNum(Integer.parseInt(floorNum)); + } + } + } + } + updateHouseList.add(house); + } + + if(!updateHouseList.isEmpty()){ + comMngPopulationHouseService.updateBatchById(updateHouseList); + } + + if(!updateHouseUserList.isEmpty()){ + comMngPopulationHouseUserService.updateBatchById(updateHouseUserList); + } + return R.ok(); + } + } -- Gitblit v1.7.1