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/ExamPaperController.java | 85 ++++++++++++++++++++++++++++++++++-------- 1 files changed, 69 insertions(+), 16 deletions(-) diff --git a/src/main/java/com/mindskip/xzs/controller/admin/ExamPaperController.java b/src/main/java/com/mindskip/xzs/controller/admin/ExamPaperController.java index f07bf1c..17bff2c 100644 --- a/src/main/java/com/mindskip/xzs/controller/admin/ExamPaperController.java +++ b/src/main/java/com/mindskip/xzs/controller/admin/ExamPaperController.java @@ -1,11 +1,13 @@ 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.ExamPaper; import com.mindskip.xzs.domain.ExamPaperSubject; +import com.mindskip.xzs.domain.vo.ExamTemplatesVO; import com.mindskip.xzs.domain.vo.PaperExcelVO; -import com.mindskip.xzs.domain.vo.UserCountExcelVO; +import com.mindskip.xzs.domain.vo.UserVO; import com.mindskip.xzs.service.ExamPaperDepartmentService; import com.mindskip.xzs.service.ExamPaperService; import com.mindskip.xzs.service.ExamPaperSubjectService; @@ -13,10 +15,7 @@ import com.mindskip.xzs.utility.DateTimeUtil; import com.mindskip.xzs.utility.PageInfoHelper; import com.mindskip.xzs.utility.excel.ExcelUtils; -import com.mindskip.xzs.viewmodel.admin.exam.ExamPaperPageRequestVM; -import com.mindskip.xzs.viewmodel.admin.exam.ExamPaperEditRequestVM; -import com.mindskip.xzs.viewmodel.admin.exam.ExamResponseVM; -import com.github.pagehelper.PageInfo; +import com.mindskip.xzs.viewmodel.admin.exam.*; import lombok.SneakyThrows; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; @@ -24,8 +23,9 @@ import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.validation.Valid; -import java.util.Arrays; +import java.util.Collections; import java.util.List; +import java.util.Objects; @RestController("AdminExamPaperController") @RequestMapping(value = "/api/admin/exam/paper") @@ -46,6 +46,10 @@ @RequestMapping(value = "/page", method = RequestMethod.POST) public RestResponse<PageInfo<ExamResponseVM>> pageList(@RequestBody ExamPaperPageRequestVM model) { +// model.setDeptIds(ObjectUtils.isNotEmpty(model.getDeptIds()) ? model.getDeptIds() : getAdminDeptIds()); + if (Objects.nonNull(model.getLevel())) { + model.setDeptIds(Collections.singletonList(model.getLevel())); + } model.setType("0"); PageInfo<ExamPaper> pageInfo = examPaperService.page(model); PageInfo<ExamResponseVM> page = PageInfoHelper.copyMap(pageInfo, e -> { @@ -53,6 +57,7 @@ vm.setCreateTime(DateTimeUtil.dateFormat(e.getCreateTime())); vm.setSubjectId(examPaperSubjectService.getByExamPaperId(vm.getId()) .stream().map(ExamPaperSubject::getSubjectId).toArray(Integer[]::new)); + vm.setCreateDepartment(examPaperDepartmentService.selectByUserId(vm.getCreateUser())); return vm; }); return RestResponse.ok(page); @@ -77,21 +82,52 @@ @RequestMapping(value = "/edit", method = RequestMethod.POST) - public RestResponse<ExamPaperEditRequestVM> edit(@RequestBody @Valid ExamPaperEditRequestVM model) throws Exception { - Object[] obj = Arrays.stream(model.getUserIds()).sorted().distinct().toArray(); - Integer[] userIds = new Integer[obj.length]; - for(int i = 0;i<obj.length;i++) { - userIds[i] = (Integer)obj[i]; - } - model.setUserIds(userIds); + public RestResponse<ExamPaperEditRequestVO> edit(@RequestBody @Valid ExamPaperEditRequestVM model) throws Exception { + // Object[] obj = Arrays.stream(model.getUserIds()).sorted().distinct().toArray(); + // Integer[] userIds = new Integer[obj.length]; + // for(int i = 0;i<obj.length;i++) { + // userIds[i] = (Integer)obj[i]; + // } + // model.setUserIds(userIds); ExamPaper examPaper = examPaperService.savePaperFromVM(model, getCurrentUser()); - ExamPaperEditRequestVM newVM = examPaperService.examPaperToVM(examPaper.getId()); + ExamPaperEditRequestVO newVM = examPaperService.examPaperToVM(examPaper.getId()); + return RestResponse.ok(newVM); } + /** + * 琛ヨ�� + * @param model 鏁版嵁 + * @return 鎿嶄綔缁撴灉 + */ + @RequestMapping(value = "/missExam", method = RequestMethod.POST) + public RestResponse<String> missExam(@RequestBody ExamPaperEditRequestVM model) { + examPaperService.missExam(model); + return RestResponse.ok("鎿嶄綔鎴愬姛"); + } + + /** + * 琛ヨ�� + * @param model 鏁版嵁 + * @return 鎿嶄綔缁撴灉 + */ + @RequestMapping(value = "/missExamByTemplateId", method = RequestMethod.POST) + public RestResponse<String> missExamByTemplateId(@RequestBody ExamTemplatesVO model) { + examPaperService.missExamByTemplateId(model); + return RestResponse.ok("鎿嶄綔鎴愬姛"); + } + @RequestMapping(value = "/select/{id}", method = RequestMethod.POST) - public RestResponse<ExamPaperEditRequestVM> select(@PathVariable Integer id) { - ExamPaperEditRequestVM vm = examPaperService.examPaperToVM(id); + public RestResponse<ExamPaperEditRequestVO> select(@PathVariable Integer id) { + ExamPaperEditRequestVO vm = examPaperService.examPaperToVM(id); + for (ExamPaperTitleItemVO titleItem : vm.getTitleItems()) { + titleItem.getQuestionItems().stream().forEach(question -> { + // 娓呯┖绛旀銆佽В鏋� + question.setCorrect(""); + question.setAnalyze(""); + question.setCorrectArray(null); + }); + } return RestResponse.ok(vm); } @@ -111,4 +147,21 @@ List<PaperExcelVO> list = examPaperService.getPaperExcelById(id); ExcelUtils.export(response,"涓汉缁冧範",list,PaperExcelVO.class); } + + @RequestMapping(value = "/list", method = RequestMethod.GET) + public RestResponse<List<ExamPaper>> list() { + List<Integer> deptIds = isDeptAdmin() ? getAdminDeptIds() : null; + return RestResponse.ok(examPaperService.list(deptIds)); + } + + @RequestMapping(value = "/selectStudent", method = RequestMethod.POST) + public RestResponse<PageInfo<UserVO>> selectStudent(@RequestBody UserVO userVO) { + List<Integer> adminDeptIds = getAdminDeptIds(); + return RestResponse.ok(examPaperService.selectStudent(userVO, adminDeptIds)); + } + + @RequestMapping(value = "/queryCondition", method = RequestMethod.GET) + public RestResponse<List<ExamPaper>> queryCondition() { + return RestResponse.ok(examPaperService.queryCondition()); + } } -- Gitblit v1.8.0