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