From a9bf1fc6ffb80c2de56e1730595b3abde4910484 Mon Sep 17 00:00:00 2001
From: hjl <1657978663@qq.com>
Date: 星期五, 21 六月 2024 17:17:55 +0800
Subject: [PATCH] fix: 学习端bug

---
 ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java |   51 ++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 50 insertions(+), 1 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 a0c4e65..e9719c5 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
@@ -416,12 +416,39 @@
 
     @Override
     public int computeSchedule(TUserStudy result, Integer week) {
+        List<TStudy> studyList = this.lambdaQuery().eq(TStudy::getDisabled, 0)
+                .eq(TStudy::getType, 1)
+                .orderByAsc(TStudy::getWeek).list();
         // 基础学习进度
         Integer day = result.getDay();
+        Integer studyWeek = result.getWeek();
+        Map<Integer, List<TStudy>> studyMap = new HashMap<>(8);
+        for (TStudy study : studyList) {
+            Integer quarter = study.getQuarter();
+            List<TStudy> itemList = studyMap.get(quarter);
+            if (null == itemList) {
+                itemList = new ArrayList<>();
+            }
+            itemList.add(study);
+            studyMap.put(quarter, itemList);
+        }
+        // 临时判断参数
+        boolean itemBool = false;
+        for (Map.Entry<Integer, List<TStudy>> map : studyMap.entrySet()) {
+            List<TStudy> list = map.getValue();
+            List<Integer> collect = list.stream().map(TStudy::getWeek).collect(Collectors.toList());
+            if (collect.contains(studyWeek)) {
+                int i = collect.indexOf(studyWeek);
+                if (collect.contains(week)) {
+                    int x = collect.indexOf(week);
+                    itemBool = i > x;
+                }
+            }
+        }
         // 默认进度为 0
         int defaultSchedule;
         // week以超过当前week,进度为 100%
-        if (result.getWeek() > week) {
+        if (itemBool) {
             defaultSchedule = 100;
         } else {
             // 根据day初始化学习进度
@@ -438,6 +465,28 @@
             } else {
                 defaultSchedule = 0;
             }
+            // 根据五种学习计算进度
+            Integer listen = result.getListen();
+            if (!Constants.BURDEN_ONE.equals(listen)) {
+                defaultSchedule += (int)(((double)listen / 100) * 4);
+            }
+            Integer look = result.getLook();
+            if (!Constants.BURDEN_ONE.equals(look)) {
+                defaultSchedule += (int)(((double)look / 100) * 4);
+            }
+            Integer induction = result.getInduction();
+            if (!Constants.BURDEN_ONE.equals(induction)) {
+                defaultSchedule += (int)(((double)induction / 100) * 4);
+            }
+            Integer answer = result.getAnswer();
+            if (!Constants.BURDEN_ONE.equals(answer)) {
+                defaultSchedule += (int)(((double)answer / 100) * 4);
+            }
+            Integer pair = result.getPair();
+            if (!Constants.BURDEN_ONE.equals(pair)) {
+                defaultSchedule += (int)(((double)pair / 100) * 4);
+            }
+
         }
         return defaultSchedule;
     }

--
Gitblit v1.7.1