From 53e7558400dcacecdce70e39ebfe1727740f9296 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期六, 25 十一月 2023 17:20:06 +0800
Subject: [PATCH] 重写课包支付和排课逻辑

---
 cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java | 1911 ++++++++++++++++++++++-------------------------------------
 1 files changed, 710 insertions(+), 1,201 deletions(-)

diff --git a/cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java b/cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java
index 0cc4ea6..199a25d 100644
--- a/cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java
+++ b/cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java
@@ -39,6 +39,7 @@
 import io.vertx.core.json.Json;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+
 import javax.annotation.Resource;
 import java.math.BigDecimal;
 import java.math.RoundingMode;
@@ -74,6 +75,9 @@
     private ICoursePackagePaymentConfigService coursePackagePaymentConfigService;
 
     @Autowired
+    private CourseCounsumService courseCounsumService;
+
+    @Autowired
     private TCoursePackageDiscountService coursePackageDiscountService;
 
     @Resource
@@ -99,6 +103,9 @@
     @Resource
     private CoursePackageStudentMapper cpsMapper;
 
+    @Autowired
+    private ICoursePackageOrderStudentService coursePackageOrderStudentService;
+
 
     private String aliAppid = "2021004105665036";//支付宝appid
 
@@ -107,6 +114,14 @@
     private String alipayPublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAouYvZ1v4RiydwNOnGcU0Hb4hQu0x6XUooaE2Bi6/atNOobtFdunnATGP6OMOW7yF9DpP8qH5mbFXAiaQD721y/7qlayI50UcV4mngRU4ZcaAVE3bp721Eg2H85RISa+Tb1CiOh+pc9p4l5UBseKsvB2ruHHForfZDPI8FL7AVUKBYCQPsa4zL6KAO2C6KULaTg/lCa+bYQKU0n9ca569VtdsqJUyxB9eSZjVd+9nKl62FLqp2NELGj7cXqiVBgDnBnVS5ZUO3mrBM5z/AxQbw3RwE3JqdkhzUA1BFjejAlT2zIGNOjUFagF8ao0wGElYfuk0bum6Hz5qWAt02QdNNwIDAQAB";//支付宝应用公钥
 
     private String alipay_public_key = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAmu8n/4yTHWbn7VOrNc9OsLtDL1bEQ8gC1dHkj8Wy5z0mkaOsjJRIG/28ze12M0V8jdCKuuDr5Z1OPKiqf+XO3ypguEh+mYUVMBM/cZodDFQfTY1TKLWjvQCuaqlA+QUTCK6f7T7stsgyQ1o9Jj0rXZDz6PM4QHSTzjrLIBaeqM5WIBvH+fy/X+QG5Utd+/UT0kc0JyvuKhZ65yVUd/C9VcwJJAPliRsAQNrqYterwAJ9zvw9tF11wj9W0XgJ8Ccu4x3gR1vrlLRJJo/OA97RmxPQ+5hSacWQZCUd1dwiBq+YCrKVHGTj14izRHXrLc0yBlRXo7tBOIqcy3IsvKVthQIDAQAB";//支付宝支付公钥
+
+    @Autowired
+    private ICoursePackageOrderService coursePackageOrderService;
+
+    @Autowired
+    private TOrderService orderService;
+    @Autowired
+    private TCoursePackageService coursePackageService;
 
 
     @Override
@@ -117,6 +132,7 @@
 
     /**
      * 获取课程列表
+     *
      * @param coursePackageList
      * @return
      * @throws Exception
@@ -132,20 +148,20 @@
 
         QueryWrapper<TCoursePackage> wrapper = new QueryWrapper<TCoursePackage>().in("status", Arrays.asList(1, 2))
                 .eq("auditStatus", 2).eq("state", 1);
-        if(null != coursePackageList.getCoursePackageTypeId()){
+        if (null != coursePackageList.getCoursePackageTypeId()) {
             wrapper.eq("coursePackageTypeId", coursePackageList.getCoursePackageTypeId());
         }
-        if(null != coursePackageList.getStoreId()){
+        if (null != coursePackageList.getStoreId()) {
             wrapper.eq("storeId", coursePackageList.getStoreId());
         }
-        if(null != coursePackageList.getStoreId()){
+        if (null != coursePackageList.getStoreId()) {
             wrapper.eq("storeId", coursePackageList.getStoreId());
         }
-        if(ToolUtil.isNotEmpty(coursePackageList.getSearch())){
+        if (ToolUtil.isNotEmpty(coursePackageList.getSearch())) {
             wrapper.like("name", coursePackageList.getSearch());
             List<Store> stores = storeClient.queryStoreListByName(coursePackageList.getSearch());
             List<Integer> collect = stores.stream().map(Store::getId).collect(Collectors.toList());
-            if(collect.size() > 0){
+            if (collect.size() > 0) {
                 wrapper.or().in("storeId", collect);
             }
         }
@@ -175,9 +191,9 @@
             ArrayList<String> classTime = new ArrayList<>();
             String[] split = classStartTime.split(",");
             String[] split3 = classEndTime.split(",");
-            if(ToolUtil.isNotEmpty(classStartTime)) {
+            if (ToolUtil.isNotEmpty(classStartTime)) {
                 for (int i = 0; i < split.length; i++) {
-                    String s = split[i].substring(0,5) + "-" + split3[i].substring(0,5);
+                    String s = split[i].substring(0, 5) + "-" + split3[i].substring(0, 5);
                     classTime.add(s);
                 }
             }
@@ -185,114 +201,112 @@
             coursePackageListVo.setType(coursePackage.getType());
 
 
-
             coursePackageListVo.setApplicantsNumber(integer);
             Double cashPayment1 = coursePackagePaymentConfig.getCashPayment();
             Integer playPaiCoin = coursePackagePaymentConfig.getPlayPaiCoin();
-            if(ToolUtil.isNotEmpty(cashPayment1) && cashPayment1>0 && ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin>0){
+            if (ToolUtil.isNotEmpty(cashPayment1) && cashPayment1 > 0 && ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin > 0) {
                 coursePackageListVo.setPayType(3);
-            }else if(ToolUtil.isNotEmpty(cashPayment1) && cashPayment1>0){
+            } else if (ToolUtil.isNotEmpty(cashPayment1) && cashPayment1 > 0) {
                 coursePackageListVo.setPayType(1);
-            }else if(ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin>0){
+            } else if (ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin > 0) {
                 coursePackageListVo.setPayType(2);
             }
 
 
-
-            if (coursePackagePaymentConfig!=null) {
+            if (coursePackagePaymentConfig != null) {
                 coursePackageListVo.setPlayPaiCoin(coursePackagePaymentConfig.getPlayPaiCoin());
             }
             //会员显示原价和会员价(最低)。非会员显示会员价和支付价(最低)
 //            if(appUser.getIsVip() == 0){//非会员
-                List<TCoursePackageDiscount> list2 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
-                        .eq("type", 1).eq("auditStatus", 2).eq("status",1));
-                Double vipPrice = coursePackagePaymentConfig.getCashPayment();
-                for (TCoursePackageDiscount coursePackageDiscount : list2) {
-                    Double num1 = JSON.parseObject(coursePackageDiscount.getContent()).getDouble("discountMember");
-                    if(vipPrice.compareTo(num1) > 0){
-                        vipPrice = num1;
-                    }
+            List<TCoursePackageDiscount> list2 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
+                    .eq("type", 1).eq("auditStatus", 2).eq("status", 1));
+            Double vipPrice = coursePackagePaymentConfig.getCashPayment();
+            for (TCoursePackageDiscount coursePackageDiscount : list2) {
+                Double num1 = JSON.parseObject(coursePackageDiscount.getContent()).getDouble("discountMember");
+                if (vipPrice.compareTo(num1) > 0) {
+                    vipPrice = num1;
                 }
-                coursePackageListVo.setVipPrice(vipPrice);
-                coursePackageListVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
+            }
+            coursePackageListVo.setVipPrice(vipPrice);
+            coursePackageListVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
 
-                Double paymentPrice = coursePackagePaymentConfig.getCashPayment();
-                    List<TCoursePackageDiscount> list3 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
-                        .eq("type", 3).eq("auditStatus", 2).eq("status",1));
-                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
-                for (TCoursePackageDiscount coursePackageDiscount : list3) {
-                    /**
-                     * [{
-                     * 	"startDate": "2023-01-01 00:00:00",
-                     * 	"endDate": "2023-12-31 23:59:59",
-                     * 	"startTime": "02:00:00",
-                     * 	"endTime": "23:00:00",
-                     * 	"weeks": [1, 2, 7],
-                     * 	"cashPayment": 100
-                     * }]
-                     */
-                    JSONArray jsonArray = JSON.parseArray(coursePackageDiscount.getContent());
-                    for (int i = 0; i < jsonArray.size(); i++) {
-                        try {
-                            JSONObject jsonObject = jsonArray.getJSONObject(i);
-                            String startDate = jsonObject.getString("startDate");
-                            String endDate = jsonObject.getString("endDate");
-                            String startTime = jsonObject.getString("startTime");
-                            String endTime = jsonObject.getString("endTime");
-                            List<Integer> weeks = jsonObject.getJSONArray("weeks").toJavaList(Integer.class);
-                            Double cashPayment = jsonObject.getDouble("cashPayment");
-                            Date startDate_date = sdf.parse(startDate);
-                            Date endDate_date = sdf.parse(endDate);
-                            long timeMillis = System.currentTimeMillis();
-                            if(timeMillis >= startDate_date.getTime() && timeMillis < endDate_date.getTime()){
-                                Date date = new Date();
-                                Calendar calendar = Calendar.getInstance();
-                                calendar.setTime(date);
-                                int week = calendar.get(Calendar.DAY_OF_WEEK);
-                                boolean isFirstSunday = (calendar.getFirstDayOfWeek() == Calendar.SUNDAY);
-                                if(isFirstSunday){
-                                    week = week - 1;
-                                    if(week == 0){
-                                        week = 7;
-                                    }
-                                }
-                                if(!weeks.contains(week)){
-                                    continue;
-                                }
-
-                                String[] split1 = startTime.split(":");
-                                Integer hour1 = Integer.valueOf(split1[0]);
-                                Calendar s = Calendar.getInstance();
-                                s.setTime(date);
-                                s.set(Calendar.HOUR_OF_DAY, hour1);
-                                s.set(Calendar.MINUTE, Integer.valueOf(split1[1]));
-                                s.set(Calendar.SECOND, Integer.valueOf(split1[2]));
-
-                                String[] split2 = endTime.split(":");
-                                Integer hour2 = Integer.valueOf(split2[0]);
-                                Calendar e = Calendar.getInstance();
-                                e.setTime(date);
-                                e.set(Calendar.HOUR_OF_DAY, hour2);
-                                e.set(Calendar.MINUTE, Integer.valueOf(split2[1]));
-                                e.set(Calendar.SECOND, Integer.valueOf(split2[2]));
-
-                                if(hour1 > hour2){
-                                    if(s.getTimeInMillis() > date.getTime()){
-                                        s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) - 1);
-                                    }else{
-                                        e.set(Calendar.DAY_OF_YEAR, e.get(Calendar.DAY_OF_YEAR) + 1);
-                                    }
-                                }
-                                if(timeMillis >= s.getTimeInMillis() && timeMillis < e.getTimeInMillis() && paymentPrice.compareTo(cashPayment) > 0){
-                                    paymentPrice = cashPayment;
+            Double paymentPrice = coursePackagePaymentConfig.getCashPayment();
+            List<TCoursePackageDiscount> list3 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
+                    .eq("type", 3).eq("auditStatus", 2).eq("status", 1));
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+            for (TCoursePackageDiscount coursePackageDiscount : list3) {
+                /**
+                 * [{
+                 * 	"startDate": "2023-01-01 00:00:00",
+                 * 	"endDate": "2023-12-31 23:59:59",
+                 * 	"startTime": "02:00:00",
+                 * 	"endTime": "23:00:00",
+                 * 	"weeks": [1, 2, 7],
+                 * 	"cashPayment": 100
+                 * }]
+                 */
+                JSONArray jsonArray = JSON.parseArray(coursePackageDiscount.getContent());
+                for (int i = 0; i < jsonArray.size(); i++) {
+                    try {
+                        JSONObject jsonObject = jsonArray.getJSONObject(i);
+                        String startDate = jsonObject.getString("startDate");
+                        String endDate = jsonObject.getString("endDate");
+                        String startTime = jsonObject.getString("startTime");
+                        String endTime = jsonObject.getString("endTime");
+                        List<Integer> weeks = jsonObject.getJSONArray("weeks").toJavaList(Integer.class);
+                        Double cashPayment = jsonObject.getDouble("cashPayment");
+                        Date startDate_date = sdf.parse(startDate);
+                        Date endDate_date = sdf.parse(endDate);
+                        long timeMillis = System.currentTimeMillis();
+                        if (timeMillis >= startDate_date.getTime() && timeMillis < endDate_date.getTime()) {
+                            Date date = new Date();
+                            Calendar calendar = Calendar.getInstance();
+                            calendar.setTime(date);
+                            int week = calendar.get(Calendar.DAY_OF_WEEK);
+                            boolean isFirstSunday = (calendar.getFirstDayOfWeek() == Calendar.SUNDAY);
+                            if (isFirstSunday) {
+                                week = week - 1;
+                                if (week == 0) {
+                                    week = 7;
                                 }
                             }
-                        }catch (Exception e){
-                            e.printStackTrace();
+                            if (!weeks.contains(week)) {
+                                continue;
+                            }
+
+                            String[] split1 = startTime.split(":");
+                            Integer hour1 = Integer.valueOf(split1[0]);
+                            Calendar s = Calendar.getInstance();
+                            s.setTime(date);
+                            s.set(Calendar.HOUR_OF_DAY, hour1);
+                            s.set(Calendar.MINUTE, Integer.valueOf(split1[1]));
+                            s.set(Calendar.SECOND, Integer.valueOf(split1[2]));
+
+                            String[] split2 = endTime.split(":");
+                            Integer hour2 = Integer.valueOf(split2[0]);
+                            Calendar e = Calendar.getInstance();
+                            e.setTime(date);
+                            e.set(Calendar.HOUR_OF_DAY, hour2);
+                            e.set(Calendar.MINUTE, Integer.valueOf(split2[1]));
+                            e.set(Calendar.SECOND, Integer.valueOf(split2[2]));
+
+                            if (hour1 > hour2) {
+                                if (s.getTimeInMillis() > date.getTime()) {
+                                    s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) - 1);
+                                } else {
+                                    e.set(Calendar.DAY_OF_YEAR, e.get(Calendar.DAY_OF_YEAR) + 1);
+                                }
+                            }
+                            if (timeMillis >= s.getTimeInMillis() && timeMillis < e.getTimeInMillis() && paymentPrice.compareTo(cashPayment) > 0) {
+                                paymentPrice = cashPayment;
+                            }
                         }
+                    } catch (Exception e) {
+                        e.printStackTrace();
                     }
                 }
-                coursePackageListVo.setPaymentPrice(paymentPrice);
+            }
+            coursePackageListVo.setPaymentPrice(paymentPrice);
 
             double vipPrice1 = coursePackageListVo.getVipPrice();
             double originalPrice1 = coursePackageListVo.getOriginalPrice();
@@ -303,7 +317,6 @@
 //            coursePackageListVo.setPaymentPrice(minPrice);
 //            coursePackageListVo.setOriginalPrice(maxPrice);
 //            System.out.println("Minimum price: " + minPrice);
-
 
 
 //            }
@@ -321,16 +334,16 @@
 //                coursePackageListVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
 //            }
 
-            if (coursePackageListVo.getPaymentPrice()<coursePackageListVo.getVipPrice()){
+            if (coursePackageListVo.getPaymentPrice() < coursePackageListVo.getVipPrice()) {
                 coursePackageListVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
 //                coursePackageListVo.setVipPrice(null);
             }
 
-            if(appUser.getIsVip() == 1) {
+            if (appUser.getIsVip() == 1) {
                 if (coursePackageListVo.getVipPrice() < coursePackageListVo.getPaymentPrice()) {
                     coursePackageListVo.setPaymentPrice(coursePackageListVo.getVipPrice());
                 }
-            }else {
+            } else {
                 coursePackageListVo.setVipPrice(null);
             }
 
@@ -341,7 +354,7 @@
         }
 
         //销量排行
-        if(ToolUtil.isNotEmpty(coursePackageList.getSalesRanking())&&coursePackageList.getSalesRanking().equals("asc")){
+        if (ToolUtil.isNotEmpty(coursePackageList.getSalesRanking()) && coursePackageList.getSalesRanking().equals("asc")) {
             Collections.sort(listVos, new Comparator<CoursePackageListVo>() {
                 public int compare(CoursePackageListVo s1, CoursePackageListVo s2) {
                     return Integer.compare(s1.getApplicantsNumber(), s2.getApplicantsNumber());
@@ -350,7 +363,7 @@
         }
 
 
-        if(ToolUtil.isNotEmpty(coursePackageList.getSalesRanking())&&coursePackageList.getSalesRanking().equals("desc")){
+        if (ToolUtil.isNotEmpty(coursePackageList.getSalesRanking()) && coursePackageList.getSalesRanking().equals("desc")) {
             Collections.sort(listVos, new Comparator<CoursePackageListVo>() {
                 public int compare(CoursePackageListVo s1, CoursePackageListVo s2) {
                     return Integer.compare(s2.getApplicantsNumber(), s1.getApplicantsNumber());
@@ -360,14 +373,14 @@
 
 
         //距离排行
-        if(ToolUtil.isNotEmpty(coursePackageList.getDistanceSort())&&coursePackageList.getDistanceSort().equals("asc")){
+        if (ToolUtil.isNotEmpty(coursePackageList.getDistanceSort()) && coursePackageList.getDistanceSort().equals("asc")) {
             Collections.sort(listVos, new Comparator<CoursePackageListVo>() {
                 public int compare(CoursePackageListVo s1, CoursePackageListVo s2) {
                     return Double.compare(s1.getDistance(), s2.getDistance());
                 }
             });
         }
-        if (ToolUtil.isNotEmpty(coursePackageList.getDistanceSort())&&coursePackageList.getDistanceSort().equals("desc")) {
+        if (ToolUtil.isNotEmpty(coursePackageList.getDistanceSort()) && coursePackageList.getDistanceSort().equals("desc")) {
             Collections.sort(listVos, new Comparator<CoursePackageListVo>() {
                 public int compare(CoursePackageListVo s1, CoursePackageListVo s2) {
                     return Double.compare(s2.getDistance(), s1.getDistance());
@@ -380,7 +393,6 @@
     }
 
 
-
     @Override
     public List<CoursePackageListVo> queryCourseListOne(CoursePackageList coursePackageList) throws Exception {
 //        AppUser appUser = appUserClient.queryAppUser(uid);
@@ -389,20 +401,20 @@
         String cityCode = geocode.get("cityCode");
         QueryWrapper<TCoursePackage> wrapper = new QueryWrapper<TCoursePackage>().in("status", Arrays.asList(1, 2))
                 .eq("auditStatus", 2).eq("state", 1).eq("provinceCode", provinceCode).eq("cityCode", cityCode);
-        if(null != coursePackageList.getCoursePackageTypeId()){
+        if (null != coursePackageList.getCoursePackageTypeId()) {
             wrapper.eq("coursePackageTypeId", coursePackageList.getCoursePackageTypeId());
         }
-        if(null != coursePackageList.getStoreId()){
+        if (null != coursePackageList.getStoreId()) {
             wrapper.eq("storeId", coursePackageList.getStoreId());
         }
-        if(null != coursePackageList.getStoreId()){
+        if (null != coursePackageList.getStoreId()) {
             wrapper.eq("storeId", coursePackageList.getStoreId());
         }
-        if(ToolUtil.isNotEmpty(coursePackageList.getSearch())){
+        if (ToolUtil.isNotEmpty(coursePackageList.getSearch())) {
             wrapper.like("name", coursePackageList.getSearch());
             List<Store> stores = storeClient.queryStoreListByName(coursePackageList.getSearch());
             List<Integer> collect = stores.stream().map(Store::getId).collect(Collectors.toList());
-            if(collect.size() > 0){
+            if (collect.size() > 0) {
                 wrapper.or().in("storeId", collect);
             }
         }
@@ -422,11 +434,11 @@
 
             Double cashPayment1 = coursePackagePaymentConfig.getCashPayment();
             Integer playPaiCoin = coursePackagePaymentConfig.getPlayPaiCoin();
-            if(ToolUtil.isNotEmpty(cashPayment1) && cashPayment1>0 && ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin>0){
+            if (ToolUtil.isNotEmpty(cashPayment1) && cashPayment1 > 0 && ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin > 0) {
                 coursePackageListVo.setPayType(3);
-            }else if(ToolUtil.isNotEmpty(cashPayment1) && cashPayment1>0){
+            } else if (ToolUtil.isNotEmpty(cashPayment1) && cashPayment1 > 0) {
                 coursePackageListVo.setPayType(1);
-            }else if(ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin>0){
+            } else if (ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin > 0) {
                 coursePackageListVo.setPayType(2);
             }
 
@@ -437,12 +449,11 @@
             String[] split = classStartTime.split(",");
             String[] split3 = classEndTime.split(",");
             for (int i = 0; i < split.length; i++) {
-                String s = split[i] + "-" +  split3[i];
+                String s = split[i] + "-" + split3[i];
                 classTime.add(s);
             }
             coursePackageListVo.setClassStartTime(classTime);
             coursePackageListVo.setType(coursePackage.getType());
-
 
 
             coursePackageListVo.setApplicantsNumber(integer);
@@ -450,13 +461,13 @@
             coursePackageListVo.setPlayPaiCoin(coursePackagePaymentConfig.getPlayPaiCoin());
 
             //会员显示原价和会员价(最低)。非会员显示会员价和支付价(最低)
-            if(false){//非会员
+            if (false) {//非会员
                 List<TCoursePackageDiscount> list2 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
                         .eq("type", 1).eq("auditStatus", 2));
                 Double vipPrice = coursePackagePaymentConfig.getCashPayment();
                 for (TCoursePackageDiscount coursePackageDiscount : list2) {
                     Double num1 = JSON.parseObject(coursePackageDiscount.getContent()).getDouble("discountMember");
-                    if(vipPrice.compareTo(num1) > 0){
+                    if (vipPrice.compareTo(num1) > 0) {
                         vipPrice = num1;
                     }
                 }
@@ -490,19 +501,19 @@
                             Date startDate_date = sdf.parse(startDate);
                             Date endDate_date = sdf.parse(endDate);
                             long timeMillis = System.currentTimeMillis();
-                            if(timeMillis >= startDate_date.getTime() && timeMillis < endDate_date.getTime()){
+                            if (timeMillis >= startDate_date.getTime() && timeMillis < endDate_date.getTime()) {
                                 Date date = new Date();
                                 Calendar calendar = Calendar.getInstance();
                                 calendar.setTime(date);
                                 int week = calendar.get(Calendar.DAY_OF_WEEK);
                                 boolean isFirstSunday = (calendar.getFirstDayOfWeek() == Calendar.SUNDAY);
-                                if(isFirstSunday){
+                                if (isFirstSunday) {
                                     week = week - 1;
-                                    if(week == 0){
+                                    if (week == 0) {
                                         week = 7;
                                     }
                                 }
-                                if(!weeks.contains(week)){
+                                if (!weeks.contains(week)) {
                                     continue;
                                 }
 
@@ -522,30 +533,30 @@
                                 e.set(Calendar.MINUTE, Integer.valueOf(split2[1]));
                                 e.set(Calendar.SECOND, Integer.valueOf(split2[2]));
 
-                                if(hour1 > hour2){
-                                    if(s.getTimeInMillis() > date.getTime()){
+                                if (hour1 > hour2) {
+                                    if (s.getTimeInMillis() > date.getTime()) {
                                         s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) - 1);
-                                    }else{
+                                    } else {
                                         e.set(Calendar.DAY_OF_YEAR, e.get(Calendar.DAY_OF_YEAR) + 1);
                                     }
                                 }
-                                if(timeMillis >= s.getTimeInMillis() && timeMillis < e.getTimeInMillis() && paymentPrice.compareTo(cashPayment) > 0){
+                                if (timeMillis >= s.getTimeInMillis() && timeMillis < e.getTimeInMillis() && paymentPrice.compareTo(cashPayment) > 0) {
                                     paymentPrice = cashPayment;
                                 }
                             }
-                        }catch (Exception e){
+                        } catch (Exception e) {
                             e.printStackTrace();
                         }
                     }
                 }
                 coursePackageListVo.setPaymentPrice(paymentPrice);
-            }else{
+            } else {
                 List<TCoursePackageDiscount> list2 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
                         .eq("type", 1).eq("auditStatus", 2));
                 Double vipPrice = coursePackagePaymentConfig.getCashPayment();
                 for (TCoursePackageDiscount coursePackageDiscount : list2) {
                     Double num1 = JSON.parseObject(coursePackageDiscount.getContent()).getDouble("discountMember");
-                    if(vipPrice.compareTo(num1) > 0){
+                    if (vipPrice.compareTo(num1) > 0) {
                         vipPrice = num1;
                     }
                 }
@@ -559,7 +570,7 @@
         }
 
         //销量排行
-        if(ToolUtil.isNotEmpty(coursePackageList.getSalesRanking())){
+        if (ToolUtil.isNotEmpty(coursePackageList.getSalesRanking())) {
             Collections.sort(listVos, new Comparator<CoursePackageListVo>() {
                 public int compare(CoursePackageListVo s1, CoursePackageListVo s2) {
                     return Integer.compare(s1.getApplicantsNumber(), s2.getApplicantsNumber());
@@ -567,7 +578,7 @@
             });
         }
         //距离排行
-        if(ToolUtil.isNotEmpty(coursePackageList.getDistanceSort())){
+        if (ToolUtil.isNotEmpty(coursePackageList.getDistanceSort())) {
             Collections.sort(listVos, new Comparator<CoursePackageListVo>() {
                 public int compare(CoursePackageListVo s1, CoursePackageListVo s2) {
                     return Double.compare(s1.getDistance(), s2.getDistance());
@@ -580,6 +591,7 @@
 
     /**
      * 获取课包详情
+     *
      * @param uid
      * @param id
      * @return
@@ -587,161 +599,160 @@
      */
     @Override
     public CoursePackageInfo queryCourseInfo(Integer uid, Integer id, String lon, String lat) throws Exception {
-            AppUser appUser = appUserClient.queryAppUser(uid);
-            TCoursePackage coursePackage = this.getById(id);
-            CoursePackageInfo coursePackageInfo = new CoursePackageInfo();
-            coursePackageInfo.setIsVip(appUser.getIsVip());
-            coursePackageInfo.setId(id);
+        AppUser appUser = appUserClient.queryAppUser(uid);
+        TCoursePackage coursePackage = this.getById(id);
+        CoursePackageInfo coursePackageInfo = new CoursePackageInfo();
+        coursePackageInfo.setIsVip(appUser.getIsVip());
+        coursePackageInfo.setId(id);
         SimpleDateFormat format = new SimpleDateFormat("yyyy.MM.dd");
-        if(coursePackage.getType()==2){
+        if (coursePackage.getType() == 2) {
 
-            coursePackageInfo.setTime(format.format(coursePackage.getStartTime())+"-"+format.format(coursePackage.getEndTime()));
+            coursePackageInfo.setTime(format.format(coursePackage.getStartTime()) + "-" + format.format(coursePackage.getEndTime()));
         }
-            coursePackageInfo.setCoverDrawing(coursePackage.getCoverDrawing());
+        coursePackageInfo.setCoverDrawing(coursePackage.getCoverDrawing());
 
-            coursePackageInfo.setName(coursePackage.getName());
-            Store store = storeClient.queryStoreById(coursePackage.getStoreId());
-            coursePackageInfo.setStoreName(store.getName());
-            coursePackageInfo.setStoreCoverDrawing(store.getCoverDrawing());
-            coursePackageInfo.setStoreAddress(store.getAddress());
-            coursePackageInfo.setLon(store.getLon());
-            coursePackageInfo.setLat(store.getLat());
-            if(ToolUtil.isNotEmpty(lon) && ToolUtil.isNotEmpty(lat)){
-                Map<String, Double> distance = GeodesyUtil.getDistance(lon + "," + lat, store.getLon() + "," + store.getLat());
-                double wgs84 = new BigDecimal(distance.get("WGS84")).divide(new BigDecimal(1000)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
-                coursePackageInfo.setDistance(wgs84);
+        coursePackageInfo.setName(coursePackage.getName());
+        Store store = storeClient.queryStoreById(coursePackage.getStoreId());
+        coursePackageInfo.setStoreName(store.getName());
+        coursePackageInfo.setStoreCoverDrawing(store.getCoverDrawing());
+        coursePackageInfo.setStoreAddress(store.getAddress());
+        coursePackageInfo.setLon(store.getLon());
+        coursePackageInfo.setLat(store.getLat());
+        if (ToolUtil.isNotEmpty(lon) && ToolUtil.isNotEmpty(lat)) {
+            Map<String, Double> distance = GeodesyUtil.getDistance(lon + "," + lat, store.getLon() + "," + store.getLat());
+            double wgs84 = new BigDecimal(distance.get("WGS84")).divide(new BigDecimal(1000)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+            coursePackageInfo.setDistance(wgs84);
+        }
+
+        String[] split = coursePackage.getClassWeeks().split(";");
+        coursePackageInfo.setWeeks(Arrays.asList(split));
+
+        // 2.0
+        String classStartTime = coursePackage.getClassStartTime();
+        String classEndTime = coursePackage.getClassEndTime();
+        ArrayList<String> classTime = new ArrayList<>();
+        String[] split4 = classStartTime.split(",");
+        String[] split3 = classEndTime.split(",");
+        if (ToolUtil.isNotEmpty(classStartTime)) {
+            for (int i = 0; i < split4.length; i++) {
+                String s = split4[i].substring(0, 5) + "-" + split3[i].substring(0, 5);
+                classTime.add(s);
             }
+        }
 
-            String[] split = coursePackage.getClassWeeks().split(";");
-            coursePackageInfo.setWeeks(Arrays.asList(split));
+        coursePackageInfo.setTimes(classTime);
+        coursePackageInfo.setType(coursePackage.getType());
 
-            // 2.0
-            String classStartTime = coursePackage.getClassStartTime();
-            String classEndTime = coursePackage.getClassEndTime();
-            ArrayList<String> classTime = new ArrayList<>();
-            String[] split4 = classStartTime.split(",");
-            String[] split3 = classEndTime.split(",");
-            if(ToolUtil.isNotEmpty(classStartTime)){
-                for (int i = 0; i < split4.length; i++) {
-                    String s = split4[i].substring(0,5) + "-" +  split3[i].substring(0,5);
-                    classTime.add(s);
-                }
+        coursePackageInfo.setDetailDrawing(coursePackage.getDetailDrawing());
+        coursePackageInfo.setIntroduceDrawing(coursePackage.getIntroduceDrawing());
+
+
+        List<CoursePackagePaymentConfigVo> list = new ArrayList<>();
+        List<CoursePackagePaymentConfig> list1 = coursePackagePaymentConfigService.list(new QueryWrapper<CoursePackagePaymentConfig>().eq("coursePackageId", id).orderByAsc("classHours"));
+        list1.forEach(coursePackagePaymentConfig -> {
+            CoursePackagePaymentConfigVo coursePackagePaymentConfigVo = new CoursePackagePaymentConfigVo();
+            coursePackagePaymentConfigVo.setId(coursePackagePaymentConfig.getId());
+            coursePackagePaymentConfigVo.setClassHours(coursePackagePaymentConfig.getClassHours());
+            coursePackagePaymentConfigVo.setPlayPaiCoin(coursePackagePaymentConfig.getPlayPaiCoin());
+
+            if (ToolUtil.isNotEmpty(coursePackagePaymentConfig.getCashPayment()) && coursePackagePaymentConfig.getCashPayment() > 0 && ToolUtil.isNotEmpty(coursePackagePaymentConfig.getPlayPaiCoin()) && coursePackagePaymentConfig.getPlayPaiCoin() > 0) {
+                coursePackagePaymentConfigVo.setPayType(3);
+            } else if (ToolUtil.isNotEmpty(coursePackagePaymentConfig.getCashPayment()) && coursePackagePaymentConfig.getCashPayment() > 0) {
+                coursePackagePaymentConfigVo.setPayType(1);
+            } else if (ToolUtil.isNotEmpty(coursePackagePaymentConfig.getPlayPaiCoin()) && coursePackagePaymentConfig.getPlayPaiCoin() > 0) {
+                coursePackagePaymentConfigVo.setPayType(2);
             }
-
-            coursePackageInfo.setTimes(classTime);
-            coursePackageInfo.setType(coursePackage.getType());
-
-            coursePackageInfo.setDetailDrawing(coursePackage.getDetailDrawing());
-            coursePackageInfo.setIntroduceDrawing(coursePackage.getIntroduceDrawing());
-
-
-            List<CoursePackagePaymentConfigVo> list = new ArrayList<>();
-            List<CoursePackagePaymentConfig> list1 = coursePackagePaymentConfigService.list(new QueryWrapper<CoursePackagePaymentConfig>().eq("coursePackageId", id).orderByAsc("classHours"));
-            list1.forEach(coursePackagePaymentConfig -> {
-                CoursePackagePaymentConfigVo coursePackagePaymentConfigVo = new CoursePackagePaymentConfigVo();
-                coursePackagePaymentConfigVo.setId(coursePackagePaymentConfig.getId());
-                coursePackagePaymentConfigVo.setClassHours(coursePackagePaymentConfig.getClassHours());
-                coursePackagePaymentConfigVo.setPlayPaiCoin(coursePackagePaymentConfig.getPlayPaiCoin());
-
-                if(ToolUtil.isNotEmpty(coursePackagePaymentConfig.getCashPayment()) && coursePackagePaymentConfig.getCashPayment()>0 && ToolUtil.isNotEmpty(coursePackagePaymentConfig.getPlayPaiCoin()) && coursePackagePaymentConfig.getPlayPaiCoin()>0 ){
-                    coursePackagePaymentConfigVo.setPayType(3);
-                }else if(ToolUtil.isNotEmpty(coursePackagePaymentConfig.getCashPayment()) && coursePackagePaymentConfig.getCashPayment()>0){
-                    coursePackagePaymentConfigVo.setPayType(1);
-                }else if( ToolUtil.isNotEmpty(coursePackagePaymentConfig.getPlayPaiCoin()) && coursePackagePaymentConfig.getPlayPaiCoin()>0 ){
-                    coursePackagePaymentConfigVo.setPayType(2);
-                }
 
 //                coursePackagePaymentConfigVo.setPayType(coursePackage.getPayType());
-                //会员显示原价和支付价(会员价)。非会员显示会员价和支付价(最低)
+            //会员显示原价和支付价(会员价)。非会员显示会员价和支付价(最低)
 //                if(appUser.getIsVip() == 0){//非会员
-                    List<TCoursePackageDiscount> list2 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
-                            .eq("type", 1).eq("auditStatus", 2));
-                    Double vipPrice = coursePackagePaymentConfig.getCashPayment();
-                    for (TCoursePackageDiscount coursePackageDiscount : list2) {
-                        Double num1 = JSON.parseObject(coursePackageDiscount.getContent()).getDouble("discountMember");
-                        if(vipPrice.compareTo(num1) > 0){
-                            vipPrice = num1;
-                        }
-                    }
-                    coursePackagePaymentConfigVo.setVipPrice(vipPrice);
-                    Double paymentPrice = coursePackagePaymentConfig.getCashPayment();
-                    List<TCoursePackageDiscount> list3 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
-                            .eq("type", 3).eq("auditStatus", 2));
-                    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
-                    for (TCoursePackageDiscount coursePackageDiscount : list3) {
-                        /**
-                         * [{
-                         * 	"startDate": "2023-01-01 00:00:00",
-                         * 	"endDate": "2023-12-31 23:59:59",
-                         * 	"startTime": "02:00:00",
-                         * 	"endTime": "23:00:00",
-                         * 	"weeks": [1, 2, 7],
-                         * 	"cashPayment": 100
-                         * }]
-                         */
-                        JSONArray jsonArray = JSON.parseArray(coursePackageDiscount.getContent());
-                        for (int i = 0; i < jsonArray.size(); i++) {
-                            try {
-                                JSONObject jsonObject = jsonArray.getJSONObject(i);
-                                String startDate = jsonObject.getString("startDate");
-                                String endDate = jsonObject.getString("endDate");
-                                String startTime = jsonObject.getString("startTime");
-                                String endTime = jsonObject.getString("endTime");
-                                List<Integer> weeks = jsonObject.getJSONArray("weeks").toJavaList(Integer.class);
-                                Double cashPayment = jsonObject.getDouble("cashPayment");
-                                Date startDate_date = sdf.parse(startDate);
-                                Date endDate_date = sdf.parse(endDate);
-                                long timeMillis = System.currentTimeMillis();
-                                if(timeMillis >= startDate_date.getTime() && timeMillis < endDate_date.getTime()){
-                                    Date date = new Date();
-                                    Calendar calendar = Calendar.getInstance();
-                                    calendar.setTime(date);
-                                    int week = calendar.get(Calendar.DAY_OF_WEEK);
-                                    boolean isFirstSunday = (calendar.getFirstDayOfWeek() == Calendar.SUNDAY);
-                                    if(isFirstSunday){
-                                        week = week - 1;
-                                        if(week == 0){
-                                            week = 7;
-                                        }
-                                    }
-                                    if(!weeks.contains(week)){
-                                        continue;
-                                    }
-
-                                    String[] split1 = startTime.split(":");
-                                    Integer hour1 = Integer.valueOf(split1[0]);
-                                    Calendar s = Calendar.getInstance();
-                                    s.setTime(date);
-                                    s.set(Calendar.HOUR_OF_DAY, hour1);
-                                    s.set(Calendar.MINUTE, Integer.valueOf(split1[1]));
-                                    s.set(Calendar.SECOND, Integer.valueOf(split1[2]));
-
-                                    String[] split2 = endTime.split(":");
-                                    Integer hour2 = Integer.valueOf(split2[0]);
-                                    Calendar e = Calendar.getInstance();
-                                    e.setTime(date);
-                                    e.set(Calendar.HOUR_OF_DAY, hour2);
-                                    e.set(Calendar.MINUTE, Integer.valueOf(split2[1]));
-                                    e.set(Calendar.SECOND, Integer.valueOf(split2[2]));
-
-                                    if(hour1 > hour2){
-                                        if(s.getTimeInMillis() > date.getTime()){
-                                            s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) - 1);
-                                        }else{
-                                            e.set(Calendar.DAY_OF_YEAR, e.get(Calendar.DAY_OF_YEAR) + 1);
-                                        }
-                                    }
-                                    if(timeMillis >= s.getTimeInMillis() && timeMillis < e.getTimeInMillis() && paymentPrice.compareTo(cashPayment) > 0){
-                                        paymentPrice = cashPayment;
-                                    }
+            List<TCoursePackageDiscount> list2 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
+                    .eq("type", 1).eq("auditStatus", 2));
+            Double vipPrice = coursePackagePaymentConfig.getCashPayment();
+            for (TCoursePackageDiscount coursePackageDiscount : list2) {
+                Double num1 = JSON.parseObject(coursePackageDiscount.getContent()).getDouble("discountMember");
+                if (vipPrice.compareTo(num1) > 0) {
+                    vipPrice = num1;
+                }
+            }
+            coursePackagePaymentConfigVo.setVipPrice(vipPrice);
+            Double paymentPrice = coursePackagePaymentConfig.getCashPayment();
+            List<TCoursePackageDiscount> list3 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
+                    .eq("type", 3).eq("auditStatus", 2));
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+            for (TCoursePackageDiscount coursePackageDiscount : list3) {
+                /**
+                 * [{
+                 * 	"startDate": "2023-01-01 00:00:00",
+                 * 	"endDate": "2023-12-31 23:59:59",
+                 * 	"startTime": "02:00:00",
+                 * 	"endTime": "23:00:00",
+                 * 	"weeks": [1, 2, 7],
+                 * 	"cashPayment": 100
+                 * }]
+                 */
+                JSONArray jsonArray = JSON.parseArray(coursePackageDiscount.getContent());
+                for (int i = 0; i < jsonArray.size(); i++) {
+                    try {
+                        JSONObject jsonObject = jsonArray.getJSONObject(i);
+                        String startDate = jsonObject.getString("startDate");
+                        String endDate = jsonObject.getString("endDate");
+                        String startTime = jsonObject.getString("startTime");
+                        String endTime = jsonObject.getString("endTime");
+                        List<Integer> weeks = jsonObject.getJSONArray("weeks").toJavaList(Integer.class);
+                        Double cashPayment = jsonObject.getDouble("cashPayment");
+                        Date startDate_date = sdf.parse(startDate);
+                        Date endDate_date = sdf.parse(endDate);
+                        long timeMillis = System.currentTimeMillis();
+                        if (timeMillis >= startDate_date.getTime() && timeMillis < endDate_date.getTime()) {
+                            Date date = new Date();
+                            Calendar calendar = Calendar.getInstance();
+                            calendar.setTime(date);
+                            int week = calendar.get(Calendar.DAY_OF_WEEK);
+                            boolean isFirstSunday = (calendar.getFirstDayOfWeek() == Calendar.SUNDAY);
+                            if (isFirstSunday) {
+                                week = week - 1;
+                                if (week == 0) {
+                                    week = 7;
                                 }
-                            }catch (Exception e){
-                                e.printStackTrace();
+                            }
+                            if (!weeks.contains(week)) {
+                                continue;
+                            }
+
+                            String[] split1 = startTime.split(":");
+                            Integer hour1 = Integer.valueOf(split1[0]);
+                            Calendar s = Calendar.getInstance();
+                            s.setTime(date);
+                            s.set(Calendar.HOUR_OF_DAY, hour1);
+                            s.set(Calendar.MINUTE, Integer.valueOf(split1[1]));
+                            s.set(Calendar.SECOND, Integer.valueOf(split1[2]));
+
+                            String[] split2 = endTime.split(":");
+                            Integer hour2 = Integer.valueOf(split2[0]);
+                            Calendar e = Calendar.getInstance();
+                            e.setTime(date);
+                            e.set(Calendar.HOUR_OF_DAY, hour2);
+                            e.set(Calendar.MINUTE, Integer.valueOf(split2[1]));
+                            e.set(Calendar.SECOND, Integer.valueOf(split2[2]));
+
+                            if (hour1 > hour2) {
+                                if (s.getTimeInMillis() > date.getTime()) {
+                                    s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) - 1);
+                                } else {
+                                    e.set(Calendar.DAY_OF_YEAR, e.get(Calendar.DAY_OF_YEAR) + 1);
+                                }
+                            }
+                            if (timeMillis >= s.getTimeInMillis() && timeMillis < e.getTimeInMillis() && paymentPrice.compareTo(cashPayment) > 0) {
+                                paymentPrice = cashPayment;
                             }
                         }
+                    } catch (Exception e) {
+                        e.printStackTrace();
                     }
-                    coursePackagePaymentConfigVo.setPaymentPrice(paymentPrice);
-
+                }
+            }
+            coursePackagePaymentConfigVo.setPaymentPrice(paymentPrice);
 
 
 //                    TCoursePackageDiscount discount = coursePackageDiscountService.getOne(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
@@ -759,20 +770,18 @@
 //                    if (coursePackagePaymentConfigVo.getVipPrice()>vipcontinuingMember){
 //                        coursePackagePaymentConfigVo.setVipPrice(vipcontinuingMember);
 //                    }
-                if(appUser.getIsVip() == 1) {
-                        if (coursePackagePaymentConfigVo.getVipPrice()<coursePackagePaymentConfigVo.getPaymentPrice()){
-                            coursePackagePaymentConfigVo.setPaymentPrice(coursePackagePaymentConfigVo.getVipPrice());
-                            coursePackagePaymentConfigVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
-                        }
+            if (appUser.getIsVip() == 1) {
+                if (coursePackagePaymentConfigVo.getVipPrice() < coursePackagePaymentConfigVo.getPaymentPrice()) {
+                    coursePackagePaymentConfigVo.setPaymentPrice(coursePackagePaymentConfigVo.getVipPrice());
+                    coursePackagePaymentConfigVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
+                }
 
-                                }
+            }
 
-                if (coursePackagePaymentConfigVo.getPaymentPrice()<coursePackagePaymentConfigVo.getVipPrice()){
-                        coursePackagePaymentConfigVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
-                        coursePackagePaymentConfigVo.setVipPrice(null);
-                    }
-
-
+            if (coursePackagePaymentConfigVo.getPaymentPrice() < coursePackagePaymentConfigVo.getVipPrice()) {
+                coursePackagePaymentConfigVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
+                coursePackagePaymentConfigVo.setVipPrice(null);
+            }
 
 
 //                }
@@ -789,26 +798,27 @@
 //                    coursePackagePaymentConfigVo.setPaymentPrice(vipPrice);
 //                    coursePackagePaymentConfigVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
 //                }
-                list.add(coursePackagePaymentConfigVo);
-            });
-            coursePackageInfo.setList(list);
+            list.add(coursePackagePaymentConfigVo);
+        });
+        coursePackageInfo.setList(list);
 
-            Student student = studentClient.queryDefaultStudent(uid);
-            StudentVo studentVo = new StudentVo();
-            if(null != student){
-                studentVo.setId(student.getId());
-                studentVo.setPhone(student.getPhone());
-                studentVo.setName(student.getName());
-                SimpleDateFormat sdf = new SimpleDateFormat("yyyy");
-                studentVo.setAge(Integer.valueOf(sdf.format(new Date())) - Integer.valueOf(sdf.format(student.getBirthday())));
-            }
-            coursePackageInfo.setStudent(studentVo);
-            return coursePackageInfo;
+        Student student = studentClient.queryDefaultStudent(uid);
+        StudentVo studentVo = new StudentVo();
+        if (null != student) {
+            studentVo.setId(student.getId());
+            studentVo.setPhone(student.getPhone());
+            studentVo.setName(student.getName());
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyy");
+            studentVo.setAge(Integer.valueOf(sdf.format(new Date())) - Integer.valueOf(sdf.format(student.getBirthday())));
+        }
+        coursePackageInfo.setStudent(studentVo);
+        return coursePackageInfo;
     }
 
 
     /**
      * 课程包名支付
+     *
      * @param uid
      * @param paymentCourseVo
      * @return
@@ -821,7 +831,7 @@
         //校验是否已经报满
         Integer integer = coursePackagePaymentService.queryCountNumber(paymentCourseVo.getId());
         TCoursePackage course = coursePackageService.getById(paymentCourseVo.getId());
-        if (course.getType()!=3) {
+        if (course.getType() != 3) {
 
             if (integer + paymentCourseVo.getStudentIds().split(";").length > course.getMaxSubscribeNumber()) {
                 return ResultUtil.error("报名失败,已达最大报名人数");
@@ -830,26 +840,26 @@
         List<CoursePackagePaymentConfigVo> list = coursePackageInfo.getList();
         String[] students = paymentCourseVo.getStudentIds().split(";");
         for (CoursePackagePaymentConfigVo coursePackagePaymentConfigVo : list) {
-            if(paymentCourseVo.getCoursePackagePaymentConfigId().compareTo(coursePackagePaymentConfigVo.getId()) == 0){
+            if (paymentCourseVo.getCoursePackagePaymentConfigId().compareTo(coursePackagePaymentConfigVo.getId()) == 0) {
                 CoursePackagePaymentConfig byId = coursePackagePaymentConfigService.getById(paymentCourseVo.getCoursePackagePaymentConfigId());
                 Double cashPayment = byId.getCashPayment();
                 Integer payType = coursePackagePaymentConfigVo.getPayType();
                 Integer playPaiCoin1 = byId.getPlayPaiCoin();
-                if(cashPayment!=null || cashPayment>0){
-                    payType=1;
+                if (cashPayment != null || cashPayment > 0) {
+                    payType = 1;
                 }
-                if(playPaiCoin1!=null || playPaiCoin1>0){
-                    payType=2;
+                if (playPaiCoin1 != null || playPaiCoin1 > 0) {
+                    payType = 2;
                 }
-                if((cashPayment!=null || cashPayment>0) &&(playPaiCoin1!=null || playPaiCoin1>0)){
-                    payType=3;
+                if ((cashPayment != null || cashPayment > 0) && (playPaiCoin1 != null || playPaiCoin1 > 0)) {
+                    payType = 3;
                 }
-                if(cashPayment!=null && cashPayment>0 && playPaiCoin1 !=null && playPaiCoin1>0){
-                }else {
-                    if(payType == 1 && paymentCourseVo.getPayType() == 3){//现金支付
+                if (cashPayment != null && cashPayment > 0 && playPaiCoin1 != null && playPaiCoin1 > 0) {
+                } else {
+                    if (payType == 1 && paymentCourseVo.getPayType() == 3) {//现金支付
                         return ResultUtil.error("支付方式错误,请刷新后重试");
                     }
-                    if(payType == 2 && paymentCourseVo.getPayType() != 3){//玩湃币支付
+                    if (payType == 2 && paymentCourseVo.getPayType() != 3) {//玩湃币支付
                         return ResultUtil.error("支付方式错误,请刷新后重试");
                     }
                 }
@@ -858,10 +868,7 @@
                 Double playPaiCoin = coursePackagePaymentConfigVo.getPlayPaiCoin().doubleValue();//支付币
                 playPaiCoin = new BigDecimal(students.length).multiply(new BigDecimal(playPaiCoin)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
 
-//                if(paymentCourseVo.getPayType() != 3 && paymentPrice.compareTo(paymentCourseVo.getPrice()) != 0&&paymentCourseVo.getCouponId()!=null){
-//                    return ResultUtil.error("支付金额异常,请刷新后重试");
-//                }
-                if(paymentCourseVo.getPayType() == 3 && playPaiCoin.compareTo(paymentCourseVo.getPrice()) != 0){
+                if (paymentCourseVo.getPayType() == 3 && playPaiCoin.compareTo(paymentCourseVo.getPrice()) != 0) {
                     return ResultUtil.error("支付金额异常,请刷新后重试");
                 }
             }
@@ -869,48 +876,48 @@
         Double price = paymentCourseVo.getPrice();//支付金额
         //校验优惠券
         Long couponId = paymentCourseVo.getCouponId();
-        if(null != couponId && paymentCourseVo.getPayType() != 3){
+        if (null != couponId && paymentCourseVo.getPayType() != 3) {
             UserCoupon userCoupon = userCouponClient.queryUserCouponById(couponId);
-            if(userCoupon.getStatus() == 2){
+            if (userCoupon.getStatus() == 2) {
                 return ResultUtil.error("优惠券已被使用");
             }
             Coupon coupon = couponClient.queryCouponById(userCoupon.getCouponId());
             long time = coupon.getEndTime().getTime();
-            if(System.currentTimeMillis() >= time){
+            if (System.currentTimeMillis() >= time) {
                 return ResultUtil.error("优惠券已过期");
             }
-            if(coupon.getType() == 1){//满减
+            if (coupon.getType() == 1) {//满减
                 JSONObject jsonObject = JSON.parseObject(coupon.getContent());
 //                {"conditionalAmount":50,"deductionAmount":10,"experienceName":""}
                 Double num1 = jsonObject.getDouble("conditionalAmount");
                 Double num2 = jsonObject.getDouble("deductionAmount");
-                if(price.compareTo(num1) <= 0){
+                if (price.compareTo(num1) <= 0) {
                     return ResultUtil.error("该优惠券无法使用");
                 }
 
                 price = new BigDecimal(price).subtract(new BigDecimal(num2)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
             }
-            if(coupon.getType() == 2){//代金券
+            if (coupon.getType() == 2) {//代金券
                 JSONObject jsonObject = JSON.parseObject(coupon.getContent());
                 Double num1 = jsonObject.getDouble("conditionalAmount");
-                if(price.compareTo(num1) <= 0){
+                if (price.compareTo(num1) <= 0) {
                     return ResultUtil.error("该优惠券无法使用");
                 }
                 price = new BigDecimal(price).subtract(new BigDecimal(num1)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
             }
             userCoupon.setStatus(2);
-           userCouponClient.edit(userCoupon);
+            userCouponClient.edit(userCoupon);
 
         }
 
-        if(paymentCourseVo.getPayType() == 1){//微信支付
+        if (paymentCourseVo.getPayType() == 1) {//微信支付
             return weChatPaymentCourse(uid, price, paymentCourseVo);
         }
-        if(paymentCourseVo.getPayType() == 2){//支付宝支付
+        if (paymentCourseVo.getPayType() == 2) {//支付宝支付
             return aliPaymentCourse(uid, price, paymentCourseVo);
         }
-        if(paymentCourseVo.getPayType() == 3){//玩湃币支付
-            if(appUser.getPlayPaiCoins() < price.intValue()){
+        if (paymentCourseVo.getPayType() == 3) {//玩湃币支付
+            if (appUser.getPlayPaiCoins() < price.intValue()) {
                 return ResultUtil.error("报名失败,玩湃币不足,请充值!");
             }
             return playPaiCoinPaymentCourse(appUser, price, paymentCourseVo);
@@ -923,74 +930,54 @@
 
     /**
      * 课程微信支付
+     *
      * @param uid
      * @param paymentPrice
      * @param paymentCourseVo
      * @return
      * @throws Exception
      */
-    public ResultUtil weChatPaymentCourse(Integer uid, Double paymentPrice, PaymentCourseVo paymentCourseVo) throws Exception{
+    public ResultUtil weChatPaymentCourse(Integer uid, Double paymentPrice, PaymentCourseVo paymentCourseVo) throws Exception {
         CoursePackagePaymentConfig coursePackagePaymentConfig = coursePackagePaymentConfigService.getById(paymentCourseVo.getCoursePackagePaymentConfigId());
-        String[] split = paymentCourseVo.getStudentIds().split(";");
         SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
         String code = sdf.format(new Date()) + UUIDUtil.getNumberRandom(5);
-        for (String s : split) {
-            TCoursePackagePayment coursePackagePayment = new TCoursePackagePayment();
-            coursePackagePayment.setCode(code);
-            coursePackagePayment.setAppUserId(uid);
-            coursePackagePayment.setStudentId(Integer.valueOf(s));
-            coursePackagePayment.setCoursePackageId(paymentCourseVo.getId());
-            coursePackagePayment.setPayType(paymentCourseVo.getPayType());
-            coursePackagePayment.setClassHours(coursePackagePaymentConfig.getClassHours());
-            coursePackagePayment.setOriginalPrice(paymentCourseVo.getPrice());
-            coursePackagePayment.setUserCouponId(paymentCourseVo.getCouponId());
-            coursePackagePayment.setCashPayment(new BigDecimal(paymentPrice));
-            coursePackagePayment.setTotalClassHours(coursePackagePaymentConfig.getClassHours());
-            coursePackagePayment.setLaveClassHours(coursePackagePaymentConfig.getClassHours());
-            coursePackagePayment.setAbsencesNumber(0);
-            coursePackagePayment.setPayUserType(1);
-            coursePackagePayment.setPayStatus(1);
-            coursePackagePayment.setPayUserId(uid);
-            coursePackagePayment.setStatus(1);
-            coursePackagePayment.setState(1);
-            coursePackagePayment.setInsertTime(new Date());
-            coursePackagePaymentService.save(coursePackagePayment);
+        //生成支付订单
+        CoursePackageOrder coursePackageOrder = new CoursePackageOrder();
+        coursePackageOrder.setCode(code);
+        coursePackageOrder.setAppUserId(uid);
+        coursePackageOrder.setStudentIds(paymentCourseVo.getStudentIds());
+        coursePackageOrder.setCoursePackageId(paymentCourseVo.getId());
+        coursePackageOrder.setPayType(paymentCourseVo.getPayType());
+        coursePackageOrder.setClassHours(coursePackagePaymentConfig.getClassHours());
+        coursePackageOrder.setOriginalPrice(paymentCourseVo.getPrice());
+        coursePackageOrder.setUserCouponId(paymentCourseVo.getCouponId());
+        coursePackageOrder.setCashPayment(new BigDecimal(paymentPrice));
+        coursePackageOrder.setPayUserType(1);
+        coursePackageOrder.setPayStatus(1);
+        coursePackageOrder.setPayUserId(uid);
+        coursePackageOrder.setState(1);
+        coursePackageOrder.setInsertTime(new Date());
+        coursePackageOrderService.save(coursePackageOrder);
 
-
-            CourseCounsum courseCounsum = new CourseCounsum();
-            courseCounsum.setPaymentId(coursePackagePayment.getId());
-            courseCounsum.setChangeType(1);
-            courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
-            courseCounsum.setInsertTime(new Date());
-            courseCounsum.setReason("购买课包");
-            courseCounsumService.save(courseCounsum);
-        }
-
-        Student student = studentClient.queryDefaultStudent(uid);
-        Integer sid=null;
-        if(student!=null){
-            sid=student.getId();
-        }
-        ResultUtil weixinpay = payMoneyUtil.weixinpay("购买课程", "", code, paymentPrice.toString(), "/base/course/weChatPaymentCourseCallback", "APP", "");
-        if(weixinpay.getCode() == 200){
-            Integer finalSid = sid;
+        ResultUtil weixinpay = payMoneyUtil.weixinpay("购买课程", coursePackagePaymentConfig.getId().toString(), code, paymentPrice.toString(), "/base/course/weChatPaymentCourseCallback", "APP", "");
+        if (weixinpay.getCode() == 200) {
             new Thread(new Runnable() {
                 @Override
                 public void run() {
                     try {
                         int num = 1;
                         int wait = 0;
-                        while (num <= 10){
+                        while (num <= 10) {
                             int min = 5000;
                             wait += (min * num);
                             Thread.sleep(wait);
-                            List<TCoursePackagePayment> list = coursePackagePaymentService.list(new QueryWrapper<TCoursePackagePayment>().eq("state", 1).eq("code", code).eq("payType", 1));
-                            TCoursePackagePayment one = list.get(0);
-                            if(one.getPayStatus() == 2){
+                            CoursePackageOrder coursePackageOrder1 = coursePackageOrderService.getOne(new QueryWrapper<CoursePackageOrder>()
+                                    .eq("code", code).eq("state", 1));
+                            if (coursePackageOrder1.getPayStatus() == 2) {
                                 break;
                             }
                             ResultUtil<Map<String, String>> resultUtil = payMoneyUtil.queryWXOrder(code, "");
-                            if(resultUtil.getCode() == 200 && one.getPayStatus() == 1){
+                            if (resultUtil.getCode() == 200 && coursePackageOrder1.getPayStatus() == 1) {
                                 /**
                                  * SUCCESS—支付成功,
                                  * REFUND—转入退款,
@@ -1003,31 +990,26 @@
                                 Map<String, String> data1 = resultUtil.getData();
                                 String s = data1.get("trade_state");
                                 String transaction_id = data1.get("transaction_id");
-                                if("REFUND".equals(s) || "NOTPAY".equals(s) || "CLOSED".equals(s) || "REVOKED".equals(s) || "PAYERROR".equals(s) || num == 10){
-                                    for (TCoursePackagePayment coursePackagePayment : list) {
-                                        coursePackagePayment.setStatus(3);
-                                    }
-                                    coursePackagePaymentService.updateBatchById(list);
+                                if ("REFUND".equals(s) || "NOTPAY".equals(s) || "CLOSED".equals(s) || "REVOKED".equals(s) || "PAYERROR".equals(s) || num == 10) {
+                                    //有待支付的订单,这里不处理
+//                                    coursePackageOrder1.setState(3);
+//                                    coursePackageOrderService.updateById(coursePackageOrder1);
                                     break;
                                 }
-                                if("SUCCESS".equals(s)){
-                                    for (TCoursePackagePayment coursePackagePayment : list) {
-                                        coursePackagePayment.setPayStatus(2);
-                                        coursePackagePayment.setOrderNumber(transaction_id);
-                                    }
-                                    coursePackagePaymentService.updateBatchById(list);
-                                    // 2.0
-                                    userCouponClient.sendUserCoupon(new SendCouponReq(uid,coursePackagePaymentConfig.getCouponIds()));
-
-                                    addPackageStudent(paymentCourseVo.getId(),uid, finalSid,one.getId(),null);
+                                if ("SUCCESS".equals(s)) {
+                                    coursePackageOrder1.setPayStatus(2);
+                                    coursePackageOrder1.setOrderNumber(transaction_id);
+                                    coursePackageOrder1.setAppUserId(null);
+                                    coursePackageOrderService.updateById(coursePackageOrder1);
+                                    addCoursePackageOrderStudent(coursePackageOrder1, coursePackagePaymentConfig);
                                     break;
                                 }
-                                if("USERPAYING".equals(s)){
+                                if ("USERPAYING".equals(s)) {
                                     num++;
                                 }
                             }
                         }
-                    }catch (Exception e){
+                    } catch (Exception e) {
                         e.printStackTrace();
                     }
                 }
@@ -1036,205 +1018,40 @@
         return weixinpay;
     }
 
-    @Autowired
-    private TOrderService orderService;
 
     /**
      * 课程支付宝支付
+     *
      * @param uid
      * @param paymentPrice
      * @param paymentCourseVo
      * @return
      * @throws Exception
      */
-    public ResultUtil aliPaymentCourse(Integer uid, Double paymentPrice, PaymentCourseVo paymentCourseVo) throws Exception{
+    public ResultUtil aliPaymentCourse(Integer uid, Double paymentPrice, PaymentCourseVo paymentCourseVo) throws Exception {
         CoursePackagePaymentConfig coursePackagePaymentConfig = coursePackagePaymentConfigService.getById(paymentCourseVo.getCoursePackagePaymentConfigId());
-        String[] split = paymentCourseVo.getStudentIds().split(";");
         SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
         String code = sdf.format(new Date()) + UUIDUtil.getNumberRandom(5);
-        List<Long> pays = new ArrayList<>();
+        //生成支付订单
+        CoursePackageOrder coursePackageOrder = new CoursePackageOrder();
+        coursePackageOrder.setCode(code);
+        coursePackageOrder.setAppUserId(uid);
+        coursePackageOrder.setStudentIds(paymentCourseVo.getStudentIds());
+        coursePackageOrder.setCoursePackageId(paymentCourseVo.getId());
+        coursePackageOrder.setPayType(paymentCourseVo.getPayType());
+        coursePackageOrder.setClassHours(coursePackagePaymentConfig.getClassHours());
+        coursePackageOrder.setOriginalPrice(paymentCourseVo.getPrice());
+        coursePackageOrder.setUserCouponId(paymentCourseVo.getCouponId());
+        coursePackageOrder.setCashPayment(new BigDecimal(paymentPrice));
+        coursePackageOrder.setPayUserType(1);
+        coursePackageOrder.setPayStatus(1);
+        coursePackageOrder.setPayUserId(uid);
+        coursePackageOrder.setState(1);
+        coursePackageOrder.setInsertTime(new Date());
+        coursePackageOrderService.save(coursePackageOrder);
 
-        int isContinue = 0;
-
-        for (String s : split) {
-//            TCoursePackagePayment coursePackagePayment = new TCoursePackagePayment();
-//            coursePackagePayment.setCode(code);
-//            coursePackagePayment.setAppUserId(uid);
-//            coursePackagePayment.setStudentId(Integer.valueOf(s));
-//            coursePackagePayment.setCoursePackageId(paymentCourseVo.getId());
-//            coursePackagePayment.setPayType(paymentCourseVo.getPayType());
-//            coursePackagePayment.setClassHours(coursePackagePaymentConfig.getClassHours());
-//            coursePackagePayment.setOriginalPrice(paymentCourseVo.getPrice());
-//            coursePackagePayment.setUserCouponId(paymentCourseVo.getCouponId());
-//            coursePackagePayment.setCashPayment(new BigDecimal(paymentPrice));
-//            coursePackagePayment.setTotalClassHours(coursePackagePaymentConfig.getClassHours());
-//            coursePackagePayment.setLaveClassHours(coursePackagePaymentConfig.getClassHours());
-//            coursePackagePayment.setAbsencesNumber(0);
-//            coursePackagePayment.setPayUserType(1);
-//            coursePackagePayment.setPayStatus(1);
-//            coursePackagePayment.setPayUserId(uid);
-//            coursePackagePayment.setStatus(1);
-//            coursePackagePayment.setState(1);
-//            coursePackagePayment.setInsertTime(new Date());
-//            coursePackagePaymentService.save(coursePackagePayment);
-//
-//
-//            CourseCounsum courseCounsum = new CourseCounsum();
-//            courseCounsum.setPaymentId(coursePackagePayment.getId());
-//            courseCounsum.setChangeType(1);
-//            courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
-//            courseCounsum.setInsertTime(new Date());
-//            courseCounsum.setReason("购买课包");
-//            courseCounsumService.save(courseCounsum);
-
-            TCoursePackagePayment coursePackagePaymentServiceOne = coursePackagePaymentService.getOne(new QueryWrapper<TCoursePackagePayment>().eq("studentId", s).eq("coursePackageId", paymentCourseVo.getId()));
-
-            //赠送课时
-            int weekday = DateUtil.dayOfWeek(new Date()) - 1;
-            TCoursePackageDiscount discount = coursePackageDiscountService.getOne(new QueryWrapper<TCoursePackageDiscount>().eq("type",4).eq("coursePackageId", paymentCourseVo.getId()).last("limit 1"));
-
-            Integer hour = 0;
-            if (discount!=null) {
-                JSONArray objects = JSONObject.parseArray(discount.getContent());
-                JSONObject parse = JSONObject.parseObject(JSONObject.toJSONString(objects.get(0)));
-                hour = parse.getInteger("hour");
-                if (hour == null) {
-                    hour = 0;
-                }
-            }
-
-
-
-            if (coursePackagePaymentServiceOne==null) {
-                isContinue = 1;
-                TCoursePackagePayment coursePackagePayment = new TCoursePackagePayment();
-                coursePackagePayment.setCode(code);
-                coursePackagePayment.setAppUserId(uid);
-                coursePackagePayment.setStudentId(Integer.valueOf(s));
-                coursePackagePayment.setCoursePackageId(paymentCourseVo.getId());
-                coursePackagePayment.setPayType(paymentCourseVo.getPayType());
-                coursePackagePayment.setClassHours(coursePackagePaymentConfig.getClassHours()+hour);
-                coursePackagePayment.setOriginalPrice(paymentCourseVo.getPrice());
-                coursePackagePayment.setPlayPaiCoin(paymentPrice.intValue());
-                coursePackagePayment.setTotalClassHours(coursePackagePaymentConfig.getClassHours()+hour);
-                coursePackagePayment.setLaveClassHours(coursePackagePaymentConfig.getClassHours()+hour);
-                coursePackagePayment.setAbsencesNumber(0);
-                coursePackagePayment.setPayUserType(1);
-                coursePackagePayment.setPayStatus(1);
-                coursePackagePayment.setPayUserId(uid);
-                coursePackagePayment.setStatus(1);
-                coursePackagePayment.setState(1);
-                coursePackagePayment.setInsertTime(new Date());
-                coursePackagePaymentService.save(coursePackagePayment);
-                Integer sId = null;
-                Student student = studentClient.queryDefaultStudent(uid);
-                if (student != null) {
-                    sId = student.getId();
-                }
-
-                pays.add(coursePackagePayment.getId());
-
-//                coursePackagePaymentServiceOne.setPlayPaiCoin(coursePackagePaymentServiceOne.getPlayPaiCoin()+paymentPrice.intValue());
-
-//                addPackageStudent(paymentCourseVo.getId(), uid, Integer.valueOf(s), coursePackagePayment.getId());
-
-                CourseCounsum courseCounsum = new CourseCounsum();
-                courseCounsum.setPaymentId(coursePackagePayment.getId());
-                courseCounsum.setChangeType(1);
-                courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
-                courseCounsum.setInsertTime(new Date());
-                courseCounsum.setReason("购买课包");
-                courseCounsumService.save(courseCounsum);
-
-
-
-
-                if (hour!=0){
-                    CourseCounsum courseCounsum1 = new CourseCounsum();
-                    courseCounsum1.setPaymentId(coursePackagePayment.getId());
-                    courseCounsum1.setChangeType(1);
-                    courseCounsum1.setNum(hour);
-                    courseCounsum1.setInsertTime(new Date());
-                    courseCounsum1.setReason("赠送课时");
-                    courseCounsumService.save(courseCounsum);
-
-                }
-
-                //保存订单
-
-
-
-
-            }else {
-                if (coursePackagePaymentServiceOne.getPayStatus()==1){
-                    isContinue = 1;
-
-                }
-//                coursePackagePaymentServiceOne.setClassHours(coursePackagePaymentServiceOne.getClassHours()+coursePackagePaymentConfig.getClassHours());
-//                coursePackagePaymentServiceOne.setOriginalPrice(coursePackagePaymentServiceOne.getOriginalPrice()+paymentCourseVo.getPrice());
-//                coursePackagePaymentServiceOne.setPlayPaiCoin(coursePackagePaymentServiceOne.getPlayPaiCoin()+paymentPrice.intValue());
-//                coursePackagePaymentServiceOne.setTotalClassHours(coursePackagePaymentServiceOne.getTotalClassHours()+coursePackagePaymentConfig.getClassHours());
-//                coursePackagePaymentServiceOne.setLaveClassHours(coursePackagePaymentServiceOne.getLaveClassHours()+coursePackagePaymentConfig.getClassHours());
-                coursePackagePaymentServiceOne.setCode(code);
-//
-                coursePackagePaymentServiceOne.setPayStatus(1);
-//                coursePackagePaymentServiceOne.setSalesName("续课");
-                coursePackagePaymentServiceOne.setAppUserId(null);
-//                coursePackagePaymentServiceOne.setPayStatus(2);
-                coursePackagePaymentService.updateById(coursePackagePaymentServiceOne);
-                pays.add(coursePackagePaymentServiceOne.getId());
-
-
-//
-//                Integer sId = null;
-//                Student student = studentClient.queryDefaultStudent(uid);
-//                if (student != null) {
-//                    sId = student.getId();
-//                }
-//                coursePackagePaymentServiceOne.setPlayPaiCoin(coursePackagePaymentServiceOne.getPlayPaiCoin()+paymentPrice.intValue());
-//
-//
-//                CourseCounsum courseCounsum = new CourseCounsum();
-//                courseCounsum.setPaymentId(coursePackagePaymentServiceOne.getId());
-//                courseCounsum.setChangeType(1);
-//                courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
-//                courseCounsum.setInsertTime(new Date());
-//                courseCounsum.setReason("续课");
-//                courseCounsumService.save(courseCounsum);
-
-
-            }
-        }
-
-
-        //新的订单添加
-        if (paymentCourseVo.getOrderId()==null) {
-            TOrder order = new TOrder();
-            order.setIsPay(1);
-            order.setPayType(1);
-            order.setAppUserId(uid);
-            order.setPrice(paymentPrice);
-            order.setCode(code);
-
-            String paysStr = pays.stream()
-                    .map(String::valueOf)
-                    .collect(Collectors.joining(","));
-            order.setPaysId(paysStr);
-
-            orderService.save(order);
-
-        }
-
-        Student student = studentClient.queryDefaultStudent(uid);
-        Integer sid=null;
-        if(student!=null){
-            sid=student.getId();
-        }
-
-        ResultUtil alipay = payMoneyUtil.alipay("购买课程", "购买课程", student.getId().toString(), code, paymentPrice.toString(), "/base/course/aliPaymentCourseCallback");
-        if(alipay.getCode() == 200){
-            Integer finalSid = sid;
-            int finalIsContinue = isContinue;
+        ResultUtil alipay = payMoneyUtil.alipay("购买课程", "购买课程", coursePackagePaymentConfig.getId().toString(), code, paymentPrice.toString(), "/base/course/aliPaymentCourseCallback");
+        if (alipay.getCode() == 200) {
             new Thread(new Runnable() {
                 @Override
                 public void run() {
@@ -1243,23 +1060,17 @@
 
                         int num = 1;
                         int wait = 0;
-                        while (num <= 10){
+                        while (num <= 10) {
                             int min = 5000;
                             wait += (min * num);
                             Thread.sleep(wait);
-                            List<TCoursePackagePayment> list = coursePackagePaymentService.list(new QueryWrapper<TCoursePackagePayment>().eq("state", 1).eq("code", code).eq("payType", 2));
-                            TCoursePackagePayment one = list.get(0);
-
-                            List<TOrder> list1 = orderService.list(new QueryWrapper<TOrder>().eq("code", code).eq("payType", 1));
-                            TOrder order = list1.get(0);
-
-
-                            AlipayTradeQueryResponse alipayTradeQueryResponse = payMoneyUtil.queryALIOrder(code);
-                            if(order.getIsPay() == 2){
+                            CoursePackageOrder coursePackageOrder1 = coursePackageOrderService.getOne(new QueryWrapper<CoursePackageOrder>()
+                                    .eq("code", code).eq("state", 1));
+                            if (coursePackageOrder1.getPayStatus() == 2) {
                                 break;
                             }
-
-                            if(order.getIsPay() == 1){
+                            AlipayTradeQueryResponse alipayTradeQueryResponse = payMoneyUtil.queryALIOrder(code);
+                            if (null != alipayTradeQueryResponse) {
                                 /**
                                  * WAIT_BUYER_PAY(交易创建,等待买家付款)、
                                  * TRADE_CLOSED(未付款交易超时关闭,或支付完成后全额退款)、
@@ -1269,123 +1080,26 @@
                                 String s = alipayTradeQueryResponse.getTradeStatus();
 
                                 String tradeNo = alipayTradeQueryResponse.getTradeNo();
-                                if("TRADE_CLOSED".equals(s) || "TRADE_FINISHED".equals(s) || num == 10){
-                                        for (TCoursePackagePayment coursePackagePayment : list) {
-
-                                        coursePackagePayment.setStatus(3);
-                                    }
-                                    coursePackagePaymentService.updateBatchById(list);
+                                if ("TRADE_CLOSED".equals(s) || "TRADE_FINISHED".equals(s) || num == 10) {
+                                    //有待支付的订单,这里不处理
+//                                    coursePackageOrder1.setState(3);
+//                                    coursePackageOrderService.updateById(coursePackageOrder1);
                                     break;
                                 }
-                                if("TRADE_SUCCESS".equals(s)){
-                                    for (TCoursePackagePayment coursePackagePayment : list) {
-                                        coursePackagePayment.setPayStatus(2);
-                                        coursePackagePayment.setOrderNumber(tradeNo);
-                                        coursePackagePayment.setAppUserId(null);
-                                    }
-
-                                    coursePackagePaymentService.updateBatchById(list);
-
-
-                                    for (TOrder tOrder : list1) {
-                                        tOrder.setIsPay(2);
-                                        tOrder.setOrderNum(tradeNo);
-                                    }
-                                    orderService.updateBatchById(list1);
-
-
-
-                                    for (String s1 : split) {
-                                        TCoursePackagePayment coursePackagePaymentServiceOne = coursePackagePaymentService.getOne(new QueryWrapper<TCoursePackagePayment>().eq("studentId", s1).eq("coursePackageId", paymentCourseVo.getId()));
-                                        if (finalIsContinue !=1) {
-
-                                            TCoursePackageDiscount discount = coursePackageDiscountService.getOne(new QueryWrapper<TCoursePackageDiscount>().eq("type",4).eq("coursePackageId", paymentCourseVo.getId()).last("limit 1"));
-
-                                            Integer hour = 0;
-                                            if (discount!=null) {
-                                                JSONArray objects = JSONObject.parseArray(discount.getContent());
-                                                JSONObject parse = JSONObject.parseObject(JSONObject.toJSONString(objects.get(0)));
-                                                hour = parse.getInteger("hour");
-                                                if (hour == null) {
-                                                    hour = 0;
-                                                }
-                                            }
-
-
-
-                                            coursePackagePaymentServiceOne.setClassHours(coursePackagePaymentServiceOne.getClassHours()+coursePackagePaymentConfig.getClassHours()+hour);
-                                            coursePackagePaymentServiceOne.setOriginalPrice(coursePackagePaymentServiceOne.getOriginalPrice()+paymentCourseVo.getPrice());
-                                            coursePackagePaymentServiceOne.setPlayPaiCoin(coursePackagePaymentServiceOne.getPlayPaiCoin()+paymentPrice.intValue());
-                                            coursePackagePaymentServiceOne.setTotalClassHours(coursePackagePaymentServiceOne.getTotalClassHours()+coursePackagePaymentConfig.getClassHours()+hour);
-                                            coursePackagePaymentServiceOne.setLaveClassHours(coursePackagePaymentServiceOne.getLaveClassHours()+coursePackagePaymentConfig.getClassHours()+hour);
-                                            coursePackagePaymentServiceOne.setCode(code);
-
-                                            coursePackagePaymentServiceOne.setAppUserId(null);
-                                            coursePackagePaymentServiceOne.setPayStatus(2);
-                                            coursePackagePaymentService.updateById(coursePackagePaymentServiceOne);
-
-                                            Integer sId = null;
-                                            Student student = studentClient.queryDefaultStudent(uid);
-                                            if (student != null) {
-                                                sId = student.getId();
-                                            }
-                                            coursePackagePaymentServiceOne.setPlayPaiCoin(coursePackagePaymentServiceOne.getPlayPaiCoin()+paymentPrice.intValue());
-
-
-                                            CourseCounsum courseCounsum = new CourseCounsum();
-                                            courseCounsum.setPaymentId(coursePackagePaymentServiceOne.getId());
-                                            courseCounsum.setChangeType(1);
-                                            courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
-                                            courseCounsum.setInsertTime(new Date());
-                                            courseCounsum.setReason("续课");
-                                            courseCounsumService.save(courseCounsum);
-
-
-                                            if (hour!=0){
-                                                CourseCounsum courseCounsum1 = new CourseCounsum();
-                                                courseCounsum1.setPaymentId(coursePackagePaymentServiceOne.getId());
-                                                courseCounsum1.setChangeType(1);
-                                                courseCounsum1.setNum(hour);
-                                                courseCounsum1.setInsertTime(new Date());
-                                                courseCounsum1.setReason("赠送课时");
-                                                courseCounsumService.save(courseCounsum);
-
-                                            }
-
-
-                                        }
-                                    }
-
-                                System.out.println("===========到达支付");
-                                    // 2.0
-                                    String[] coupons = coursePackagePaymentConfig.getCouponIds().split(",");
-
-
-
-                                    userCouponClient.sendUserCoupon(new SendCouponReq(uid,coursePackagePaymentConfig.getCouponIds()));
-
-                                    for (TCoursePackagePayment coursePackagePayment : list) {
-                                        addPackageStudent(paymentCourseVo.getId(),uid, finalSid,coursePackagePayment.getId(),paymentPrice);
-                                    }
-
-                                    moneyOut(tradeNo,tradeNo);
-
-
-
-
-
-
-                                    if(student!=null){
-
-                                    }
+                                if ("TRADE_SUCCESS".equals(s)) {
+                                    coursePackageOrder1.setPayStatus(2);
+                                    coursePackageOrder1.setOrderNumber(tradeNo);
+                                    coursePackageOrder1.setAppUserId(null);
+                                    coursePackageOrderService.updateById(coursePackageOrder1);
+                                    addCoursePackageOrderStudent(coursePackageOrder1, coursePackagePaymentConfig);
                                     break;
                                 }
-                                if("WAIT_BUYER_PAY".equals(s)){
+                                if ("WAIT_BUYER_PAY".equals(s)) {
                                     num++;
                                 }
                             }
                         }
-                    }catch (Exception e){
+                    } catch (Exception e) {
                         e.printStackTrace();
                     }
                 }
@@ -1395,492 +1109,283 @@
     }
 
 
-    @Autowired
-    private TCoursePackageService coursePackageService;
-    public void moneyOut(String outNum,String tradeNo) throws AlipayApiException {
-        AlipayClient alipayClient = new DefaultAlipayClient("https://openapi.alipay.com/gateway.do", aliAppid, appPrivateKey, "json", "UTF-8", alipay_public_key, "RSA2");
-        AlipayTradeOrderSettleRequest request = new AlipayTradeOrderSettleRequest();
-        AlipayTradeOrderSettleModel model = new AlipayTradeOrderSettleModel();
-        model.setOutRequestNo(outNum);
-        model.setTradeNo(tradeNo);
-        List<RoyaltyDetailInfos> royaltyDetailInfos = new ArrayList<>();
-//
-
-        AlipayTradeRoyaltyRelationBindRequest request1 = new AlipayTradeRoyaltyRelationBindRequest();
-        AlipayTradeRoyaltyRelationBindModel bindModel = new AlipayTradeRoyaltyRelationBindModel();
-
-
-        request1.setBizContent("{" +
-                "  \"receiver_list\":[" +
-                "    {" +
-                "      \"type\":\"loginName\"," +
-                "      \"account\":\"19522115070\"," +
-                "      \"name\":\"罗易胜\"," +
-                "      \"memo\":\"分账给测试商户\"," +
-                "    }" +
-                "  ]," +
-                "  \"out_request_no\":\""+tradeNo+"\"" +
-                "}");
-        AlipayTradeRoyaltyRelationBindResponse response = alipayClient.execute(request1);
-        if(response.isSuccess()){
-            System.out.println("绑定调用成功");
-        } else {
-            System.out.println("调用失败");
-        }
-
-
-
-//        RoyaltyDetailInfos royaltyDetailInfos1 = new RoyaltyDetailInfos();
-//        royaltyDetailInfos1.setTransOutType("loginName");
-//        royaltyDetailInfos1.setTransOut("happysports@weparklife.com");
-//        royaltyDetailInfos1.setTransInType("loginName");
-//        royaltyDetailInfos1.setTransIn("19522115070");
-////        royaltyDetailInfos1.setAmount("0.01");
-//        royaltyDetailInfos1.setAmountPercentage("100");
-
-//        royaltyDetailInfos.add(royaltyDetailInfos1);
-
-        TCoursePackagePayment one = coursePackagePaymentService.getOne(new QueryWrapper<TCoursePackagePayment>().eq("code", outNum));
-        TCoursePackage byId = coursePackageService.getById(one.getCoursePackageId());
-        OperatorUser operatorUser =  storeClient.queryByStoreId(byId.getStoreId());
-
-
-
-//        Integer paymentCompetitions = competitionsClient.queryByCode(outTradeNo);
-//        Integer siteBookings = siteClient.queryByCode(outTradeNo);
-//        List<Integer> stores = new ArrayList<>();
-//        stores.add(coursePackagePayments);
-//        stores.add(paymentCompetitions);
-//        stores.add(siteBookings);
-//        OperatorUser operatorUser = siteClient.queryOperator(stores);
-
-
-
-
-        OpenApiRoyaltyDetailInfoPojo op = new OpenApiRoyaltyDetailInfoPojo();
-        op.setTransOutType("loginName");
-        op.setTransOut("happysports@weparklife.com");
-        op.setTransInType("userId");
-        op.setTransIn(operatorUser.getAlipayNum());
-        op.setAmountPercentage(Long.valueOf(operatorUser.getAlipayProportion()));
-
-        List<OpenApiRoyaltyDetailInfoPojo> ops = new ArrayList<>();
-        ops.add(op);
-        model.setRoyaltyParameters(ops);
-
-        request.setBizModel(model);
-
-
-        AlipayTradeOrderSettleResponse response1 = alipayClient.execute(request);
-        if(response1.isSuccess()){
-            System.out.println("调用成功");
-        } else {
-            System.out.println("调用失败");
-        }
-    }
-
-
-
-    @Autowired
-    private  CourseCounsumService courseCounsumService;
-
-
-
     /**
      * 玩湃币支付课程
+     *
      * @param appUser
      * @param paymentPrice
      * @param paymentCourseVo
      * @return
      * @throws Exception
      */
-    public ResultUtil playPaiCoinPaymentCourse(AppUser appUser, Double paymentPrice, PaymentCourseVo paymentCourseVo) throws Exception{
-        CoursePackagePaymentConfig coursePackagePaymentConfig = coursePackagePaymentConfigService.getById(paymentCourseVo.getCoursePackagePaymentConfigId());
-        String[] split = paymentCourseVo.getStudentIds().split(";");
-        SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
-        String code = sdf.format(new Date()) + UUIDUtil.getNumberRandom(5);
-
-        List<Long> pays = new ArrayList<>();
-
-
-        TCoursePackage course = coursePackageService.getById(paymentCourseVo.getId());
-
-
-        //赠送课时
-        int weekday = DateUtil.dayOfWeek(new Date()) - 1;
-        TCoursePackageDiscount discount = coursePackageDiscountService.getOne(new QueryWrapper<TCoursePackageDiscount>().eq("type",4).eq("coursePackageId", paymentCourseVo.getId()).last("limit 1"));
-
-        Integer hour = 0;
-        if (discount!=null) {
-            JSONArray objects = JSONObject.parseArray(discount.getContent());
-            JSONObject parse = JSONObject.parseObject(JSONObject.toJSONString(objects.get(0)));
-             hour = parse.getInteger("hour");
-            if (hour == null) {
-                hour = 0;
-            }
-        }
-
-        for (String s : split) {
-            TCoursePackagePayment coursePackagePaymentServiceOne = coursePackagePaymentService.getOne(new QueryWrapper<TCoursePackagePayment>().eq("studentId", s).eq("coursePackageId", paymentCourseVo.getId()));
-
-
-
-            if (coursePackagePaymentServiceOne==null) {
-                TCoursePackagePayment coursePackagePayment = new TCoursePackagePayment();
-                coursePackagePayment.setCode(code);
-                coursePackagePayment.setAppUserId(appUser.getId());
-                coursePackagePayment.setStudentId(Integer.valueOf(s));
-                coursePackagePayment.setCoursePackageId(paymentCourseVo.getId());
-                coursePackagePayment.setPayType(paymentCourseVo.getPayType());
-                coursePackagePayment.setClassHours(coursePackagePaymentConfig.getClassHours()+hour);
-                coursePackagePayment.setOriginalPrice(paymentCourseVo.getPrice());
-                coursePackagePayment.setPlayPaiCoin(paymentPrice.intValue());
-                coursePackagePayment.setTotalClassHours(coursePackagePaymentConfig.getClassHours()+hour);
-                coursePackagePayment.setLaveClassHours(coursePackagePaymentConfig.getClassHours()+hour);
-                coursePackagePayment.setAbsencesNumber(0);
-                coursePackagePayment.setPayUserType(1);
-                coursePackagePayment.setPayStatus(2);
-                coursePackagePayment.setPayUserId(appUser.getId());
-                coursePackagePayment.setStatus(1);
-                coursePackagePayment.setState(1);
-                coursePackagePayment.setInsertTime(new Date());
-
-                if (course.getValidDays()!=null) {
-                    Date date = new Date();
-                    Calendar calendar = Calendar.getInstance();
-                    calendar.setTime(date);
-                    calendar.add(Calendar.DATE, course.getValidDays());
-                    date = calendar.getTime();
-                    coursePackagePayment.setUseTime(date);
-                }
-
-                coursePackagePaymentService.save(coursePackagePayment);
-                Integer sId = null;
-                Student student = studentClient.queryDefaultStudent(appUser.getId());
-                if (student != null) {
-                    sId = student.getId();
-                }
-                addPackageStudent(paymentCourseVo.getId(), appUser.getId(), Integer.valueOf(s), coursePackagePayment.getId(),null);
-
-                //课时记录
-                CourseCounsum courseCounsum = new CourseCounsum();
-                courseCounsum.setPaymentId(coursePackagePayment.getId());
-                courseCounsum.setChangeType(1);
-                courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
-                courseCounsum.setInsertTime(new Date());
-                courseCounsum.setReason("购买课包");
-                courseCounsumService.save(courseCounsum);
-
-                if (hour!=0){
-                    CourseCounsum courseCounsum1 = new CourseCounsum();
-                    courseCounsum1.setPaymentId(coursePackagePayment.getId());
-                    courseCounsum1.setChangeType(1);
-                    courseCounsum1.setNum(hour);
-                    courseCounsum1.setInsertTime(new Date());
-                    courseCounsum1.setReason("赠送课时");
-                    courseCounsumService.save(courseCounsum1);
-                }
-
-
-                pays.add(coursePackagePayment.getId());
-            }else{
-                coursePackagePaymentServiceOne.setClassHours(coursePackagePaymentServiceOne.getClassHours()+coursePackagePaymentConfig.getClassHours()+hour);
-                if (coursePackagePaymentServiceOne.getOriginalPrice()!=null) {
-                    coursePackagePaymentServiceOne.setOriginalPrice(coursePackagePaymentServiceOne.getOriginalPrice() + paymentCourseVo.getPrice());
-                }else {
-                    coursePackagePaymentServiceOne.setOriginalPrice(paymentCourseVo.getPrice());
-                }
-                if (coursePackagePaymentServiceOne.getPlayPaiCoin()==null){
-                    coursePackagePaymentServiceOne.setPlayPaiCoin(paymentPrice.intValue());
-
-                }else {
-                coursePackagePaymentServiceOne.setPlayPaiCoin(coursePackagePaymentServiceOne.getPlayPaiCoin()+paymentPrice.intValue());}
-                coursePackagePaymentServiceOne.setTotalClassHours(coursePackagePaymentServiceOne.getTotalClassHours()+coursePackagePaymentConfig.getClassHours()+hour);
-                coursePackagePaymentServiceOne.setLaveClassHours(coursePackagePaymentServiceOne.getLaveClassHours()+coursePackagePaymentConfig.getClassHours()+hour);
-                coursePackagePaymentServiceOne.setAppUserId(null);
-
-
-                if (course.getValidDays()!=null) {
-                    Date date = coursePackagePaymentServiceOne.getUseTime();
-                    Calendar calendar = Calendar.getInstance();
-                    calendar.setTime(date);
-                    calendar.add(Calendar.DATE, course.getValidDays());
-                    date = calendar.getTime();
-                    coursePackagePaymentServiceOne.setUseTime(date);
-                }
-
-
-                coursePackagePaymentService.updateById(coursePackagePaymentServiceOne);
-
-//                coursePackagePaymentService.save(coursePackagePayment);
-                Integer sId = null;
-                Student student = studentClient.queryDefaultStudent(appUser.getId());
-                if (student != null) {
-                    sId = student.getId();
-                }
-                addPackageStudent(paymentCourseVo.getId(), appUser.getId(), Integer.valueOf(s), coursePackagePaymentServiceOne.getId(),null);
-
-
-                CourseCounsum courseCounsum = new CourseCounsum();
-                courseCounsum.setPaymentId(coursePackagePaymentServiceOne.getId());
-                courseCounsum.setChangeType(1);
-                courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
-                courseCounsum.setInsertTime(new Date());
-                courseCounsum.setReason("续课");
-                courseCounsumService.save(courseCounsum);
-
-                if (hour!=0){
-                    CourseCounsum courseCounsum1 = new CourseCounsum();
-                    courseCounsum1.setPaymentId(coursePackagePaymentServiceOne.getId());
-                    courseCounsum1.setChangeType(1);
-                    courseCounsum1.setNum(hour);
-                    courseCounsum1.setInsertTime(new Date());
-                    courseCounsum1.setReason("赠送课时");
-                    courseCounsumService.save(courseCounsum1);
-                }
-
-
-                pays.add(coursePackagePaymentServiceOne.getId());
-
-
-
-            }
-
-        }
-
-
-        if (paymentCourseVo.getOrderId()==null) {
-            TOrder order = new TOrder();
-            order.setIsPay(1);
-            order.setPayType(2);
-            order.setAppUserId(appUser.getId());
-            order.setPrice(paymentPrice);
-            order.setCode(code);
-
-            String paysStr = pays.stream()
-                    .map(String::valueOf)
-                    .collect(Collectors.joining(","));
-            order.setPaysId(paysStr);
-
-            orderService.save(order);
-
-        }
-
-
-
+    public ResultUtil playPaiCoinPaymentCourse(AppUser appUser, Double paymentPrice, PaymentCourseVo paymentCourseVo) throws Exception {
         Integer playPaiCoins = appUser.getPlayPaiCoins();
+        if (playPaiCoins.compareTo(paymentPrice.intValue()) < 0) {
+            return ResultUtil.error("玩湃币不足");
+        }
         appUser.setPlayPaiCoins(playPaiCoins - paymentPrice.intValue());
         appUserClient.updateAppUser(appUser);
 
-        // 2.0
-        String couponIds = coursePackagePaymentConfig.getCouponIds();
-        if(ToolUtil.isNotEmpty(couponIds)){
-            // 赠送优惠券
-            userCouponClient.sendUserCoupon(new SendCouponReq(appUser.getId(),couponIds));
-        }
+        CoursePackagePaymentConfig coursePackagePaymentConfig = coursePackagePaymentConfigService.getById(paymentCourseVo.getCoursePackagePaymentConfigId());
+        SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
+        String code = sdf.format(new Date()) + UUIDUtil.getNumberRandom(5);
+        //生成支付订单
+        CoursePackageOrder coursePackageOrder = new CoursePackageOrder();
+        coursePackageOrder.setCode(code);
+        coursePackageOrder.setAppUserId(appUser.getId());
+        coursePackageOrder.setStudentIds(paymentCourseVo.getStudentIds());
+        coursePackageOrder.setCoursePackageId(paymentCourseVo.getId());
+        coursePackageOrder.setPayType(paymentCourseVo.getPayType());
+        coursePackageOrder.setClassHours(coursePackagePaymentConfig.getClassHours());
+        coursePackageOrder.setOriginalPrice(paymentCourseVo.getPrice());
+        coursePackageOrder.setUserCouponId(paymentCourseVo.getCouponId());
+        coursePackageOrder.setCashPayment(new BigDecimal(paymentPrice));
+        coursePackageOrder.setPayUserType(1);
+        coursePackageOrder.setPayStatus(2);
+        coursePackageOrder.setPayUserId(appUser.getId());
+        coursePackageOrder.setState(1);
+        coursePackageOrder.setInsertTime(new Date());
+        coursePackageOrderService.save(coursePackageOrder);
+
+        addCoursePackageOrderStudent(coursePackageOrder, coursePackagePaymentConfig);
         return ResultUtil.success();
     }
 
 
-
-
-
-    private void addPackageStudent(Integer courseId, Integer userId, Integer sId,Long paymentId,Double price) throws ParseException {
-        // 课包
-        TCoursePackage tCoursePackage = this.baseMapper.selectById(courseId);
-
-        if (tCoursePackage.getType()==1) {
-            String classWeeks = tCoursePackage.getClassWeeks();
-
-            List<Integer> week = week(classWeeks);
-
-            String[] split = tCoursePackage.getClassStartTime().split(",");
-            String[] split1 = tCoursePackage.getClassEndTime().split(",");
-            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
-            SimpleDateFormat format1 = new SimpleDateFormat("yyyy-MM-dd HH:mm");
-
-            //查出当前用户当前学员当前课包最后一天的排课数据
-            List<CoursePackageStudent> studentCourse = coursePackageStudentService.list(new QueryWrapper<CoursePackageStudent>().eq("studentId", sId).eq("coursePackageId", courseId));
-            List<Long> collect = studentCourse.stream().map(CoursePackageStudent::getCoursePackageSchedulingId).collect(Collectors.toList());
-
-
-
-
-            //拿到最后一天的排课记录
-            if (collect.size() > 0){
-                coursePackageSchedulingService.remove(new QueryWrapper<CoursePackageScheduling>().in("id", collect));
-                coursePackageStudentService.remove(new QueryWrapper<CoursePackageStudent>().eq("studentId", sId).eq("coursePackageId", courseId));
-                if (price!=null) {
-                    CourseCounsum courseCounsum = new CourseCounsum();
-                    courseCounsum.setPaymentId(paymentId);
-                    courseCounsum.setChangeType(3);
-                    courseCounsum.setInsertTime(new Date());
-                    courseCounsum.setReason("续课;" + price);
-                    courseCounsum.setAppUserId(userId);
-                    courseCounsumService.save(courseCounsum);
-                }
-
-            }else {
-                if (price!=null) {
-                    CourseCounsum courseCounsum = new CourseCounsum();
-                    courseCounsum.setPaymentId(paymentId);
-                    courseCounsum.setChangeType(3);
-                    courseCounsum.setInsertTime(new Date());
-                    courseCounsum.setReason("报名课程;" + price);
-                    courseCounsum.setAppUserId(userId);
-                    courseCounsumService.save(courseCounsum);
-                }
-            }
-            Date today = new Date();
-            TCoursePackagePayment pay = coursePackagePaymentService.getById(paymentId);
-            Integer laveClassHours = pay.getLaveClassHours();
-            Integer codeTime = tCoursePackage.getCodeTime();
-            Integer can = 0;
-            int count = 0;
-            // 本周周几
-            Date[] dates = generateDateArray(14, today);
-            if (tCoursePackage.getType() == 1) {
-                can = laveClassHours / codeTime;
-            }
-            if (tCoursePackage.getType() == 2) {
-                Date startDate = tCoursePackage.getStartTime();
-                Date endDate = tCoursePackage.getEndTime();
-                dates = generateDateArray1(startDate, endDate);
-                can = 999;
-            }
-            for (Date date : dates) {
-                if (count == can) {
-                    break;
-                }
-                int wei = DateUtil.dayOfWeek(date)-1;
-                if (wei == 0){
-                    wei = 7;
-                }
-                if (week.contains(wei)) {
-                    for (int i1 = 0; i1 < split.length; i1++) {
-                        if (count == can) {
-                            break;
-                        }
-                        CoursePackageScheduling coursePackageScheduling = new CoursePackageScheduling();
-                        coursePackageScheduling.setCoursePackageId(tCoursePackage.getId());
-                        Date parse = format1.parse(format.format(date) + " " + split[i1]);
-                        Date parse1 = format1.parse(format.format(date) + " " + split1[i1]);
-                        coursePackageScheduling.setClassDate(parse);
-                        coursePackageScheduling.setEndDate(parse1);
-                        coursePackageScheduling.setStatus(1);
-                        coursePackageSchedulingService.save(coursePackageScheduling);
-                        CoursePackageStudent student1 = new CoursePackageStudent();
-                        student1.setAppUserId(userId);
-                        student1.setStudentId(sId);
-                        student1.setCoursePackageId(tCoursePackage.getId());
-                        student1.setCoursePackagePaymentId(paymentId);
-                        student1.setCoursePackageSchedulingId(coursePackageScheduling.getId());
-                        student1.setSignInOrNot(1);
-                        student1.setReservationStatus(1);
-                        student1.setInsertTime(new Date());
-                        cpsMapper.insert(student1);
-                        count++;
-                    }
-                }
-            }
-
-        }else if (tCoursePackage.getType()==2){
-            String classWeeks = tCoursePackage.getClassWeeks();
-            List<Integer> week = week(classWeeks);
-
-            Date today = new Date();
-
-            Date startTime = tCoursePackage.getStartTime();
-            Date endTime = tCoursePackage.getEndTime();
-            LocalDate startDate = startTime.toInstant().atZone(ZoneId.systemDefault()).toLocalDate();
-            LocalDate endDate = endTime.toInstant().atZone(ZoneId.systemDefault()).toLocalDate();
-            Period period = Period.between(startDate, endDate);
-            int days = period.getDays() + 1;
-            Integer can =999;
-            int count = 0;
-            String[] split = tCoursePackage.getClassStartTime().split(",");
-            String[] split1 = tCoursePackage.getClassEndTime().split(",");
-            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
-            SimpleDateFormat format1 = new SimpleDateFormat("yyyy-MM-dd HH:mm");
-
-            Calendar calendar = Calendar.getInstance();
-            calendar.setTime(startTime);
-            calendar.add(Calendar.DAY_OF_MONTH, -1);
-
-            TCoursePackagePayment pay = coursePackagePaymentService.getById(paymentId);
-
-
-            Date[] dates = generateDateArray(days,calendar.getTime());
-            for (Date date : dates) {
-                if (count==can){
-                    break;
-                }
-                int wei =  cn.hutool.core.date.DateUtil.dayOfWeek(date)-1;
-                if (wei == 0){
-                    wei =7;
-                }
-                if (week.contains(wei)){
-                    for (int i1 = 0; i1 < split.length; i1++) {
-                        if (count==can){
-                            break;
-                        }
-                        CoursePackageScheduling coursePackageScheduling = new CoursePackageScheduling();
-                        coursePackageScheduling.setCoursePackageId(tCoursePackage.getId());
-                        Date parse = format1.parse(format.format(date) + " " + split[i1]);
-                        Date parse1 = format1.parse(format.format(date) + " " + split1[i1]);
-                        coursePackageScheduling.setClassDate(parse);
-                        coursePackageScheduling.setEndDate(parse1);
-                        coursePackageScheduling.setStatus(1);
-                        coursePackageSchedulingService.save(coursePackageScheduling);
-                        CoursePackageStudent student1 = new CoursePackageStudent();
-                        student1.setAppUserId(userId);
-                        student1.setStudentId(sId);
-                        student1.setCoursePackageId(tCoursePackage.getId());
-                        student1.setCoursePackagePaymentId(pay.getId());
-                        student1.setCoursePackageSchedulingId(coursePackageScheduling.getId());
-                        student1.setSignInOrNot(1);
-                        student1.setReservationStatus(1);
-                        student1.setInsertTime(new Date());
-                        cpsMapper.insert(student1);
-                        count++;
-                    }
-                }
-            }
-        }else if (tCoursePackage.getType()==3){
-
-            if (price!=null) {
-                CourseCounsum courseCounsum = new CourseCounsum();
-                courseCounsum.setPaymentId(paymentId);
-                courseCounsum.setChangeType(3);
-                courseCounsum.setInsertTime(new Date());
-                courseCounsum.setReason("购买体验课;" + price);
-                courseCounsum.setAppUserId(userId);
-                courseCounsumService.save(courseCounsum);
-            }
-
-
-            //生成当天的排课记录
-
-            //生成学员的上课表
-
-
-
-
-
+    /**
+     * 购买课程支付成功后的回调处理
+     *
+     * @param code
+     * @param trade_no
+     * @return
+     */
+    @Override
+    public ResultUtil paymentCourseCallback(String code, String trade_no, String attach) {
+        CoursePackageOrder coursePackageOrder1 = coursePackageOrderService.getOne(new QueryWrapper<CoursePackageOrder>()
+                .eq("code", code).eq("state", 1));
+        if (coursePackageOrder1.getPayStatus() == 2) {
+            return ResultUtil.success();
         }
+        coursePackageOrder1.setPayStatus(2);
+        coursePackageOrder1.setOrderNumber(trade_no);
+        coursePackageOrder1.setAppUserId(null);
+        coursePackageOrderService.updateById(coursePackageOrder1);
+
+        CoursePackagePaymentConfig coursePackagePaymentConfig = coursePackagePaymentConfigService.getById(attach);
+        addCoursePackageOrderStudent(coursePackageOrder1, coursePackagePaymentConfig);
+        return ResultUtil.success();
+    }
 
 
-        // 2.0
-        TCourseInfoRecord tCourseInfoRecord = new TCourseInfoRecord();
-        tCourseInfoRecord.setUserId(userId);
-        tCourseInfoRecord.setCourseId(courseId);
-        tCourseInfoRecord.setName("报名运动营");
-        tCourseInfoRecord.setNum(tCoursePackage.getNeedNum());
-        tCourseInfoRecord.setTime(new Date());
-        tCourseInfoRecord.setType(2);
-        appUserClient.addCourseInfoRecord(tCourseInfoRecord);
+    /**
+     * 支付成功后添加学员课时数据
+     *
+     * @param coursePackageOrder
+     * @param coursePackagePaymentConfig
+     */
+    public void addCoursePackageOrderStudent(CoursePackageOrder coursePackageOrder, CoursePackagePaymentConfig coursePackagePaymentConfig) {
+        // 发放优惠券
+        userCouponClient.sendUserCoupon(new SendCouponReq(coursePackageOrder.getAppUserId(), coursePackagePaymentConfig.getCouponIds()));
+
+        //开始处理学员课程课时记录和排课数据
+        TCoursePackage coursePackage = coursePackageService.getById(coursePackageOrder.getCoursePackageId());
+        String[] split = coursePackageOrder.getStudentIds().split(";");
+        for (String id : split) {
+            CoursePackageOrderStudent coursePackageOrderStudent = coursePackageOrderStudentService.getOne(new QueryWrapper<CoursePackageOrderStudent>().eq("studentId", id)
+                    .eq("coursePackageId", coursePackageOrder.getCoursePackageId()).eq("status", 1).eq("state", 1));
+            if (null == coursePackageOrderStudent) {
+                coursePackageOrderStudent = new CoursePackageOrderStudent();
+                coursePackageOrderStudent.setAppUserId(coursePackageOrder.getAppUserId());
+                coursePackageOrderStudent.setStudentId(Integer.valueOf(id));
+                coursePackageOrderStudent.setCoursePackageId(coursePackageOrder.getCoursePackageId());
+                coursePackageOrderStudent.setTotalClassHours(coursePackagePaymentConfig.getClassHours());
+                coursePackageOrderStudent.setLaveClassHours(coursePackagePaymentConfig.getClassHours());
+                coursePackageOrderStudent.setAbsencesNumber(0);
+                coursePackageOrderStudent.setStatus(1);
+                coursePackageOrderStudent.setState(1);
+                coursePackageOrderStudent.setInsertTime(new Date());
+                coursePackageOrderStudent.setGiftClassHours(0);
+
+                Integer validDays = coursePackage.getValidDays();
+                Calendar calendar = Calendar.getInstance();
+                calendar.setTime(new Date());
+                calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + validDays);
+                coursePackageOrderStudent.setUseTime(calendar.getTime());
+
+                //开始排课
+                addPackageStudent(coursePackage, coursePackageOrder.getAppUserId(), Integer.valueOf(id), coursePackageOrderStudent);
+            } else {
+                Date useTime = coursePackageOrderStudent.getUseTime();
+                coursePackageOrderStudent.setTotalClassHours(coursePackageOrderStudent.getTotalClassHours() + coursePackagePaymentConfig.getClassHours());
+                coursePackageOrderStudent.setLaveClassHours(coursePackageOrderStudent.getLaveClassHours() + coursePackagePaymentConfig.getClassHours());
+                Integer validDays = coursePackage.getValidDays();
+                Calendar calendar = Calendar.getInstance();
+                calendar.setTime(useTime.compareTo(new Date()) < 0 ? new Date() : useTime);
+                calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + validDays);
+                coursePackageOrderStudent.setUseTime(calendar.getTime());
+                //中间断课,没有连续续费的情况需要重新排课
+                if (useTime.compareTo(new Date()) < 0) {
+                    addPackageStudent(coursePackage, coursePackageOrder.getAppUserId(), Integer.valueOf(id), coursePackageOrderStudent);
+                }
+            }
+            coursePackageOrderStudentService.saveOrUpdate(coursePackageOrderStudent);
+
+            CourseCounsum courseCounsum = new CourseCounsum();
+            courseCounsum.setPaymentId(coursePackageOrder.getId());
+            courseCounsum.setChangeType(1);
+            courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
+            courseCounsum.setInsertTime(new Date());
+            courseCounsum.setReason("购买课包");
+            courseCounsumService.save(courseCounsum);
+        }
+    }
 
 
+    /**
+     * 新购买课程后的排课
+     *
+     * @param userId
+     * @param sId
+     * @throws ParseException
+     */
+    private void addPackageStudent(TCoursePackage tCoursePackage, Integer userId, Integer sId, CoursePackageOrderStudent coursePackageOrderStudent) {
+        try {
+            //1常规 2假期 3体验
+            if (tCoursePackage.getType() == 1) {
+                //上课星期
+                String classWeeks = tCoursePackage.getClassWeeks();
+                List<Integer> week = week(classWeeks);
+                //上课时段
+                String[] split = tCoursePackage.getClassStartTime().split(",");
+                String[] split1 = tCoursePackage.getClassEndTime().split(",");
+                SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+                SimpleDateFormat format1 = new SimpleDateFormat("yyyy-MM-dd HH:mm");
+
+                //剩余课时
+                Integer laveClassHours = coursePackageOrderStudent.getLaveClassHours();
+                //扣除课时数
+                Integer codeTime = tCoursePackage.getCodeTime();
+                //排课 本周+下周,课时不够扣则直接剩余不排课
+                Calendar calendar = Calendar.getInstance();
+                calendar.setTime(new Date());
+                calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1);
+                calendar.set(Calendar.HOUR_OF_DAY, 0);
+                calendar.set(Calendar.MINUTE, 0);
+                calendar.set(Calendar.SECOND, 0);
+                int day_week = calendar.get(Calendar.DAY_OF_WEEK);
+                day_week = day_week - 1 == 0 ? 7 : day_week - 1;
+                int num = 8 - day_week + 7;
+                Date useTime = coursePackageOrderStudent.getUseTime();
+
+                for (int i = 0; i < num; i++) {
+                    Date time = calendar.getTime();
+                    for (int j = 0; j < split.length; j++) {
+                        //判断当天是否在排课星期内
+                        int day = calendar.get(Calendar.DAY_OF_WEEK);
+                        day = day - 1 == 0 ? 7 : day - 1;
+                        if (!week.contains(day)) {
+                            calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1);
+                            continue;
+                        }
+
+
+                        //大于有效期不进行排课
+                        if (calendar.getTimeInMillis() >= useTime.getTime()) {
+                            break;
+                        }
+                        //剩余数量不足以排课
+                        if (laveClassHours.compareTo(codeTime) < 0) {
+                            break;
+                        }
+
+                        laveClassHours -= codeTime;
+
+                        CoursePackageScheduling coursePackageScheduling = new CoursePackageScheduling();
+                        coursePackageScheduling.setCoursePackageId(tCoursePackage.getId());
+                        Date parse = format1.parse(format.format(time) + " " + split[j]);
+                        Date parse1 = format1.parse(format.format(time) + " " + split1[j]);
+                        coursePackageScheduling.setClassDate(parse);
+                        coursePackageScheduling.setEndDate(parse1);
+                        coursePackageScheduling.setStatus(1);
+                        coursePackageSchedulingService.save(coursePackageScheduling);
+                        CoursePackageStudent student1 = new CoursePackageStudent();
+                        student1.setAppUserId(userId);
+                        student1.setStudentId(sId);
+                        student1.setCoursePackageId(tCoursePackage.getId());
+                        student1.setCoursePackagePaymentId(coursePackageOrderStudent.getId());
+                        student1.setCoursePackageSchedulingId(coursePackageScheduling.getId());
+                        student1.setSignInOrNot(1);
+                        student1.setReservationStatus(1);
+                        student1.setInsertTime(new Date());
+                        cpsMapper.insert(student1);
+
+                        //增加日期,用于判断
+                        calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1);
+                    }
+                }
+            }
+
+            if (tCoursePackage.getType() == 2) {
+                //上课星期
+                String classWeeks = tCoursePackage.getClassWeeks();
+                List<Integer> week = week(classWeeks);
+                //上课时段
+                String[] split = tCoursePackage.getClassStartTime().split(",");
+                String[] split1 = tCoursePackage.getClassEndTime().split(",");
+                SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+                SimpleDateFormat format1 = new SimpleDateFormat("yyyy-MM-dd HH:mm");
+
+                Date startTime = tCoursePackage.getStartTime();
+                Date endTime = tCoursePackage.getEndTime();
+                //排课 本周+下周,课时不够扣则直接剩余不排课
+                Calendar calendar = Calendar.getInstance();
+                //假期开始使用当前时间为起始时间进行排课
+                calendar.setTime(startTime.getTime() > System.currentTimeMillis() ? startTime : new Date());
+                int day_week = calendar.get(Calendar.DAY_OF_WEEK);
+                day_week = day_week - 1 == 0 ? 7 : day_week - 1;
+                int num = 8 - day_week + 7;
+                for (int i = 0; i < num; i++) {
+                    Date time = calendar.getTime();
+                    for (int j = 0; j < split.length; j++) {
+                        //判断当天是否在排课星期内
+                        int day = calendar.get(Calendar.DAY_OF_WEEK);
+                        day = day - 1 == 0 ? 7 : day - 1;
+                        if (!week.contains(day)) {
+                            calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1);
+                            continue;
+                        }
+
+                        //大于有效期不进行排课
+                        if (calendar.getTimeInMillis() >= endTime.getTime()) {
+                            break;
+                        }
+                        CoursePackageScheduling coursePackageScheduling = new CoursePackageScheduling();
+                        coursePackageScheduling.setCoursePackageId(tCoursePackage.getId());
+                        Date parse = format1.parse(format.format(time) + " " + split[j]);
+                        Date parse1 = format1.parse(format.format(time) + " " + split1[j]);
+                        coursePackageScheduling.setClassDate(parse);
+                        coursePackageScheduling.setEndDate(parse1);
+                        coursePackageScheduling.setStatus(1);
+                        coursePackageSchedulingService.save(coursePackageScheduling);
+                        CoursePackageStudent student1 = new CoursePackageStudent();
+                        student1.setAppUserId(userId);
+                        student1.setStudentId(sId);
+                        student1.setCoursePackageId(tCoursePackage.getId());
+                        student1.setCoursePackagePaymentId(coursePackageOrderStudent.getId());
+                        student1.setCoursePackageSchedulingId(coursePackageScheduling.getId());
+                        student1.setSignInOrNot(1);
+                        student1.setReservationStatus(1);
+                        student1.setInsertTime(new Date());
+                        cpsMapper.insert(student1);
+
+                        //增加日期,用于判断
+                        calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1);
+                    }
+                }
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
     }
 
 
@@ -1904,40 +1409,39 @@
         return calendar.getTime();
     }
 
-    private List<Integer> week(String week){
+    private List<Integer> week(String week) {
         String[] split = week.split(";");
         ArrayList<Integer> integers = new ArrayList<>();
         for (String s : split) {
-                switch (s){
-                    case "周一":
-                        integers.add(1);
-                        break;
-                    case "周二":
-                        integers.add(2);
-                        break;
-                    case "周三":
-                        integers.add(3);
-                        break;
-                    case "周四":
-                        integers.add(4);
-                        break;
-                    case "周五":
-                        integers.add(5);
-                        break;
-                    case "周六":
-                        integers.add(6);
-                        break;
-                    case "周日":
-                        integers.add(7);
-                        break;
+            switch (s) {
+                case "周一":
+                    integers.add(1);
+                    break;
+                case "周二":
+                    integers.add(2);
+                    break;
+                case "周三":
+                    integers.add(3);
+                    break;
+                case "周四":
+                    integers.add(4);
+                    break;
+                case "周五":
+                    integers.add(5);
+                    break;
+                case "周六":
+                    integers.add(6);
+                    break;
+                case "周日":
+                    integers.add(7);
+                    break;
             }
         }
         return integers;
     }
 
 
-
-    public static Date[] generateDateArray(int numDays,Date date) {
+    public static Date[] generateDateArray(int numDays, Date date) {
 //        LocalDate tomorrow = LocalDate.now().plusDays(1);
         LocalDate tomorrow = date.toInstant().atZone(ZoneId.systemDefault()).toLocalDate().plusDays(1);
 
@@ -1950,8 +1454,10 @@
 
         return dates;
     }
+
     /**
      * 获取课包管理列表数据
+     *
      * @param queryCoursePackageLists
      * @return
      */
@@ -1967,14 +1473,14 @@
             boolean coin = false;
             List<CoursePackagePaymentConfig> coursePackagePaymentConfigs = coursePackagePaymentConfigService.list(new QueryWrapper<CoursePackagePaymentConfig>().eq("coursePackageId", id));
             for (CoursePackagePaymentConfig coursePackagePaymentConfig : coursePackagePaymentConfigs) {
-                if(0 != coursePackagePaymentConfig.getCashPayment()){
+                if (0 != coursePackagePaymentConfig.getCashPayment()) {
                     cash = true;
                 }
-                if(0 != coursePackagePaymentConfig.getPlayPaiCoin()){
+                if (0 != coursePackagePaymentConfig.getPlayPaiCoin()) {
                     coin = true;
                 }
             }
-            map.put("payType", (cash ? "现金支付" : "") + (coin ?  cash ? "&玩湃币支付" : "玩湃币支付" : ""));
+            map.put("payType", (cash ? "现金支付" : "") + (coin ? cash ? "&玩湃币支付" : "玩湃币支付" : ""));
         }
         return list;
     }
@@ -1982,6 +1488,7 @@
 
     /**
      * 添加课包
+     *
      * @param coursePackage
      * @return
      */
@@ -1991,7 +1498,7 @@
 
             this.baseMapper.insert(coursePackage);
 
-            if (coursePackage.getClassStartTime()!=null&&coursePackage.getClassStartTime()!="") {
+            if (coursePackage.getClassStartTime() != null && coursePackage.getClassStartTime() != "") {
                 //生成排课数据
                 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
                 SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
@@ -2062,7 +1569,7 @@
             }
 
             return coursePackage.getId();
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return null;
         }
@@ -2071,6 +1578,7 @@
 
     /**
      * 修改数据
+     *
      * @param coursePackage
      */
     @Override
@@ -2080,7 +1588,7 @@
             List<Long> collect = coursePackageStudents.stream().map(CoursePackageStudent::getCoursePackageSchedulingId).collect(Collectors.toList());
 
             QueryWrapper<CoursePackageScheduling> coursePackageSchedulingQueryWrapper = new QueryWrapper<CoursePackageScheduling>().eq("coursePackageId", coursePackage.getId());
-            if(collect.size() > 0){
+            if (collect.size() > 0) {
                 coursePackageSchedulingQueryWrapper.notIn("id", collect);
             }
             coursePackageSchedulingService.remove(coursePackageSchedulingQueryWrapper);
@@ -2092,9 +1600,9 @@
             SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
             SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
             CoursePackageScheduling coursePackageScheduling = coursePackageSchedulingService.getOne(new QueryWrapper<CoursePackageScheduling>().eq("coursePackageId", coursePackage.getId()).last(" and classDate > now() order by classDate desc limit 0, 1"));
-            if(null != coursePackageScheduling){
+            if (null != coursePackageScheduling) {
                 date = sdf1.parse(sdf.format(coursePackageScheduling.getClassDate()) + " 00:00:00");
-            }else{
+            } else {
                 date = sdf1.parse(sdf.format(new Date()) + " 00:00:00");
             }
             List<String> list = Arrays.asList(coursePackage.getClassWeeks().split(";"));
@@ -2108,19 +1616,19 @@
 
             Calendar e = Calendar.getInstance();
             e.setTime(date);
-            if(null != coursePackageScheduling){
+            if (null != coursePackageScheduling) {
                 long time = sdf1.parse(sdf.format(new Date()) + " 00:00:00").getTime();
                 int d = Long.valueOf(14L - ((s.getTimeInMillis() - time) / 86400000L)).intValue();
                 e.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + d);
-            }else{
+            } else {
                 e.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 14);
             }
             long timeInMillis = e.getTimeInMillis();
 
-            while (true){
+            while (true) {
                 int w = s.get(Calendar.DAY_OF_WEEK);
                 WeekEnum weekEnum = WeekEnum.getWeekEnum(w);
-                if(list.contains(weekEnum.getChineseName())){
+                if (list.contains(weekEnum.getChineseName())) {
                     Calendar classDate = Calendar.getInstance();
                     classDate.setTime(s.getTime());
                     classDate.set(Calendar.HOUR_OF_DAY, Integer.valueOf(split[0]));
@@ -2141,11 +1649,11 @@
                     coursePackageSchedulingService.save(coursePackageScheduling1);
                 }
                 s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 1);
-                if(s.getTimeInMillis() > timeInMillis){
+                if (s.getTimeInMillis() > timeInMillis) {
                     break;
                 }
             }
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
         }
     }
@@ -2153,6 +1661,7 @@
 
     /**
      * 获取课包审核列表
+     *
      * @param page
      * @param queryExamineCoursePackageLists
      * @return
@@ -2166,14 +1675,14 @@
             boolean coin = false;
             List<CoursePackagePaymentConfig> coursePackagePaymentConfigs = coursePackagePaymentConfigService.list(new QueryWrapper<CoursePackagePaymentConfig>().eq("coursePackageId", id));
             for (CoursePackagePaymentConfig coursePackagePaymentConfig : coursePackagePaymentConfigs) {
-                if(0 != coursePackagePaymentConfig.getCashPayment()){
+                if (0 != coursePackagePaymentConfig.getCashPayment()) {
                     cash = true;
                 }
-                if(0 != coursePackagePaymentConfig.getPlayPaiCoin()){
+                if (0 != coursePackagePaymentConfig.getPlayPaiCoin()) {
                     coin = true;
                 }
             }
-            map.put("payType", (cash ? "现金支付" : "") + (coin ?  cash ? "&玩湃币支付" : "玩湃币支付" : ""));
+            map.put("payType", (cash ? "现金支付" : "") + (coin ? cash ? "&玩湃币支付" : "玩湃币支付" : ""));
         }
         return list;
     }
@@ -2200,7 +1709,7 @@
 
 
         if (CollectionUtil.isNotEmpty(coupons)) {
-            for (Coupon coupon : coupons){
+            for (Coupon coupon : coupons) {
                 Date date1 = coupon.getStartTime(); // 2023-10-01 00:00:00
                 Date date2 = coupon.getEndTime(); // 2023-10-12 00:00:00
 

--
Gitblit v1.7.1