From 135090721ee50abef2577e61617d3f2b2e15bb4a Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期五, 09 五月 2025 18:19:07 +0800 Subject: [PATCH] Merge remote-tracking branch '喜望/dev-2.0.1' into dev-2.0.1 --- springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/api/SystemUserController.java | 38 ++++++++++++++++++++++++++++++++++++++ 1 files changed, 38 insertions(+), 0 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 b50f429..cbc75ff 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 @@ -1,6 +1,7 @@ package com.panzhihua.sangeshenbian.api; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.panzhihua.common.controller.BaseController; import com.panzhihua.common.interfaces.OperLog; @@ -67,6 +68,9 @@ @Resource private ISystemLogService systemLogService; + + @Resource + private ISystemUserLevelService systemUserLevelService; @@ -209,6 +213,16 @@ public R add(@RequestBody SystemUser systemUser){ Integer id = this.getLoginUserInfoSanGeShenBian().getId(); SystemUser user = systemUserService.getById(id); + List<SystemUserLevel> systemUserLevels = systemUser.getSystemUserLevels(); + if(systemUserLevels==null || systemUserLevels.isEmpty()){ + return R.fail("请选择账号层级"); + } + // 获取最高层级的用于原来的判断 + systemUserLevels.sort(Comparator.comparing(SystemUserLevel::getLevel)); + Integer level = systemUserLevels.get(0).getLevel(); + user.setAccountLevel(level); + + if(2 == user.getAccountLevel() && 1 == systemUser.getAccountLevel()){ return R.fail("不能添加市级账号"); } @@ -245,6 +259,13 @@ // 2.0.1 默认管理员 systemUser.setIsAdmin(1); systemUserService.save(systemUser); + + // 2.0.1添加账号层级 + systemUserLevels.forEach(e->{ + e.setSystemUserId(systemUser.getId()); + e.setStatus(1); + }); + systemUserLevelService.saveBatch(systemUserLevels); return R.ok(); } @@ -253,6 +274,10 @@ @ApiOperation(value = "编辑人员", tags = {"三个身边后台-人员管理"}) @SysLog(operatorCategory = "编辑账号",operId = 4) public R edit(@RequestBody SystemUser systemUser){ + List<SystemUserLevel> systemUserLevels = systemUser.getSystemUserLevels(); + if(systemUserLevels==null || systemUserLevels.isEmpty()){ + return R.fail("请选择账号层级"); + } long count = systemUserService.count(new LambdaQueryWrapper<SystemUser>().eq(SystemUser::getPhone, systemUser.getPhone()) .ne(SystemUser::getStatus, 3).ne(SystemUser::getId, systemUser.getId())); if(0 < count){ @@ -280,6 +305,15 @@ systemUser.setStatus(1); systemUser.setCreateTime(LocalDateTime.now()); systemUserService.updateById(systemUser); + // 移除原来层级 在添加新层级 + systemUserLevelService.remove(new LambdaQueryWrapper<SystemUserLevel>().eq(SystemUserLevel::getSystemUserId, systemUser.getId())); + systemUserLevels.forEach(e->{ + e.setSystemUserId(systemUser.getId()); + e.setStatus(1); + }); + systemUserLevelService.saveBatch(systemUserLevels); + + return R.ok(); } @@ -291,6 +325,7 @@ SystemUser systemUser = systemUserService.getById(id); systemUser.setStatus(3); systemUserService.updateById(systemUser); + systemUserLevelService.update(new LambdaUpdateWrapper<SystemUserLevel>().eq(SystemUserLevel::getSystemUserId, id).set(SystemUserLevel::getStatus,3)); return R.ok(systemUser.getName()); } @@ -300,6 +335,9 @@ @OperLog(operModul = "三个身边后台",operType = 0,businessType = "查询人员详情") public R<SystemUser> getSystemUserInfo(@PathVariable("id") Integer id){ SystemUser systemUser = systemUserService.getById(id); + List<SystemUserLevel> listBySystemUserId = systemUserLevelService.getListBySystemUserId(id); + listBySystemUserId.sort(Comparator.comparing(SystemUserLevel::getLevel)); + systemUser.setSystemUserLevels(listBySystemUserId); return R.ok(systemUser); } -- Gitblit v1.7.1