From 318d743292e40a939619cd9425066e10d67cf482 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期二, 12 十一月 2024 18:20:44 +0800
Subject: [PATCH] 答题记录表、阅卷时保存答题记录

---
 src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java |   55 ++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 50 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java b/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java
index 678767c..1a77e99 100644
--- a/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java
+++ b/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java
@@ -2,6 +2,7 @@
 
 import com.alibaba.fastjson2.JSON;
 import com.alibaba.fastjson2.JSONArray;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
@@ -79,6 +80,7 @@
     private final UserMapper userMapper;
     private final ExamPaperScoreMapper examPaperScoreMapper;
     private final ExamPaperScoreService examPaperScoreService;
+    private final QuestionAnswerRecordMapper questionAnswerRecordMapper;
 
     private final Producer producer;
 
@@ -242,6 +244,13 @@
     public Result studentPage(ExamQuery query) {
         IPage<ExamVO> page = PageUtil.getPage(query, ExamVO.class);
         baseMapper.studentPage(page, query, webContext.getCurrentUser().getId());
+        for (ExamVO record : page.getRecords()) {
+            ExamSubmitTemp one = new LambdaQueryChainWrapper<>(examSubmitTempMapper)
+                    .eq(ExamSubmitTemp::getExamId, record.getId())
+                    .eq(ExamSubmitTemp::getUserId, webContext.getCurrentUser().getId())
+                    .one();
+            record.setIsContinue(Objects.isNull(one) || ExamSubmitTempStatusEnum.temp.equals(one.getExamSubmit()));
+        }
         return Result.ok().data(page.getRecords()).total(page.getTotal());
     }
 
@@ -550,10 +559,21 @@
      * @return
      */
     @Override
-    public Result all() {
-        List<Exam> entities = baseMapper.selectList(null);
+    public Result all(ExamQuery query) {
+        List<Exam> entities;
+        // 鍒ゆ柇濡傛灉examName涓虹┖鎴栫┖瀛楃涓诧紝鍒欐煡璇㈡墍鏈�
+        if (query.getExamName() == null || query.getExamName().isEmpty()) {
+            entities = baseMapper.selectList(null);
+        }else {
+            entities = baseMapper.selectList(new LambdaQueryWrapper<>(Exam.class).like(Exam::getExamName,query.getExamName()));
+        }
         List<ExamVO> vos = entities.stream()
-                .map(entity -> ExamVO.getVoByEntity(entity, null))
+                .map(entity -> {
+                    ExamVO vo = new ExamVO();
+                    vo = ExamVO.getVoByEntity(entity, vo);
+                    vo.setStatus(entity.getStatus().getDesc());
+                    return vo;
+                })
                 .collect(Collectors.toList());
         return Result.ok().data(vos);
     }
@@ -985,10 +1005,12 @@
         examPaperScore.setTotalScore(new BigDecimal(examPaperMark.getTotalScore()));
         examPaperScore.setJudgeUser(userId);
         examPaperScore.setJudgeTime(new Date());
-        if (!StringUtils.isEmpty(examPaperMark.getTitleItems())) {
+        if (!org.springframework.util.CollectionUtils.isEmpty(examPaperMark.getTitleItems())) {
             examPaperScore.setPaperContent(JSON.toJSONString(examPaperMark.getTitleItems()));
+            // 淇濆瓨绛旈璁板綍
+            this.saveQuestionAnswerRecord(examPaperMark.getUserId(), examPaperMark.getTitleItems());
         }
-        if (!StringUtils.isEmpty(examPaperMark.getNavbar())) {
+        if (!org.springframework.util.CollectionUtils.isEmpty(examPaperMark.getNavbar())) {
             examPaperScore.setNavbar(JSON.toJSONString(examPaperMark.getNavbar()));
         }
         long questionCorrect = 0;
@@ -1026,6 +1048,29 @@
         return Result.ok();
     }
 
+    /**
+     * 淇濆瓨绛旈璁板綍
+     *
+     * @param titleItems
+     */
+    private void saveQuestionAnswerRecord(Integer studentUserId, List<PaperFixQuestionVO> titleItems) {
+        for (PaperFixQuestionVO titleItem : titleItems) {
+            for (DoQuestionVO question : titleItem.getQuestionList()) {
+                QuestionAnswerRecord record = new QuestionAnswerRecord();
+                record.setQuestionType(titleItem.getQuestionType());
+                record.setUserId(studentUserId);
+                record.setDoRight(question.getRight());
+                record.setExamId(question.getExamId());
+                record.setQuestionId(question.getId());
+                record.setScore(question.getScore());
+                record.setUserAnswer(StringUtils.hasText(question.getAnswer()) ? question.getAnswer() : question.getAnswerList().stream().collect(Collectors.joining("銆�")));
+                questionAnswerRecordMapper.insert(record);
+            }
+        }
+
+
+    }
+
 
     @Override
     public Result monitorList(ExamQuery query) {

--
Gitblit v1.8.0