From 224e0bbfc8d24785fea2e0160c36d7a8f6cd7269 Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Thu, 21 Dec 2023 14:17:17 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/main/java/org/springblade/modules/doorplateAddress/service/impl/DoorplateAddressServiceImpl.java |  133 +++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 118 insertions(+), 15 deletions(-)

diff --git a/src/main/java/org/springblade/modules/doorplateAddress/service/impl/DoorplateAddressServiceImpl.java b/src/main/java/org/springblade/modules/doorplateAddress/service/impl/DoorplateAddressServiceImpl.java
index 2a6d590..efe9394 100644
--- a/src/main/java/org/springblade/modules/doorplateAddress/service/impl/DoorplateAddressServiceImpl.java
+++ b/src/main/java/org/springblade/modules/doorplateAddress/service/impl/DoorplateAddressServiceImpl.java
@@ -29,6 +29,8 @@
 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.community.entity.CommunityEntity;
+import org.springblade.modules.community.service.ICommunityService;
 import org.springblade.modules.district.entity.DistrictEntity;
 import org.springblade.modules.district.service.IDistrictService;
 import org.springblade.modules.doorplateAddress.entity.DoorplateAddressEntity;
@@ -94,6 +96,9 @@
 
 	@Autowired
 	private ICategoryLabelService iCategoryLabelService;
+
+	@Autowired
+	private ICommunityService communityService;
 
 
 	@Override
@@ -471,7 +476,42 @@
 				tempList.add(funcNode);
 			});
 			// 排序
-			List<FuncNode> sortList = tempList.stream().sorted(Comparator.comparing(X -> X.getUnitName())).collect(Collectors.toList());
+			sortUnit(tempList,list);
+//			List<FuncNode> sortList = tempList.stream().sorted(Comparator.comparing(X -> X.getUnitName())).collect(Collectors.toList());
+//			list.addAll(sortList);
+		}
+	}
+
+	/**
+	 * 单元排序
+	 * @param tempList
+	 * @param list
+	 */
+	private void sortUnit(List<FuncNode> tempList,List<FuncNode> list) {
+		// 遍历
+		if(tempList.size()>1){
+			for (FuncNode funcNode : tempList) {
+				if (funcNode.getUnitName().contains("一")){
+					funcNode.setSort(1);
+				}
+				if (funcNode.getUnitName().contains("二")){
+					funcNode.setSort(2);
+				}
+				if (funcNode.getUnitName().contains("三")){
+					funcNode.setSort(3);
+				}
+				if (funcNode.getUnitName().contains("四")){
+					funcNode.setSort(4);
+				}
+				if (funcNode.getUnitName().contains("五")){
+					funcNode.setSort(5);
+				}
+				if (funcNode.getUnitName().contains("六")){
+					funcNode.setSort(6);
+				}
+			}
+			// 排序
+			List<FuncNode> sortList = tempList.stream().sorted(Comparator.comparing(X -> X.getSort())).collect(Collectors.toList());
 			list.addAll(sortList);
 		}
 	}
@@ -686,22 +726,85 @@
 		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());
-			// 设置来源( 1:地址总表  2:国控采集)
-			placeEntity.setSource(1);
-			// 加入集合
-			placeList.add(placeEntity);
+		if (list.size()>0) {
+			// 将场所数据保存到场所表中
+			for (DoorplateAddressEntity addressEntity : list) {
+				// pio 名称不为空的进行插入操作
+				if (!Strings.isBlank(addressEntity.getPoi())) {
+					PlaceEntity placeEntity = new PlaceEntity();
+					placeEntity.setHouseCode(addressEntity.getAddressCode());
+					placeEntity.setPlaceName(addressEntity.getPoi());
+					placeEntity.setLng(addressEntity.getX());
+					placeEntity.setLat(addressEntity.getY());
+					placeEntity.setLocaltion(addressEntity.getAddressName());
+					// 设置来源( 1:地址总表  2:国控采集)
+					placeEntity.setSource(1);
+					// 加入集合
+					placeList.add(placeEntity);
+				}
+			}
+			// 批量插入
+			placeService.saveBatch(placeList);
 		}
-		// 批量插入
-		placeService.saveBatch(placeList);
 		// 返回
 		return null;
 	}
+
+	/**
+	 * 门牌地址表(总台账数据) 自定义详情
+	 */
+	@Override
+	public Object getDetail(DoorplateAddressVO doorplateAddress) {
+		List<String> list = new ArrayList<>();
+		// 扫码时调用,需判断是否有权限查看
+		DoorplateAddressVO one = baseMapper.getDoorplateAddressVODetail(doorplateAddress);
+		if (null!=one){
+			if (!Strings.isBlank(doorplateAddress.getRoleName())) {
+				// 判断是否有权限
+				if (doorplateAddress.getRoleName().equals("网格员")) {
+					list = gridService.getAddressCodeListByUserId(AuthUtil.getUserId());
+					boolean contains = list.contains(doorplateAddress.getAddressCode());
+					if (list.size()==0 || !contains){
+						// 无权限
+						one.setIsJur(2);
+					}else {
+						one.setIsJur(1);
+					}
+				}else {
+					// 不限制
+					one.setIsJur(1);
+				}
+			}
+			return one;
+		}
+		return null;
+	}
+
+	/**
+	 * 社区数据处理
+	 * @return
+	 */
+	@Override
+	public Object communityDataHandle() {
+		// 查询所有的社区差值
+		List<DoorplateAddressEntity> doorplateAddressEntities = baseMapper.getAllCommunityList();
+		// 遍历,插入库
+		for (DoorplateAddressEntity doorplateAddressEntity : doorplateAddressEntities) {
+			QueryWrapper<CommunityEntity> queryWrapper = new QueryWrapper<>();
+			queryWrapper.eq("name",doorplateAddressEntity.getNeiName())
+				.eq("code",doorplateAddressEntity.getNeiCode())
+				.eq("is_deleted",0);
+			CommunityEntity one = communityService.getOne(queryWrapper);
+			if (null==one){
+				// 插入
+				CommunityEntity communityEntity = new CommunityEntity();
+				communityEntity.setCode(doorplateAddressEntity.getNeiCode());
+				communityEntity.setName(doorplateAddressEntity.getNeiName());
+				communityEntity.setStreetCode(doorplateAddressEntity.getTownStreetCode().replaceAll("0+$", ""));
+				//新增操作
+				communityService.save(communityEntity);
+			}
+		}
+		return null;
+	}
 }

--
Gitblit v1.9.3