From dd663d0ac783755d889e270eee57ee58630c88c8 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期五, 28 二月 2025 17:46:52 +0800 Subject: [PATCH] 冥想2.0新增代码 --- xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientTutorSpecialColumnController.java | 88 ++++++++++++++++++++++++++++--------------- 1 files changed, 57 insertions(+), 31 deletions(-) diff --git a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientTutorSpecialColumnController.java b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientTutorSpecialColumnController.java index 7641f59..fb581e4 100644 --- a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientTutorSpecialColumnController.java +++ b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientTutorSpecialColumnController.java @@ -1,6 +1,7 @@ package com.xinquan.course.controller.client; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.xinquan.common.core.domain.R; import com.xinquan.common.core.utils.page.BeanUtils; @@ -9,15 +10,16 @@ import com.xinquan.common.security.utils.SecurityUtils; import com.xinquan.course.api.domain.Course; import com.xinquan.course.api.domain.CourseCategory; +import com.xinquan.course.api.domain.CourseChapter; +import com.xinquan.course.domain.CourseLearningRecord; import com.xinquan.course.domain.TutorSpecialColumn; import com.xinquan.course.domain.TutorSpecialColumnCourse; import com.xinquan.course.domain.vo.ClientCourseVO; import com.xinquan.course.domain.vo.TutorCourseVO; import com.xinquan.course.domain.vo.TutorVo; -import com.xinquan.course.service.CourseCategoryService; -import com.xinquan.course.service.CourseService; -import com.xinquan.course.service.TutorSpecialColumnCourseService; -import com.xinquan.course.service.TutorSpecialColumnService; +import com.xinquan.course.service.*; +import com.xinquan.system.api.domain.AppUser; +import com.xinquan.user.api.feign.RemoteAppUserService; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; @@ -52,6 +54,12 @@ private CourseCategoryService courseCategoryService; @Resource private CourseService courseService; + @Resource + private CourseLearningRecordService courseLearningRecordService; + @Resource + private CourseChapterService courseChapterService; + @Resource + private RemoteAppUserService remoteAppUserService; @PostMapping("/getCoursePageList") @ApiOperation(value = "导师专栏",tags = "导师专栏") public R<TutorVo> getCourseList() { @@ -59,39 +67,64 @@ TutorSpecialColumn one = tutorSpecialColumnService.lambdaQuery().one(); List<TutorCourseVO> clientCourseVOS = new ArrayList<>(); if (one!=null){ - TutorSpecialColumnCourse one1 = tutorSpecialColumnCourseService.lambdaQuery().eq(TutorSpecialColumnCourse::getTutorSpecialColumnId, one.getId()).one(); BeanUtils.copyProperties(one, tutorVo); - List<Course> page = courseService.lambdaQuery() - .in(Course::getId, Arrays.asList(one1.getCourseId().split(","))) - .orderByDesc(Course::getSortNum).list().stream().limit(2).collect(Collectors.toList()); - for (Course course : page) { - TutorCourseVO tutorCourseVO = new TutorCourseVO(); - BeanUtils.copyProperties(course, tutorCourseVO); - clientCourseVOS.add(tutorCourseVO); + TutorSpecialColumnCourse one1 = tutorSpecialColumnCourseService.lambdaQuery().eq(TutorSpecialColumnCourse::getTutorSpecialColumnId, one.getId()).one(); + if (one1!=null){ + LambdaQueryWrapper<Course> courseLambdaQueryWrapper = new LambdaQueryWrapper<>(); + if (StringUtils.hasLength(one1.getCourseId())){ + courseLambdaQueryWrapper.in(Course::getId, Arrays.asList(one1.getCourseId().split(","))); + } + courseLambdaQueryWrapper.orderByDesc(Course::getSortNum); + List<Course> page = courseService.list(courseLambdaQueryWrapper); + for (Course course : page) { + TutorCourseVO tutorCourseVO = new TutorCourseVO(); + List<AppUser> data = remoteAppUserService.getUserByCourseId(course.getId()).getData(); + List<CourseChapter> list1 = courseChapterService.lambdaQuery().eq(CourseChapter::getCourseId, course.getId()).list(); + int a = 0; + int b = 0; + for (CourseChapter courseChapter : list1) { + a+= courseChapter.getVirtualLearnedNum(); + Long data1 = remoteAppUserService.getCourseChapterHistoryCount(courseChapter.getId()).getData(); + b+=data1; + } + course.setCount(a+b); + course.setRealLearnedNum(a+b); + BeanUtils.copyProperties(course, tutorCourseVO); + clientCourseVOS.add(tutorCourseVO); + } + tutorVo.setList(clientCourseVOS); + return R.ok(tutorVo); + }else{ + return R.ok(tutorVo); } - tutorVo.setList(clientCourseVOS); - return R.ok(tutorVo); }else{ tutorVo.setList(clientCourseVOS); return R.ok(tutorVo); } } @GetMapping("/detailTutor") - @ApiOperation(value = "查看详情导师专栏", notes = "管理后台-导师专栏") + @ApiOperation(value = "查看详情导师专栏", tags = "管理后台-导师专栏") public R<TutorSpecialColumn> detailTutor() { TutorSpecialColumn one = tutorSpecialColumnService.getOne(null); if (one!=null){ - List<Long> collect = tutorSpecialColumnCourseService.lambdaQuery().eq(TutorSpecialColumnCourse::getTutorSpecialColumnId, one.getId()) - .list().stream().map(TutorSpecialColumnCourse::getId).collect(Collectors.toList()); - if (!collect.isEmpty()){ + TutorSpecialColumnCourse one1 = tutorSpecialColumnCourseService.lambdaQuery() + .eq(TutorSpecialColumnCourse::getTutorSpecialColumnId, one.getId()).one(); + if (one1!=null){ + List<String> collect = Arrays.asList(one1.getCourseId().split(",")); List<Course> list = courseService.lambdaQuery().in(Course::getId, collect).list(); + for (Course course : list) { + CourseCategory byId = courseCategoryService.getById(course.getCateId()); + if (byId!=null){ + course.setCategoryName(byId.getName()); + } + } one.setCourses(list); } } return R.ok(one); } @PostMapping("/updateTutor") - @ApiOperation(value = "修改分类导师专栏", notes = "管理后台-导师专栏") + @ApiOperation(value = "修改分类导师专栏", tags = "管理后台-导师专栏") public R updateTutor(@RequestBody TutorSpecialColumn homeBackgroundMusic) { TutorSpecialColumn one = tutorSpecialColumnService.getOne(null); if (one == null){ @@ -104,19 +137,12 @@ .list().stream().map(TutorSpecialColumnCourse::getId) .collect(Collectors.toList()); tutorSpecialColumnCourseService.removeBatchByIds(collect); - List<TutorSpecialColumnCourse> tutorSpecialColumnCourses = new ArrayList<>(); if (StringUtils.hasLength(homeBackgroundMusic.getCourseIds())){ - String[] split = homeBackgroundMusic.getCourseIds().split(","); - for (int i = 0; i < split.length; i++) { - TutorSpecialColumnCourse tutorSpecialColumnCourse = new TutorSpecialColumnCourse(); - tutorSpecialColumnCourse.setCourseId(split[i]); - tutorSpecialColumnCourse.setTutorSpecialColumnId(homeBackgroundMusic.getId()); - tutorSpecialColumnCourse.setCreateBy(SecurityUtils.getUsername()); - tutorSpecialColumnCourse.setCreateTime(LocalDateTime.now()); - tutorSpecialColumnCourse.setUpdateBy(SecurityUtils.getUsername()); - tutorSpecialColumnCourse.setUpdateTime(LocalDateTime.now()); - tutorSpecialColumnCourses.add(tutorSpecialColumnCourse); - } + List<TutorSpecialColumnCourse> tutorSpecialColumnCourses = new ArrayList<>(); + TutorSpecialColumnCourse tutorSpecialColumnCourse = new TutorSpecialColumnCourse(); + tutorSpecialColumnCourse.setCourseId(homeBackgroundMusic.getCourseIds()); + tutorSpecialColumnCourse.setTutorSpecialColumnId(homeBackgroundMusic.getId()); + tutorSpecialColumnCourses.add(tutorSpecialColumnCourse); tutorSpecialColumnCourseService.saveBatch(tutorSpecialColumnCourses); } return R.ok(tutorSpecialColumnService.updateById(homeBackgroundMusic)); -- Gitblit v1.7.1