From 9a1c378ec5566a727efcb85120cdafd52c3ee9f1 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期四, 23 五月 2024 16:21:37 +0800
Subject: [PATCH] 在线练习增加练习模式、融合在线练题

---
 src/main/java/com/mindskip/xzs/service/impl/SelfPracticeServiceImpl.java |   60 +++++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 53 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/mindskip/xzs/service/impl/SelfPracticeServiceImpl.java b/src/main/java/com/mindskip/xzs/service/impl/SelfPracticeServiceImpl.java
index d137530..6040be6 100644
--- a/src/main/java/com/mindskip/xzs/service/impl/SelfPracticeServiceImpl.java
+++ b/src/main/java/com/mindskip/xzs/service/impl/SelfPracticeServiceImpl.java
@@ -10,6 +10,7 @@
 import com.mindskip.xzs.domain.PracticeQuestionCondition;
 import com.mindskip.xzs.domain.Question;
 import com.mindskip.xzs.domain.SelfPractice;
+import com.mindskip.xzs.domain.enums.PracticeModeENum;
 import com.mindskip.xzs.domain.enums.PracticeQuestionTypeEnum;
 import com.mindskip.xzs.domain.enums.PracticeTypeEnum;
 import com.mindskip.xzs.domain.enums.QuestionTypeEnum;
@@ -147,7 +148,7 @@
                 throw new RuntimeException("娌℃湁鎵惧埌棰樼洰锛屽彲鑳芥墍閫夎鐩寘鍚鐩笉瓒�");
             }
             QuestionVO questionVO = one.get(0);
-            jsonQuestion(questionVO);
+            jsonQuestion(questionVO, Boolean.TRUE);
             return RestResponse.ok(questionVO);
         }
         return RestResponse.ok();
@@ -165,9 +166,52 @@
             throw new RuntimeException("娌℃湁鎵惧埌棰樼洰锛屽彲鑳芥墍閫夎鐩寘鍚鐩笉瓒�");
         }
         QuestionVO questionVO = one.get(0);
-        jsonQuestion(questionVO);
+        jsonQuestion(questionVO, Boolean.TRUE);
 
         return RestResponse.ok(questionVO);
+    }
+
+    @Override
+    public RestResponse startLook(Integer id) {
+        SelfPractice en = selfPracticeMapper.selectById(id);
+        if (Objects.isNull(en)) {
+            throw new RuntimeException("缁冧範涓嶅瓨鍦�");
+        }
+        List<Integer> subjectIds = JSON.parseArray(en.getSubjects(), Integer.class);
+        if (PracticeTypeEnum.ORDERED.getValue().equals(en.getPracticeType())) {
+            List<SubjectQuestionVO> list = new ArrayList<>(2);
+            // 椤哄簭鍋氶锛屾妸閫夋嫨鐨勯搴撶殑棰�(id)鍏ㄩ儴鏌ュ嚭鏉ワ紝鍓嶇鏈変釜搴忓彿闈㈡澘锛岀偣鍑诲摢閬撻鍋氬摢閬�
+            for (Integer subjectId : subjectIds) {
+                // 鏌ヨ鐩悕瀛�
+                String subjectName = subjectMapper.selectSubjectNameById(subjectId);
+                List<QuestionVO> questionVOs = new ArrayList<>();
+                if (PracticeQuestionTypeEnum.ALL.getValue().equals(en.getQuestionType())) {
+                    questionVOs = questionSubjectMapper.bySubjectId(subjectId);
+                } else {
+                    questionVOs = questionSubjectMapper.bySubjectIdAndQuestionType(subjectId, PracticeQuestionTypeEnum.getDataBaseValueByValue(en.getQuestionType()));
+                }
+                questionVOs.stream().forEach(question -> {
+                    question.setContent(JSON.parseObject(question.getContentJson(), QuestionContentVO.class));
+                });
+                // 杩斿洖鍝嶅簲鏁版嵁
+                SubjectQuestionVO subjectQuestionVO = new SubjectQuestionVO();
+                subjectQuestionVO.setSubjectId(subjectId);
+                subjectQuestionVO.setSubjectName(subjectName);
+                subjectQuestionVO.setLookQuestionList(questionVOs);
+                list.add(subjectQuestionVO);
+            }
+            return RestResponse.ok(list);
+        } else if (PracticeTypeEnum.RANDOM.getValue().equals(en.getPracticeType())) {
+            // 闅忔満缁冧範锛屾槸涓�閬撻涓�閬撻缁冧範
+            List<QuestionVO> one = questionSubjectMapper.getRandomQuestionId(subjectIds, PracticeQuestionTypeEnum.getDataBaseValueByValue(en.getQuestionType()), 1);
+            if (one.size() < 1) {
+                throw new RuntimeException("娌℃湁鎵惧埌棰樼洰锛屽彲鑳芥墍閫夎鐩寘鍚鐩笉瓒�");
+            }
+            QuestionVO questionVO = one.get(0);
+            jsonQuestion(questionVO, Boolean.FALSE);
+            return RestResponse.ok(questionVO);
+        }
+        return RestResponse.ok();
     }
 
     /**
@@ -175,7 +219,7 @@
      *
      * @param questionVO
      */
-    public void jsonQuestion(QuestionVO questionVO) {
+    public void jsonQuestion(QuestionVO questionVO, Boolean clearAnswer) {
         if (StringUtils.hasText(questionVO.getContentJson())) {
             QuestionContentVO questionContent = JSON.parseObject(questionVO.getContentJson(), QuestionContentVO.class);
             questionVO.setContent(questionContent);
@@ -186,9 +230,11 @@
                 questionVO.setAnswerNum(questionVO.getCorrect().split(",").length);
             }
         }
-        questionVO.setContentJson("");
-        questionVO.setCorrect("");
-        questionVO.getContent().setCorrect("");
-        questionVO.getContent().setAnalyze("");
+        if (clearAnswer) {
+            questionVO.setContentJson("");
+            questionVO.setCorrect("");
+            questionVO.getContent().setCorrect("");
+            questionVO.getContent().setAnalyze("");
+        }
     }
 }

--
Gitblit v1.8.0