From 984dc83c2e93ee05d8ea57db5beec76a773d4716 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 04 七月 2025 18:08:49 +0800
Subject: [PATCH] 部分代码

---
 ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java |  195 ++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 185 insertions(+), 10 deletions(-)

diff --git a/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java b/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java
index b418d5c..2f5da68 100644
--- a/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java
+++ b/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java
@@ -1,8 +1,11 @@
 package com.ruoyi.study.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.core.constant.Constants;
+import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.exception.GlobalException;
+import com.ruoyi.common.core.web.domain.BaseModel;
 import com.ruoyi.study.domain.*;
 import com.ruoyi.study.dto.StudyWeekDTO;
 import com.ruoyi.study.mapper.TStudyMapper;
@@ -442,7 +445,28 @@
         List<List<TSubject>> subjectList = new ArrayList<>();
 
         StudyListenResultVO studyListenResultVO = new StudyListenResultVO(learnStudy, subjectList);
-
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 1).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) listenPass /listenSize;
+            TStudyListen one = studyListenService.lambdaQuery().eq(TStudyListen::getWeek, week)
+                    .eq(TStudyListen::getDay, 1).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                            ,1));
+                }
+            }
+        }
         List<TSubjectRecordDetail> list = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
                 .eq(TSubjectRecordDetail::getWeek, week)
                 .eq(TSubjectRecordDetail::getDay, day)
@@ -515,7 +539,7 @@
     }
 
     @Override
-    public StudyLookResultVO pictureSelectVoice(Integer week, Integer day, List<TStudyLook> lookList, Integer userid) {
+    public R<StudyLookResultVO> pictureSelectVoice(Integer week, Integer day, List<TStudyLook> lookList, Integer userid) {
         if (lookList.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -535,7 +559,44 @@
         List<List<TSubject>> subjectList = new ArrayList<>();
 
         StudyLookResultVO studyListenResultVO = new StudyLookResultVO(learnStudy, subjectList);
-
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 1).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 先计算上一天的通关率 设置为两位小数
+            double listenRate = (double) listenPass /listenSize;
+            BigDecimal divide = new BigDecimal(listenPass).divide(new BigDecimal(listenSize), 2, RoundingMode.HALF_UP);
+            TStudyListen one = studyListenService.lambdaQuery().eq(TStudyListen::getWeek, week)
+                    .eq(TStudyListen::getDay, 1).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    return R.fail("听音选图未达到通关率"+one.getRate()+"%,"+"当前通关率:"+divide+"%");
+                }
+            }
+        }
+        List<TSubjectRecordDetail> lookList1 = subjectRecordDetails.stream().filter(e -> e.getType() == 2).collect(Collectors.toList());
+        int lookPass = (int) lookList1.stream().filter(e -> e.getStatus() == 2).count();
+        int lookSize = lookList1.size();
+        if (lookSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) lookPass /lookSize;
+            TStudyLook one = studyLookService.lambdaQuery().eq(TStudyLook::getWeek, week)
+                    .eq(TStudyLook::getDay, 2).last("limit 1").one();
+            if (one!=null){
+                // 通关率未达标
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                                    ,2));
+                }
+            }
+        }
         List<TSubjectRecordDetail> list = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
                 .eq(TSubjectRecordDetail::getWeek, week)
                 .eq(TSubjectRecordDetail::getDay, day)
@@ -613,11 +674,11 @@
             studyListenResultVO.setList(tSubjectRecordDetails);
             studyListenResultVO.setSubjectList(subjectList);
         }
-        return studyListenResultVO;
+        return R.ok(studyListenResultVO);
     }
 
     @Override
-    public StudyInductionResultVO induceExclude(Integer week, Integer day, List<TStudyInduction> inductionList, Integer userid) {
+    public R<StudyInductionResultVO> induceExclude(Integer week, Integer day, List<TStudyInduction> inductionList, Integer userid) {
         if (inductionList.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -642,6 +703,44 @@
                 .eq(TSubjectRecordDetail::getWeek, week)
                 .eq(TSubjectRecordDetail::getDay, day)
                 .eq(TSubjectRecordDetail::getType, 3).list();
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 2).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 先计算上一天的通关率 设置为两位小数
+            double listenRate = (double) listenPass /listenSize;
+            BigDecimal divide = new BigDecimal(listenPass).divide(new BigDecimal(listenSize), 2, RoundingMode.HALF_UP);
+            TStudyLook one = studyLookService.lambdaQuery().eq(TStudyLook::getWeek, week)
+                    .eq(TStudyLook::getDay, 2).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    return R.fail("看图选音未达到通关率"+one.getRate()+"%,"+"当前通关率:"+divide+"%");
+                }
+            }
+        }
+        List<TSubjectRecordDetail> lookList1 = subjectRecordDetails.stream().filter(e -> e.getType() == 3).collect(Collectors.toList());
+        int lookPass = (int) lookList1.stream().filter(e -> e.getStatus() == 2).count();
+        int lookSize = lookList1.size();
+        if (lookSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) lookPass /lookSize;
+            TStudyInduction one = studyInductionService.lambdaQuery().eq(TStudyInduction::getWeek, week)
+                    .eq(TStudyInduction::getDay, 3).last("limit 1").one();
+            if (one!=null){
+                // 通关率未达标
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                                    ,3));
+                }
+            }
+        }
         if (list.isEmpty()) {
             List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
             for (TStudyInduction data : inductionList) {
@@ -752,11 +851,11 @@
                     .divide(new BigDecimal(tSubjectRecordDetails.size()), 2, RoundingMode.HALF_UP));
         }
         studyListenResultVO.setSubjectList(subjectList);
-        return studyListenResultVO;
+        return R.ok(studyListenResultVO);
     }
 
     @Override
-    public StudyAnswerResultVO questionsAndAnswers(Integer week, Integer day, List<TStudyAnswer> answerList, Integer userid) {
+    public R<StudyAnswerResultVO> questionsAndAnswers(Integer week, Integer day, List<TStudyAnswer> answerList, Integer userid) {
         if (answerList.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -781,6 +880,44 @@
                 .eq(TSubjectRecordDetail::getWeek, week)
                 .eq(TSubjectRecordDetail::getDay, day)
                 .eq(TSubjectRecordDetail::getType, 4).list();
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 3).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 先计算上一天的通关率 设置为两位小数
+            double listenRate = (double) listenPass /listenSize;
+            BigDecimal divide = new BigDecimal(listenPass).divide(new BigDecimal(listenSize), 2, RoundingMode.HALF_UP);
+            TStudyInduction one = studyInductionService.lambdaQuery().eq(TStudyInduction::getWeek, week)
+                    .eq(TStudyInduction::getDay, 3).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    return R.fail("归纳排除未达到通关率"+one.getRate()+"%,"+"当前通关率:"+divide+"%");
+                }
+            }
+        }
+        List<TSubjectRecordDetail> lookList1 = subjectRecordDetails.stream().filter(e -> e.getType() == 4).collect(Collectors.toList());
+        int lookPass = (int) lookList1.stream().filter(e -> e.getStatus() == 2).count();
+        int lookSize = lookList1.size();
+        if (lookSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) lookPass /lookSize;
+            TStudyAnswer one = studyAnswerService.lambdaQuery().eq(TStudyAnswer::getWeek, week)
+                    .eq(TStudyAnswer::getDay, 4).last("limit 1").one();
+            if (one!=null){
+                // 通关率未达标
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                                    ,4));
+                }
+            }
+        }
         if (list.isEmpty()) {
             List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
             for (int i = 0; i < answerList.size(); i += Constants.TWO) {
@@ -861,7 +998,7 @@
                     .divide(new BigDecimal(tSubjectRecordDetails.size()), 2, RoundingMode.HALF_UP));
         }
         studyListenResultVO.setSubjectList(subjectList);
-        return studyListenResultVO;
+        return R.ok(studyListenResultVO);
     }
 
     private void voAdd(List<QuestionsAnswersSubjectVO> voList, TStudyAnswer one) {
@@ -903,7 +1040,7 @@
     }
 
     @Override
-    public StudyPairResultVO pictureMateVoice(Integer week, Integer day, List<TStudyPair> pair, Integer userid) {
+    public R<StudyPairResultVO> pictureMateVoice(Integer week, Integer day, List<TStudyPair> pair, Integer userid) {
         if (pair.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -928,6 +1065,44 @@
                 .eq(TSubjectRecordDetail::getWeek, week)
                 .eq(TSubjectRecordDetail::getDay, day)
                 .eq(TSubjectRecordDetail::getType, 5).list();
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 4).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 先计算上一天的通关率 设置为两位小数
+            double listenRate = (double) listenPass /listenSize;
+            BigDecimal divide = new BigDecimal(listenPass).divide(new BigDecimal(listenSize), 2, RoundingMode.HALF_UP);
+            TStudyAnswer one = studyAnswerService.lambdaQuery().eq(TStudyAnswer::getWeek, week)
+                    .eq(TStudyAnswer::getDay, 4).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    return R.fail("归纳排除未达到通关率"+one.getRate()+"%,"+"当前通关率:"+divide+"%");
+                }
+            }
+        }
+        List<TSubjectRecordDetail> lookList1 = subjectRecordDetails.stream().filter(e -> e.getType() == 5).collect(Collectors.toList());
+        int lookPass = (int) lookList1.stream().filter(e -> e.getStatus() == 2).count();
+        int lookSize = lookList1.size();
+        if (lookSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) lookPass /lookSize;
+            TStudyPair one = studyPairService.lambdaQuery().eq(TStudyPair::getWeek, week)
+                    .eq(TStudyPair::getDay, 5).last("limit 1").one();
+            if (one!=null){
+                // 通关率未达标
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                                    ,5));
+                }
+            }
+        }
         if (list.isEmpty()) {
             List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
             for (TStudyPair data : pair) {
@@ -991,7 +1166,7 @@
             studyListenResultVO.setAccuracy(new BigDecimal(tSubjectRecordDetails.stream().filter(tSubjectRecordDetail -> tSubjectRecordDetail.getStatus().equals(2)).count())
                     .divide(new BigDecimal(tSubjectRecordDetails.size()), 2, RoundingMode.HALF_UP));
         }
-        return studyListenResultVO;
+        return R.ok(studyListenResultVO);
     }
 
     @Override

--
Gitblit v1.7.1