From 3ec909b27b3eba956aa9d00cc7a94c179bd04bbf Mon Sep 17 00:00:00 2001 From: 龚焕茏 <2842157468@qq.com> Date: 星期三, 03 七月 2024 18:29:31 +0800 Subject: [PATCH] feat:新增随机时间题目配置 --- src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java | 65 ++++++++++++++++++++++++-------- 1 files changed, 49 insertions(+), 16 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 5228899..6e85feb 100644 --- a/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java +++ b/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java @@ -4,27 +4,24 @@ import com.mindskip.xzs.base.BaseApiController; import com.mindskip.xzs.base.RestResponse; import com.mindskip.xzs.domain.Department; +import com.mindskip.xzs.domain.ExamPaper; 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.DepartmentVO; import com.mindskip.xzs.domain.vo.UpdateDeptAdminVO; -import com.mindskip.xzs.domain.vo.UserVO; import com.mindskip.xzs.repository.DepartmentMapper; import com.mindskip.xzs.repository.UserDepartmentMapper; import com.mindskip.xzs.service.DepartmentService; import com.mindskip.xzs.service.UserService; -import com.mindskip.xzs.utility.PageInfoHelper; import com.mindskip.xzs.viewmodel.admin.department.DepartmentResponseVM; import lombok.RequiredArgsConstructor; import org.apache.commons.lang3.ObjectUtils; -import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import javax.validation.Valid; import java.util.ArrayList; import java.util.List; -import java.util.Objects; import java.util.stream.Collectors; @@ -61,7 +58,7 @@ @RequestMapping(value = "/list", method = RequestMethod.POST) public RestResponse<List<Department>> getAll(){ - List<Department> res = departmentService.gets(-1); + List<Department> res = departmentService.gets(new ArrayList<>()); return RestResponse.ok(res); } @@ -93,22 +90,23 @@ } @RequestMapping(value = "/getDepartmentUser", method = RequestMethod.POST) - public RestResponse<List<DepartmentVO>> getUserDepartment(){ - User currentUser = webContext.getCurrentUser(); - Integer deptId = null; - if (Objects.nonNull(currentUser)) { - // 濡傛灉鏄儴闂ㄧ鐞嗗憳锛岄渶瑕佸仛鏁版嵁鏉冮檺 - if ("1".equals(currentUser.getDeptAdmin())) { - deptId = departmentMapper.selectByAdminId(currentUser.getId()); - } - } - List<DepartmentVO> res = departmentService.gets(deptId) + public RestResponse<List<DepartmentVO>> getUserDepartment(Integer examPaperId){ + 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 = userService.getUserById(userDepartment.getUserId()); + User user; + // 閫夋嫨琛ヨ�冪敤鎴锋椂鏌ヨ绗﹀悎琛ヨ�冩潯浠剁殑鐢ㄦ埛 + if (examPaperId != null) { + ExamPaper examPaper = new ExamPaper(); + examPaper.setCreateUser(userDepartment.getUserId()); + examPaper.setId(examPaperId); + user = userService.getUserByExam(examPaper); + } else { + user = userService.getUserById(userDepartment.getUserId()); + } if (ObjectUtils.isNotEmpty(user)) { list.add(user); } @@ -119,4 +117,39 @@ }).collect(Collectors.toList()); 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)); + } + } -- Gitblit v1.8.0