From 03a9cd21c1589e98978dc7296bb7fb48f1dcd7fe Mon Sep 17 00:00:00 2001 From: 龚焕茏 <2842157468@qq.com> Date: 星期五, 17 五月 2024 16:13:45 +0800 Subject: [PATCH] feat:创建试卷时新增选择用户查询条件 --- src/main/java/com/mindskip/xzs/service/impl/SelfPracticeServiceImpl.java | 85 +++++++++++++++++++++++++++--------------- 1 files changed, 55 insertions(+), 30 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 68ad3dd..d137530 100644 --- a/src/main/java/com/mindskip/xzs/service/impl/SelfPracticeServiceImpl.java +++ b/src/main/java/com/mindskip/xzs/service/impl/SelfPracticeServiceImpl.java @@ -7,6 +7,7 @@ import com.mindskip.xzs.base.RestResponse; import com.mindskip.xzs.context.WebContext; import com.mindskip.xzs.domain.ExamPaperAnswer; +import com.mindskip.xzs.domain.PracticeQuestionCondition; import com.mindskip.xzs.domain.Question; import com.mindskip.xzs.domain.SelfPractice; import com.mindskip.xzs.domain.enums.PracticeQuestionTypeEnum; @@ -16,10 +17,7 @@ import com.mindskip.xzs.domain.vo.QuestionVO; import com.mindskip.xzs.domain.vo.SelfPracticeVO; import com.mindskip.xzs.domain.vo.SubjectQuestionVO; -import com.mindskip.xzs.repository.QuestionMapper; -import com.mindskip.xzs.repository.QuestionSubjectMapper; -import com.mindskip.xzs.repository.SelfPracticeMapper; -import com.mindskip.xzs.repository.SubjectMapper; +import com.mindskip.xzs.repository.*; import com.mindskip.xzs.service.SelfPracticeService; import lombok.RequiredArgsConstructor; import org.springframework.beans.BeanUtils; @@ -45,7 +43,7 @@ private final WebContext webContext; private final QuestionSubjectMapper questionSubjectMapper; private final SubjectMapper subjectMapper; - private final QuestionMapper questionMapper; + private final PracticeQuestionConditionMapper practiceQuestionConditionMapper; @Override public RestResponse add(SelfPracticeVO vo) { @@ -69,13 +67,22 @@ PageInfo<SelfPracticeVO> info = PageHelper.startPage(query.getPageNum(), query.getPageSize()).doSelectPageInfo(() -> selfPracticeMapper.page(query)); info.getList().stream().forEach(item -> { + // 鏌ヨ璇剧洰鍚嶃�佽鐩�讳綋鏁� List<Integer> subjects = JSON.parseArray(item.getSubjectString(), Integer.class); item.setSubjects(subjects); List<String> subjectNames = subjectMapper.selectSubjectName(subjects); if (! CollectionUtils.isEmpty(subjectNames)) { item.setSubjectNames(subjectNames.stream().collect(Collectors.joining("銆�"))); } - item.setTotalQuestionNum(questionSubjectMapper.countQuestionNum(subjects)); + item.setTotalQuestionNum(questionSubjectMapper.countQuestionNum(subjects, PracticeQuestionTypeEnum.getDataBaseValueByValue(item.getQuestionType()))); + // 鏌ヨ宸茬粡鍋氫簡澶氬皯 + PracticeQuestionCondition practiceQuestionCondition = practiceQuestionConditionMapper.selectByPracticeId(item.getId()); + if (Objects.nonNull(practiceQuestionCondition)) { + List<PracticeQuestionCondition.QuestionFinishCondition> questionFinishConditions = JSON.parseArray(practiceQuestionCondition.getContent(), PracticeQuestionCondition.QuestionFinishCondition.class); + item.setDoNum(questionFinishConditions.size()); + } else { + item.setDoNum(0); + } }); return RestResponse.ok(info); } @@ -97,36 +104,53 @@ List<SubjectQuestionVO> list = new ArrayList<>(2); // 椤哄簭鍋氶锛屾妸閫夋嫨鐨勯搴撶殑棰�(id)鍏ㄩ儴鏌ュ嚭鏉ワ紝鍓嶇鏈変釜搴忓彿闈㈡澘锛岀偣鍑诲摢閬撻鍋氬摢閬� for (Integer subjectId : subjectIds) { + // 鏌ヨ鐩悕瀛� String subjectName = subjectMapper.selectSubjectNameById(subjectId); - // todo鏍规嵁鍋氶璁板綍鏌ヨ鍋氭病鍋氳繃 List<Integer> questionIds = new ArrayList<>(); if (PracticeQuestionTypeEnum.ALL.getValue().equals(en.getQuestionType())) { questionIds = questionSubjectMapper.questionsBySubjectId(subjectId); } else { questionIds = questionSubjectMapper.questionsBySubjectIdAndQuestionType(subjectId, PracticeQuestionTypeEnum.getDataBaseValueByValue(en.getQuestionType())); } + // 鏍规嵁鍋氶璁板綍澧炲姞鏍囪瘑锛岄〉闈㈡覆鏌撳仛娌″仛杩囷紝鍋氬娌℃湁 + PracticeQuestionCondition practiceQuestionCondition = practiceQuestionConditionMapper.selectByPracticeId(id); + List<PracticeQuestionCondition.QuestionFinishCondition> questionFinishConditions = new ArrayList<>(48); + if (Objects.nonNull(practiceQuestionCondition)) { // json鍙嶅簭鍒楀寲寰楀埌鍋氶鎯呭喌 + questionFinishConditions = JSON.parseArray(practiceQuestionCondition.getContent(), PracticeQuestionCondition.QuestionFinishCondition.class); + } + List<PracticeQuestionCondition.QuestionFinishCondition> finalQuestionFinishConditions = questionFinishConditions; + // 缁勮鍓嶇鏁版嵁 + List<PracticeQuestionCondition.QuestionFinishCondition> questionData = questionIds.stream().map(questionId -> { + PracticeQuestionCondition.QuestionFinishCondition questionPractice = new PracticeQuestionCondition.QuestionFinishCondition(); + questionPractice.setQuestionId(questionId); + for (PracticeQuestionCondition.QuestionFinishCondition questionFinishCondition : finalQuestionFinishConditions) { + if (questionFinishCondition.getQuestionId().equals(questionId)) { + questionPractice.setRight(questionFinishCondition.getRight()); + questionPractice.setAnswer(questionFinishCondition.getAnswer()); + questionPractice.setHasDo(questionFinishCondition.getHasDo()); + } + } + return questionPractice; + }).collect(Collectors.toList()); + // 杩斿洖鍝嶅簲鏁版嵁 SubjectQuestionVO subjectQuestionVO = new SubjectQuestionVO(); subjectQuestionVO.setSubjectId(subjectId); subjectQuestionVO.setSubjectName(subjectName); - subjectQuestionVO.setQuestionIds(questionIds); + subjectQuestionVO.setQuestionConditions(questionData); list.add(subjectQuestionVO); } return RestResponse.ok(list); } else if (PracticeTypeEnum.RANDOM.getValue().equals(en.getPracticeType())) { // 闅忔満缁冧範锛屾槸涓�閬撻涓�閬撻缁冧範 - List<QuestionVO> one = questionSubjectMapper.getRandomQuestionId(subjectIds, 1); + List<QuestionVO> one = questionSubjectMapper.getRandomQuestionId(subjectIds, PracticeQuestionTypeEnum.getDataBaseValueByValue(en.getQuestionType()), 1); if (one.size() < 1) { throw new RuntimeException("娌℃湁鎵惧埌棰樼洰锛屽彲鑳芥墍閫夎鐩寘鍚鐩笉瓒�"); } - return RestResponse.ok(one.get(0)); + QuestionVO questionVO = one.get(0); + jsonQuestion(questionVO); + return RestResponse.ok(questionVO); } return RestResponse.ok(); - } - - @Override - public RestResponse subjectQuestionNum(List<Integer> subjectIds) { - Integer num = questionSubjectMapper.countQuestionNum(subjectIds); - return RestResponse.ok(num); } @Override @@ -136,12 +160,26 @@ throw new RuntimeException("缁冧範涓嶅瓨鍦�"); } List<Integer> subjectIds = JSON.parseArray(en.getSubjects(), Integer.class); - List<QuestionVO> one = questionSubjectMapper.getRandomQuestionId(subjectIds, 1); + 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); + + return RestResponse.ok(questionVO); + } + + /** + * 澶勭悊棰樼洰鍐呭JSON + * + * @param questionVO + */ + public void jsonQuestion(QuestionVO questionVO) { + if (StringUtils.hasText(questionVO.getContentJson())) { + QuestionContentVO questionContent = JSON.parseObject(questionVO.getContentJson(), QuestionContentVO.class); + questionVO.setContent(questionContent); + } if (QuestionTypeEnum.MultipleChoice.getCode().equals(questionVO.getQuestionType())) { // 澶氶�夐闇�瑕佽繑鍥炵瓟妗堟暟閲忥紝瀛﹀憳閫変腑瀵瑰簲鏁伴噺鎵嶆煡璇㈢瓟妗� if (StringUtils.hasText(questionVO.getCorrect())) { @@ -152,18 +190,5 @@ questionVO.setCorrect(""); questionVO.getContent().setCorrect(""); questionVO.getContent().setAnalyze(""); - return RestResponse.ok(questionVO); - } - - /** - * 澶勭悊棰樼洰鍐呭JSON - * - * @param vo - */ - public void jsonQuestion(QuestionVO vo) { - if (StringUtils.hasText(vo.getContentJson())) { - QuestionContentVO questionContent = JSON.parseObject(vo.getContentJson(), QuestionContentVO.class); - vo.setContent(questionContent); - } } } -- Gitblit v1.8.0