From 274ac0857d88bf72aabe9372dd4d2e1edca52ec4 Mon Sep 17 00:00:00 2001
From: lisy <linlangsur163@163.com>
Date: 星期三, 26 七月 2023 14:37:36 +0800
Subject: [PATCH] 兑换商品详情字段增加

---
 cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackageController.java |  132 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 131 insertions(+), 1 deletions(-)

diff --git a/cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackageController.java b/cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackageController.java
index 3c83277..9f060b1 100644
--- a/cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackageController.java
+++ b/cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackageController.java
@@ -1,9 +1,30 @@
 package com.dsh.course.controller;
 
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.dsh.course.entity.CoursePackagePaymentConfig;
 import com.dsh.course.entity.TCoursePackage;
+import com.dsh.course.entity.TCoursePackagePayment;
+import com.dsh.course.feignclient.model.StoreOfCourseVo;
+import com.dsh.course.feignclient.other.StoreClient;
+import com.dsh.course.feignclient.other.model.Store;
+import com.dsh.course.model.vo.response.Details;
+import com.dsh.course.model.vo.response.ExchangeCoursePackageResponse;
+import com.dsh.course.service.ICoursePackagePaymentConfigService;
+import com.dsh.course.service.TCoursePackageDiscountService;
+import com.dsh.course.service.TCoursePackagePaymentService;
 import com.dsh.course.service.TCoursePackageService;
+import com.dsh.course.util.ResultUtil;
+import com.dsh.course.util.TokenUtil;
+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.util.ArrayList;
+import java.util.Comparator;
+import java.util.List;
 
 /**
  * @author zhibing.pu
@@ -17,13 +38,29 @@
     private TCoursePackageService coursePackageService;
 
 
+    @Autowired
+    private TCoursePackageDiscountService tcpdService;
+
+    @Resource
+    private StoreClient storeClient;
+
+    @Resource
+    private TCoursePackagePaymentService tcppmenService;
+
+    @Resource
+    private ICoursePackagePaymentConfigService icppconfigService;
+
+
+    @Autowired
+    private TokenUtil tokenUtil;
+
     /**
      * 根据id获取课包
      * @param id
      * @return
      */
     @ResponseBody
-    @PostMapping("/coursePackage/queryCoursePackageById")
+    @PostMapping("/base/coursePackage/queryCoursePackageById")
     public TCoursePackage queryCoursePackageById(@RequestBody Integer id){
         try {
             TCoursePackage coursePackage = coursePackageService.getById(id);
@@ -33,4 +70,97 @@
             return null;
         }
     }
+
+    /**
+     * 本周福利列表
+     */
+    @ResponseBody
+    @PostMapping("/api/useBenefit/weekLimitedBenefit")
+    @ApiOperation(value = "本周福利-限时折扣列表", tags = {"APP-使用福利"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
+            @ApiImplicitParam(name = "discountType",value = "默认显示 限时折扣 (1限时折扣 2赠送课时)",dataType = "int"),
+            @ApiImplicitParam(name = "lon",value = "经度",dataType = "String"),
+            @ApiImplicitParam(name = "lat",value = "纬度",dataType = "String"),
+    })
+    public ResultUtil<List<Details>> thisWeeksBenefitList(Integer discountType, String lon, String lat){
+        try {
+            Integer appUserId = tokenUtil.getUserIdFormRedis();
+            if(null == appUserId){
+                return ResultUtil.tokenErr();
+            }
+            return ResultUtil.success(tcpdService.getWeeksBenefitCourse(appUserId,discountType,lon,lat));
+        }catch (Exception e){
+            return ResultUtil.runErr();
+        }
+    }
+
+
+    /**
+     * 折扣课包详情
+     */
+    @ResponseBody
+    @PostMapping("/api/useBenefit/discountCourseDatas")
+    @ApiOperation(value = "本周福利-折扣课包详情", tags = {"APP-使用福利"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
+            @ApiImplicitParam(name = "coursePackageDiscountId",value = "限时折扣配置id/赠送课时配置id",dataType = "int"),
+            @ApiImplicitParam(name = "lon",value = "经度",dataType = "String"),
+            @ApiImplicitParam(name = "lat",value = "纬度",dataType = "String"),
+    })
+    public ResultUtil<ExchangeCoursePackageResponse> discountCourseDatas(Integer coursePackageDiscountId,String lon,String lat){
+        try {
+            return ResultUtil.success(tcpdService.getWeekFreeCourseDetails(coursePackageDiscountId,lat,lon));
+        }catch (Exception e){
+            return ResultUtil.runErr();
+        }
+    }
+
+
+    @ResponseBody
+    @PostMapping("/base/coursePack/courseList")
+    public List<StoreOfCourseVo> getStoreOfCourseList(@RequestBody Integer storeId){
+        List<StoreOfCourseVo> courseVoList = new ArrayList<>();
+        Store store = storeClient.queryStoreById(storeId);
+        List<TCoursePackage> list = coursePackageService.list(new QueryWrapper<TCoursePackage>()
+                .eq("storeId", storeId)
+                .eq("auditStatus",2)
+                .eq("state",1));
+        if (list.size() >  0){
+            for (TCoursePackage coursePackage : list) {
+                int count = tcppmenService.count(new QueryWrapper<TCoursePackagePayment>()
+                        .eq("coursePackageId",coursePackage.getId()));
+                StoreOfCourseVo courseVo = new StoreOfCourseVo();
+                courseVo.setCourseId(coursePackage.getId());
+                courseVo.setName(coursePackage.getName()+"(" + store.getName() + ")");
+                courseVo.setClassStartTime(coursePackage.getClassStartTime() +"-"+ coursePackage.getClassEndTime());
+                courseVo.setApplicantsNumber(count);
+                List<CoursePackagePaymentConfig> list1 = icppconfigService.list(new QueryWrapper<CoursePackagePaymentConfig>()
+                        .eq("coursePackageId",coursePackage.getId()));
+//                取价格最低的课时
+                CoursePackagePaymentConfig minConfig = list1.stream()
+                        .min(Comparator.comparingDouble(CoursePackagePaymentConfig::getCashPayment))
+                        .orElse(null);
+                if (minConfig != null){
+                    courseVo.setClassHours(minConfig.getClassHours());
+                    courseVo.setOriginalPrice(minConfig.getCashPayment());
+                }
+
+                courseVoList.add(courseVo);
+            }
+        }
+        return courseVoList;
+    }
+
+    /**
+     * 根据id获取课包
+     * @param coursePackConfigId
+     * @return
+     */
+    @ResponseBody
+    @PostMapping("/base/coursePackage/queryConfigCoursePackData")
+    public CoursePackagePaymentConfig queryConfigCoursePackData(@RequestBody Integer coursePackConfigId){
+        return icppconfigService.getById(coursePackConfigId);
+    }
+
 }

--
Gitblit v1.7.1