From 64f7ccb9ef8b5a0618e65cddc14b981c1f108ba3 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期一, 04 十一月 2024 09:01:59 +0800
Subject: [PATCH] 代码提交

---
 xinquan-modules/xinquan-course/src/main/java/com/xinquan/course/controller/client/ClientCourseController.java |  541 +++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 474 insertions(+), 67 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 f586f82..685d5ac 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
@@ -1,29 +1,33 @@
 package com.xinquan.course.controller.client;
 
 
+import cn.afterturn.easypoi.excel.ExcelExportUtil;
+import cn.afterturn.easypoi.excel.entity.ExportParams;
 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;
+import com.xinquan.common.core.utils.WebUtils;
 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.common.core.web.domain.BaseModel;
+import com.xinquan.common.security.service.TokenService;
 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.api.domain.CourseChapter;
+import com.xinquan.course.domain.CourseLearningRecord;
 import com.xinquan.course.domain.CourseUserFavorite;
+import com.xinquan.course.domain.export.CourseExport;
+import com.xinquan.course.domain.export.CourseOffExport;
 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.course.service.*;
 import com.xinquan.meditation.api.domain.Meditation;
 import com.xinquan.meditation.api.feign.RemoteMeditationService;
 import com.xinquan.system.api.RemoteBannerService;
@@ -33,13 +37,17 @@
 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.system.api.model.LoginUser;
 import com.xinquan.user.api.feign.RemoteAppUserService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
 
+import java.io.IOException;
+import java.net.URLEncoder;
 import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
 import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.List;
@@ -47,10 +55,13 @@
 import java.util.stream.Collectors;
 
 import lombok.RequiredArgsConstructor;
-import org.springframework.data.domain.jaxb.SpringDataJaxb;
+import org.apache.poi.ss.usermodel.Workbook;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
+import javax.servlet.ServletOutputStream;
+import javax.servlet.http.HttpServletResponse;
 
 /**
  * <p>
@@ -74,8 +85,74 @@
     private CourseChapterService courseChapterService;
     @Resource
     private CourseUserFavoriteService courseUserFavoriteService;
+
     @Resource
     private RemoteMeditationService remoteMeditationService;
+    @Resource
+    private CourseLearningRecordService courseLearningRecordService;
+
+    @GetMapping("/getCourseCount")
+    public R<String> getCourseCount() {
+        StringBuilder stringBuilder = new StringBuilder();
+        List<Course> list = courseService.lambdaQuery().eq(BaseModel::getDelFlag, 0)
+                .eq(Course::getCourseType,1).list();
+        List<Course> list1 = courseService.lambdaQuery().eq(BaseModel::getDelFlag, 0)
+                .eq(Course::getCourseType, 2).list();
+        stringBuilder.append(list.size()+list1.size()).append(",");
+        List<Course> collect1 = list.stream().filter(t -> t.getChargeType() == 1).collect(Collectors.toList());
+        List<Course> collect2 = list.stream().filter(t -> t.getChargeType() == 2).collect(Collectors.toList());
+        List<Course> collect3 = list.stream().filter(t -> t.getChargeType() == 3).collect(Collectors.toList());
+        stringBuilder.append(collect1.size()).append(",");
+        stringBuilder.append(collect2.size()).append(",");
+        stringBuilder.append(collect3.size()).append(",");
+        stringBuilder.append(list1.size());
+        return R.ok(stringBuilder.toString());
+    }
+    /**
+     * 根据课程id 查询学习人数
+     * @param id
+     * @return
+     */
+    @GetMapping("/getCountByCourseId/{id}")
+    public R<Integer> getCountByCourseId(
+                                          @PathVariable("id")String id)
+    {
+        int size = courseLearningRecordService.lambdaQuery().eq(CourseLearningRecord::getCourseId, id)
+                .groupBy(CourseLearningRecord::getAppUserId).list().size();
+
+        return R.ok(size);
+    }
+    /**
+     * 根据课程id 查询章节列表
+     * @param id
+     * @return
+     */
+    @GetMapping("/getChapterByCourseId/{id}")
+    public R<List<CourseChapter>> getChapterByCourseId(
+                                          @PathVariable("id")String id)
+    {
+        return R.ok(courseChapterService.lambdaQuery().eq(CourseChapter::getCourseId,id).list());
+    }
+
+
+
+
+    @GetMapping("/getCourseByIds/{pageCurr}/{pageSize}/{ids}")
+    public R<Page<Course>> getCourseByIds(@PathVariable("pageCurr") Integer pageCurr,
+                                                  @PathVariable("pageSize") Integer pageSize,
+                                                  @PathVariable("ids")String ids)
+    {
+
+        Page<Course> page = courseService
+                .lambdaQuery()
+                .in(Course::getId,Arrays.asList(ids.split(",")))
+                .page(new Page<>(pageCurr, pageSize));
+        if (page.getRecords().isEmpty()){
+            return R.ok(page);
+        }
+        // 查询人数
+        return R.ok(page);
+    }
 
     /**
      * 远程调用 通过课程名字查询课程ids
@@ -89,6 +166,137 @@
         return R.ok(collect);
     }
 
+    @ApiOperation(value = "课程管理列表导出", tags = {"管理后台-课程管理"})
+    @PutMapping("/export")
+    public void export(@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.getIds())){
+            courseLambdaQueryWrapper.in(Course::getId, Arrays.asList(courseDTO.getIds().split(",")));
+        }
+        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);
+        }
+        List<Course> page = courseService.list(courseLambdaQueryWrapper);
+        List<CourseExport> courseExports = new ArrayList<>();
+        List<CourseOffExport> courseOffExports = new ArrayList<>();
+        for (Course record : page) {
+            CourseExport courseExport = new CourseExport();
+            CourseOffExport courseOffExport = new CourseOffExport();
+            CourseCategory byId = courseCategoryService.getById(record.getCateId());
+            if (Objects.nonNull(byId)){
+                record.setCategoryName(byId.getName());
+                courseExport.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);
+            int size1 = courseLearningRecordService.lambdaQuery().eq(CourseLearningRecord::getCourseId, record.getId())
+                    .groupBy(CourseLearningRecord::getAppUserId).list().size();
+            // 查询学习人数
+//            int size = remoteAppUserService.getUserByCourseId(record.getId()).getData().size();
+            record.setCount(size1);
+            courseExport.setName(record.getCourseTitle());
+            courseExport.setTutor(record.getTutor());
+            if (record.getCourseType()==1){
+            switch (record.getChargeType()){
+                case 1:
+                    courseExport.setGeneralPrice("免费");
+                    break;
+                case 2:
+                    courseExport.setGeneralPrice("会员免费");
+                    break;
+                case 3:
+                    courseExport.setGeneralPrice("¥"+record.getGeneralPrice());
+                    break;
+            }
+            }
+
+            courseExport.setCourseChapterCount(count+"");
+            courseExport.setListingStatus(record.getListingStatus()+"");
+            courseExport.setRealLearnedNum(size1+"");
+            courseExport.setCollectCount(count1+"");
+            DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+            String format = df.format(record.getCreateTime());
+            courseExport.setCreateTime(format);
+            courseExports.add(courseExport);
+            // 线下
+            courseOffExport.setName(record.getCourseTitle());
+            courseOffExport.setTutor(record.getTutor());
+            courseOffExport.setAddress(record.getAddress()+record.getAddressDetail());
+            courseOffExport.setListingStatus(record.getListingStatus()+"");
+            courseOffExport.setCollectCount(count1+"");
+            courseOffExport.setCreateTime(format);
+            courseOffExports.add(courseOffExport);
+        }
+        if (courseDTO.getCourseType()==1){
+            Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), CourseExport.class, courseExports);
+            HttpServletResponse response = WebUtils.response();
+            response.setContentType("application/vnd.ms-excel");
+            response.setCharacterEncoding("utf-8");
+            ServletOutputStream outputStream = null;
+            try {
+                String fileName = URLEncoder.encode("线上课程导出.xls", "utf-8");
+                response.setHeader("Content-Disposition", "attachment;filename=" + fileName);
+                response.setContentType("application/vnd.ms-excel;charset=UTF-8");
+                response.setHeader("Pragma", "no-cache");
+                response.setHeader("Cache-Control", "no-cache");
+                outputStream = response.getOutputStream();
+                workbook.write(outputStream);
+            } catch (IOException e) {
+                e.printStackTrace();
+            } finally {
+                try {
+                    outputStream.close();
+                } catch (IOException e) {
+                    e.printStackTrace();
+                }
+            }
+        }else{
+            Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), CourseOffExport.class, courseOffExports);
+            HttpServletResponse response = WebUtils.response();
+            response.setContentType("application/vnd.ms-excel");
+            response.setCharacterEncoding("utf-8");
+            ServletOutputStream outputStream = null;
+            try {
+                String fileName = URLEncoder.encode("线下课程导出.xls", "utf-8");
+                response.setHeader("Content-Disposition", "attachment;filename=" + fileName);
+                response.setContentType("application/vnd.ms-excel;charset=UTF-8");
+                response.setHeader("Pragma", "no-cache");
+                response.setHeader("Cache-Control", "no-cache");
+                outputStream = response.getOutputStream();
+                workbook.write(outputStream);
+            } catch (IOException e) {
+                e.printStackTrace();
+            } finally {
+                try {
+                    outputStream.close();
+                } catch (IOException e) {
+                    e.printStackTrace();
+                }
+            }
+        }
+    }
     @PostMapping("/courseManagementList")
     @ApiOperation(value = "课程管理列表-分页", tags = {"管理后台-课程管理"})
     public R<PageDTO<Course>> courseManagementList(@RequestBody CourseDTO courseDTO) {
@@ -128,23 +336,62 @@
             long count1 = courseUserFavoriteService.count(new LambdaQueryWrapper<CourseUserFavorite>()
                     .eq(CourseUserFavorite::getCourseId, record.getId()));
             record.setCollectCount(count1);
+            // 查询学习人数
+//            record.setCount(remoteAppUserService.getUserByCourseId(record.getId()).getData().size());
+            int size1 = courseLearningRecordService.lambdaQuery().eq(CourseLearningRecord::getCourseId, record.getId())
+                    .groupBy(CourseLearningRecord::getAppUserId).list().size();
+            List<CourseChapter> list = courseChapterService.lambdaQuery()
+                    .eq(CourseChapter::getCourseId, record.getId()).list();
+            // 章节列表累加虚拟学习人数
+            int temp = 0;
+            for (CourseChapter courseChapter : list) {
+                temp+=courseChapter.getVirtualLearnedNum();
+            }
+            record.setCount(size1+temp);
         }
         return R.ok(PageDTO.of(page, Course.class));
     }
     @PostMapping("/addCourse")
-    @ApiOperation(value = "新增课程管理", notes = "管理后台-课程管理")
+    @ApiOperation(value = "新增课程管理", tags = "管理后台-课程管理")
     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 = "管理后台-课程管理")
+    @ApiOperation(value = "查看详情课程管理", tags = "管理后台-课程管理")
     public R<Course> detailCourse(String uid) {
-        return R.ok(courseService.getById(uid));
+        Course byId = courseService.getById(uid);
+        CourseCategory byId1 = courseCategoryService.getById(byId.getCateId());
+        if (byId1!=null){
+            byId.setCategoryName(byId1.getName());
+        }
+        List<CourseChapter> list = courseChapterService.lambdaQuery()
+                .eq(CourseChapter::getCourseId, uid).list();
+        int temp = 0;
+        int temp1 = 0;
+        for (CourseChapter courseChapter : list) {
+            int size = courseLearningRecordService.lambdaQuery()
+                    .eq(CourseLearningRecord::getChapterId, courseChapter.getId())
+                    .list().size();
+            courseChapter.setRealLearnedNum(size+courseChapter.getVirtualLearnedNum());
+            temp+=courseChapter.getVirtualLearnedNum();
+            temp1+=size;
+        }
+        int size1 = courseLearningRecordService.lambdaQuery()
+                .eq(CourseLearningRecord::getCourseId, uid).groupBy(CourseLearningRecord::getAppUserId)
+                .list().size();
+        byId.setVirtualLearnedNum(temp);
+        byId.setRealLearnedNum(size1);
+        byId.setCount(temp+size1);
+        byId.setList(list);
+        int size = courseUserFavoriteService.lambdaQuery()
+                .eq(CourseUserFavorite::getCourseId, uid).list().size();
+        byId.setCollectCount((long) size);
+        return R.ok(byId);
     }
     @GetMapping("/updateState")
-    @ApiOperation(value = "修改课程上下架状态", notes = "管理后台-课程管理")
+    @ApiOperation(value = "修改课程上下架状态", tags = "管理后台-课程管理")
     public R updateState(String uid) {
         Course byId = courseService.getById(uid);
         if (byId.getListingStatus() == 1){
@@ -152,24 +399,25 @@
         }else {
             byId.setListingStatus(1);
         }
+        courseService.updateById(byId);
         return R.ok();
     }
     @PostMapping("/updateCourse")
-    @ApiOperation(value = "修改课程管理", notes = "管理后台-课程管理")
+    @ApiOperation(value = "修改课程管理", tags = "管理后台-课程管理")
     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 = "管理后台-课程管理")
+    @ApiOperation(value = "批量删除", tags = "管理后台-课程管理")
     public R deleteCourse(String ids) {
-        return R.ok(courseService.removeBatchByIds(Arrays.asList(ids.split(","))));
+        return R.ok(courseService.removeBatchByIds(Arrays.asList(ids.split(",")).stream().map(Long::valueOf).collect(Collectors.toList())));
     }
 
 
 
-    @PostMapping("/cateList")
+    @GetMapping("/cateList")
     public R<List<CourseCategory>> cateList() {
         List<CourseCategory> list = courseCategoryService.list();
         for (CourseCategory courseCategory : list) {
@@ -198,6 +446,8 @@
         }
         return R.ok(PageDTO.of(page, Course.class));
     }
+    @Autowired
+    private TokenService tokenService;
     @PostMapping("/myCollect")
     @ApiOperation(value = "我的收藏")
     @ApiImplicitParams({
@@ -205,30 +455,66 @@
             @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,
+    public R<List<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("登录失效");
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
+        List<OrderCourseVO> orderCourseVOS = new ArrayList<>();
+
         switch (state){
             case 1:
-                Page<Meditation> data = remoteMeditationService.getMeditationById(pageCurr, pageSize)
+                Page<Meditation> data = remoteMeditationService.getMeditationById(pageCurr, pageSize,userId)
                         .getData();
                 for (Meditation meditation : data.getRecords()) {
-
+                    OrderCourseVO orderCourseVO = new OrderCourseVO();
+                    orderCourseVO.setBusinessId(meditation.getId());
+                    orderCourseVO.setCourseTitle(meditation.getMeditationTitle());
+                    orderCourseVO.setDescription(meditation.getDetailDescription());
+                    orderCourseVO.setChargeType(meditation.getChargeType());
+                    orderCourseVO.setGeneralPrice(meditation.getGeneralPrice());
+                    orderCourseVO.setIosPrice(meditation.getIosPrice());
+                    orderCourseVO.setCoverUrl(meditation.getCoverUrl());
+                    orderCourseVO.setCount(meditation.getRealLearnedNum()+meditation.getVirtualLearnedNum());
+                    orderCourseVOS.add(orderCourseVO);
                 }
                 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()) {
+                List<Long> collect = courseUserFavoriteService.lambdaQuery()
+                        .eq(CourseUserFavorite::getAppUserId, userId).list().stream()
+                        .map(CourseUserFavorite::getCourseId).collect(Collectors.toList());
+                if(collect.isEmpty())collect.add(-1L);
+                Page<Course> page = courseService
+                .lambdaQuery()
+                .in(Course::getId, collect)
+                .page(new Page<>(pageCurr, pageSize));
+                for (Course record : page.getRecords()) {
+                    OrderCourseVO orderCourseVO = new OrderCourseVO();
+                    orderCourseVO.setBusinessId(record.getId());
+                    orderCourseVO.setCourseTitle(record.getCourseTitle());
+                    orderCourseVO.setDescription(record.getDescription());
+                    orderCourseVO.setChargeType(record.getChargeType());
+                    orderCourseVO.setGeneralPrice(record.getGeneralPrice());
+                    orderCourseVO.setIosPrice(record.getIosPrice());
+                    orderCourseVO.setCoverUrl(record.getCoverUrl());
+                    List<AppUser> data1 = remoteAppUserService.getUserByCourseId(record.getId()).getData();
 
+                    List<CourseChapter> list = courseChapterService.lambdaQuery().eq(CourseChapter::getCourseId, record.getId()).list();
+                    int temp = 0 ;
+                    for (CourseChapter courseChapter : list) {
+                        temp+= courseChapter.getVirtualLearnedNum();
+                    }
+                    int size = courseLearningRecordService.lambdaQuery().eq(CourseLearningRecord::getCourseId, record.getId())
+                            .groupBy(CourseLearningRecord::getAppUserId).list().size();
+                    orderCourseVO.setCount(temp+size);
+                    orderCourseVOS.add(orderCourseVO);
                 }
                 break;
         }
-        return R.ok();
+        return R.ok(orderCourseVOS);
     }
     @PostMapping("/collectCourse")
     @ApiOperation(value = "收藏/取消课程")
@@ -236,8 +522,11 @@
             @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("登录失效");
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
         CourseUserFavorite one = courseUserFavoriteService.lambdaQuery()
                 .eq(CourseUserFavorite::getAppUserId, userId)
                 .eq(CourseUserFavorite::getCourseId, id).one();
@@ -260,8 +549,8 @@
      *
      * @return 课程分类列表
      */
-    @PostMapping("/getCourseByCourseId/{courseId}")
-    public R<OrderCourseVO> getCourseCategoryList(@RequestBody OrderCourseVO req) {
+    @PostMapping("/getCourseByIdAny")
+    public R<OrderCourseVO> getCourseByIdAny(@RequestBody OrderCourseVO req) {
         Course byId = courseService.getById(req.getBusinessId());
         List<AppUser> data = remoteAppUserService.getUserByCourseId(req.getBusinessId()).getData();
         if (data!=null){
@@ -311,6 +600,7 @@
      * @return 课程详情
      */
 
+
     /**
      * 课程详情
      *
@@ -322,8 +612,11 @@
             @ApiImplicitParam(value = "课程id", name = "id", required = true, dataType = "String"),
     })
     public R<ClientCourseVO> getPayCourseInfoById(@RequestParam(value = "id")Long id) {
-        Long userId = SecurityUtils.getUserId();
-        if (userId == 0)return R.tokenError("登录失效");
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
         AppUserVO data1 = remoteAppUserService.getCurrentUser().getData();
 
         Course byId = courseService.getById(id);
@@ -340,6 +633,86 @@
                 .eq(CourseChapter::getCourseId, id)
                 .orderByDesc(CourseChapter::getSortNum)
                 .list();
+        for (CourseChapter courseChapter : page) {
+            int size = courseLearningRecordService.lambdaQuery()
+                    .eq(CourseLearningRecord::getChapterId, courseChapter.getId())
+                    .list().size();
+            courseChapter.setRealLearnedNum(size+courseChapter.getVirtualLearnedNum());
+        }
+        clientCourseVO.setList(page);
+        clientCourseVO.setIsBuy(0);
+        // 查询学习人数和头像列表
+        List<AppUser> data = remoteAppUserService.getUserByCourseId(id).getData();
+        if (data!=null){
+            clientCourseVO.setCount(data.size());
+            if (data.size()>=5){
+                clientCourseVO.setHeaders(data.stream().limit(5).map(AppUser::getAvatar).collect(Collectors.toList()));
+            }else{
+                clientCourseVO.setHeaders(data.stream().map(AppUser::getAvatar).collect(Collectors.toList()));
+            }
+            List<Long> collect = data.stream().map(AppUser::getId).collect(Collectors.toList());
+            if (!collect.isEmpty()){
+                if (collect.contains(userId)){
+                    clientCourseVO.setIsBuy(1);
+                }
+            }
+        }
+
+        // 查询推荐课程
+        List<Course> list = courseService.lambdaQuery().eq(Course::getCateId, byId.getCateId())
+                .eq(Course::getCourseType,1)
+                .eq(Course::getRecommend, 1).list();
+        List<Course> courses = new ArrayList<>();
+        // 随机获取两个课程
+        if (CollUtils.isNotEmpty(list)) {
+            int size = list.size();
+            int index = (int) (Math.random() * size);
+            if (size >= 2){
+                for (int i = 0; i < 2; i++) {
+                    courses.add(list.get(index));
+                }
+            }else{
+                courses.add(list.get(index));
+            }
+        }
+        for (Course cours : courses) {
+            List<AppUser> data3 = remoteAppUserService.getUserByCourseId(id).getData();
+            cours.setCount(data3.size());
+        }
+        clientCourseVO.setList2(courses);
+        // 查询是否已收藏课程
+        clientCourseVO.setIsCollect(courseUserFavoriteService.lambdaQuery()
+                .eq(CourseUserFavorite::getAppUserId, userId)
+                .eq(CourseUserFavorite::getCourseId, id).one() == null ? 2 : 1);
+        return R.ok(clientCourseVO);
+    }
+    /**
+     * 课程详情
+     *
+     * @return 课程详情
+     */
+    @PostMapping("/getPayCourseInfoByIdShare")
+    @ApiOperation(value = "根据id获取课程详情",tags = "分享H5")
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "课程id", name = "id", required = true, dataType = "String"),
+    })
+    public R<ClientCourseVO> getPayCourseInfoByIdShare(@RequestParam(value = "id")Long id) {
+
+        Course byId = courseService.getById(id);
+        ClientCourseVO clientCourseVO = new ClientCourseVO();
+        BeanUtils.copyProperties(byId, clientCourseVO);
+        // 查询章节
+        List<CourseChapter> page = courseChapterService.lambdaQuery()
+                .eq(CourseChapter::getCourseId, id)
+                .orderByDesc(CourseChapter::getSortNum)
+                .list();
+        for (CourseChapter courseChapter : page) {
+            int size = courseLearningRecordService.lambdaQuery()
+                    .eq(CourseLearningRecord::getChapterId, courseChapter.getId())
+                    .list().size();
+            courseChapter.setRealLearnedNum(size+courseChapter.getVirtualLearnedNum());
+        }
+        clientCourseVO.setList(page);
         clientCourseVO.setIsBuy(0);
         // 查询学习人数和头像列表
         List<AppUser> data = remoteAppUserService.getUserByCourseId(id).getData();
@@ -351,11 +724,6 @@
                 clientCourseVO.setHeaders(data.stream().map(AppUser::getAvatar).collect(Collectors.toList()));
             }
             List<Long> collect = data.stream().map(AppUser::getUserId).collect(Collectors.toList());
-            if (!collect.isEmpty()){
-                if (collect.contains(userId)){
-                    clientCourseVO.setIsBuy(1);
-                }
-            }
         }
         // 查询推荐课程
         List<Course> list = courseService.lambdaQuery().eq(Course::getCateId, byId.getCateId())
@@ -374,11 +742,11 @@
                 courses.add(list.get(index));
             }
         }
+        for (Course cours : courses) {
+            List<AppUser> data1 = remoteAppUserService.getUserByCourseId(id).getData();
+            cours.setCount(data1.size());
+        }
         clientCourseVO.setList2(courses);
-        // 查询是否已收藏课程
-        clientCourseVO.setIsCollect(courseUserFavoriteService.lambdaQuery()
-                .eq(CourseUserFavorite::getAppUserId, userId)
-                .eq(CourseUserFavorite::getCourseId, id) == null ? 2 : 1);
         return R.ok(clientCourseVO);
     }
 
@@ -404,51 +772,84 @@
             @RequestParam(required = false) Long cateId,
             @RequestParam(value = "pageCurr", defaultValue = "1") Integer pageCurr,
             @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) {
-        return R.ok(courseService.getCoursePageList(courseTitle, cateId, pageCurr, pageSize));
+        PageDTO<ClientCourseVO> coursePageList = courseService.getCoursePageList(courseTitle, cateId, pageCurr, pageSize);
+
+        for (ClientCourseVO record : coursePageList.getList()) {
+            int size1 = courseLearningRecordService.lambdaQuery().eq(CourseLearningRecord::getCourseId, record.getId())
+                    .groupBy(CourseLearningRecord::getAppUserId).list().size();
+            List<CourseChapter> list = courseChapterService.lambdaQuery()
+                    .eq(CourseChapter::getCourseId, record.getId()).list();
+            // 章节列表累加虚拟学习人数
+            int temp = 0;
+            for (CourseChapter courseChapter : list) {
+                temp+=courseChapter.getVirtualLearnedNum();
+            }
+            record.setCount(size1+temp);
+        }
+        return R.ok(coursePageList);
     }
     @PostMapping("/studyPageByChapterId")
     @ApiOperation(value = "课程学习页面")
     @ApiImplicitParams({
             @ApiImplicitParam(value = "章节id", name = "chapterId", required = true, dataType = "Long"),
-            @ApiImplicitParam(value = "分页参数,当前页码", name = "pageCurr", required = true, dataType = "Integer"),
-            @ApiImplicitParam(value = "分页参数,每页数量", name = "pageSize", required = true, dataType = "Integer")
+
     })
-    public R<PageDTO<CourseChapter>> studyPageByChapterId(@RequestParam(value = "chapterId")Long chapterId,
-                                                  @RequestParam(value = "pageCurr", defaultValue = "1") Integer pageCurr,
-                                                  @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) {
+    public R<List<CourseChapter>> studyPageByChapterId(@RequestParam(value = "chapterId")Long chapterId) {
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userid = loginUser.getUserid();
         CourseChapter byId1 = courseChapterService.getById(chapterId);
+        Course byId = courseService.getById(byId1.getCourseId());
+        // 新增学习记录
+        CourseLearningRecord one = courseLearningRecordService.lambdaQuery().eq(CourseLearningRecord::getAppUserId, userid)
+                .eq(CourseLearningRecord::getChapterId, chapterId).one();
+        if (one==null){
+            CourseLearningRecord courseLearningRecord = new CourseLearningRecord();
+            courseLearningRecord.setAppUserId(userid);
+            if (byId!=null){
+                courseLearningRecord.setCourseId(byId.getId());
+            }
+            courseLearningRecord.setChapterId(chapterId);
+            courseLearningRecordService.save(courseLearningRecord);
+        }
         Long id = byId1.getCourseId();
         // 查询章节
-        Page<CourseChapter> page = courseChapterService.lambdaQuery()
+        List<CourseChapter> page = courseChapterService.lambdaQuery()
                 .eq(CourseChapter::getCourseId, id)
                 .orderByDesc(CourseChapter::getSortNum)
-                .page(new Page<>(pageCurr, pageSize));
-        if (CollUtils.isEmpty(page.getRecords())) {
-            PageDTO<CourseChapter> empty = PageDTO.empty(page);
-            return R.ok(empty);
-        }
-        PageDTO<CourseChapter> courseChapterPageDTO = PageDTO.of(page, CourseChapter.class);
-        if (CollUtils.isNotEmpty(courseChapterPageDTO.getList())) {
-            for (CourseChapter courseChapter : courseChapterPageDTO.getList()) {
+                .list();
+
+            for (CourseChapter courseChapter : page) {
                 AppUserViewingHistory data = remoteAppUserService.getCourseStudyHistory(courseChapter.getId()).getData();
                 if (data!=null){
                     courseChapter.setMinuteLook(data.getMinuteLook());
                     courseChapter.setSecondLook(data.getSecondLook());
                     courseChapter.setIsOver(data.getIsOver());
                 }
+                int size = courseLearningRecordService
+                        .lambdaQuery().eq(CourseLearningRecord::getChapterId, courseChapter.getId())
+                        .list().size();
+                courseChapter.setRealLearnedNum(size+courseChapter.getVirtualLearnedNum());
             }
-        }
-        return R.ok();
+        return R.ok(page);
     }
     @PostMapping("/confirmOrder")
     @ApiOperation(value = "确认订单页面")
     @ApiImplicitParams({
             @ApiImplicitParam(value = "课程id", name = "courseId", required = true, dataType = "Long")
     })
-    public R<Course> studyPageByChapterId(@RequestParam(value = "courseId")Long courseId) {
-        Long userId = SecurityUtils.getUserId();
-        if (userId == 0)return R.tokenError("登录失效");
+    public R<Course> confirmOrder(@RequestParam(value = "courseId")Long courseId) {
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
+
         Course byId = courseService.getById(courseId);
+        AppUser data = remoteAppUserService.getAppUserById(userId + "").getData();
+        byId.setBalance(data.getBalance());
         return R.ok(byId);
     }
     @PostMapping("/successOrder")
@@ -457,8 +858,11 @@
             @ApiImplicitParam(value = "课程id", name = "courseId", required = true, dataType = "Long")
     })
     public R<List<Course>> successOrder(@RequestParam(value = "courseId")Long courseId) {
-        Long userId = SecurityUtils.getUserId();
-        if (userId == 0)return R.tokenError("登录失效");
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
         Course byId = courseService.getById(courseId);
         List<Course> list = courseService.lambdaQuery().eq(Course::getCateId, byId.getCateId())
                 .eq(Course::getCourseType, 1).list();
@@ -482,14 +886,17 @@
     }
     @GetMapping("/studyPage")
     @ApiOperation(value = "学习")
-
     public R<StudyPageVO> studyPage() {
-        Long userId = SecurityUtils.getUserId();
-        if (userId == 0)return R.tokenError("登录失效");
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
+        if(userId ==null || userId == 0)return R.tokenError("登录失效");
         StudyPageVO studyPageVO = new StudyPageVO();
         List<CourseVO> courseVOS = new ArrayList<>();
 
-        PageDTO<AppUserCourse> data = remoteAppUserService.getPayCourse(1, 909999).getData();
+        PageDTO<AppUserCourse> data = remoteAppUserService.getPayCourse(1, 909999,userId+"").getData();
         List<AppUserCourse> list = data.getList();
         if (CollUtils.isNotEmpty(list)) {
             List<Long> courseIds = list.stream().map(AppUserCourse::getCourseId).collect(Collectors.toList());

--
Gitblit v1.7.1