From 47712cc6cd4d52fcd1dde44e2a400ccbb9c6ae7a Mon Sep 17 00:00:00 2001
From: zhongrj <646384940@qq.com>
Date: Fri, 12 Apr 2024 15:20:49 +0800
Subject: [PATCH] 民警网格区域查询合并,网格员区域树查询修改,解决不显示网格问题

---
 src/main/java/org/springblade/common/cache/SysCache.java |   70 ++++++++++++++++++++++++++++++++++
 1 files changed, 69 insertions(+), 1 deletions(-)

diff --git a/src/main/java/org/springblade/common/cache/SysCache.java b/src/main/java/org/springblade/common/cache/SysCache.java
index 9f6c384..100c552 100644
--- a/src/main/java/org/springblade/common/cache/SysCache.java
+++ b/src/main/java/org/springblade/common/cache/SysCache.java
@@ -348,7 +348,6 @@
 	 * @return regionCode
 	 */
 	public static List<String> getPoliceRegionChildCodesByDeptId(String deptId,String communityCode) {
-		// 去重
 		List<String> regionCodeList = new ArrayList<>();
 		if (!Strings.isBlank(deptId)) {
 			//多个部门按逗号分割
@@ -376,6 +375,65 @@
 		}
 		return regionCodeList;
 	}
+
+
+	/**
+	 * 查询综治网格/公安相关的网格,社区编号集合
+	 * @param deptId
+	 * @param communityCode
+	 * @param roleName
+	 * @return
+	 */
+	public static List<String> getGridRegionChildCodesByDeptId(String deptId, String communityCode,String roleName) {
+		List<String> regionCodeList = new ArrayList<>();
+		if (!Strings.isBlank(deptId)) {
+			//多个部门按逗号分割
+			List<String> deptIdList = Arrays.asList(deptId.split(","));
+			List<String> finalRegionCodeList = regionCodeList;
+			String key = AuthUtil.getUserId().toString();
+			if (!Strings.isBlank(roleName)){
+				key = key + ":" + roleName;
+			}
+			String finalKey = key;
+			deptIdList.forEach(id -> {
+				List<String> list = new ArrayList<>();
+				// 查询对应的区域编号code
+				Dept dept = deptService.getById(id);
+				if (null != dept) {
+					if (
+						(roleName.equals("mj") && dept.getDeptNature()==1) ||
+						(
+							(roleName.equals("wgy") || roleName.equals("wzcj")) && dept.getDeptNature()==2
+						)
+					){
+						if (!AuthUtil.isAdministrator()) {
+							if (dept.getRegionCode() == null) {
+								return;
+							}
+							list = CacheUtil.get(SYS_CACHE, REGION_CHILDCODES_CODE, finalKey, List.class);
+							if (list == null || list.size() == 0) {
+								list = new ArrayList<>();
+								List<Region> deptChild = getGridRegionChild(dept.getRegionCode(), communityCode, roleName);
+								if (deptChild != null) {
+									List<String> collect = deptChild.stream().map(Region::getCode).collect(Collectors.toList());
+									list.addAll(collect);
+								}
+							}
+							//行政区划不为空添加进集合
+							if (list.size() > 0) {
+								finalRegionCodeList.addAll(list);
+							}
+						}
+					}
+				}
+			});
+			// 去重
+			regionCodeList = finalRegionCodeList.stream().distinct().collect(Collectors.toList());
+			CacheUtil.put(SYS_CACHE, REGION_CHILDCODES_CODE, key, regionCodeList);
+		}
+		return regionCodeList;
+	}
+
 
 	/**
 	 * 获取下级所有区域code
@@ -424,6 +482,15 @@
 	}
 
 	/**
+	 * 获取综治下级区域
+	 * @param regionCode
+	 * @return
+	 */
+	private static List<Region> getGridRegionChild(String regionCode, String communityCode,String roleName) {
+		return CacheUtil.get(SYS_CACHE, REGION_CHILD_CODE, regionCode, () -> regionService.getGridRegionChild(regionCode,communityCode,roleName));
+	}
+
+	/**
 	 * 获取民警下级区域
 	 * @param regionCode
 	 * @return
@@ -440,4 +507,5 @@
 	private static List<Region> getRegionChild(String regionCode,String communityCode) {
 		return CacheUtil.get(SYS_CACHE, REGION_CHILD_CODE, regionCode, () -> regionService.getRegionChild(regionCode,communityCode));
 	}
+
 }

--
Gitblit v1.9.3