From 5912494a3298c006e47c0d81c8feb59ea978d43c Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期日, 07 七月 2024 22:14:15 +0800
Subject: [PATCH] 部门管理树状:分页

---
 src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java |   42 +++++++++++++++++++++++++++++++++++++-----
 1 files changed, 37 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java b/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java
index 9f1e521..d924abd 100644
--- a/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java
+++ b/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java
@@ -8,6 +8,7 @@
 import com.mindskip.xzs.domain.User;
 import com.mindskip.xzs.domain.UserDepartment;
 import com.mindskip.xzs.domain.vo.BaseSelect;
+import com.mindskip.xzs.domain.vo.CascaderDataVO;
 import com.mindskip.xzs.domain.vo.DepartmentVO;
 import com.mindskip.xzs.domain.vo.UpdateDeptAdminVO;
 import com.mindskip.xzs.repository.DepartmentMapper;
@@ -30,13 +31,10 @@
 @RequiredArgsConstructor
 public class DepartmentController extends BaseApiController {
 
-
     private final DepartmentService departmentService;
     private final UserService userService;
     private final UserDepartmentMapper userDepartmentMapper;
     private final DepartmentMapper departmentMapper;
-
-
 
     /**
      * 鑾峰彇閮ㄩ棬涓嬬敤鎴峰垪琛�(涓嬫媺)
@@ -64,8 +62,8 @@
 
 
     @RequestMapping(value = "/page/list", method = RequestMethod.POST)
-    public RestResponse<PageInfo<DepartmentResponseVM>> pageList(@RequestBody DepartmentResponseVM model) {
-        PageInfo<DepartmentResponseVM> pageInfo = departmentService.gets(model);
+    public RestResponse<List<DepartmentResponseVM>> pageList(@RequestBody DepartmentResponseVM model) {
+        List<DepartmentResponseVM> pageInfo = departmentService.gets(model);
         return RestResponse.ok(pageInfo);
     }
 
@@ -118,9 +116,43 @@
         return RestResponse.ok(res);
     }
 
+    @RequestMapping(value = "/getDepartmentUserByTemplateId", method = RequestMethod.POST)
+    public RestResponse<List<DepartmentVO>> getDepartmentUserByTemplateId(Integer templateId){
+        List<DepartmentVO> res = departmentService.gets(isDeptAdmin() ? getAdminDeptIds() : null)
+                .stream().map(e->{
+                    DepartmentVO departmentVO = new DepartmentVO();
+                    List<UserDepartment> userDepartments = userDepartmentMapper.selectByDepartmentId(e.getId());
+                    List<User> list = new ArrayList<>();
+                    for (UserDepartment userDepartment : userDepartments) {
+                        User user;
+                        // 閫夋嫨琛ヨ�冪敤鎴锋椂鏌ヨ绗﹀悎琛ヨ�冩潯浠剁殑鐢ㄦ埛
+                        if (templateId != null) {
+                            ExamPaper examPaper = new ExamPaper();
+                            examPaper.setCreateUser(userDepartment.getUserId());
+                            examPaper.setId(templateId);
+                            user = userService.getUserByExamByTemplateId(examPaper);
+                        } else {
+                            user = userService.getUserById(userDepartment.getUserId());
+                        }
+                        if (ObjectUtils.isNotEmpty(user)) {
+                            list.add(user);
+                        }
+                    }
+                    departmentVO.setUserList(list);
+                    departmentVO.setDepartment(e);
+                    return departmentVO;
+                }).collect(Collectors.toList());
+        return RestResponse.ok(res);
+    }
+
     @RequestMapping(value = "/getDeptAdmins", method = RequestMethod.GET)
     public RestResponse<List<Department>> getDeptAdmins(){
         return RestResponse.ok(userService.getDeptAdmins(isDeptAdmin() ? getCurrentUser().getId() : null));
     }
 
+    @GetMapping("/cascader")
+    public RestResponse<List<CascaderDataVO>> cascader(){
+        return RestResponse.ok(departmentService.cascader());
+    }
+
 }

--
Gitblit v1.8.0