From e11deb9e6fb08fa526175b3057e03f0e6ee40e18 Mon Sep 17 00:00:00 2001 From: ludc Date: 星期一, 24 七月 2023 20:11:01 +0800 Subject: [PATCH] 修改菜单别名重复问题 --- Source/UBCS/ubcs-service/ubcs-system/src/main/java/com/vci/ubcs/system/service/impl/MenuServiceImpl.java | 45 +++++++++++++++++++++++++++++++++++++-------- 1 files changed, 37 insertions(+), 8 deletions(-) diff --git a/Source/UBCS/ubcs-service/ubcs-system/src/main/java/com/vci/ubcs/system/service/impl/MenuServiceImpl.java b/Source/UBCS/ubcs-service/ubcs-system/src/main/java/com/vci/ubcs/system/service/impl/MenuServiceImpl.java index b926374..07612e6 100644 --- a/Source/UBCS/ubcs-service/ubcs-system/src/main/java/com/vci/ubcs/system/service/impl/MenuServiceImpl.java +++ b/Source/UBCS/ubcs-service/ubcs-system/src/main/java/com/vci/ubcs/system/service/impl/MenuServiceImpl.java @@ -17,6 +17,7 @@ package com.vci.ubcs.system.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.vci.ubcs.system.cache.SysCache; @@ -31,8 +32,11 @@ import com.vci.ubcs.system.wrapper.MenuWrapper; import lombok.AllArgsConstructor; import org.springblade.core.log.exception.ServiceException; +import org.springblade.core.mp.support.Condition; +import org.springblade.core.mp.support.Query; import org.springblade.core.secure.BladeUser; import org.springblade.core.secure.utils.AuthUtil; +import org.springblade.core.tool.api.R; import org.springblade.core.tool.constant.BladeConstant; import org.springblade.core.tool.node.ForestNodeMerger; import org.springblade.core.tool.node.TreeNode; @@ -73,11 +77,11 @@ } @Override - public List<MenuVO> lazyMenuList(Long parentId, Map<String, Object> param) { + public IPage<MenuVO> lazyMenuPage(Long parentId, Map<String, Object> param, Query query) { if (Func.isEmpty(Func.toStr(param.get(PARENT_ID)))) { parentId = null; } - return baseMapper.lazyMenuList(parentId, param); + return baseMapper.lazyMenuPage(parentId, param, Condition.getPage(query)); } @@ -266,15 +270,19 @@ @Override public boolean submit(Menu menu) { LambdaQueryWrapper<Menu> menuQueryWrapper = Wrappers.lambdaQuery(); + // 鏂板 if (menu.getId() == null) { - menuQueryWrapper.eq(Menu::getCode, menu.getCode()).or( - wrapper -> wrapper.eq(Menu::getName, menu.getName()).eq(Menu::getCategory, MENU_CATEGORY) - ); + //妫�楠屾槸鍚﹂噸澶嶈彍鍗曞埆鍚嶏紝鍙牎楠屽悓涓�鐖跺垎绫昏彍鍗曚笅鐨勭紪鍙锋槸鍚﹂噸澶� + menuQueryWrapper.eq(Menu::getParentId,menu.getParentId()!=null ? menu.getParentId():BladeConstant.TOP_PARENT_ID) + .eq(Menu::getCode, menu.getCode()) + .or(wrapper -> wrapper.eq(Menu::getName, menu.getName()).eq(Menu::getCategory, MENU_CATEGORY)) + ; } else { + // 淇敼 menuQueryWrapper.ne(Menu::getId, menu.getId()).and( - wrapper -> wrapper.eq(Menu::getCode, menu.getCode()).or( - o -> o.eq(Menu::getName, menu.getName()).eq(Menu::getCategory, MENU_CATEGORY) - ) + wrapper -> wrapper.eq(Menu::getCode, menu.getCode()) + .eq(Menu::getParentId,menu.getParentId()) + .or(o -> o.eq(Menu::getName, menu.getName()).eq(Menu::getCategory, MENU_CATEGORY)) ); } Long cnt = baseMapper.selectCount(menuQueryWrapper); @@ -294,4 +302,25 @@ return saveOrUpdate(menu); } + @Override + public List<Menu> getMenuButtonByType(String btmType) { + return baseMapper.selectMenuChildByBtnType(btmType); + } + + /** + * 瀵筀eepAlive鍊艰浆鎹㈡垚甯冨皵绫诲瀷杩涜灏佽 + * + * @param childMenu + * @return + */ + @Override + public void handleKeepAlive(List<MenuVO> childMenu) { + childMenu.forEach(list->{ + list.getMeta().put("keepAlive","true".equals(list.getKeepAlive())); + if(list.getChildren().size()>0){ + handleKeepAlive(list.getChildren()); + } + }); + } + } -- Gitblit v1.9.3