From 039a33d1bfa6ef041161666bbd120c34086fe7c1 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期一, 14 十月 2024 14:09:25 +0800
Subject: [PATCH] 课程代码

---
 xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java |  128 +++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 125 insertions(+), 3 deletions(-)

diff --git a/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java b/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java
index 6ac7f22..449f193 100644
--- a/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java
+++ b/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java
@@ -1,10 +1,22 @@
 package com.xinquan.order.controller.client;
 
 
+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.common.core.web.domain.BaseModel;
+import com.xinquan.common.security.utils.SecurityUtils;
+import com.xinquan.course.api.feign.RemoteCourseService;
+import com.xinquan.meditation.api.domain.Meditation;
+import com.xinquan.meditation.api.feign.RemoteMeditationService;
 import com.xinquan.order.api.domain.Order;
+import com.xinquan.order.domain.OrderPaymentRecord;
 import com.xinquan.order.domain.vo.ClientPlaceOrderVO;
+import com.xinquan.order.service.OrderPaymentRecordService;
 import com.xinquan.order.service.OrderService;
+import com.xinquan.course.api.domain.OrderCourseVO;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
@@ -12,6 +24,7 @@
 import lombok.RequiredArgsConstructor;
 import org.springframework.web.bind.annotation.*;
 
+import javax.annotation.Resource;
 import java.math.BigDecimal;
 import java.util.List;
 
@@ -29,7 +42,55 @@
 @RequestMapping("/client/order/order")
 public class ClientOrderController {
 
+    @Resource
     private OrderService orderService;
+    @Resource
+    private OrderPaymentRecordService orderPaymentRecordService;
+    @Resource
+    private RemoteCourseService remoteCourseService;
+    @Resource
+    private RemoteMeditationService remoteMeditationService;
+    @PostMapping("/myOrderCourse")
+    @ApiOperation(value = "我的已购",tags = "我的已购")
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "state", value = "1冥想 2课程", dataType = "Integer", required = true),
+            @ApiImplicitParam(name = "pageCurr", value = "分页参数,当前页码", dataType = "Integer", required = true),
+            @ApiImplicitParam(name = "pageSize", value = "分页参数,每页数量", dataType = "Integer", required = true)
+    })
+    public R<PageDTO<OrderCourseVO>> balanceList(Integer state, Integer pageCurr, Integer pageSize) {
+        Long userId = SecurityUtils.getUserId();
+        if (userId==0)return R.tokenError("登录失效");
+        Page<Order> page = orderService.lambdaQuery()
+                .eq(Order::getAppUserId, userId)
+                .eq(Order::getOrderFrom, state)
+                .ne(Order::getPaymentStatus, 3)
+                .orderByDesc(BaseModel::getCreateTime).page(new Page<>(pageCurr, pageSize));
+        if (CollUtils.isEmpty(page.getRecords())){
+            PageDTO<OrderCourseVO> empty = PageDTO.empty(page);
+            return R.ok(empty);
+        }
+        PageDTO<OrderCourseVO> res = PageDTO.of(page, OrderCourseVO.class);
+        for (OrderCourseVO orderCourseVO : res.getList()) {
+            switch (orderCourseVO.getChargeType()){
+                case 1:
+                    Meditation data1 = remoteMeditationService.getMeditationById(orderCourseVO.getBusinessId()).getData();
+                    orderCourseVO.setCourseTitle(data1.getMeditationTitle());
+                    orderCourseVO.setDescription(data1.getCoverDescription());
+                    orderCourseVO.setCoverUrl(data1.getCoverUrl());
+                    orderCourseVO.setGeneralPrice(data1.getGeneralPrice());
+                    orderCourseVO.setIosPrice(data1.getIosPrice());
+                    orderCourseVO.setCount(data1.getRealLearnedNum()+data1.getVirtualLearnedNum());
+                    break;
+                case 2:
+                    OrderCourseVO data = remoteCourseService.getCourseCategoryList(orderCourseVO).getData();
+                    BeanUtils.copyProperties(data, orderCourseVO);
+                    break;
+
+            }
+
+        }
+        return R.ok(res);
+    }
     /**
      * 根据邀请用户ids 查询对应佣金
      */
@@ -65,10 +126,10 @@
     @ApiOperation(value = "创建待支付订单", notes = "微信|支付宝")
     @ApiImplicitParams({
             @ApiImplicitParam(name = "targetId", value = "目标id", dataType = "Long", required = true),
-            @ApiImplicitParam(name = "orderFrom", value = "订单来源 1=冥想音频 2=课程", dataType = "Integer", required = true),
+            @ApiImplicitParam(name = "orderFrom", value = "订单来源 1=冥想音频 2=课程 3=购买会员 4充值", dataType = "Integer", required = true),
             @ApiImplicitParam(name = "receiverId", value = "被赠送课程APP用户id", dataType = "Long", required = false),
-            @ApiImplicitParam(name = "balanceFlag", value = "是否使用余额抵扣 1=是 2=否", dataType = "Integer", required = true),
-            @ApiImplicitParam(name = "payType", value = "支付方式 1=微信 2=支付宝", dataType = "Integer", required = true)
+            @ApiImplicitParam(name = "balanceFlag", value = "是否使用余额抵扣 1=是 2=否", dataType = "Integer", required = false),
+            @ApiImplicitParam(name = "payType", value = "支付方式 1=微信 2=支付宝", dataType = "Integer", required = false)
     })
     public R<ClientPlaceOrderVO> placeOrder(
             @RequestParam(value = "targetId") Long targetId,
@@ -84,5 +145,66 @@
             throw new RuntimeException(e);
         }
     }
+    /**
+     * 远程调用 根据用户id 查询充值金额
+     */
+    @PostMapping("/queryChargeByUserId/{userId}")
+    public R<String> queryChargeByUserId(@PathVariable("userId") Long userId) {
+        BigDecimal reduce = orderService.lambdaQuery()
+                .eq(Order::getAppUserId, userId)
+                .eq(Order::getOrderFrom, 4)
+                .eq(Order::getPaymentStatus, 2)
+                .list().stream().filter(t -> t.getTotalAmount() != null)
+                .map(Order::getTotalAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
+        return R.ok(reduce.toString());
+    }
+    /**
+     * 远程调用 根据订单id 查询订单明细
+     */
+    @PostMapping("/getOrderById/{orderId}")
+    public R<Order> getOrderById(@PathVariable("orderId") Long orderId) {
+        Long userId = SecurityUtils.getUserId();
+        if (userId==0)return R.tokenError("登录失效");
+        Order one = orderService.lambdaQuery()
+                .eq(Order::getId, orderId).one();
+        if (one!=null){
+            OrderPaymentRecord two = orderPaymentRecordService.lambdaQuery()
+                    .eq(OrderPaymentRecord::getOrderId, orderId)
+                    .ne(OrderPaymentRecord::getPaymentType, 4)
+                    .eq(OrderPaymentRecord::getPaymentStatus, 2).one();
+            if (two==null){
+                one.setRemark("余额支付");
+            }else{
+                switch (two.getPaymentType()){
+                    case 1:
+                        one.setRemark("微信支付");
+                        break;
+                    case 2:
+                        one.setRemark("支付宝支付");
+                        break;
+                    case 3:
+                        one.setRemark("苹果内购");
+                }
+            }
+            if (one.getCommissionId()!=null){
+                switch (one.getOrderFrom()){
+                    case 1:
+                        one.setRemark("购买疗愈");
+                        break;
+                    case 2:
+                        one.setRemark("购买课程");
+                        break;
+                    case 3:
+                        one.setRemark("购买会员");
+                        case 4:
+                        one.setRemark("充值");
+                }
+            }
+            return R.ok(one);
+        }
+        return R.ok();
+    }
+
+
 }
 

--
Gitblit v1.7.1