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/ClientCourseChapterController.java |   89 +++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 86 insertions(+), 3 deletions(-)

diff --git a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseChapterController.java b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseChapterController.java
index dd45576..9cea515 100644
--- a/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseChapterController.java
+++ b/xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseChapterController.java
@@ -1,12 +1,32 @@
 package com.xinquan.course.controller.client;
 
 
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+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.CollUtils;
+import com.xinquan.common.core.utils.page.PageDTO;
+import com.xinquan.common.security.utils.SecurityUtils;
+import com.xinquan.course.api.domain.CourseChapter;
+import com.xinquan.course.domain.CourseLearningRecord;
+import com.xinquan.course.service.CourseChapterService;
+import com.xinquan.course.service.CourseLearningRecordService;
+import com.xinquan.user.api.feign.RemoteAppUserService;
+import io.swagger.annotations.ApiImplicitParam;
+import io.swagger.annotations.ApiImplicitParams;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import javax.annotation.Resource;
+import java.time.LocalDateTime;
+import java.util.Arrays;
+import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * <p>
- * 在线课程章节表 前端控制器
+ * 在线章节章节表 前端控制器
  * </p>
  *
  * @author mitao
@@ -15,6 +35,69 @@
 @RestController
 @RequestMapping("/client/course/course-chapter")
 public class ClientCourseChapterController {
+    @Autowired
+    private CourseChapterService courseChapterService;
+    @Autowired
+    private CourseLearningRecordService courseLearningRecordService;
+    @PostMapping("/courseChapterManagementList")
+    @ApiOperation(value = "章节列表-分页", tags = {"管理后台-章节管理"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "pageCurr", value = "分页参数,当前页码", dataType = "Integer", required = true),
+            @ApiImplicitParam(name = "courseId", value = "课程id", dataType = "String", required = true),
+            @ApiImplicitParam(name = "pageSize", value = "分页参数,每页数量", dataType = "Integer", required = true)
+    })
+    public R<PageDTO<CourseChapter>> courseChapterManagementList(@RequestParam(value = "pageCurr")Integer pageCurr,
+                                                                 @RequestParam(value = "courseId")String courseId,
+                                                                 @RequestParam(value = "pageSize")Integer pageSize) {
+        LambdaQueryWrapper<CourseChapter> courseLambdaQueryWrapper = new LambdaQueryWrapper<>();
+        courseLambdaQueryWrapper.orderByDesc(CourseChapter::getSortNum);
+        courseLambdaQueryWrapper.eq(CourseChapter::getCourseId,courseId);
+        Page<CourseChapter> page = courseChapterService.page(new Page<>(pageCurr, pageSize), courseLambdaQueryWrapper);
+        if (CollUtils.isEmpty(page.getRecords())) {
+            return R.ok(PageDTO.empty(page));
+        }
+        for (CourseChapter record : page.getRecords()) {
+            record.setUid(record.getId()+"");
+            int b = 0;
+            Long data1 = remoteAppUserService.getCourseChapterHistoryCount(record.getId()).getData();
+            b+=data1;
+            record.setRealLearnedNum(b);
+        }
 
+        return R.ok(PageDTO.of(page, CourseChapter.class));
+    }
+    @PostMapping("/addChapter")
+    @ApiOperation(value = "新增章节管理", tags = "管理后台-章节管理")
+    public R addCourseChapter(@RequestBody CourseChapter homeBackgroundMusic) {
+        homeBackgroundMusic.setCreateBy(SecurityUtils.getUsername());
+        homeBackgroundMusic.setCreateTime(LocalDateTime.now());
+        return R.ok(courseChapterService.save(homeBackgroundMusic));
+    }
+    @Resource
+    private RemoteAppUserService remoteAppUserService;
+    @GetMapping("/detailCourseChapter")
+    @ApiOperation(value = "查看详情章节管理", tags = "管理后台-章节管理")
+    public R<CourseChapter> detailCourseChapter(String uid) {
+        CourseChapter byId = courseChapterService.getById(uid);
+        int a = 0;
+        int b = 0;
+        a+= byId.getVirtualLearnedNum();
+        Long data1 = remoteAppUserService.getCourseChapterHistoryCount(byId.getId()).getData();
+        b+=data1;
+        byId.setRealLearnedNum(b);
+        return R.ok(byId);
+    }
+    @PostMapping("/updateCourseChapter")
+    @ApiOperation(value = "修改章节管理", tags = "管理后台-章节管理")
+    public R updateCourseChapter(@RequestBody CourseChapter homeBackgroundMusic) {
+        homeBackgroundMusic.setUpdateBy(SecurityUtils.getUsername());
+        homeBackgroundMusic.setUpdateTime(LocalDateTime.now());
+        return R.ok(courseChapterService.updateById(homeBackgroundMusic));
+    }
+    @PostMapping("/deleteCourseChapter")
+    @ApiOperation(value = "批量删除", tags = "管理后台-章节管理")
+    public R deleteCourseChapter(String ids) {
+        return R.ok(courseChapterService.removeBatchByIds(Arrays.asList(ids.split(",")).stream().map(Long::valueOf).collect(Collectors.toList())));
+    }
 }
 

--
Gitblit v1.7.1