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/controller/admin/UserController.java |  131 +++++++++++++++++++++++++++++++++++++------
 1 files changed, 113 insertions(+), 18 deletions(-)

diff --git a/src/main/java/com/mindskip/xzs/controller/admin/UserController.java b/src/main/java/com/mindskip/xzs/controller/admin/UserController.java
index 2c151d7..a645248 100644
--- a/src/main/java/com/mindskip/xzs/controller/admin/UserController.java
+++ b/src/main/java/com/mindskip/xzs/controller/admin/UserController.java
@@ -1,27 +1,28 @@
 package com.mindskip.xzs.controller.admin;
 
+import com.github.pagehelper.PageInfo;
 import com.mindskip.xzs.base.BaseApiController;
 import com.mindskip.xzs.base.RestResponse;
-import com.mindskip.xzs.domain.other.KeyValue;
-import com.mindskip.xzs.domain.User;
-import com.mindskip.xzs.domain.UserEventLog;
+import com.mindskip.xzs.domain.*;
 import com.mindskip.xzs.domain.enums.UserStatusEnum;
-import com.mindskip.xzs.service.AuthenticationService;
-import com.mindskip.xzs.service.UserEventLogService;
-import com.mindskip.xzs.service.UserService;
+import com.mindskip.xzs.domain.other.KeyValue;
+import com.mindskip.xzs.domain.vo.UserVO;
+import com.mindskip.xzs.repository.UserDepartmentMapper;
+import com.mindskip.xzs.service.*;
 import com.mindskip.xzs.utility.DateTimeUtil;
-import com.mindskip.xzs.viewmodel.admin.user.*;
 import com.mindskip.xzs.utility.PageInfoHelper;
-import com.github.pagehelper.PageInfo;
-
+import com.mindskip.xzs.utility.convert.UserClassConvert;
+import com.mindskip.xzs.utility.excel.ExcelUtils;
+import com.mindskip.xzs.viewmodel.admin.user.*;
+import org.apache.commons.lang3.ObjectUtils;
 import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
 
 import javax.validation.Valid;
-import java.util.Date;
-import java.util.List;
-import java.util.UUID;
+import java.util.*;
+import java.util.stream.Collectors;
 
 
 @RestController("AdminUserController")
@@ -31,19 +32,39 @@
     private final UserService userService;
     private final UserEventLogService userEventLogService;
     private final AuthenticationService authenticationService;
+    private final DepartmentService departmentService;
+    private final UserDepartmentMapper userDepartmentMapper;
+    private final TagService tagService;
 
     @Autowired
-    public UserController(UserService userService, UserEventLogService userEventLogService, AuthenticationService authenticationService) {
+    public UserController(UserService userService, UserEventLogService userEventLogService, AuthenticationService authenticationService, DepartmentService departmentService, UserDepartmentMapper userDepartmentMapper, TagService tagService) {
         this.userService = userService;
         this.userEventLogService = userEventLogService;
         this.authenticationService = authenticationService;
+        this.departmentService = departmentService;
+        this.userDepartmentMapper = userDepartmentMapper;
+        this.tagService = tagService;
     }
 
 
     @RequestMapping(value = "/page/list", method = RequestMethod.POST)
     public RestResponse<PageInfo<UserResponseVM>> pageList(@RequestBody UserPageRequestVM model) {
-        PageInfo<User> pageInfo = userService.userPage(model);
-        PageInfo<UserResponseVM> page = PageInfoHelper.copyMap(pageInfo, d -> UserResponseVM.from(d));
+        model.setDepartmentId(ObjectUtils.isNotEmpty(model.getDepartmentId()) ? model.getDepartmentId() : getAdminDeptIds());
+        PageInfo<UserResponseVM> page = userService.userPage(model);
+        page.setList(page.getList().stream().map(e->{
+            List<UserDepartment> userDepartments = userDepartmentMapper.selectByUserId(e.getId());
+            List<Department> list = new ArrayList<>();
+            for (UserDepartment userDepartment : userDepartments) {
+                Department byId = departmentService.getById(userDepartment.getDepartmentId());
+                if (ObjectUtils.isNotEmpty(byId)) {
+                    list.add(byId);
+                }
+            }
+            e.setDeptNames(StringUtils.join(list.stream().map(Department::getName).collect(Collectors.toList()), ","));
+            e.setDeptIdList(list.stream().map(Department::getId).collect(Collectors.toList()));
+            e.setTagNames(tagService.selectTagNamesByUserId(e.getId()));
+            return e;
+        }).collect(Collectors.toList()));
         return RestResponse.ok(page);
     }
 
@@ -61,8 +82,16 @@
 
     @RequestMapping(value = "/select/{id}", method = RequestMethod.POST)
     public RestResponse<UserResponseVM> select(@PathVariable Integer id) {
-        User user = userService.getUserById(id);
+        User user = userService.getUserInfoById(id);
         UserResponseVM userVm = UserResponseVM.from(user);
+        List<UserDepartment> userDepartments = userDepartmentMapper.selectByUserId(user.getId());
+        String deptIds = "";
+        for (UserDepartment userDepartment : userDepartments) {
+            deptIds = deptIds + userDepartment.getDepartmentId().toString() + ",";
+        }
+        userVm.setDeptIds(deptIds.equals("") ? "" : deptIds.substring(0,deptIds.length()-1));
+        userVm.setTagIds(tagService.selectTagIdsByUserId(user.getId()));
+        userVm.setPassword(authenticationService.pwdDecode(user.getPassword()));
         return RestResponse.ok(userVm);
     }
 
@@ -107,6 +136,30 @@
             user.setModifyTime(new Date());
             userService.updateByIdFilter(user);
         }
+        Map<Integer, UserDepartment> oldDeptUser = userDepartmentMapper.selectByUserId(user.getId()).stream().collect(Collectors.toMap(UserDepartment::getDepartmentId, userDept -> userDept));
+        userDepartmentMapper.removeByUserId(user.getId());
+        if (ObjectUtils.isNotEmpty(model.getDeptIds())) {
+            for (Integer s : model.getDeptIds()) {
+                UserDepartment userDepartment = new UserDepartment();
+                userDepartment.setUserId(user.getId());
+                userDepartment.setDepartmentId(s);
+                if (Objects.nonNull(oldDeptUser.get(s))) {
+                    userDepartment.setDeptAdmin(oldDeptUser.get(s).getDeptAdmin());
+                } else {
+                    userDepartment.setDeptAdmin("0");
+                }
+                userDepartmentMapper.insert(userDepartment);
+            }
+        }
+        tagService.removeUserTagByUserId(user.getId());
+        if (ObjectUtils.isNotEmpty(model.getTagIds())) {
+            tagService.saveBatchUserTag(model.getTagIds().stream().map(
+                    tagId -> new UserTag() {{
+                        setUserId(user.getId());
+                        setTagId(tagId);
+                    }}
+            ).collect(Collectors.toList()));
+        }
         return RestResponse.ok(user);
     }
 
@@ -123,7 +176,7 @@
 
     @RequestMapping(value = "/changeStatus/{id}", method = RequestMethod.POST)
     public RestResponse<Integer> changeStatus(@PathVariable Integer id) {
-        User user = userService.getUserById(id);
+        User user = userService.selectById(id);
         UserStatusEnum userStatusEnum = UserStatusEnum.fromCode(user.getStatus());
         Integer newStatus = userStatusEnum == UserStatusEnum.Enable ? UserStatusEnum.Disable.getCode() : UserStatusEnum.Enable.getCode();
         user.setStatus(newStatus);
@@ -135,7 +188,7 @@
 
     @RequestMapping(value = "/delete/{id}", method = RequestMethod.POST)
     public RestResponse delete(@PathVariable Integer id) {
-        User user = userService.getUserById(id);
+        User user = userService.getUserInfoById(id);
         user.setDeleted(true);
         userService.updateByIdFilter(user);
         return RestResponse.ok();
@@ -148,4 +201,46 @@
         return RestResponse.ok(keyValues);
     }
 
+    @PostMapping("/import")
+    public RestResponse importUser(@RequestPart("file") MultipartFile file) throws Exception {
+        List<UserVO> userVOS = ExcelUtils.readMultipartFile(file, UserVO.class)
+                .stream().map(e -> {
+                    e.setUserLevel(departmentService.getName(e.getDepartment()).getId());
+                    String encodePwd = authenticationService.pwdEncode(e.getPassword());
+                    e.setPassword(encodePwd);
+                    e.setUserUuid(UUID.randomUUID().toString());
+                    e.setCreateTime(new Date());
+                    e.setLastActiveTime(new Date());
+                    e.setDeleted(false);
+                    e.setAge(null);
+                    return e;
+                }).collect(Collectors.toList());
+        List<User> users = UserClassConvert.INSTANCE.UserVOListToUserList(userVOS);
+        userService.insertUsers(users);
+        return RestResponse.ok();
+    }
+
+    @RequestMapping(value = "/conversion", method = RequestMethod.GET)
+    public RestResponse conversion() {
+        List<User> users = userService.getUsers();
+        for (User user : users) {
+            UserDepartment userDepartment = new UserDepartment();
+            userDepartment.setUserId(user.getId());
+            userDepartment.setDepartmentId(user.getUserLevel());
+            userDepartmentMapper.insert(userDepartment);
+        }
+
+        return RestResponse.ok();
+    }
+
+    @GetMapping("/getFailExamUser/{examPaperId}")
+    public RestResponse<List<User>> getFailExamUser(@PathVariable Integer examPaperId) {
+        return RestResponse.ok(userService.getFailExamUser(examPaperId));
+    }
+
+    @GetMapping("/getFailTemplateUser/{templateId}")
+    public RestResponse<List<User>> getFailTemplateUser(@PathVariable Integer templateId) {
+        return RestResponse.ok(userService.getFailTemplateUser(templateId));
+    }
+
 }

--
Gitblit v1.8.0