From d0542b6f8b7ead9cea467f12d989eaabb8ec6e60 Mon Sep 17 00:00:00 2001
From: luodangjia <luodangjia>
Date: 星期二, 07 一月 2025 17:06:57 +0800
Subject: [PATCH] 添加车辆运输路线记录

---
 medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java |   38 +++++++++++++++++++++++++++++++-------
 1 files changed, 31 insertions(+), 7 deletions(-)

diff --git a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java
index cdb4916..a531559 100644
--- a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java
+++ b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java
@@ -1,5 +1,6 @@
 package com.sinata.system.service.impl;
 
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.sinata.common.annotation.DataScope;
@@ -12,6 +13,7 @@
 import com.sinata.common.exception.ServiceException;
 import com.sinata.common.utils.BeanUtils;
 import com.sinata.common.utils.CollUtils;
+import com.sinata.common.utils.DateUtils;
 import com.sinata.common.utils.SecurityUtils;
 import com.sinata.common.utils.StringUtils;
 import com.sinata.common.utils.spring.SpringUtils;
@@ -465,14 +467,22 @@
     @Override
     public void saveRole(SysRoleDTO dto) {
         SysRole sysRole = BeanUtils.copyBean(dto, SysRole.class);
+
         if (!this.checkRoleNameUnique(sysRole)) {
             throw new ServiceException("保存角色'" + sysRole.getRoleName() + "'失败,角色名称已存在");
         }
-        if (Objects.nonNull(sysRole.getRoleId())) {
+        if (Objects.isNull(sysRole.getRoleId())) {
+            sysRole.setCreateBy(SecurityUtils.getUserId().toString());
+            sysRole.setCreateTime(DateUtils.getNowDate());
             baseMapper.insert(sysRole);
         } else {
+            // 删除角色与菜单关联
+            roleMenuMapper.deleteRoleMenuByRoleId(sysRole.getRoleId());
+            sysRole.setUpdateBy(SecurityUtils.getUserId().toString());
+            sysRole.setUpdateTime(DateUtils.getNowDate());
             baseMapper.updateById(sysRole);
         }
+        insertRoleMenu(sysRole);
     }
 
     /**
@@ -502,12 +512,15 @@
     @Override
     public List<SysRoleVO> getManageRoleList(LoginUser loginUser) {
         List<SysRoleVO> res = CollUtils.emptyList();
-        Long roleId = loginUser.getUser().getRoleId();
-        SysRole role = this.getById(roleId);
-        if (Objects.nonNull(role)) {
-            List<SysRole> list = this.lambdaQuery().in(SysRole::getRoleId, Arrays.asList(role.getManageRoleIdStr().split(","))).list();
-            if (CollUtils.isNotEmpty(list)) {
-                res = BeanUtils.copyToList(list, SysRoleVO.class);
+        Long userId = loginUser.getUserId();
+        SysUserRole sysUserRole = userRoleMapper.selectOne(Wrappers.lambdaQuery(SysUserRole.class).eq(SysUserRole::getUserId, userId).last("LIMIT 1"));
+        if (Objects.nonNull(sysUserRole)) {
+            SysRole role = this.getById(sysUserRole.getRoleId());
+            if (Objects.nonNull(role)) {
+                List<SysRole> list = this.lambdaQuery().in(SysRole::getRoleId, Arrays.asList(role.getManageRoleIdStr().split(","))).list();
+                if (CollUtils.isNotEmpty(list)) {
+                    res = BeanUtils.copyToList(list, SysRoleVO.class);
+                }
             }
         }
         return res;
@@ -554,4 +567,15 @@
         // 获取当前的权限菜单(有层级)
         return this.getMenuLevelList(menusId);
     }
+
+    /**
+     * 角色列表
+     *
+     * @return
+     */
+    @Override
+    public List<SysRoleVO> queryList() {
+        List<SysRole> list = list();
+        return BeanUtils.copyToList(list, SysRoleVO.class);
+    }
 }

--
Gitblit v1.7.1