From 764d883b5ea3bdc06abbec548b6df0511e567978 Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Tue, 03 Sep 2024 09:46:05 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/binlog' into binlog

---
 src/main/java/org/springblade/modules/system/service/impl/RegionServiceImpl.java |  102 +++++++++++++++++++++++++++++++++++---------------
 1 files changed, 71 insertions(+), 31 deletions(-)

diff --git a/src/main/java/org/springblade/modules/system/service/impl/RegionServiceImpl.java b/src/main/java/org/springblade/modules/system/service/impl/RegionServiceImpl.java
index df5cc70..552d5b4 100644
--- a/src/main/java/org/springblade/modules/system/service/impl/RegionServiceImpl.java
+++ b/src/main/java/org/springblade/modules/system/service/impl/RegionServiceImpl.java
@@ -17,14 +17,13 @@
 package org.springblade.modules.system.service.impl;
 
 import com.baomidou.mybatisplus.core.conditions.Wrapper;
-import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-import com.google.common.collect.Lists;
 import org.apache.commons.lang3.StringUtils;
 import org.apache.logging.log4j.util.Strings;
 import org.springblade.common.cache.SysCache;
 import org.springblade.common.node.TreeStringNode;
+import org.springblade.common.utils.AuthUtils;
 import org.springblade.common.utils.NodeTreeUtil;
 import org.springblade.core.log.exception.ServiceException;
 import org.springblade.core.secure.utils.AuthUtil;
@@ -45,7 +44,6 @@
 import java.util.ArrayList;
 import java.util.List;
 import java.util.Map;
-import java.util.stream.Collectors;
 
 import static org.springblade.common.cache.RegionCache.*;
 
@@ -141,21 +139,27 @@
 	 */
 	@Override
 	public List<TreeStringNode> getTree(RegionParamVO region) {
-		List<String> regionChildCodesList = SysCache.getRegionChildCodesByDeptId(AuthUtil.getDeptId(),null);
-		Integer isAdministrator = AuthUtil.isAdministrator()==true?1:2;
-		if (null!=region.getDeptNature()){
+		List<String> regionChildCodesList = SysCache.getRegionChildCodesByDeptId(AuthUtil.getDeptId(), null);
+		Integer isAdministrator = AuthUtils.isAdministratorOrAdmin(AuthUtil.getUserRole()) == true ? 1 : 2;
+		if (null != region.getDeptNature()) {
 			// 公安
-			if (region.getDeptNature()==1){
+			if (region.getDeptNature() == 1) {
 				// 查询公安对应的辖区树
 				return NodeTreeUtil.getStringNodeTree(baseMapper.getPoliceTreeList());
 			}
 			// 综治的需要查到网格
 			if (region.getDeptNature()==2){
-				region.setCityCode("361100");
+				region.setCityCode("361102");
+				region.setDistrictCode("361102");
+			}
+			// 综治的需要查到网格
+			if (region.getDeptNature()==3){
+				region.setDistrictCode("361102");
 			}
 		}
 		// 非公安
-		return NodeTreeUtil.getStringNodeTree(baseMapper.getTreeList(region,regionChildCodesList,isAdministrator));
+		Map<String, TreeStringNode> treeList = baseMapper.getTreeList(region, regionChildCodesList, isAdministrator);
+		return NodeTreeUtil.getStringNodeTree(treeList);
 	}
 
 	/**
@@ -167,7 +171,7 @@
 	@Override
 	public List<TreeStringNode> getTownTree(String code) {
 		String regionCode = null;
-		if (!AuthUtil.isAdministrator() && !AuthUtil.isAdmin()){
+		if (!AuthUtil.isAdministrator() && !AuthUtil.isAdmin()) {
 			Dept dept = deptService.getById(AuthUtil.getDeptId());
 			if (null != dept) {
 				regionCode = dept.getRegionCode();
@@ -199,21 +203,21 @@
 		// 遍历处理
 		for (Region region : regionList) {
 			// 设置code
-			region.setCode(StringUtils.rightPad(region.getCode(),12,"0"));
+			region.setCode(StringUtils.rightPad(region.getCode(), 12, "0"));
 			// 设置parent_code
-			region.setParentCode(StringUtils.rightPad(region.getParentCode(),12,"0"));
+			region.setParentCode(StringUtils.rightPad(region.getParentCode(), 12, "0"));
 			// 设置Ancestors
 			setAncestors(region);
 			// 设置ProvinceCode
-			region.setProvinceCode(StringUtils.rightPad(region.getProvinceCode(),12,"0"));
+			region.setProvinceCode(StringUtils.rightPad(region.getProvinceCode(), 12, "0"));
 			// 设置CityCode
-			region.setCityCode(StringUtils.rightPad(region.getCityCode(),12,"0"));
+			region.setCityCode(StringUtils.rightPad(region.getCityCode(), 12, "0"));
 			// 设置DistrictCode
-			region.setDistrictCode(StringUtils.rightPad(region.getDistrictCode(),12,"0"));
+			region.setDistrictCode(StringUtils.rightPad(region.getDistrictCode(), 12, "0"));
 			// 设置TownCode
-			region.setTownCode(StringUtils.rightPad(region.getTownCode(),12,"0"));
+			region.setTownCode(StringUtils.rightPad(region.getTownCode(), 12, "0"));
 			// 设置VillageCode
-			region.setVillageCode(StringUtils.rightPad(region.getVillageCode(),12,"0"));
+			region.setVillageCode(StringUtils.rightPad(region.getVillageCode(), 12, "0"));
 			// 更新
 			updateById(region);
 		}
@@ -221,34 +225,36 @@
 
 	/**
 	 * Ancestors 字段处理
+	 *
 	 * @param region
 	 */
 	private void setAncestors(Region region) {
 		String[] split = region.getAncestors().split(",");
 		List<String> list = new ArrayList<>();
 		for (String s : split) {
-			list.add(StringUtils.rightPad(s,12,"0"));
+			list.add(StringUtils.rightPad(s, 12, "0"));
 		}
 		region.setAncestors(Strings.join(list, ','));
 	}
 
 	/**
 	 * 查询下级区域(拼接网格)
+	 *
 	 * @param regionCode
 	 * @return
 	 */
 	@Override
-	public List<Region> getRegionChild(String regionCode,String communityCode) {
+	public List<Region> getRegionChild(String regionCode, String communityCode) {
 		// 创建区域对象
 		List<Region> list = new ArrayList<>();
 		// 查询公安相关的区域数据
 		List<Region> regionList = baseMapper.getPoliceList(communityCode);
-		if (regionList.size()>0) {
-			List<Region> policeList = treeRegionList(regionList,regionCode, list);
+		if (regionList.size() > 0) {
+			List<Region> policeList = treeRegionList(regionList, regionCode, list);
 			list.addAll(policeList);
 		}
 		// 查询综治区域集合
-		List<Region> regionChildList = baseMapper.getRegionChildList(regionCode,null,null);
+		List<Region> regionChildList = baseMapper.getRegionChildList(regionCode, null, null);
 		list.addAll(regionChildList);
 		//  返回
 		return list;
@@ -256,17 +262,18 @@
 
 	/**
 	 * 获取民警下级区域
+	 *
 	 * @param regionCode
 	 * @return
 	 */
 	@Override
-	public List<Region> getPoliceRegionChild(String regionCode,String communityCode) {
+	public List<Region> getPoliceRegionChild(String regionCode, String communityCode) {
 		// 创建区域对象
 		List<Region> list = new ArrayList<>();
 		// 查询公安相关的区域数据
 		List<Region> regionList = baseMapper.getPoliceList(communityCode);
-		if (regionList.size()>0) {
-			List<Region> policeList = treeRegionList(regionList,regionCode, list);
+		if (regionList.size() > 0) {
+			List<Region> policeList = treeRegionList(regionList, regionCode, list);
 			list.addAll(policeList);
 		}
 		//  返回
@@ -275,6 +282,7 @@
 
 	/**
 	 * 获取综治下级区域
+	 *
 	 * @param regionCode
 	 * @return
 	 */
@@ -282,7 +290,7 @@
 	public List<Region> getGridRegionChild(String regionCode, String communityCode, String roleName) {
 		// 创建区域对象
 		List<Region> list = new ArrayList<>();
-		if (!Strings.isBlank(roleName) && roleName.equals("wgy")){
+		if (!Strings.isBlank(roleName) && roleName.equals("wgy")) {
 			// 查询综治区域集合
 			List<Region> regionChildList = baseMapper.getGridRegionChildList(regionCode);
 			list.addAll(regionChildList);
@@ -293,7 +301,7 @@
 				List<Region> policeList = treeRegionList(regionList,regionCode, list);
 				list.addAll(policeList);
 			}
-		}else {
+		} else {
 			// 查询综治区域集合
 			List<Region> regionChildList = baseMapper.getRegionChildList(regionCode, communityCode, roleName);
 			list.addAll(regionChildList);
@@ -304,18 +312,19 @@
 
 	/**
 	 * 获取某个父节点下面的所有子节点
+	 *
 	 * @param regionList
 	 * @param parentCode
 	 * @param list
 	 * @return
 	 */
-	public static List<Region> treeRegionList( List<Region> regionList, String parentCode,List<Region> list){
-		for(Region region: regionList){
+	public static List<Region> treeRegionList(List<Region> regionList, String parentCode, List<Region> list) {
+		for (Region region : regionList) {
 			//遍历出父id等于参数的id,add进子节点集合
-			if(region.getParentCode().equals(parentCode)){
+			if (region.getParentCode().equals(parentCode)) {
 				list.add(region);
 				//递归遍历下一级
-				treeRegionList(regionList,region.getCode(),list);
+				treeRegionList(regionList, region.getCode(), list);
 			}
 			if(region.getCode().equals(parentCode)){
 				// 本身也加入
@@ -324,4 +333,35 @@
 		}
 		return list;
 	}
+
+	/**
+	 * 查询当前文章范围对应的社区编号字符串集合
+	 * @param articleRange
+	 * @return
+	 */
+	@Override
+	public String getAllCommunityNameListString(String articleRange) {
+		// 分割后es搜索才有效果,不能用逗号分割
+		return String.join("\\",baseMapper.getAllCommunityNameListString(articleRange));
+	}
+
+	/**
+	 * 树列表-查询到社区的树
+	 *
+	 * @return
+	 */
+	@Override
+	public List<TreeStringNode> treeToCommunity(String isFiter) {
+		List<String> regionChildCodesList = SysCache.getRegionChildCodesByDeptId(AuthUtil.getDeptId(), null);
+		Integer isAdministrator;
+		// 判断是否是超级管理员,并且是否过滤,isfiter为空时,过滤
+		if (StringUtils.isBlank(isFiter)) {
+			isAdministrator = AuthUtils.isAdministratorOrAdmin(AuthUtil.getUserRole()) == true ? 1 : 2;
+		} else {
+			isAdministrator = 1;
+		}
+		// 查询
+		Map<String, TreeStringNode> treeList = baseMapper.treeToCommunity(regionChildCodesList, isAdministrator);
+		return NodeTreeUtil.getStringNodeTree(treeList);
+	}
 }

--
Gitblit v1.9.3