From e0d10eddc8721e6447787ccb6807c00e1b0b91f7 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期二, 10 九月 2024 09:49:45 +0800
Subject: [PATCH] 课程代码

---
 xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/Course.java                                        |    7 +++
 xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/TutorSpecialColumnCourse.java                      |    2 
 xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientTutorSpecialColumnController.java |   61 ++++++++++++++++++++++++++++++
 xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseController.java             |   24 ++++++++++++
 xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/vo/TutorVo.java                                    |   18 +++++++++
 5 files changed, 110 insertions(+), 2 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 d538e7f..774b4b8 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
@@ -4,6 +4,7 @@
 import com.xinquan.common.core.constant.SecurityConstants;
 import com.xinquan.common.core.domain.R;
 import com.xinquan.common.core.utils.page.PageDTO;
+import com.xinquan.course.domain.Course;
 import com.xinquan.course.domain.vo.ClientCourseCategoryVO;
 import com.xinquan.course.domain.vo.ClientCourseVO;
 import com.xinquan.course.service.CourseCategoryService;
@@ -15,6 +16,8 @@
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
 import java.util.List;
+
+import io.swagger.models.auth.In;
 import lombok.RequiredArgsConstructor;
 import org.springframework.web.bind.annotation.GetMapping;
 import org.springframework.web.bind.annotation.PostMapping;
@@ -61,6 +64,27 @@
     public R<List<ClientCourseCategoryVO>> getCourseCategoryList() {
         return R.ok(courseCategoryService.getCourseCategoryList());
     }
+    /**
+     * 课程详情
+     *
+     * @return 课程详情
+     */
+    @GetMapping("/getCourseInfoById")
+    @ApiOperation(value = "根据id获取课程详情-线下课程")
+    public R<Course> getCourseInfoById(String id) {
+        return R.ok(courseService.getById(id));
+    }
+    /**
+     * 课程详情
+     *
+     * @return 课程详情
+     */
+    @GetMapping("/getPayCourseInfoById")
+    @ApiOperation(value = "根据id获取课程详情-付费课程")
+    public R<Course> getPayCourseInfoById(String id) {
+
+        return R.ok(courseService.getById(id));
+    }
 
     /**
      * 获取课程列表-分页
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 0116cc2..417eafe 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,8 +1,32 @@
 package com.xinquan.course.controller.client;
 
 
+import com.alibaba.nacos.common.utils.StringUtils;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.xinquan.common.core.domain.R;
+import com.xinquan.common.core.utils.page.BeanUtils;
+import com.xinquan.common.core.utils.page.CollUtils;
+import com.xinquan.common.core.utils.page.PageDTO;
+import com.xinquan.course.domain.Course;
+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.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 io.swagger.annotations.ApiImplicitParam;
+import io.swagger.annotations.ApiImplicitParams;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
 import org.springframework.web.bind.annotation.RestController;
+
+import javax.annotation.Resource;
+import java.util.Arrays;
+import java.util.Objects;
 
 /**
  * <p>
@@ -16,5 +40,42 @@
 @RequestMapping("/client/course/tutor-special-column")
 public class ClientTutorSpecialColumnController {
 
+    @Resource
+    private TutorSpecialColumnService tutorSpecialColumnService;
+    @Resource
+    private TutorSpecialColumnCourseService tutorSpecialColumnCourseService;
+    @Resource
+    private CourseCategoryService courseCategoryService;
+    @Resource
+    private CourseService courseService;
+    @PostMapping("/getCoursePageList")
+    @ApiOperation(value = "导师专栏",tags = "导师专栏")
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "分页参数,当前页码", name = "pageCurr", required = true, dataType = "Integer"),
+            @ApiImplicitParam(value = "分页参数,每页数量", name = "pageSize", required = true, dataType = "Integer")
+    })
+    public R<TutorVo> getCourseList(
+            @RequestParam(value = "pageCurr", defaultValue = "1") Integer pageCurr,
+            @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) {
+        TutorVo tutorVo = new TutorVo();
+        TutorSpecialColumn one = tutorSpecialColumnService.lambdaQuery().one();
+        if (one!=null){
+            TutorSpecialColumnCourse one1 = tutorSpecialColumnCourseService.lambdaQuery().eq(TutorSpecialColumnCourse::getTutorSpecialColumnId, one.getId()).one();
+            BeanUtils.copyProperties(one, tutorVo);
+            Page<Course> page = courseService.lambdaQuery()
+                    .in(Course::getId, Arrays.asList(one1.getCourseId().split(",")))
+                    .orderByDesc(Course::getSortNum)
+                    .page(new Page<>(pageCurr, pageSize));
+            if (CollUtils.isEmpty(page.getRecords())) {
+                PageDTO.empty(page);
+            }
+            tutorVo.setList(PageDTO.of(page, ClientCourseVO.class));
+        }else{
+            return R.ok(tutorVo);
+        }
+        return R.ok();
+    }
+
+
 }
 
diff --git a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/Course.java b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/Course.java
index 8442478..15016a1 100644
--- a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/Course.java
+++ b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/Course.java
@@ -5,10 +5,13 @@
 import com.xinquan.common.core.web.domain.BaseModel;
 import com.baomidou.mybatisplus.annotation.TableId;
 import com.baomidou.mybatisplus.annotation.TableField;
+import com.xinquan.user.api.domain.AppUser;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
 import lombok.EqualsAndHashCode;
+
+import java.util.List;
 
 /**
  * <p>
@@ -98,5 +101,7 @@
     @TableField("latitude")
     private Double latitude;
 
-
+    @ApiModelProperty(value = "xx人已加入学习")
+    @TableField(exist = false)
+    private List<AppUser> listUser;
 }
diff --git a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/TutorSpecialColumnCourse.java b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/TutorSpecialColumnCourse.java
index 9029bc7..a0da37a 100644
--- a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/TutorSpecialColumnCourse.java
+++ b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/TutorSpecialColumnCourse.java
@@ -32,7 +32,7 @@
 
     @ApiModelProperty(value = "课程id")
     @TableField("course_id")
-    private Long courseId;
+    private String courseId;
 
     @ApiModelProperty(value = "导师专栏id")
     @TableField("tutor_special_column_id")
diff --git a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/vo/TutorVo.java b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/vo/TutorVo.java
new file mode 100644
index 0000000..0315f61
--- /dev/null
+++ b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/domain/vo/TutorVo.java
@@ -0,0 +1,18 @@
+package com.xinquan.course.domain.vo;
+
+import com.xinquan.common.core.utils.page.PageDTO;
+import com.xinquan.course.domain.TutorSpecialColumn;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+/**
+ * @author mitao
+ * @date 2024/9/7
+ */
+@Data
+@ApiModel(value = "导师专栏对象")
+public class TutorVo extends TutorSpecialColumn {
+    @ApiModelProperty(value = "相关课程")
+    private PageDTO<ClientCourseVO> list;
+}

--
Gitblit v1.7.1