From 770de42c8bbb10676663f33e2748c733c993d27b Mon Sep 17 00:00:00 2001 From: hjl <1657978663@qq.com> Date: 星期四, 20 六月 2024 15:28:42 +0800 Subject: [PATCH] fix: 学习端bug --- ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java | 72 ++++++++++++++++++++---------------- 1 files changed, 40 insertions(+), 32 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 1f7d72f..68186aa 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 @@ -5,7 +5,6 @@ import com.ruoyi.common.core.exception.GlobalException; import com.ruoyi.common.core.utils.bean.BeanUtils; import com.ruoyi.study.domain.*; -import com.ruoyi.study.dto.CompleteGameDTO; import com.ruoyi.study.dto.StudyWeekDTO; import com.ruoyi.study.mapper.TStudyMapper; import com.ruoyi.study.service.*; @@ -56,7 +55,7 @@ } @Override - public List<StudyWeekDTO> weekList(Integer type, Integer quarter) { + public List<StudyWeekDTO> weekList(Integer type, Integer quarter, Integer userId) { List<StudyWeekDTO> result = new ArrayList<>(); // 根据季度和type查询学习配置 List<TStudy> study = lambdaQuery().eq(TStudy::getQuarter, quarter).eq(TStudy::getType, type) @@ -125,9 +124,41 @@ total += storyListenList.stream().map(TStoryListen::getIntegral).mapToInt(Integer::intValue).sum(); // 自主故事 - 看图配音 total += storyListenList.stream().map(TStoryListen::getLookIntegral).mapToInt(Integer::intValue).sum(); - result.add(new StudyWeekDTO(week, type, quarter, title, total)); + // 判断周目是否可以进入学习 + Boolean canStudy = checkWeekCanStudy(userId, item); + result.add(new StudyWeekDTO(week, type, quarter, title, total, canStudy)); } return result; + } + + /** + * @param userId 用户id + * @return 当前周目是否学习 + */ + private Boolean checkWeekCanStudy(Integer userId, TStudy study) { + TUserStudy userStudy = userStudyService.lambdaQuery().eq(TUserStudy::getUserId, userId) + .eq(TUserStudy::getDisabled, 0).one(); + if (null == userStudy) { + userStudy = new TUserStudy(); + userStudy.setUserId(userId); + // 学习周目 + TStudy tStudy = this.lambdaQuery().eq(TStudy::getQuarter, Constants.ONE) + .orderByAsc(TStudy::getWeek).last("limit 1").one(); + userStudy.setWeek(tStudy.getWeek()); + userStudy.setDay(Constants.ONE); + userStudy.setTotalStudy(Constants.ZERO); + userStudy.setTodayStudy(Constants.ZERO); + userStudy.setWeekStudy(Constants.ZERO); + userStudy.setMonthStudy(Constants.ZERO); + userStudy.setListen(Constants.BURDEN_ONE); + userStudy.setLook(Constants.BURDEN_ONE); + userStudy.setInduction(Constants.BURDEN_ONE); + userStudy.setAnswer(Constants.BURDEN_ONE); + userStudy.setPair(Constants.BURDEN_ONE); + userStudyService.save(userStudy); + } + // 学习记录所属周目大于当前学习周目,判断为已学习 + return userStudy.getWeek() >= study.getWeek(); } @Override @@ -209,14 +240,18 @@ // 语音及图片 List<List<TSubject>> subjectList = new ArrayList<>(); for (TStudyLook studyLook : lookList) { + List<String> sortList = Arrays.stream(studyLook.getSort().split(",")).collect(Collectors.toList()); List<String> subjectIds = Arrays.stream(studyLook.getSubject().split(",")).collect(Collectors.toList()); List<TSubject> list = new ArrayList<>(); // 图片及语音集合 - for (String id : subjectIds) { - TSubject data = subjectService.lambdaQuery().eq(TSubject::getId, id) + for (int i = 0; i < subjectIds.size(); i++) { + TSubject data = subjectService.lambdaQuery().eq(TSubject::getId, subjectIds.get(i)) .eq(TSubject::getDisabled, 0).one(); + data.setSort(Integer.parseInt(sortList.get(i))); list.add(data); } + // 根据顺序排序 + list.sort(Comparator.comparingInt(TSubject::getSort)); subjectList.add(list); } return new StudyLookResultVO(learnStudy, subjectList); @@ -348,11 +383,6 @@ @Override public int computeSchedule(TUserStudy result, Integer week) { // 基础学习进度 - Integer listen = result.getListen(); - Integer look = result.getLook(); - Integer induction = result.getInduction(); - Integer answer = result.getAnswer(); - Integer pair = result.getPair(); Integer day = result.getDay(); // 默认进度为 0 int defaultSchedule; @@ -374,23 +404,6 @@ } else { defaultSchedule = 0; } - // 进度学习完成度计算总学习进度 - // todo 不确定是否需要累计计算 中途退出的进度 - /*if (!Constants.ZERO.equals(listen) && !Constants.BURDEN_ONE.equals(listen)) { - defaultSchedule += 4 * (100 / listen); - } - if (!Constants.ZERO.equals(look) && !Constants.BURDEN_ONE.equals(look)) { - defaultSchedule += 4 * (100 / look); - } - if (!Constants.ZERO.equals(induction) && !Constants.BURDEN_ONE.equals(induction)) { - defaultSchedule += 4 * (100 / induction); - } - if (!Constants.ZERO.equals(answer) && !Constants.BURDEN_ONE.equals(answer)) { - defaultSchedule += 4 * (100 / answer); - } - if (!Constants.ZERO.equals(pair) && !Constants.BURDEN_ONE.equals(pair)) { - defaultSchedule += 4 * (100 / pair); - }*/ } return defaultSchedule; } @@ -437,11 +450,6 @@ throw new GlobalException("题目信息异常!"); } return (int) (sum * ((double) accuracy / 100)); - } - - @Override - public void checkRate(TGame game, Integer userid, CompleteGameDTO completeStudy) { - } } -- Gitblit v1.7.1