From dce6874cfd280e5b6160bc103dff11e7f6073865 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期三, 19 六月 2024 10:19:53 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
src/main/java/com/ycl/jxkg/controller/wx/student/ExamPaperAnswerController.java | 114 ++++++++++++++++++++++++++++-----------------------------
1 files changed, 56 insertions(+), 58 deletions(-)
diff --git a/src/main/java/com/ycl/jxkg/controller/wx/student/ExamPaperAnswerController.java b/src/main/java/com/ycl/jxkg/controller/wx/student/ExamPaperAnswerController.java
index 483aca6..49b1487 100644
--- a/src/main/java/com/ycl/jxkg/controller/wx/student/ExamPaperAnswerController.java
+++ b/src/main/java/com/ycl/jxkg/controller/wx/student/ExamPaperAnswerController.java
@@ -1,25 +1,30 @@
package com.ycl.jxkg.controller.wx.student;
-import com.ycl.jxkg.base.RestResponse;
+import com.ycl.jxkg.base.Result;
import com.ycl.jxkg.controller.wx.BaseWXApiController;
import com.ycl.jxkg.domain.*;
-import com.ycl.jxkg.domain.enums.QuestionTypeEnum;
+import com.ycl.jxkg.domain.entity.ExamPaperAnswer;
+import com.ycl.jxkg.domain.entity.Subject;
+import com.ycl.jxkg.domain.entity.User;
+import com.ycl.jxkg.domain.entity.UserEventLog;
+import com.ycl.jxkg.enums.QuestionTypeEnum;
import com.ycl.jxkg.event.CalculateExamPaperAnswerCompleteEvent;
import com.ycl.jxkg.event.UserEvent;
import com.ycl.jxkg.service.ExamPaperAnswerService;
import com.ycl.jxkg.service.ExamPaperService;
import com.ycl.jxkg.service.SubjectService;
-import com.ycl.jxkg.utility.DateTimeUtil;
-import com.ycl.jxkg.utility.ExamUtil;
-import com.ycl.jxkg.utility.PageInfoHelper;
-import com.ycl.jxkg.viewmodel.admin.exam.ExamPaperEditRequestVM;
-import com.ycl.jxkg.viewmodel.student.exampaper.ExamPaperAnswerPageResponseVM;
-import com.ycl.jxkg.viewmodel.student.exampaper.ExamPaperAnswerPageVM;
+import com.ycl.jxkg.utils.DateTimeUtil;
+import com.ycl.jxkg.utils.ExamUtil;
+import com.ycl.jxkg.utils.PageInfoHelper;
+import com.ycl.jxkg.domain.vo.admin.exam.ExamPaperEditRequestVO;
+import com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO;
+import com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageVO;
import com.github.pagehelper.PageInfo;
-import com.ycl.jxkg.viewmodel.student.exam.ExamPaperReadVM;
-import com.ycl.jxkg.viewmodel.student.exam.ExamPaperSubmitItemVM;
-import com.ycl.jxkg.viewmodel.student.exam.ExamPaperSubmitVM;
-import org.springframework.beans.factory.annotation.Autowired;
+import com.ycl.jxkg.domain.vo.student.exam.ExamPaperReadVO;
+import com.ycl.jxkg.domain.vo.student.exam.ExamPaperSubmitItemVO;
+import com.ycl.jxkg.domain.vo.student.exam.ExamPaperSubmitVO;
+import lombok.RequiredArgsConstructor;
+import org.springframework.beans.BeanUtils;
import org.springframework.context.ApplicationEventPublisher;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
@@ -29,7 +34,7 @@
import java.util.*;
import java.util.stream.Collectors;
-
+@RequiredArgsConstructor
@Controller("WXStudentExamPaperAnswerController")
@RequestMapping(value = "/api/wx/student/exampaper/answer")
@ResponseBody
@@ -40,40 +45,33 @@
private final ApplicationEventPublisher eventPublisher;
private final ExamPaperService examPaperService;
- @Autowired
- public ExamPaperAnswerController(ExamPaperAnswerService examPaperAnswerService, SubjectService subjectService, ApplicationEventPublisher eventPublisher, ExamPaperService examPaperService) {
- this.examPaperAnswerService = examPaperAnswerService;
- this.subjectService = subjectService;
- this.eventPublisher = eventPublisher;
- this.examPaperService = examPaperService;
- }
-
@RequestMapping(value = "/pageList", method = RequestMethod.POST)
- public RestResponse<PageInfo<ExamPaperAnswerPageResponseVM>> pageList(@Valid ExamPaperAnswerPageVM model) {
+ public Result<PageInfo<ExamPaperAnswerPageResponseVO>> pageList(@Valid ExamPaperAnswerPageVO model) {
model.setCreateUser(getCurrentUser().getId());
PageInfo<ExamPaperAnswer> pageInfo = examPaperAnswerService.studentPage(model);
- PageInfo<ExamPaperAnswerPageResponseVM> page = PageInfoHelper.copyMap(pageInfo, e -> {
- ExamPaperAnswerPageResponseVM vm = modelMapper.map(e, ExamPaperAnswerPageResponseVM.class);
- Subject subject = subjectService.selectById(vm.getSubjectId());
- vm.setDoTime(ExamUtil.secondToVM(e.getDoTime()));
- vm.setSystemScore(ExamUtil.scoreToVM(e.getSystemScore()));
- vm.setUserScore(ExamUtil.scoreToVM(e.getUserScore()));
- vm.setPaperScore(ExamUtil.scoreToVM(e.getPaperScore()));
- vm.setSubjectName(subject.getName());
- vm.setCreateTime(DateTimeUtil.dateFormat(e.getCreateTime()));
- return vm;
+ PageInfo<ExamPaperAnswerPageResponseVO> page = PageInfoHelper.copyMap(pageInfo, e -> {
+ ExamPaperAnswerPageResponseVO vo = new ExamPaperAnswerPageResponseVO();
+ BeanUtils.copyProperties(e, vo);
+ Subject subject = subjectService.getById(vo.getSubjectId());
+ vo.setDoTime(ExamUtil.secondToVM(e.getDoTime()));
+ vo.setSystemScore(ExamUtil.scoreToVM(e.getSystemScore()));
+ vo.setUserScore(ExamUtil.scoreToVM(e.getUserScore()));
+ vo.setPaperScore(ExamUtil.scoreToVM(e.getPaperScore()));
+ vo.setSubjectName(subject.getName());
+ vo.setCreateTime(DateTimeUtil.dateFormat(e.getCreateTime()));
+ return vo;
});
- return RestResponse.ok(page);
+ return Result.ok(page);
}
@RequestMapping(value = "/answerSubmit", method = RequestMethod.POST)
- public RestResponse answerSubmit(HttpServletRequest request) {
- ExamPaperSubmitVM examPaperSubmitVM = requestToExamPaperSubmitVM(request);
+ public Result answerSubmit(HttpServletRequest request) {
+ ExamPaperSubmitVO examPaperSubmitVO = requestToExamPaperSubmitVM(request);
User user = getCurrentUser();
- ExamPaperAnswerInfo examPaperAnswerInfo = examPaperAnswerService.calculateExamPaperAnswer(examPaperSubmitVM, user);
+ ExamPaperAnswerInfo examPaperAnswerInfo = examPaperAnswerService.calculateExamPaperAnswer(examPaperSubmitVO, user);
if (null == examPaperAnswerInfo) {
- return RestResponse.fail(2, "璇曞嵎涓嶈兘閲嶅鍋�");
+ return Result.fail(2, "璇曞嵎涓嶈兘閲嶅鍋�");
}
ExamPaperAnswer examPaperAnswer = examPaperAnswerInfo.getExamPaperAnswer();
Integer userScore = examPaperAnswer.getUserScore();
@@ -85,51 +83,51 @@
userEventLog.setContent(content);
eventPublisher.publishEvent(new CalculateExamPaperAnswerCompleteEvent(examPaperAnswerInfo));
eventPublisher.publishEvent(new UserEvent(userEventLog));
- return RestResponse.ok(scoreVm);
+ return Result.ok(scoreVm);
}
- private ExamPaperSubmitVM requestToExamPaperSubmitVM(HttpServletRequest request) {
- ExamPaperSubmitVM examPaperSubmitVM = new ExamPaperSubmitVM();
- examPaperSubmitVM.setId(Integer.parseInt(request.getParameter("id")));
- examPaperSubmitVM.setDoTime(Integer.parseInt(request.getParameter("doTime")));
+ private ExamPaperSubmitVO requestToExamPaperSubmitVM(HttpServletRequest request) {
+ ExamPaperSubmitVO examPaperSubmitVO = new ExamPaperSubmitVO();
+ examPaperSubmitVO.setId(Integer.parseInt(request.getParameter("id")));
+ examPaperSubmitVO.setDoTime(Integer.parseInt(request.getParameter("doTime")));
List<String> parameterNames = Collections.list(request.getParameterNames()).stream()
.filter(n -> n.contains("_"))
.collect(Collectors.toList());
//棰樼洰绛旀鎸夊簭鍙峰垎缁�
Map<String, List<String>> questionGroup = parameterNames.stream().collect(Collectors.groupingBy(p -> p.substring(0, p.indexOf("_"))));
- List<ExamPaperSubmitItemVM> answerItems = new ArrayList<>();
+ List<ExamPaperSubmitItemVO> answerItems = new ArrayList<>();
questionGroup.forEach((k, v) -> {
- ExamPaperSubmitItemVM examPaperSubmitItemVM = new ExamPaperSubmitItemVM();
+ ExamPaperSubmitItemVO examPaperSubmitItemVO = new ExamPaperSubmitItemVO();
String p = v.get(0);
String[] keys = p.split("_");
- examPaperSubmitItemVM.setQuestionId(Integer.parseInt(keys[1]));
- examPaperSubmitItemVM.setItemOrder(Integer.parseInt(keys[0]));
+ examPaperSubmitItemVO.setQuestionId(Integer.parseInt(keys[1]));
+ examPaperSubmitItemVO.setItemOrder(Integer.parseInt(keys[0]));
QuestionTypeEnum typeEnum = QuestionTypeEnum.fromCode(Integer.parseInt(keys[2]));
if (v.size() == 1) {
String content = request.getParameter(p);
- examPaperSubmitItemVM.setContent(content);
+ examPaperSubmitItemVO.setContent(content);
if (typeEnum == QuestionTypeEnum.MultipleChoice) {
- examPaperSubmitItemVM.setContentArray(Arrays.asList(content.split(",")));
+ examPaperSubmitItemVO.setContentArray(Arrays.asList(content.split(",")));
}
} else { //澶氫釜绌� 濉┖棰�
List<String> answers = v.stream().sorted(Comparator.comparingInt(ExamUtil::lastNum)).map(inputKey -> request.getParameter(inputKey)).collect(Collectors.toList());
- examPaperSubmitItemVM.setContentArray(answers);
+ examPaperSubmitItemVO.setContentArray(answers);
}
- answerItems.add(examPaperSubmitItemVM);
+ answerItems.add(examPaperSubmitItemVO);
});
- examPaperSubmitVM.setAnswerItems(answerItems);
- return examPaperSubmitVM;
+ examPaperSubmitVO.setAnswerItems(answerItems);
+ return examPaperSubmitVO;
}
@PostMapping(value = "/read/{id}")
- public RestResponse<ExamPaperReadVM> read(@PathVariable Integer id) {
- ExamPaperReadVM vm = new ExamPaperReadVM();
- ExamPaperAnswer examPaperAnswer = examPaperAnswerService.selectById(id);
- ExamPaperEditRequestVM paper = examPaperService.examPaperToVM(examPaperAnswer.getExamPaperId());
- ExamPaperSubmitVM answer = examPaperAnswerService.examPaperAnswerToVM(examPaperAnswer.getId());
+ public Result<ExamPaperReadVO> read(@PathVariable Integer id) {
+ ExamPaperReadVO vm = new ExamPaperReadVO();
+ ExamPaperAnswer examPaperAnswer = examPaperAnswerService.getById(id);
+ ExamPaperEditRequestVO paper = examPaperService.examPaperToVM(examPaperAnswer.getExamPaperId());
+ ExamPaperSubmitVO answer = examPaperAnswerService.examPaperAnswerToVM(examPaperAnswer.getId());
vm.setPaper(paper);
vm.setAnswer(answer);
- return RestResponse.ok(vm);
+ return Result.ok(vm);
}
}
--
Gitblit v1.8.0