From 039a33d1bfa6ef041161666bbd120c34086fe7c1 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期一, 14 十月 2024 14:09:25 +0800
Subject: [PATCH] 课程代码

---
 xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseController.java |  254 +++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 237 insertions(+), 17 deletions(-)

diff --git a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseController.java b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseController.java
index bdb78ec..f586f82 100644
--- a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseController.java
+++ b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseController.java
@@ -2,6 +2,8 @@
 
 
 import com.alibaba.nacos.common.utils.StringUtils;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.xinquan.common.core.constant.SecurityConstants;
 import com.xinquan.common.core.domain.R;
@@ -10,20 +12,27 @@
 import com.xinquan.common.core.utils.page.PageDTO;
 import com.xinquan.common.security.utils.SecurityUtils;
 import com.xinquan.course.api.domain.Course;
+import com.xinquan.course.api.domain.CourseDTO;
 import com.xinquan.course.api.vo.CourseVO;
 import com.xinquan.course.api.vo.StudyPageVO;
+import com.xinquan.course.api.domain.CourseCategory;
 import com.xinquan.course.domain.CourseChapter;
+import com.xinquan.course.domain.CourseUserFavorite;
 import com.xinquan.course.domain.vo.ClientCourseCategoryVO;
 import com.xinquan.course.domain.vo.ClientCourseVO;
 import com.xinquan.course.service.CourseCategoryService;
 import com.xinquan.course.service.CourseChapterService;
 import com.xinquan.course.service.CourseService;
+import com.xinquan.course.service.CourseUserFavoriteService;
+import com.xinquan.meditation.api.domain.Meditation;
+import com.xinquan.meditation.api.feign.RemoteMeditationService;
 import com.xinquan.system.api.RemoteBannerService;
 import com.xinquan.system.api.domain.AppUser;
 import com.xinquan.system.api.domain.AppUserCourse;
 import com.xinquan.system.api.domain.AppUserViewingHistory;
 import com.xinquan.system.api.domain.vo.AppUserVO;
 import com.xinquan.system.api.domain.vo.BannerVO;
+import com.xinquan.course.api.domain.OrderCourseVO;
 import com.xinquan.user.api.feign.RemoteAppUserService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiImplicitParam;
@@ -32,12 +41,13 @@
 
 import java.time.LocalDateTime;
 import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.List;
 import java.util.Objects;
 import java.util.stream.Collectors;
 
-import io.swagger.models.auth.In;
 import lombok.RequiredArgsConstructor;
+import org.springframework.data.domain.jaxb.SpringDataJaxb;
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
@@ -60,9 +70,210 @@
     private final CourseService courseService;
     private final RemoteBannerService remoteBannerService;
     private final RemoteAppUserService remoteAppUserService;
-
     @Resource
     private CourseChapterService courseChapterService;
+    @Resource
+    private CourseUserFavoriteService courseUserFavoriteService;
+    @Resource
+    private RemoteMeditationService remoteMeditationService;
+
+    /**
+     * 远程调用 通过课程名字查询课程ids
+     * @return
+     */
+    @PostMapping("/getCourseIdsByName/{name}")
+    public R<List<Long>> getCourseIdsByName(@PathVariable("name") String name) {
+        List<Long> collect = courseService.lambdaQuery().like(Course::getCourseTitle, name)
+                .list().stream().map(Course::getId)
+                .collect(Collectors.toList());
+        return R.ok(collect);
+    }
+
+    @PostMapping("/courseManagementList")
+    @ApiOperation(value = "课程管理列表-分页", tags = {"管理后台-课程管理"})
+    public R<PageDTO<Course>> courseManagementList(@RequestBody CourseDTO courseDTO) {
+        List<Long> longs = new ArrayList<>();
+        LambdaQueryWrapper<Course> courseLambdaQueryWrapper = new LambdaQueryWrapper<>();
+        courseLambdaQueryWrapper.like(StringUtils.isNotBlank(courseDTO.getTutor()), Course::getTutor, courseDTO.getTutor())
+                .eq(Objects.nonNull(courseDTO.getCateId()), Course::getCateId, courseDTO.getCateId())
+                .eq(Objects.nonNull(courseDTO.getCourseType()), Course::getCourseType, courseDTO.getCourseType())
+                .eq(Objects.nonNull(courseDTO.getChargeType()), Course::getChargeType, courseDTO.getChargeType())
+                .eq(Objects.nonNull(courseDTO.getListingStatus()), Course::getListingStatus, courseDTO.getListingStatus())
+                .orderByDesc(Course::getSortNum);
+        if (org.springframework.util.StringUtils.hasLength(courseDTO.getCourseTitle())){
+            List<Long> collect = courseService.lambdaQuery().like(Course::getCourseTitle, courseDTO.getCourseTitle()).list()
+                    .stream().map(Course::getId).collect(Collectors.toList());
+            longs.addAll(collect);
+            List<Long> collect1 = courseChapterService.lambdaQuery().like(CourseChapter::getChapterTitle, courseDTO.getCourseTitle()).list()
+                    .stream().map(CourseChapter::getCourseId).collect(Collectors.toList());
+            longs.addAll(collect1);
+            if (longs.isEmpty()){
+                longs.add(-1L);
+            }
+            courseLambdaQueryWrapper.in(Course::getId, longs);
+        }
+        Page<Course> page = courseService.page(new Page<>(courseDTO.getPageCurr(), courseDTO.getPageSize()), courseLambdaQueryWrapper);
+        if (CollUtils.isEmpty(page.getRecords())) {
+            return R.ok(PageDTO.empty(page));
+        }
+        for (Course record : page.getRecords()) {
+            CourseCategory byId = courseCategoryService.getById(record.getCateId());
+            if (Objects.nonNull(byId)){
+                record.setCategoryName(byId.getName());
+            }
+            record.setUid(record.getId().toString());
+            long count = courseChapterService.count(new LambdaQueryWrapper<CourseChapter>().eq(CourseChapter::getCourseId, record.getId()));
+            record.setCourseChapterCount(count);
+            // 查询收藏数量
+            long count1 = courseUserFavoriteService.count(new LambdaQueryWrapper<CourseUserFavorite>()
+                    .eq(CourseUserFavorite::getCourseId, record.getId()));
+            record.setCollectCount(count1);
+        }
+        return R.ok(PageDTO.of(page, Course.class));
+    }
+    @PostMapping("/addCourse")
+    @ApiOperation(value = "新增课程管理", notes = "管理后台-课程管理")
+    public R addCourse(@RequestBody Course homeBackgroundMusic) {
+        homeBackgroundMusic.setCreateBy(SecurityUtils.getUsername());
+        homeBackgroundMusic.setCreateTime(LocalDateTime.now());
+        return R.ok(courseService.save(homeBackgroundMusic));
+    }
+    @GetMapping("/detailCourse")
+    @ApiOperation(value = "查看详情课程管理", notes = "管理后台-课程管理")
+    public R<Course> detailCourse(String uid) {
+        return R.ok(courseService.getById(uid));
+    }
+    @GetMapping("/updateState")
+    @ApiOperation(value = "修改课程上下架状态", notes = "管理后台-课程管理")
+    public R updateState(String uid) {
+        Course byId = courseService.getById(uid);
+        if (byId.getListingStatus() == 1){
+            byId.setListingStatus(2);
+        }else {
+            byId.setListingStatus(1);
+        }
+        return R.ok();
+    }
+    @PostMapping("/updateCourse")
+    @ApiOperation(value = "修改课程管理", notes = "管理后台-课程管理")
+    public R updateCourse(@RequestBody Course homeBackgroundMusic) {
+        homeBackgroundMusic.setUpdateBy(SecurityUtils.getUsername());
+        homeBackgroundMusic.setUpdateTime(LocalDateTime.now());
+        return R.ok(courseService.updateById(homeBackgroundMusic));
+    }
+    @PostMapping("/deleteCourse")
+    @ApiOperation(value = "批量删除", notes = "管理后台-课程管理")
+    public R deleteCourse(String ids) {
+        return R.ok(courseService.removeBatchByIds(Arrays.asList(ids.split(","))));
+    }
+
+
+
+    @PostMapping("/cateList")
+    public R<List<CourseCategory>> cateList() {
+        List<CourseCategory> list = courseCategoryService.list();
+        for (CourseCategory courseCategory : list) {
+            courseCategory.setUid(courseCategory.getId().toString());
+        }
+        return R.ok(list);
+    }
+    @PostMapping("/courseList")
+    public R<PageDTO<Course>> courseList(@RequestBody CourseDTO courseDTO) {
+        Page<Course> page = courseService.lambdaQuery()
+                .like(StringUtils.isNotBlank(courseDTO.getCourseTitle()), Course::getCourseTitle, courseDTO.getCourseTitle())
+                .like(StringUtils.isNotBlank(courseDTO.getTutor()), Course::getTutor, courseDTO.getTutor())
+                .eq(Objects.nonNull(courseDTO.getCateId()), Course::getCateId, courseDTO.getCateId())
+                .eq(Objects.nonNull(courseDTO.getCourseType()), Course::getCourseType, courseDTO.getCourseType())
+                .orderByDesc(Course::getSortNum)
+                .page(new Page<>(courseDTO.getPageCurr(), courseDTO.getPageSize()));
+        if (CollUtils.isEmpty(page.getRecords())) {
+            return R.ok(PageDTO.empty(page));
+        }
+        for (Course record : page.getRecords()) {
+            CourseCategory byId = courseCategoryService.getById(record.getCateId());
+            if (Objects.nonNull(byId)){
+                record.setCategoryName(byId.getName());
+            }
+            record.setUid(record.getId().toString());
+        }
+        return R.ok(PageDTO.of(page, Course.class));
+    }
+    @PostMapping("/myCollect")
+    @ApiOperation(value = "我的收藏")
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "state", value = "1冥想 2课程", dataType = "Integer", required = true),
+            @ApiImplicitParam(name = "pageCurr", value = "分页参数,当前页码", dataType = "Integer", required = true),
+            @ApiImplicitParam(name = "pageSize", value = "分页参数,每页数量", dataType = "Integer", required = true)
+    })
+    public R<PageDTO<OrderCourseVO>> myCollect(@RequestParam(value = "state")Integer state,
+                                               @RequestParam(value = "pageCurr")Integer pageCurr,
+                                               @RequestParam(value = "pageSize")Integer pageSize) {
+        Long userId = SecurityUtils.getUserId();
+        if (userId == 0)return R.tokenError("登录失效");
+        switch (state){
+            case 1:
+                Page<Meditation> data = remoteMeditationService.getMeditationById(pageCurr, pageSize)
+                        .getData();
+                for (Meditation meditation : data.getRecords()) {
+
+                }
+                break;
+            case 2:
+                Page<CourseUserFavorite> page = courseUserFavoriteService.lambdaQuery()
+                        .eq(CourseUserFavorite::getAppUserId, userId)
+                        .page(new Page<>(pageCurr, pageSize));
+                PageDTO<OrderCourseVO> courseChapterPageDTO = PageDTO.of(page, OrderCourseVO.class);
+                for (CourseUserFavorite record : page.getRecords()) {
+
+                }
+                break;
+        }
+        return R.ok();
+    }
+    @PostMapping("/collectCourse")
+    @ApiOperation(value = "收藏/取消课程")
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "课程id", name = "id", required = true, dataType = "Long"),
+    })
+    public R collectCourse(@RequestParam(value = "id")Long id) {
+        Long userId = SecurityUtils.getUserId();
+        if (userId == 0)return R.tokenError("登录失效");
+        CourseUserFavorite one = courseUserFavoriteService.lambdaQuery()
+                .eq(CourseUserFavorite::getAppUserId, userId)
+                .eq(CourseUserFavorite::getCourseId, id).one();
+        if (one==null){
+            // 收藏课程
+            CourseUserFavorite courseUserFavorite = new CourseUserFavorite();
+            courseUserFavorite.setAppUserId(userId);
+            courseUserFavorite.setCourseId(id);
+            courseUserFavoriteService.save(courseUserFavorite);
+        }else{
+            // 取消收藏
+            courseUserFavoriteService.removeById(one);
+        }
+        return R.ok();
+    }
+
+
+    /**
+     * 远程调用 根据课程id查询课程信息
+     *
+     * @return 课程分类列表
+     */
+    @PostMapping("/getCourseByCourseId/{courseId}")
+    public R<OrderCourseVO> getCourseCategoryList(@RequestBody OrderCourseVO req) {
+        Course byId = courseService.getById(req.getBusinessId());
+        List<AppUser> data = remoteAppUserService.getUserByCourseId(req.getBusinessId()).getData();
+        if (data!=null){
+            req.setCount(data.size());
+            req.setCourseTitle(byId.getCourseTitle());
+            req.setDescription(byId.getDescription());
+            req.setGeneralPrice(byId.getGeneralPrice());
+            req.setIosPrice(byId.getIosPrice());
+            req.setCoverUrl(byId.getCoverUrl());
+        }
+        return R.ok(req);
+    }
 
     /**
      * 获取轮播图列表
@@ -84,6 +295,15 @@
     @ApiOperation(value = "获取课程分类列表")
     public R<List<ClientCourseCategoryVO>> getCourseCategoryList() {
         return R.ok(courseCategoryService.getCourseCategoryList());
+    }
+    /**
+     * 远程调用 根据分类id 获取分类对象
+     *
+     * @return 课程分类列表
+     */
+    @GetMapping("/getCategoryById/{id}")
+    public R<CourseCategory> getCategoryById(@PathVariable("id") String id) {
+        return R.ok(courseCategoryService.getById(id));
     }
     /**
      * 课程详情
@@ -155,6 +375,10 @@
             }
         }
         clientCourseVO.setList2(courses);
+        // 查询是否已收藏课程
+        clientCourseVO.setIsCollect(courseUserFavoriteService.lambdaQuery()
+                .eq(CourseUserFavorite::getAppUserId, userId)
+                .eq(CourseUserFavorite::getCourseId, id) == null ? 2 : 1);
         return R.ok(clientCourseVO);
     }
 
@@ -258,29 +482,25 @@
     }
     @GetMapping("/studyPage")
     @ApiOperation(value = "学习")
-    @ApiImplicitParams({
-            @ApiImplicitParam(value = "分页参数,当前页码", name = "pageCurr", required = true, dataType = "Integer"),
-            @ApiImplicitParam(value = "分页参数,每页数量", name = "pageSize", required = true, dataType = "Integer")
-    })
-    public R<StudyPageVO> studyPage(@RequestParam(value = "pageCurr", defaultValue = "1") Integer pageCurr,
-                               @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) {
+
+    public R<StudyPageVO> studyPage() {
         Long userId = SecurityUtils.getUserId();
         if (userId == 0)return R.tokenError("登录失效");
         StudyPageVO studyPageVO = new StudyPageVO();
+        List<CourseVO> courseVOS = new ArrayList<>();
 
-        PageDTO<AppUserCourse> data = remoteAppUserService.getPayCourse(pageCurr, pageSize).getData();
+        PageDTO<AppUserCourse> data = remoteAppUserService.getPayCourse(1, 909999).getData();
         List<AppUserCourse> list = data.getList();
         if (CollUtils.isNotEmpty(list)) {
             List<Long> courseIds = list.stream().map(AppUserCourse::getCourseId).collect(Collectors.toList());
-            Page<Course> page = courseService.lambdaQuery()
+            List<Course> page = courseService.lambdaQuery()
                     .in(Course::getId, courseIds)
-                    .page(new Page<>(pageCurr, pageSize));
-            if (CollUtils.isEmpty(page.getRecords())) {
-                PageDTO<CourseVO> empty = PageDTO.empty(page);
-                studyPageVO.setCourseList(empty);
-            }else{
-                PageDTO<CourseVO> courseChapterPageDTO = PageDTO.of(page, CourseVO.class);
-                studyPageVO.setCourseList(courseChapterPageDTO);
+                    .list();
+            for (Course course : page) {
+                CourseVO courseVO = new CourseVO();
+                BeanUtils.copyProperties(course, courseVO);
+                courseVOS.add(courseVO);
+                studyPageVO.setCourseList(courseVOS);
             }
         }
         // 查询两个相同类型的线上免费课程

--
Gitblit v1.7.1