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-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserViewingHistoryController.java |  118 +++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 99 insertions(+), 19 deletions(-)

diff --git a/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserViewingHistoryController.java b/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserViewingHistoryController.java
index 144ccab..5312db0 100644
--- a/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserViewingHistoryController.java
+++ b/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserViewingHistoryController.java
@@ -7,12 +7,17 @@
 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.OrderCourseVO;
+import com.xinquan.course.api.feign.RemoteCourseService;
 import com.xinquan.meditation.api.domain.Meditation;
+import com.xinquan.meditation.api.feign.RemoteMeditationService;
 import com.xinquan.system.api.domain.AppUser;
 import com.xinquan.system.api.domain.AppUserTree;
 import com.xinquan.system.api.domain.AppUserViewingHistory;
 import com.xinquan.system.api.domain.vo.AppUserVO;
+import com.xinquan.system.api.model.LoginUser;
+import com.xinquan.user.api.feign.RemoteAppUserService;
 import com.xinquan.user.service.AppUserService;
 import com.xinquan.user.service.AppUserTreeService;
 import com.xinquan.user.service.AppUserViewingHistoryService;
@@ -23,13 +28,16 @@
 import io.swagger.models.auth.In;
 import lombok.Data;
 import lombok.RequiredArgsConstructor;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
 import java.time.LocalDateTime;
 import java.time.LocalTime;
+import java.util.ArrayList;
 import java.util.Date;
 import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -52,8 +60,13 @@
     private AppUserTreeService appUserTreeService;
     @Resource
     private AppUserService appUserService;
-
-
+    @Resource
+    private RemoteMeditationService remoteMeditationService;
+    @Resource
+    private RemoteCourseService courseUserFavoriteService;
+    @Resource
+    private RemoteCourseService remoteCourseService;
+    private final RemoteAppUserService remoteAppUserService;
     @PostMapping("/lookHistory")
     @ApiOperation(value = "观看历史")
     @ApiImplicitParams({
@@ -61,23 +74,81 @@
             @ApiImplicitParam(name = "pageCurr", value = "分页参数,当前页码", dataType = "Integer", required = true),
             @ApiImplicitParam(name = "pageSize", value = "分页参数,每页数量", dataType = "Integer", required = true)
     })
-    public R<PageDTO<OrderCourseVO>> lookHistory(Integer state, Integer pageCurr, Integer pageSize) {
-        Long userId = SecurityUtils.getUserId();
-        if (userId == 0)return R.tokenError("登录失效");
+    public R<List<OrderCourseVO>> lookHistory(Integer state, Integer pageCurr, Integer pageSize) {
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
+        List<OrderCourseVO> orderCourseVOS = new ArrayList<>();
+
         switch (state){
             case 1:
+                List<Long> collect1 = appUserViewingHistoryService.lambdaQuery()
+                        .eq(AppUserViewingHistory::getAppUserId, userId)
+                        .eq(AppUserViewingHistory::getViewingType, 1).list()
+                        .stream().map(AppUserViewingHistory::getBizId).collect(Collectors.toList());
+                List<Long> collect2 = collect1.stream().distinct().collect(Collectors.toList());
+                StringBuilder temp = new StringBuilder();
+                if (collect1.isEmpty()){
+                    temp=temp.append("-1");
+                }else{
+                    for (Long l : collect2) {
+                        temp.append(l).append(",");
+                    }
+                    temp.deleteCharAt(temp.length() - 1);
+                }
+                Page<Meditation> data = remoteMeditationService.getMeditationByIds(pageCurr,pageSize,temp.toString()).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:
-
+                List<Long> collect3 = appUserViewingHistoryService.lambdaQuery()
+                        .eq(AppUserViewingHistory::getAppUserId, userId)
+                        .eq(AppUserViewingHistory::getViewingType, 2).list()
+                        .stream().map(AppUserViewingHistory::getBizId).collect(Collectors.toList());
+                List<Long> collect4 = collect3.stream().distinct().collect(Collectors.toList());
+                StringBuilder temp1 = new StringBuilder();
+                if (collect4.isEmpty()){
+                    temp1=temp1.append("-1");
+                }else{
+                    for (Long l : collect4) {
+                        temp1.append(l).append(",");
+                    }
+                    temp1.deleteCharAt(temp1.length() - 1);
+                }
+                Page<Course> data2 = remoteCourseService.getCourseByIds(pageCurr,pageSize,temp1.toString()).getData();
+                for (Course record : data2.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();
+                    orderCourseVO.setCount(data1.size());
+                    orderCourseVOS.add(orderCourseVO);
+                }
                 break;
         }
-        return R.ok();
+        return R.ok(orderCourseVOS);
     }
     /**
      * 记录用户观看记录
      *
-     * @param bizId       业务id
-     * @param viewingType 观看类型 1=疗愈 2=课程
      */
     @PostMapping("/saveViewingHistory")
     @ApiOperation(value = "记录用户观看冥想记录", tags = {"用户端-用户相关接口"})
@@ -86,11 +157,14 @@
             @ApiImplicitParam(name = "timeLook", value = "播放时长单位秒", dataType = "Integer", required = true)
     })
     public R<?> saveViewingRecord(@RequestParam("id") Long id,
-            @RequestParam("timeLook") Integer timeLook) {
-        Long userId = SecurityUtils.getUserId();
-        if (userId == 0)return R.tokenError("登录失效");
+            @RequestParam("timeLook") Integer timeLook
+                                  ) {
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
         AppUser byId = appUserService.getById(userId);
-
         AppUserViewingHistory appUserViewingHistory = new AppUserViewingHistory();
         appUserViewingHistory.setAppUserId(userId);
         appUserViewingHistory.setBizId(id);
@@ -155,8 +229,11 @@
                                        @RequestParam("secondLook") Integer secondLook,
                                        @RequestParam("isOver") Integer isOver
     ) {
-        Long userId = SecurityUtils.getUserId();
-        if (userId == 0)return R.tokenError("登录失效");
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
         AppUserViewingHistory one = appUserViewingHistoryService.lambdaQuery()
                 .eq(AppUserViewingHistory::getAppUserId, userId)
                 .eq(AppUserViewingHistory::getViewingType, 2)
@@ -185,8 +262,11 @@
     }
     @PostMapping("/getCourseStudyHistory")
     public R<AppUserViewingHistory> getCourseStudyHistory(@RequestParam("chapterId") Long chapterId) {
-        Long userId = SecurityUtils.getUserId();
-        if (userId == 0)return R.tokenError("登录失效");
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (loginUser==null){
+            return R.tokenError("登录失效");
+        }
+        Long userId = loginUser.getUserid();
         AppUserViewingHistory one = appUserViewingHistoryService.lambdaQuery()
                 .eq(AppUserViewingHistory::getAppUserId, userId)
                 .eq(AppUserViewingHistory::getViewingType, 2)
@@ -219,8 +299,8 @@
 //                                                 @RequestParam(value = "secondLook") Integer secondLook,
 //                                                 @RequestParam(value = "isOver") Integer isOver
 //    ) {
-//        Long userId = SecurityUtils.getUserId();
-//        if (userId == 0)return R.tokenError("登录失效");
+//        Long userId = tokenService.getLoginUser().getUserid();
+//        if(userId ==null || userId == 0)return R.tokenError("登录失效");
 //        AppUserViewingHistory one = appUserViewingHistoryService.lambdaQuery()
 //                .eq(AppUserViewingHistory::getAppUserId, userId)
 //                .eq(AppUserViewingHistory::getViewingType, 2)

--
Gitblit v1.7.1