From c50e176c4a6b9331d2d1c0520bafb18f54f0dee6 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期五, 08 三月 2024 17:35:10 +0800
Subject: [PATCH] 部门增加管理员

---
 src/main/java/com/mindskip/xzs/service/impl/DepartmentServiceImpl.java |   45 +++++++++++++++++++++++++++++++++++++++------
 1 files changed, 39 insertions(+), 6 deletions(-)

diff --git a/src/main/java/com/mindskip/xzs/service/impl/DepartmentServiceImpl.java b/src/main/java/com/mindskip/xzs/service/impl/DepartmentServiceImpl.java
index 0c737eb..d138d98 100644
--- a/src/main/java/com/mindskip/xzs/service/impl/DepartmentServiceImpl.java
+++ b/src/main/java/com/mindskip/xzs/service/impl/DepartmentServiceImpl.java
@@ -5,11 +5,13 @@
 import com.github.pagehelper.PageInfo;
 import com.mindskip.xzs.domain.Department;
 import com.mindskip.xzs.domain.UserDepartment;
+import com.mindskip.xzs.domain.enums.DeptAdminEnum;
 import com.mindskip.xzs.domain.vo.BaseSelect;
 import com.mindskip.xzs.domain.vo.UpdateDeptAdminVO;
 import com.mindskip.xzs.repository.BaseMapper;
 import com.mindskip.xzs.repository.DepartmentMapper;
 import com.mindskip.xzs.repository.UserDepartmentMapper;
+import com.mindskip.xzs.repository.UserMapper;
 import com.mindskip.xzs.service.DepartmentService;
 import com.mindskip.xzs.utility.ModelMapperSingle;
 import com.mindskip.xzs.viewmodel.admin.department.DepartmentResponseVM;
@@ -27,11 +29,13 @@
 
     private final DepartmentMapper departmentMapper;
     private final UserDepartmentMapper userDepartmentMapper;
+    private final UserMapper userMapper;
 
-    public DepartmentServiceImpl(BaseMapper<Department> baseMapper, DepartmentMapper departmentMapper, UserDepartmentMapper userDepartmentMapper) {
+    public DepartmentServiceImpl(BaseMapper<Department> baseMapper, DepartmentMapper departmentMapper, UserDepartmentMapper userDepartmentMapper, UserMapper userMapper) {
         super(baseMapper);
         this.departmentMapper = departmentMapper;
         this.userDepartmentMapper = userDepartmentMapper;
+        this.userMapper = userMapper;
     }
 
     @Override
@@ -54,7 +58,24 @@
     @Override
     public Integer update(Department department) {
 //        userDepartmentMapper.removeByDepartmentId(department.getId());
-        return departmentMapper.update(department);
+        Department entity = departmentMapper.getById(department.getId());
+        if (Objects.isNull(entity)) {
+            throw new RuntimeException("璇ラ儴闂ㄤ笉瀛樺湪");
+        }
+        if (Objects.nonNull(department.getAdminId())) {
+            if (! Objects.equals(entity.getAdminId(), department.getAdminId())) {
+                // 鍙栨秷鍘熷厛鐨勭鐞嗗憳鏍囪瘑
+                List<Integer> depIds = departmentMapper.selectByAdminId(entity.getAdminId());
+                depIds.remove(department.getId());
+                if (depIds.size() < 1) {
+                    userMapper.updateDeptAdmin(entity.getAdminId(), DeptAdminEnum.NO.getValue());
+                }
+            }
+            // 鏍囪瘑閮ㄩ棬绠$悊鍛�
+            userMapper.updateDeptAdmin(department.getAdminId(), DeptAdminEnum.YES.getValue());
+        }
+        Integer update = departmentMapper.update(department);
+        return update;
     }
 
     @Override
@@ -91,11 +112,23 @@
 
     @Override
     public void updateAdmin(UpdateDeptAdminVO form) {
-        Department department = departmentMapper.getById(form.getId());
-        if (Objects.isNull(department)) {
+        Department entity = departmentMapper.getById(form.getId());
+        if (Objects.isNull(form)) {
             throw new RuntimeException("璇ラ儴闂ㄤ笉瀛樺湪");
         }
-        department.setAdminId(form.getDeptAdmin());
-        departmentMapper.update(department);
+        if (Objects.nonNull(form.getAdminId())) {
+            if (! Objects.equals(entity.getAdminId(), form.getAdminId())) {
+                // 鍙栨秷鍘熷厛鐨勭鐞嗗憳鏍囪瘑
+                List<Integer> depIds = departmentMapper.selectByAdminId(entity.getAdminId());
+                depIds.remove(form.getId());
+                if (depIds.size() < 1) {
+                    userMapper.updateDeptAdmin(entity.getAdminId(), DeptAdminEnum.NO.getValue());
+                }
+            }
+            // 鏍囪瘑閮ㄩ棬绠$悊鍛�
+            userMapper.updateDeptAdmin(form.getAdminId(), DeptAdminEnum.YES.getValue());
+        }
+        entity.setAdminId(form.getAdminId());
+        departmentMapper.update(entity);
     }
 }

--
Gitblit v1.8.0