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