From 8d42b23c07433f11cb0b1e16d9c74b0e29fd35ce Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期五, 05 七月 2024 09:57:42 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev

---
 src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java |  139 ++++++++++++++++++++++++++++------------------
 1 files changed, 85 insertions(+), 54 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 f89bf62..d45c7e3 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.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
 import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
@@ -9,10 +10,12 @@
 import com.ycl.jxkg.base.Result;
 import com.ycl.jxkg.base.SystemCode;
 import com.ycl.jxkg.context.WebContext;
+import com.ycl.jxkg.domain.base.AbsVo;
 import com.ycl.jxkg.domain.entity.*;
 import com.ycl.jxkg.domain.exam.PaperFixQuestionDTO;
 import com.ycl.jxkg.domain.exam.PaperQuestion;
 import com.ycl.jxkg.domain.exam.PaperQuestionSettingDTO;
+import com.ycl.jxkg.domain.exam.PaperSettingItem;
 import com.ycl.jxkg.domain.form.AddTimeForm;
 import com.ycl.jxkg.domain.form.ExamForm;
 import com.ycl.jxkg.domain.form.ForceSubmitForm;
@@ -32,6 +35,7 @@
 import com.ycl.jxkg.rabbitmq.msg.ExamStatusMsg;
 import com.ycl.jxkg.rabbitmq.product.Producer;
 import com.ycl.jxkg.server.WebsocketServer;
+import com.ycl.jxkg.service.ExamPaperScoreService;
 import com.ycl.jxkg.service.ExamPaperService;
 import com.ycl.jxkg.service.ExamService;
 import com.ycl.jxkg.utils.DateTimeUtil;
@@ -71,7 +75,6 @@
     private final UserMapper userMapper;
     private final ExamPaperScoreMapper examPaperScoreMapper;
     private final ExamPaperScoreService examPaperScoreService;
-    private static final String ANSWER_SPLIT = ",";
 
     private final Producer producer;
 
@@ -106,14 +109,14 @@
         // 涓虹┖鎶汭llegalArgumentException锛屽仛鍏ㄥ眬寮傚父澶勭悊
         Assert.notNull(entity, "璁板綍涓嶅瓨鍦�");
         // 鍒ゆ柇鑰冭瘯鐘舵��
-        if (! ExamStatusEnum.NOT_START.equals(entity.getStatus())) {
+        if (!ExamStatusEnum.NOT_START.equals(entity.getStatus())) {
             throw new RuntimeException("鍙兘淇敼杩樻湭寮�濮嬬殑鑰冭瘯");
         }
         BeanUtils.copyProperties(form, entity);
         entity.setStatus(ExamStatusEnum.getStatusByTime(form.getStartTime(), form.getEndTime(), null));
         // 濡傛灉淇敼鎴愬姛鍙戦�乵q娑堟伅
         if (baseMapper.updateById(entity) > 0) {
-            this.sendMQ(entity, entity.getUpdateVersion() + 1);
+            this.sendMQ(entity, entity.getUpdateVersion());
         }
         return Result.ok("淇敼鎴愬姛");
     }
@@ -121,7 +124,7 @@
     /**
      * 鍙戦�乵q娑堟伅
      *
-     * @param entity 鑰冭瘯瀹炰綋绫�
+     * @param entity  鑰冭瘯瀹炰綋绫�
      * @param version 涔愯閿佺増鏈�
      */
     public void sendMQ(Exam entity, Integer version) {
@@ -282,50 +285,58 @@
                 PaperFixQuestionVO paperFixQuestionVO = new PaperFixQuestionVO();
                 paperFixQuestionVO.setTitle(paperSetting.getTitle());
                 paperFixQuestionVO.setQuestionType(paperSetting.getQuestionType());
-                // 鎷垮埌璇剧洰涓嬫煇绫婚鍨嬬殑x閬撻殢鏈洪
-                List<Question> questions = questionMapper.getRandomQuestion(examPaper.getSubjectId(), paperSetting.getQuestionType(), paperSetting.getNum());
-                if (paperSetting.getNum() > questions.size()) {
-                    throw new RuntimeException("閰嶇疆鐨勯鐩暟涓嶈冻浠ョ敓鎴愯瘯鍗�");
-                }
-
-                // 鎷垮埌棰樼洰鍚庣粍瑁呬负鍙复鏃朵繚瀛樼殑棰樼洰缁撴瀯
-                List<DoQuestionVO> childQuestions = questions.stream().map(item -> {
-                    DoQuestionVO doQuestionVO = new DoQuestionVO();
-                    doQuestionVO.setTitle(item.getTitle());
-                    doQuestionVO.setQuestionType(item.getQuestionType());
-                    //浠庨厤缃噷鎷块鐩垎鏁�
-                    doQuestionVO.setQuestionScore(paperSetting.getScore());
-                    if (StringUtils.hasText(item.getContent())) {
-                        QuestionObject questionObject = JSON.parseObject(item.getContent(), QuestionObject.class);
-                        doQuestionVO.setQuestionItemList(questionObject.getQuestionItemObjects());
+                //涓�涓被鍨嬬殑棰樼洰list
+                List<DoQuestionVO> childQuestionList = new ArrayList<>();
+                List<PaperSettingItem> settingList = paperSetting.getSettingList();
+                for (PaperSettingItem settingItem : settingList) {
+                    Integer num = settingItem.getNum();
+                    Integer difficult = settingItem.getDifficult();
+                    //闇�瑕侀厤缃殑棰樼洰鏁伴噺涓�0鍒欒烦杩�
+                    if (num == null || num == 0) continue;
+                    List<Question> questions = questionMapper.getRandomQuestion(settingItem.getSubjectId(), paperSetting.getQuestionType(), difficult, settingItem.getNum());
+                    if (org.springframework.util.CollectionUtils.isEmpty(questions) || settingItem.getNum() > questions.size()) {
+                        throw new RuntimeException("閰嶇疆鐨勯鐩暟涓嶈冻浠ョ敓鎴愯瘯鍗�");
                     }
-                    doQuestionVO.setId(item.getId());
-                    doQuestionVO.setOriginalFile(item.getOriginalFile());
-                    doQuestionVO.setAudioFile(item.getAudioFile());
-
-                    // 棰樼洰鍓湰
-                    QuestionAnswerCopyVO copy = new QuestionAnswerCopyVO();
-                    copy.setId(item.getId());
-                    copy.setDifficult(item.getDifficult());
-                    copy.setAnalyze(JSON.parseObject(item.getContent(), PaperQuestion.class).getAnalyze());
-                    //濉┖鐨勭瓟妗堝湪Json閲�
-                    if (QuestionTypeEnum.GapFilling.getCode().equals(item.getQuestionType())) {
-                        List<String> gapAnswer = new ArrayList<>();
-                        for (QuestionItemObject questionItemObject : doQuestionVO.getQuestionItemList()) {
-                            gapAnswer.add(questionItemObject.getContent());
+                    // 鎷垮埌棰樼洰鍚庣粍瑁呬负鍙复鏃朵繚瀛樼殑棰樼洰缁撴瀯
+                    List<DoQuestionVO> childQuestions = questions.stream().map(item -> {
+                        DoQuestionVO doQuestionVO = new DoQuestionVO();
+                        doQuestionVO.setQuestionType(item.getQuestionType());
+                        //浠庨厤缃噷鎷块鐩垎鏁�
+                        doQuestionVO.setQuestionScore(settingItem.getScore());
+                        if (StringUtils.hasText(item.getContent())) {
+                            QuestionObject questionObject = JSON.parseObject(item.getContent(), QuestionObject.class);
+                            doQuestionVO.setQuestionItemList(questionObject.getQuestionItemObjects());
+                            doQuestionVO.setTitle(questionObject.getTitleContent());
                         }
-                        copy.setCorrect(String.join(ANSWER_SPLIT, gapAnswer));
-                    } else {
-                        copy.setCorrect(item.getCorrect());
-                    }
-                    questionAnswerCopyVOList.add(copy);
+                        doQuestionVO.setId(item.getId());
+                        doQuestionVO.setOriginalFile(item.getOriginalFile());
+                        doQuestionVO.setAudioFile(item.getAudioFile());
 
-                    return doQuestionVO;
-                }).collect(Collectors.toList());
-                paperFixQuestionVO.setQuestionList(childQuestions);
+                        // 棰樼洰鍓湰
+                        QuestionAnswerCopyVO copy = new QuestionAnswerCopyVO();
+                        copy.setId(item.getId());
+                        copy.setDifficult(item.getDifficult());
+                        copy.setAnalyze(JSON.parseObject(item.getContent(), PaperQuestion.class).getAnalyze());
+                        //濉┖鐨勭瓟妗堝湪Json閲�
+                        if (QuestionTypeEnum.GapFilling.getCode().equals(item.getQuestionType())) {
+                            List<String> gapAnswer = new ArrayList<>();
+                            for (QuestionItemObject questionItemObject : doQuestionVO.getQuestionItemList()) {
+                                gapAnswer.add(questionItemObject.getContent());
+                            }
+                            copy.setCorrect(String.join(ANSWER_SPLIT, gapAnswer));
+                        } else {
+                            copy.setCorrect(item.getCorrect());
+                        }
+                        questionAnswerCopyVOList.add(copy);
+
+                        return doQuestionVO;
+                    }).collect(Collectors.toList());
+                    //娣诲姞鍒拌繖涓被鍨嬬殑list涓�
+                    childQuestionList.addAll(childQuestions);
+                }
+                paperFixQuestionVO.setQuestionList(childQuestionList);
                 examData.add(paperFixQuestionVO);
             }
-            return Result.ok(startExamVO);
         }
         ExamSubmitTemp examSubmitTemp = new ExamSubmitTemp();
         examSubmitTemp.setExamId(id);
@@ -470,9 +481,6 @@
         // 鐜板湪鍙渶瑕佷繚瀛樺埌涓�寮犱复鏃惰〃
         // 璇ユ帴鍙f槸涓诲姩鎻愪氦锛屾墍浠ョ姸鎬侀兘璁剧疆涓哄畬鎴愶紝浠ヤ究鍚庣画鑰佸笀闃呭嵎
         saveTempExam(submitData, ExamSubmitTempStatusEnum.finish);
-
-        //TODO:鑰冭瘯鐘舵�佽瀹氫负缁撴潫
-
         return Result.ok();
     }
 
@@ -535,7 +543,7 @@
             throw new RuntimeException("鑰冭瘯璇曞嵎涓嶅瓨鍦�");
         }
         List<ExamSubmitTemp> examSubmitTempList = new LambdaQueryChainWrapper<>(examSubmitTempMapper)
-                .eq(ExamSubmitTemp::getDeleted,0)
+                .eq(ExamSubmitTemp::getDeleted, 0)
                 .eq(ExamSubmitTemp::getExamId, id)
                 .list();
         // 鍙傝�冧汉鏁�
@@ -543,15 +551,23 @@
         // 鍙傝�冧絾鏈畬鎴愭彁浜や汉鏁�
         Integer joinButNotFinishedNum = Math.toIntExact(examSubmitTempList.stream().filter(item -> ExamSubmitTempStatusEnum.temp.equals(item.getStatus())).count());
 
-        List<StudentExamInfoVO> studentExamList = classesUserMapper.getClassesUserList(exam.getId(), exam.getClassesId());
+        List<StudentExamInfoVO> studentExamList = classesUserMapper.getClassesUserList(exam.getClassesId());
         // 搴旇�冧汉鏁�
         Integer shouldUserNum = studentExamList.size();
-
-        studentExamList.stream().forEach(item -> {
-            if (StringUtils.hasText(item.getExamSubmit())) {
-                item.setQuestionList(JSON.parseArray(item.getExamSubmit(), DoQuestionVO.class));
+        for (StudentExamInfoVO studentExamInfoVO : studentExamList) {
+            Integer userId = studentExamInfoVO.getUserId();
+            Optional<ExamSubmitTemp> first = examSubmitTempList.stream().filter(examSubmitTemp -> examSubmitTemp.getUserId().equals(userId)).findFirst();
+            if(first.isPresent()){
+                ExamSubmitTemp examSubmitTemp = first.get();
+                studentExamInfoVO.setMarkPaperStatus(examSubmitTemp.getMarkPaperStatus());
+                studentExamInfoVO.setStatus(examSubmitTemp.getStatus());
+                studentExamInfoVO.setDoTime(examSubmitTemp.getDoTime());
+            }else {
+                studentExamInfoVO.setMarkPaperStatus(ExamSubmitTempStatusEnum.temp);
+                studentExamInfoVO.setStatus(ExamSubmitTempStatusEnum.temp);
+                studentExamInfoVO.setDoTime(0);
             }
-        });
+        }
 
         MarkPaperVO markPaperVO = new MarkPaperVO();
         markPaperVO.setExamName(exam.getExamName());
@@ -833,7 +849,7 @@
         long questionCorrect = 0;
         long questionCount = 0;
         if (!CollectionUtils.isEmpty(examPaperMark.getNavbar())) {
-            questionCorrect = examPaperMark.getNavbar().stream().filter(vo -> vo.getRight()!=null && vo.getRight()).count();
+            questionCorrect = examPaperMark.getNavbar().stream().filter(vo -> vo.getRight() != null && vo.getRight()).count();
             questionCount = examPaperMark.getNavbar().size();
         }
         examPaperScore.setQuestionCorrect(Integer.valueOf(questionCorrect + ""));
@@ -845,6 +861,13 @@
             examPaperScoreMapper.updateById(examPaperScore);
         } else {
             examPaperScoreMapper.insert(examPaperScore);
+            //淇敼鑰冭瘯閲岃瘯鍗风姸鎬佷负宸查槄鍗�
+            ExamSubmitTemp userExam = new LambdaQueryChainWrapper<>(examSubmitTempMapper)
+                    .eq(ExamSubmitTemp::getExamId, examPaperMark.getExamId())
+                    .eq(ExamSubmitTemp::getUserId, examPaperMark.getUserId())
+                    .one();
+            userExam.setMarkPaperStatus(ExamSubmitTempStatusEnum.finish);
+            examSubmitTempMapper.updateById(userExam);
         }
         return Result.ok();
     }
@@ -858,8 +881,13 @@
 
     @Override
     public Result addTime(AddTimeForm form) {
+        if (! websocketServer.checkUserOnline(form.getUserId())) {
+            throw new RuntimeException("璇ュ鍛樹笉鍦ㄧ嚎锛屾棤娉曟墽琛岃鎿嶄綔");
+        }
         WebsocketDataVO websocket = new WebsocketDataVO();
         websocket.setCommend(WebsocketCommendEnum.DELAYED.getCommend());
+        BigDecimal sed = BigDecimal.valueOf(60).multiply(form.getAddTimeM());
+        form.setAddTimeM(sed);
         websocket.setData(form);
         // 鍙戦�亀ebsocket娑堟伅
         websocketServer.sendOneMessage(form.getUserId(), JSON.toJSONString(form));
@@ -868,6 +896,9 @@
 
     @Override
     public Result forceSubmit(ForceSubmitForm form) {
+        if (! websocketServer.checkUserOnline(form.getUserId())) {
+            throw new RuntimeException("璇ュ鍛樹笉鍦ㄧ嚎锛屾棤娉曟墽琛岃鎿嶄綔");
+        }
         WebsocketDataVO websocket = new WebsocketDataVO();
         websocket.setCommend(WebsocketCommendEnum.FORCE_SUBMIT.getCommend());
         websocket.setData(form);

--
Gitblit v1.8.0