linwe
2023-12-01 5d5cd3ad979a0b85ab8c7034dcad1663fdcf71be
src/main/java/org/springblade/modules/doorplateAddress/service/impl/DoorplateAddressServiceImpl.java
@@ -21,16 +21,22 @@
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import liquibase.repackaged.org.apache.commons.lang3.StringUtils;
import org.apache.logging.log4j.util.Strings;
import org.springblade.common.constant.DictConstant;
import org.springblade.common.node.TreeNode;
import org.springblade.common.node.TreeStringNode;
import org.springblade.common.utils.NodeTreeUtil;
import org.springblade.core.secure.utils.AuthUtil;
import org.springblade.modules.category.dto.CategoryLabelDTO;
import org.springblade.modules.category.service.ICategoryLabelService;
import org.springblade.modules.district.entity.DistrictEntity;
import org.springblade.modules.district.service.IDistrictService;
import org.springblade.modules.doorplateAddress.entity.DoorplateAddressEntity;
import org.springblade.modules.doorplateAddress.mapper.DoorplateAddressMapper;
import org.springblade.modules.doorplateAddress.service.IDoorplateAddressService;
import org.springblade.modules.doorplateAddress.vo.DoorplateAddressVO;
import org.springblade.modules.doorplateAddress.vo.DoorplateAddressVOTree;
import org.springblade.modules.doorplateAddress.vo.FuncNode;
import org.springblade.modules.grid.entity.GridEntity;
import org.springblade.modules.grid.service.IGridService;
import org.springblade.modules.house.entity.HouseEntity;
import org.springblade.modules.house.service.IHouseRentalService;
@@ -39,9 +45,11 @@
import org.springblade.modules.house.vo.HouseParam;
import org.springblade.modules.house.vo.HouseRentalVO;
import org.springblade.modules.house.vo.HouseholdVO;
import org.springblade.modules.place.entity.PlaceEntity;
import org.springblade.modules.place.service.IPlaceService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.*;
import java.util.stream.Collectors;
@@ -70,6 +78,12 @@
   @Autowired
   private IGridService gridService;
   @Autowired
   private IDistrictService districtService;
   @Autowired
   private ICategoryLabelService iCategoryLabelService;
   @Override
   public IPage<DoorplateAddressVO> selectDoorplateAddressPage(IPage<DoorplateAddressVO> page, DoorplateAddressVO doorplateAddress) {
@@ -85,26 +99,28 @@
   @Override
   public Object getFuncList(Integer type,String roleName) {
      HouseParam houseParam = new HouseParam();
      String userId = AuthUtil.getUserId().toString();
      houseParam.setUserId(userId);
      List<String> stringList = new ArrayList<>();
      if (null!=roleName && !roleName.equals("")){
         houseParam.setRoleName(roleName);
         if (roleName.equals("网格员")){
         if (roleName.equals("网格员") && !userId.equals("1726859808689696770")){
            // 查询对应的房屋地址code
            stringList = gridService.getAddressCodeListByUserId(AuthUtil.getUserId());
         }
      }
      List<TreeNode> list = new ArrayList<>();
      List<TreeStringNode> list = new ArrayList<>();
      if (null!=type) {
         // 如果是网格管理员,系统管理员
         if (type==1){
            // 查询街道
            List<TreeNode> townList = baseMapper.getRegionListByGroupTwon(houseParam,stringList);
            List<TreeStringNode> townList = baseMapper.getRegionListByGroupTwon(houseParam,stringList);
            // 查询社区
            List<TreeNode> neiList = baseMapper.getRegionListByGroupNei(houseParam,stringList);
            List<TreeStringNode> neiList = baseMapper.getRegionListByGroupNei(houseParam,stringList);
            // 遍历
            for (TreeNode treeNode : townList) {
            for (TreeStringNode treeNode : townList) {
               // 遍历
               for (TreeNode node : neiList) {
               for (TreeStringNode node : neiList) {
                  if (treeNode.getId().equals(node.getParentId())){
                     node.setHasChildren(false);
                     treeNode.getChildren().add(node);
@@ -127,10 +143,10 @@
    * @param list
    * @return
    */
   private Object getInhabitantInfo(List<TreeNode> list) {
   private Object getInhabitantInfo(List<TreeStringNode> list) {
      // 查询房屋集合信息
      List<TreeNode> houseNodeList = householdService.selectHouseNodeList(AuthUtil.getUserId());
      for (TreeNode treeNode : houseNodeList) {
      List<TreeStringNode> houseNodeList = householdService.selectHouseNodeList(AuthUtil.getUserId());
      for (TreeStringNode treeNode : houseNodeList) {
         // 判断房屋类型类型
         if (DictConstant.SMALL_DOORPLATE.equals(treeNode.getDoorplateType())  ||
            (DictConstant.centre_DOORPLATE.equals(treeNode.getDoorplateType()) &&
@@ -141,9 +157,13 @@
         }
      }
      // 查询场所集合信息
      List<TreeNode> placeNodeList = placeService.selectPlaceNodeList(AuthUtil.getUserId());
      for (TreeNode treeNode : placeNodeList) {
      List<TreeStringNode> placeNodeList = placeService.selectPlaceNodeList(AuthUtil.getUserId());
      for (TreeStringNode treeNode : placeNodeList) {
         treeNode.setAddressType(2);
         CategoryLabelDTO categoryLabelDTO = new CategoryLabelDTO();
         categoryLabelDTO.setPlaceId(treeNode.getId());
         List<CategoryLabelDTO> categoryLabelDTOS = iCategoryLabelService.selectCategoryLabelList(categoryLabelDTO);
         treeNode.setCategoryLabelList(categoryLabelDTOS);
//         if (DictConstant.SMALL_DOORPLATE.equals(treeNode.getDoorplateType()) ||
//            (DictConstant.centre_DOORPLATE.equals(treeNode.getDoorplateType()) &&
//               treeNode.getAddressLevel().equals(1))) {
@@ -154,13 +174,13 @@
      }
      if (houseNodeList.size() > 0 && placeNodeList.size() > 0) {
         // 合并
         TreeNode houseNode = new TreeNode();
         TreeStringNode houseNode = new TreeStringNode();
         houseNode.setName("房屋");
         houseNode.setId("1");
         houseNode.setHasChildren(true);
         houseNode.setChildren(houseNodeList);
         TreeNode placeNode = new TreeNode();
         TreeStringNode placeNode = new TreeStringNode();
         placeNode.setName("场所");
         placeNode.setId("2");
         placeNode.setHasChildren(true);
@@ -188,9 +208,12 @@
    */
   @Override
   public Object getHousesList(HouseParam houseParam) {
      List<TreeNode> list = new ArrayList<>();
      List<TreeStringNode> list = new ArrayList<>();
      Map<String, Object> map = new HashMap<>(2);
      // 获取网格员对应的地址编号集合
      List<String> stringList = getHouseCodeList(houseParam);
      // 获取网格员对应的网格信息
      getGridInfoByGridman(houseParam);
      // 查小区,场所
      if (houseParam.getType()==1){
         // 根据社区名称查询小区集合
@@ -205,6 +228,28 @@
         return getHouseLevelData(houseParam, map);
      }
      return list;
   }
   /**
    * 获取网格员对应的网格信息
    * @param houseParam
    */
   private void getGridInfoByGridman(HouseParam houseParam) {
      if (houseParam.getRoleName().equals("网格员")) {
         QueryWrapper<GridEntity> wrapper = new QueryWrapper<>();
         wrapper.eq("is_deleted", 0)
            .eq("user_id", AuthUtil.getUserId());
         List<GridEntity> list = gridService.list(wrapper);
         if (list.size() > 0) {
            GridEntity gridEntity = list.get(0);
            if (!Strings.isBlank(gridEntity.getCommunityName())) {
               houseParam.setCommunityName(gridEntity.getCommunityName().split("居民委员会")[0]);
            }
            if (!Strings.isBlank(gridEntity.getGridName())) {
               houseParam.setGridName(gridEntity.getGridName());
            }
         }
      }
   }
   /**
@@ -236,7 +281,8 @@
         map.put("shopList",shopList);
         // 返回
         return map;
      }else{
      }
      if(houseParam.getAddressType()==3){
         // 根据街路巷编号查询街路巷门牌名称集合
         List<FuncNode> doorplateNameList = baseMapper.getDoorplateNameList(houseParam,stringList);
         map.put("aoiList",new ArrayList<>());
@@ -244,6 +290,16 @@
         // 返回
         return map;
      }
      if(houseParam.getAddressType()==4){
         getGridInfoByGridman(houseParam);
         // 查询商超
         List<FuncNode> doorplateNameList = baseMapper.getPlaceRelDetailList(houseParam);
         map.put("aoiList",new ArrayList<>());
         map.put("shopList",doorplateNameList);
         // 返回
         return map;
      }
      return map;
   }
   /**
@@ -253,37 +309,48 @@
    * @return
    */
   private Object getBuildLevelData(HouseParam houseParam,Map<String, Object> map) {
      List<String> stringList = getHouseCodeList(houseParam);
      // 判断 code 长度,如果 code 长度大于 12 则为小区查楼栋/商铺,否则则按社区查街路巷
      if (houseParam.getCode().length()>12){
         List<TreeNode> aoiList = new ArrayList<>();
         List<TreeNode> shopList = new ArrayList<>();
         // 根据社区名称查询楼栋或者商铺的集合
         List<TreeNode> list = baseMapper.getBuildingList(houseParam,stringList);
         // 排序  StringUtils.getDigits(X.getName()) 取出数字排序
         List<TreeNode> sortList = list.stream().sorted(Comparator.comparing(X -> StringUtils.getDigits(X.getName()))).collect(Collectors.toList());
         if (list.size()>0){
            for (TreeNode treeNode : sortList) {
               if (treeNode.getAddressType()==1){
                  aoiList.add(treeNode);
               }
               if (treeNode.getAddressType()==2){
                  shopList.add(treeNode);
               }
            }
         }
         map.put("aoiList",aoiList);
         map.put("shopList",shopList);
      if (houseParam.getAddressType()==4){
         // 获取网格员对应的网格信息
         getGridInfoByGridman(houseParam);
         // 查询商超
         List<TreeStringNode> list = baseMapper.getPlaceRelList(houseParam);
         map.put("aoiList", new ArrayList<>());
         map.put("shopList", list);
         // 返回
         return map;
      }else {
         // 查询街路巷
         List<TreeNode> list  = baseMapper.getStreetRuList(houseParam,stringList);
         map.put("aoiList",new ArrayList<>());
         map.put("shopList",list);
         // 返回
         return map;
         List<String> stringList = getHouseCodeList(houseParam);
         // 判断 code 长度,如果 code 长度大于 12 则为小区查楼栋/商铺,否则则按社区查街路巷
         if (houseParam.getCode().length() > 12) {
            List<TreeStringNode> aoiList = new ArrayList<>();
            List<TreeStringNode> shopList = new ArrayList<>();
            // 根据社区名称查询楼栋或者商铺的集合
            List<TreeStringNode> list = baseMapper.getBuildingList(houseParam, stringList);
            // 排序  StringUtils.getDigits(X.getName()) 取出数字排序
            List<TreeStringNode> sortList = list.stream().sorted(Comparator.comparing(X -> StringUtils.getDigits(X.getName()))).collect(Collectors.toList());
            if (list.size() > 0) {
               for (TreeStringNode treeNode : sortList) {
                  if (treeNode.getAddressType() == 1) {
                     aoiList.add(treeNode);
                  }
                  if (treeNode.getAddressType() == 2) {
                     shopList.add(treeNode);
                  }
               }
            }
            map.put("aoiList", aoiList);
            map.put("shopList", shopList);
            // 返回
            return map;
         } else {
            // 查询街路巷
            List<TreeStringNode> list = baseMapper.getStreetRuList(houseParam, stringList);
            map.put("aoiList", new ArrayList<>());
            map.put("shopList", list);
            // 返回
            return map;
         }
      }
   }
@@ -488,8 +555,10 @@
    */
   private List<String> getHouseCodeList(HouseParam houseParam) {
      List<String> stringList = new ArrayList<>();
      String userId = AuthUtil.getUserId().toString();
      houseParam.setUserId(userId);
      if (null != houseParam.getRoleName() && !houseParam.getRoleName().equals("")) {
         if (houseParam.getRoleName().equals("网格员")) {
         if (houseParam.getRoleName().equals("网格员") && !userId.equals("1726859808689696770")) {
            // 查询对应的房屋地址code
            stringList = gridService.getAddressCodeListByUserId(AuthUtil.getUserId());
         }
@@ -530,7 +599,7 @@
            houseEntity.setDistrictCode(doorplateAddressEntity.getAoiCode());
            houseEntity.setDistrictName(doorplateAddressEntity.getAoiName());
            houseEntity.setHouseName(doorplateAddressEntity.getAddressName());
            houseEntity.setFloor(Integer.parseInt(doorplateAddressEntity.getFloor()));
            houseEntity.setFloor(doorplateAddressEntity.getFloor());
            houseEntity.setBuilding(doorplateAddressEntity.getBuildingName());
            houseEntity.setUnit(doorplateAddressEntity.getUnitName());
            houseEntity.setRoom(doorplateAddressEntity.getHouseName());
@@ -546,4 +615,63 @@
      // 批量插入
      houseService.saveBatch(houseList);
   }
   /**
    * 小区数据处理
    * @return
    */
   @Override
   public Object aoiDataHandle() {
      // 查询所有的地址表id集合
      List<Long> aoiCodeList = baseMapper.getAoiCodeList();
      // 查询小区集合
      List<DoorplateAddressEntity> list = baseMapper.getAoiList(aoiCodeList);
      // 创建小区集合对象
      List<DistrictEntity> aoiList = new ArrayList<>();
      // 将小区数据保存到小区表中
      for (DoorplateAddressEntity addressEntity : list) {
         DistrictEntity districtEntity = new DistrictEntity();
         districtEntity.setCommunityCode(addressEntity.getNeiCode());
         districtEntity.setAoiCode(addressEntity.getAoiCode());
         districtEntity.setName(addressEntity.getAoiName());
         districtEntity.setAddress(addressEntity.getAddressName());
         districtEntity.setLng(addressEntity.getX());
         districtEntity.setLat(addressEntity.getY());
         // 加入集合
         aoiList.add(districtEntity);
      }
      // 批量插入
      districtService.saveBatch(aoiList);
      // 返回
      return null;
   }
   /**
    * 场所数据处理
    * @return
    */
   @Override
   @Transactional(rollbackFor = Exception.class)
   public Object placeDataHandle() {
      // 查询所有的地址表和场所表差集集合
      List<DoorplateAddressEntity> list = baseMapper.getPlaceList();
      // 创建场所集合对象
      List<PlaceEntity> placeList = new ArrayList<>();
      // 将小区数据保存到小区表中
      for (DoorplateAddressEntity addressEntity : list) {
         PlaceEntity placeEntity = new PlaceEntity();
         placeEntity.setHouseCode(addressEntity.getAddressCode());
         placeEntity.setPlaceName(addressEntity.getPoi());
         placeEntity.setLng(addressEntity.getX());
         placeEntity.setLat(addressEntity.getY());
         placeEntity.setLocaltion(addressEntity.getAddressName());
         placeEntity.setLat(addressEntity.getY());
         // 加入集合
         placeList.add(placeEntity);
      }
      // 批量插入
      placeService.saveBatch(placeList);
      // 返回
      return null;
   }
}