From 00ef2e4c4c6a85af857be272cf74a7e43e6517f0 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期日, 16 三月 2025 03:42:16 +0800
Subject: [PATCH] 修改诉求流程和新增评价功能

---
 springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/api/SystemUserController.java |   72 ++++++++++++++++++++++++++++++++++--
 1 files changed, 68 insertions(+), 4 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/api/SystemUserController.java b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/api/SystemUserController.java
index d939818..834a67b 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/api/SystemUserController.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/api/SystemUserController.java
@@ -11,6 +11,7 @@
 import com.panzhihua.sangeshenbian.model.entity.SystemMenu;
 import com.panzhihua.sangeshenbian.model.entity.SystemRoleMenu;
 import com.panzhihua.sangeshenbian.model.entity.SystemUser;
+import com.panzhihua.sangeshenbian.model.vo.RegionVO;
 import com.panzhihua.sangeshenbian.service.ISystemMenuService;
 import com.panzhihua.sangeshenbian.service.ISystemRoleMenuService;
 import com.panzhihua.sangeshenbian.service.ISystemUserService;
@@ -22,6 +23,7 @@
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.BeanUtils;
 import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.util.ObjectUtils;
@@ -38,6 +40,7 @@
  * @Date 2025/2/18 22:30
  */
 @Api
+@Slf4j
 @RestController
 @RequestMapping("/systemUser")
 public class SystemUserController extends BaseController {
@@ -96,15 +99,75 @@
 		LoginReturnVO loginReturnVO = reult.getData();
 		TokenVo tokenVo = new TokenVo();
 		BeanUtils.copyProperties(loginReturnVO, tokenVo);
+		
 		List<SystemRoleMenu> list = systemRoleMenuService.list(new LambdaQueryWrapper<SystemRoleMenu>().eq(SystemRoleMenu::getSystemRoleId, systemUser.getSystemRoleId()));
 		List<Integer> collect = list.stream().map(SystemRoleMenu::getSystemMenuId).collect(Collectors.toList());
 		Set<String> collect1 = new HashSet<>();
 		if(collect.size() > 0){
-			List<SystemMenu> systemMenus = systemMenuService.listByIds(collect);
+			LambdaQueryWrapper<SystemMenu> queryWrapper = new LambdaQueryWrapper<SystemMenu>().in(SystemMenu::getId, collect);
+			switch (systemUser.getAccountLevel()){
+				case 2:
+					queryWrapper.notIn(SystemMenu::getUrl, Arrays.asList("/system_setting/position_management", "/system_setting/position_management/add", "/system_setting/position_management/del",
+							"/system_setting/role_management", "/system_setting/role_management/add", "/system_setting/role_management/edit", "/system_setting/role_management/del",
+							"/work_order_transaction_management/work_order_item_configuration", "/work_order_transaction_management/work_order_item_configuration/save",
+							"/work_order_transaction_management/problem_type_management", "/work_order_transaction_management/problem_type_management/add",
+							"/work_order_transaction_management/problem_type_management/edit", "/work_order_transaction_management/problem_type_management/del", "/work_order_transaction_management/banner_management",
+							"/work_order_transaction_management/banner_management/add", "/work_order_transaction_management/banner_management/edit", "/work_order_transaction_management/banner_management/del"));
+					break;
+				case 3:
+					queryWrapper.notIn(SystemMenu::getUrl, Arrays.asList("/system_setting/position_management", "/system_setting/position_management/add", "/system_setting/position_management/del",
+							"/system_setting/role_management", "/system_setting/role_management/add", "/system_setting/role_management/edit", "/system_setting/role_management/del",
+							"/work_order_transaction_management/work_order_item_configuration", "/work_order_transaction_management/work_order_item_configuration/save",
+							"/work_order_transaction_management/problem_type_management", "/work_order_transaction_management/problem_type_management/add",
+							"/work_order_transaction_management/problem_type_management/edit", "/work_order_transaction_management/problem_type_management/del", "/work_order_transaction_management/banner_management",
+							"/work_order_transaction_management/banner_management/add", "/work_order_transaction_management/banner_management/edit", "/work_order_transaction_management/banner_management/del"));
+					break;
+				case 4:
+					queryWrapper.notIn(SystemMenu::getUrl, Arrays.asList("/system_setting/position_management", "/system_setting/position_management/add", "/system_setting/position_management/del",
+							"/system_setting/role_management", "/system_setting/role_management/add", "/system_setting/role_management/edit", "/system_setting/role_management/del",
+							"/work_order_transaction_management/work_order_item_configuration", "/work_order_transaction_management/work_order_item_configuration/save",
+							"/work_order_transaction_management/problem_type_management", "/work_order_transaction_management/problem_type_management/add",
+							"/work_order_transaction_management/problem_type_management/edit", "/work_order_transaction_management/problem_type_management/del", "/work_order_transaction_management/banner_management",
+							"/work_order_transaction_management/banner_management/add", "/work_order_transaction_management/banner_management/edit", "/work_order_transaction_management/banner_management/del"));
+					break;
+				case 5:
+					queryWrapper.notIn(SystemMenu::getUrl, Arrays.asList("/system_setting/position_management", "/system_setting/position_management/add", "/system_setting/position_management/del",
+							"/system_setting/role_management", "/system_setting/role_management/add", "/system_setting/role_management/edit", "/system_setting/role_management/del",
+							"/system_setting/people_management", "/system_setting/people_management/add", "/system_setting/people_management/edit", "/system_setting/people_management/del",
+							"/system_setting/people_management/freeze", "/system_setting/unit_management", "/system_setting/people_management/detail", "/system_setting/unit_management/add",
+							"/system_setting/unit_management/edit", "/system_setting/unit_management/del", "/work_order_transaction_management/work_order_item_configuration",
+							"/work_order_transaction_management/work_order_item_configuration/save", "/work_order_transaction_management/problem_type_management",
+							"/work_order_transaction_management/problem_type_management/add", "/work_order_transaction_management/problem_type_management/edit",
+							"/work_order_transaction_management/problem_type_management/del", "/work_order_transaction_management/banner_management",
+							"/work_order_transaction_management/banner_management/add", "/work_order_transaction_management/banner_management/edit", "/work_order_transaction_management/banner_management/del"));
+					break;
+			}
+			List<SystemMenu> systemMenus = systemMenuService.list(queryWrapper);
 			collect1 = systemMenus.stream().map(SystemMenu::getUrl).collect(Collectors.toSet());
 		}
 		tokenVo.setMenu(collect1);
 		tokenVo.setName(systemUser.getName());
+		tokenVo.setAccountLevel(systemUser.getAccountLevel());
+		switch (systemUser.getAccountLevel()){
+			case 1:
+				tokenVo.setCityCode("510400");
+				break;
+			case 2:
+				tokenVo.setCityCode("510400");
+				tokenVo.setDistrictsCode(systemUser.getDistrictsCode());
+				break;
+			case 3:
+				tokenVo.setCityCode("510400");
+				tokenVo.setDistrictsCode(systemUser.getDistrictsCode());
+				tokenVo.setStreetId(systemUser.getStreetId());
+				break;
+			case 4:
+				tokenVo.setCityCode("510400");
+				tokenVo.setDistrictsCode(systemUser.getDistrictsCode());
+				tokenVo.setStreetId(systemUser.getStreetId());
+				tokenVo.setCommunityId(systemUser.getCommunityId().toString());
+				break;
+		}
 		return R.ok(tokenVo);
 	}
 	
@@ -127,7 +190,7 @@
 	public R<IPage<SystemUserListVo>> list(SystemUserList query){
 		Integer id = this.getLoginUserInfoSanGeShenBian().getId();
 		SystemUser user = systemUserService.getById(id);
-		IPage<SystemUserListVo> list = systemUserService.list(user.getAccountLevel(), query);
+		IPage<SystemUserListVo> list = systemUserService.list(user, query);
 		return R.ok(list);
 	}
 	
@@ -253,8 +316,8 @@
 			@ApiImplicitParam(name = "tier", value = "数据层级(2=区县,3=街道,4=社区)", required = true, dataType = "int"),
 	})
 	@OperLog(operModul = "三个身边后台",operType = 0,businessType = "获取行政区划层级联动数据")
-	public R<List<Map<String, Object>>> getAdministrativeDivision(@PathVariable("id") String id, @PathVariable("tier") Integer tier){
-		List<Map<String, Object>> list = new ArrayList<>();
+	public R<List<RegionVO>> getAdministrativeDivision(@PathVariable("id") String id, @PathVariable("tier") Integer tier){
+		List<RegionVO> list = new ArrayList<>();
 		//区县
 		if(2 == tier){
 			list = systemUserService.getRegion("510400");
@@ -267,6 +330,7 @@
 		if(4 == tier){
 			list = systemUserService.getCommunity(id);
 		}
+		log.info("获取行政区划层级联动数据:{}", list);
 		return R.ok(list);
 	}
 }

--
Gitblit v1.7.1