From 15f4681cd32306b7efb04818e2c47cf6caa251de Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期三, 13 四月 2022 18:06:07 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/MenuService.java |   29 ++++++++++++++++++++++-------
 1 files changed, 22 insertions(+), 7 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/MenuService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/MenuService.java
index 5516885..7b1fde8 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/MenuService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/MenuService.java
@@ -2,6 +2,7 @@
 
 import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.util.StrUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.sandu.common.enums.RoleLevelStatus;
 import com.sandu.common.execption.BusinessException;
@@ -35,6 +36,7 @@
 public class MenuService extends BaseServiceImpl<MenuMapper, Menu> {
 
     private final RoleMenuRelationService roleMenuRelationService;
+
     /**
      * 鑾峰彇瑙掕壊涓嬬殑鑿滃崟
      */
@@ -49,7 +51,8 @@
 
     public boolean addMenu(MenuParam param) {
         Menu menu = new Menu();
-        BeanUtils.copyProperties(param,menu);
+        BeanUtils.copyProperties(param, menu);
+        menu.setPermission(param.getRouterName());
         return save(menu);
     }
 
@@ -78,7 +81,7 @@
         return node;
     }
 
-    public boolean updateMenu(Long menuId,MenuParam param) {
+    public boolean updateMenu(Long menuId, MenuParam param) {
         Menu one = getById(menuId);
         if (one == null) {
             throw new BusinessException("鎵句笉鍒拌彍鍗曚俊鎭�");
@@ -86,22 +89,26 @@
 
         List<Role> roles = SpringContextHolder.getBean(RoleService.class).listByAdminId(SecurityUtils.getUserId());
         Integer roleLevel = roles.stream().map(Role::getLevel).min(Integer::compareTo).orElse(RoleLevelStatus.COMMON.getCode());
-        if(!RoleLevelStatus.SUPER.getCode().equals(roleLevel)){
+        if (!RoleLevelStatus.SUPER.getCode().equals(roleLevel)) {
             throw new BusinessException("瓒呯骇绠$悊鍛樻墠鍙互缂栬緫鑿滃崟");
         }
 
         Menu menu = new Menu();
-        BeanUtils.copyProperties(param,menu);
+        BeanUtils.copyProperties(param, menu);
+        menu.setPermission(param.getRouterName());
         menu.setId(menuId);
         return updateById(menu);
     }
 
     public List<MenuNode> treeList() {
-        List<Menu> list = list();
+        LambdaQueryWrapper<Menu> menuLambdaQueryWrapper = Wrappers.lambdaQuery(Menu.class).orderByAsc(Menu::getSeq);
+        List<Menu> list = list(menuLambdaQueryWrapper);
         return list.stream()
                 .filter(menu -> menu.getPid().equals(0L))
                 .map(menu -> covertMenuNode(menu, list)).collect(Collectors.toList());
     }
+
+    private MenuMapper menuMapper;
 
     public boolean delMenu(Long menuId) {
         Menu one = getById(menuId);
@@ -111,9 +118,17 @@
 
         List<Role> roles = SpringContextHolder.getBean(RoleService.class).listByAdminId(SecurityUtils.getUserId());
         Integer roleLevel = roles.stream().map(Role::getLevel).min(Integer::compareTo).orElse(RoleLevelStatus.COMMON.getCode());
-        if(!RoleLevelStatus.SUPER.getCode().equals(roleLevel)){
+        if (!RoleLevelStatus.SUPER.getCode().equals(roleLevel)) {
             throw new BusinessException("瓒呯骇绠$悊鍛樻墠鍙互鍒犻櫎鑿滃崟");
         }
-        return removeById(menuId);
+        List<Long> list = menuMapper.listMenuIfBinding(menuId);
+        List<Long> list1 = menuMapper.listMenuIfBinding1(menuId);
+
+        if (list.size() == 0 && list1.size() == 0) {
+            return removeById(menuId);
+        } else {
+            throw new BusinessException("鑿滃崟姝e湪浣跨敤锛岃鍕垮垹闄�");
+        }
+
     }
 }

--
Gitblit v1.9.3