From ffb2063003d3e735f3f8848207078b75c3f05bfa Mon Sep 17 00:00:00 2001
From: kaiyu <404897439@qq.com>
Date: Fri, 21 May 2021 16:24:40 +0800
Subject: [PATCH] screen-manage 修改删除用户BUG
---
screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleMenuServiceImpl.java | 104 ++++++++++++++++++++++++++++++++-------------------
1 files changed, 65 insertions(+), 39 deletions(-)
diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleMenuServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleMenuServiceImpl.java
index 57b433f..0db0ef6 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleMenuServiceImpl.java
+++ b/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleMenuServiceImpl.java
@@ -16,14 +16,13 @@
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.ObjectUtils;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
+import java.util.stream.Collectors;
/**
* <p>
@@ -50,7 +49,16 @@
@Override
@Transactional
- public Map<String, Object> updateRoleMenu(List list, int id) {
+ public Map<String, Object> updateRoleMenu(List menuList, int id) {
+ //���������������
+ List supplementList = new ArrayList();
+ supplementList.addAll(menuList);
+ for (int i=0;i<supplementList.size();i++) {
+ supplementList.addAll(supplementParentMenus(Integer.parseInt(supplementList.get(i).toString())));
+ }
+ LinkedHashSet<Object> hashSet = new LinkedHashSet<>(supplementList);
+ ArrayList<Object> list = new ArrayList<>(hashSet);
+ //return null;
Map<String,Object> resultMap = new HashMap<>();
List<ManageMenu> manageMenusOld = manageMenuMapper.getManageMenuByRoleId(id);
QueryWrapper<ManageRoleMenu> wrapper = new QueryWrapper();
@@ -63,7 +71,7 @@
result = manageRoleMenuMapper.getDataByMenuIds(list,id);
}
List<Map> result1 = manageRoleMenuMapper.getDataByRoleId(id);
- if (manageRoleMenuMapper.selectCount(wrapper)==0 || result.size()==0){
+ if ((manageRoleMenuMapper.selectCount(wrapper)==0 || result.size()==0)&&list.size()!=0){
List<Map> insertList = new ArrayList<>();
for (Object temp:list) {
Map<String,Object> map = new HashMap<>();
@@ -74,47 +82,48 @@
if (insertList.size()!=0){
manageRoleMenuMapper.insertBatch(insertList);
}
- }
- List updateList = new ArrayList();
- for (Map manageRoleMenu:result1) {
- int have = 1;
- for (Object temp:list){
- if (manageRoleMenu.get("menu_id").equals(Integer.parseInt(temp.toString()))){
- have = 2;
+ }else {
+ List updateList = new ArrayList();
+ for (Map manageRoleMenu:result1) {
+ int have = 1;
+ for (Object temp:list){
+ if (manageRoleMenu.get("menu_id").equals(Integer.parseInt(temp.toString()))){
+ have = 2;
+ continue;
+ }
+ }
+ if (have == 2){
continue;
}
+ updateList.add(manageRoleMenu.get("menu_id"));
}
- if (have == 2){
- continue;
- }
- updateList.add(manageRoleMenu.get("menu_id"));
- }
- List insertList = new ArrayList();
- for (Object temp:list) {
- int have = 1;
- for (Map manageRoleMenu:result1){
- if (manageRoleMenu.get("menu_id").equals(Integer.parseInt(temp.toString()))){
- have = 2;
+ List insertList = new ArrayList();
+ for (Object temp:list) {
+ int have = 1;
+ for (Map manageRoleMenu:result1){
+ if (manageRoleMenu.get("menu_id").equals(Integer.parseInt(temp.toString()))){
+ have = 2;
+ continue;
+ }
+ }
+ if (have == 2){
continue;
}
+ insertList.add(temp);
}
- if (have == 2){
- continue;
+ if (updateList.size()>0){
+ manageRoleMenuMapper.updateDeleteStateByRoleIdMenuIds(updateList,id);
}
- insertList.add(temp);
- }
- if (updateList.size()>0){
- manageRoleMenuMapper.updateDeleteStateByRoleIdMenuIds(updateList,id);
- }
- if (insertList.size()>0){
- List mapList = new ArrayList();
- for (Object temp:insertList) {
- Map<String,Integer> insertMap = new HashMap<>();
- insertMap.put("role_id",id);
- insertMap.put("menu_id",Integer.parseInt(temp.toString()));
- mapList.add(insertMap);
+ if (insertList.size()>0){
+ List mapList = new ArrayList();
+ for (Object temp:insertList) {
+ Map<String,Integer> insertMap = new HashMap<>();
+ insertMap.put("role_id",id);
+ insertMap.put("menu_id",Integer.parseInt(temp.toString()));
+ mapList.add(insertMap);
+ }
+ manageRoleMenuMapper.insertBatch(mapList);
}
- manageRoleMenuMapper.insertBatch(mapList);
}
List<ManageMenu> manageMenusNew = manageMenuMapper.getManageMenuByRoleId(id);
List manageMenuOldList = new ArrayList();
@@ -142,4 +151,21 @@
resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
return resultMap;
}
+
+ /**
+ * @Description: ���������������
+ * @Param: [list, menuId]list���menuId������
+ * @return: void
+ * @Author: ���������
+ * @Date: 2021/4/7
+ */
+ private List supplementParentMenus(int menuId) {
+ List list = new ArrayList();
+ ManageMenu manageMenu = manageMenuMapper.getManageMenuById(menuId);
+ if (manageMenu.getParentId()!=0){
+ list.add(manageMenu.getParentId());
+ list.addAll(supplementParentMenus(manageMenu.getParentId()));
+ }
+ return list;
+ }
}
--
Gitblit v1.8.0