From 47cd9ecc0eff38ffe6b3b794b2bf197e958f4403 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期三, 14 五月 2025 15:50:57 +0800
Subject: [PATCH] bug:学员有状态不能修改问题

---
 src/main/java/com/mindskip/xzs/service/impl/DepartmentServiceImpl.java |  110 +++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 70 insertions(+), 40 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 c548f23..0389eab 100644
--- a/src/main/java/com/mindskip/xzs/service/impl/DepartmentServiceImpl.java
+++ b/src/main/java/com/mindskip/xzs/service/impl/DepartmentServiceImpl.java
@@ -1,11 +1,10 @@
 package com.mindskip.xzs.service.impl;
 
-import com.github.pagehelper.PageHelper;
-import com.github.pagehelper.PageInfo;
 import com.mindskip.xzs.domain.Department;
 import com.mindskip.xzs.domain.enums.DeptAdminEnum;
 import com.mindskip.xzs.domain.vo.BaseSelect;
 import com.mindskip.xzs.domain.vo.CascaderDataVO;
+import com.mindskip.xzs.domain.vo.DepartmentEditVO;
 import com.mindskip.xzs.domain.vo.UpdateDeptAdminVO;
 import com.mindskip.xzs.repository.BaseMapper;
 import com.mindskip.xzs.repository.DepartmentMapper;
@@ -13,8 +12,10 @@
 import com.mindskip.xzs.repository.UserMapper;
 import com.mindskip.xzs.service.DepartmentService;
 import com.mindskip.xzs.utility.ModelMapperSingle;
+import com.mindskip.xzs.utility.TreeUtils;
 import com.mindskip.xzs.viewmodel.admin.department.DepartmentResponseVM;
 import org.modelmapper.ModelMapper;
+import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.CollectionUtils;
@@ -39,11 +40,47 @@
     }
 
     @Override
-    public Integer add(String name) {
-        Department department = new Department();
-        department.setDeleted("0");
-        department.setName(name);
-        return departmentMapper.add(department);
+    public Integer add(Department model) {
+        model.setDeleted("0");
+        if (Objects.nonNull(model.getParentId())) {
+            // 鏌ュ嚭鐖剁骇鐨勫眰绾�
+            List<Integer> fatherList = departmentMapper.getFather(model.getParentId());
+            Collections.reverse(fatherList);
+            model.setLevel(fatherList.size() + 1);
+        }
+        return departmentMapper.add(model);
+    }
+
+    @Transactional(rollbackFor = Exception.class)
+    @Override
+    public Integer update(Department department) {
+        Department entity = departmentMapper.getById(department.getId());
+        if (Objects.isNull(entity)) {
+            throw new RuntimeException("璇ラ儴闂ㄤ笉瀛樺湪");
+        }
+        // 鍏堟竻闄や箣鍓嶇殑绠$悊鍛樻爣璇�
+        List<BaseSelect> deptUserList = userDepartmentMapper.getDeptUserList(entity.getId());
+        List<Integer> userIds = deptUserList.stream().map(BaseSelect::getId).collect(Collectors.toList());
+        if (! CollectionUtils.isEmpty(userIds)) {
+            userMapper.clearDeptAdmin(userIds, entity.getId());
+            userMapper.cancelUserDeptAdmin(userIds);
+        }
+        // 璁剧疆閮ㄩ棬绠$悊鍛�
+        if (! CollectionUtils.isEmpty(department.getAdminId())) {
+            userMapper.updateDeptAdmin(department.getAdminId(), DeptAdminEnum.YES.getValue(), entity.getId());
+            UpdateDeptAdminVO updateDeptAdminVO = new UpdateDeptAdminVO();
+            updateDeptAdminVO.setAdminIds(department.getAdminId());
+            userMapper.updateUserDeptAdmin(updateDeptAdminVO);
+        }
+        if (Objects.nonNull(department.getParentId())) {
+            // 鏌ュ嚭鐖剁骇鐨勫眰绾�
+            List<Integer> fatherList = departmentMapper.getFather(department.getParentId());
+            department.setLevel(fatherList.size() + 1);
+        } else {
+            department.setLevel(1);
+        }
+        Integer update = departmentMapper.update(department);
+        return update;
     }
 
     @Override
@@ -52,28 +89,6 @@
         department.setId(id);
         department.setDeleted("1");
         return departmentMapper.update(department);
-    }
-
-    @Transactional(rollbackFor = Exception.class)
-    @Override
-    public Integer update(Department department) {
-//        userDepartmentMapper.removeByDepartmentId(department.getId());
-        Department entity = departmentMapper.getById(department.getId());
-        if (Objects.isNull(entity)) {
-            throw new RuntimeException("璇ラ儴闂ㄤ笉瀛樺湪");
-        }
-        if (! CollectionUtils.isEmpty(department.getAdminId())) {
-            List<BaseSelect> deptUserList = userDepartmentMapper.getDeptUserList(entity.getId());
-            List<Integer> userIds = deptUserList.stream().map(BaseSelect::getId).collect(Collectors.toList());
-            if (! CollectionUtils.isEmpty(userIds)) {
-                // 鍏堟竻闄や箣鍓嶇殑绠$悊鍛樻爣璇�
-                userMapper.clearDeptAdmin(userIds, entity.getId());
-            }
-            // 鏍囪瘑閮ㄩ棬绠$悊鍛�
-            userMapper.updateDeptAdmin(department.getAdminId(), DeptAdminEnum.YES.getValue(), entity.getId());
-        }
-        Integer update = departmentMapper.update(department);
-        return update;
     }
 
     @Override
@@ -112,8 +127,23 @@
     }
 
     @Override
+    public DepartmentEditVO getByIdVO(Integer id) {
+        Department dept = departmentMapper.getById(id);
+        DepartmentEditVO vo = new DepartmentEditVO();
+        BeanUtils.copyProperties(dept, vo);
+        if (Objects.nonNull(dept.getParentId())) {
+            // 鏌ュ嚭瀹屾暣鐨勭埗绾D
+            List<Integer> fatherList = departmentMapper.getFather(dept.getParentId());
+            Collections.reverse(fatherList);
+            vo.setParentIds(fatherList);
+        }
+        vo.setAdminId(userDepartmentMapper.selectDeptAdmin(id));
+        return vo;
+    }
+
+    @Override
     public List<Department> gets(List<Integer> deptId) {
-        return departmentMapper.gets(deptId);
+        return TreeUtils.build(departmentMapper.gets(deptId));
     }
 
     @Override
@@ -138,20 +168,20 @@
         if (Objects.isNull(entity)) {
             throw new RuntimeException("璇ラ儴闂ㄤ笉瀛樺湪");
         }
+        List<BaseSelect> deptUserList = userDepartmentMapper.getDeptUserList(entity.getId());
+        List<Integer> userIds = deptUserList.stream().map(BaseSelect::getId).collect(Collectors.toList());
+        if (! CollectionUtils.isEmpty(userIds)) {
+            // 鍏堟竻闄や箣鍓嶇殑绠$悊鍛樻爣璇�
+            userMapper.clearDeptAdmin(userIds, entity.getId());
+            // 淇敼娌¤閫夋嫨鐨勭敤鎴峰苟涓斾笉鏄埆鐨勯儴闂ㄧ鐞嗗憳鐨勭敤鎴疯鑹蹭负1
+            userMapper.cancelUserDeptAdmin(userIds);
+        }
         if (! CollectionUtils.isEmpty(form.getAdminIds())) {
-            List<BaseSelect> deptUserList = userDepartmentMapper.getDeptUserList(entity.getId());
-            List<Integer> userIds = deptUserList.stream().map(BaseSelect::getId).collect(Collectors.toList());
-            if (! CollectionUtils.isEmpty(userIds)) {
-                // 鍏堟竻闄や箣鍓嶇殑绠$悊鍛樻爣璇�
-                userMapper.clearDeptAdmin(userIds, entity.getId());
-            }
             // 鏍囪瘑閮ㄩ棬绠$悊鍛�
             userMapper.updateDeptAdmin(form.getAdminIds(), DeptAdminEnum.YES.getValue(), entity.getId());
+            // 淇敼琚�夋嫨鐨勭敤鎴蜂负閮ㄩ棬绠$悊鍛�
+            userMapper.updateUserDeptAdmin(form);
         }
-        // 淇敼琚�夋嫨鐨勭敤鎴蜂负閮ㄩ棬绠$悊鍛�
-        userMapper.updateUserDeptAdmin(form);
-        // 淇敼娌¤閫夋嫨鐨勭敤鎴峰苟涓斾笉鏄埆鐨勯儴闂ㄧ鐞嗗憳鐨勭敤鎴疯鑹蹭负1
-        userMapper.cancelUserDeptAdmin(form);
     }
 
     @Override

--
Gitblit v1.8.0