From eb6b6dbb35a9f029e0b7d269773685c19fd40976 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期四, 11 七月 2024 10:47:51 +0800
Subject: [PATCH] 玩湃微信商户认证代码

---
 cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java | 2262 +++++++++++++++++++++++++++++++++++------------------------
 1 files changed, 1,336 insertions(+), 926 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 ced476d..736c129 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
@@ -1,13 +1,15 @@
 package com.dsh.course.service.impl;
 
-import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.collection.CollectionUtil;
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.alipay.api.AlipayApiException;
 import com.alipay.api.AlipayClient;
 import com.alipay.api.DefaultAlipayClient;
-import com.alipay.api.domain.*;
+import com.alipay.api.domain.AlipayTradeOrderSettleModel;
+import com.alipay.api.domain.OpenApiRoyaltyDetailInfoPojo;
+import com.alipay.api.domain.RoyaltyDetailInfos;
 import com.alipay.api.request.AlipayTradeOrderSettleRequest;
 import com.alipay.api.request.AlipayTradeRoyaltyRelationBindRequest;
 import com.alipay.api.response.AlipayTradeOrderSettleResponse;
@@ -21,7 +23,6 @@
 import com.dsh.course.feignclient.account.StudentClient;
 import com.dsh.course.feignclient.account.model.AppUser;
 import com.dsh.course.feignclient.account.model.Student;
-import com.dsh.course.feignclient.account.model.TCourseInfoRecord;
 import com.dsh.course.feignclient.activity.CouponClient;
 import com.dsh.course.feignclient.activity.UserCouponClient;
 import com.dsh.course.feignclient.activity.model.Coupon;
@@ -37,12 +38,14 @@
 import com.dsh.course.util.*;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+
 import javax.annotation.Resource;
 import java.math.BigDecimal;
 import java.math.RoundingMode;
 import java.text.ParseException;
 import java.text.SimpleDateFormat;
 import java.time.LocalDate;
+import java.time.Period;
 import java.time.ZoneId;
 import java.util.*;
 import java.util.stream.Collectors;
@@ -58,6 +61,16 @@
 @Service
 public class TCoursePackageServiceImpl extends ServiceImpl<TCoursePackageMapper, TCoursePackage> implements TCoursePackageService {
 
+    private String aliAppid = "2021004105665036";//支付宝appid
+
+    private String appPrivateKey = "MIIEvwIBADANBgkqhkiG9w0BAQEFAASCBKkwggSlAgEAAoIBAQCi5i9nW/hGLJ3A06cZxTQdviFC7THpdSihoTYGLr9q006hu0V26ecBMY/o4w5bvIX0Ok/yofmZsVcCJpAPvbXL/uqVrIjnRRxXiaeBFThlxoBUTdunvbUSDYfzlEhJr5NvUKI6H6lz2niXlQGx4qy8Hau4ccWit9kM8jwUvsBVQoFgJA+xrjMvooA7YLopQtpOD+UJr5thApTSf1xrnr1W12yolTLEH15JmNV372cqXrYUuqnY0QsaPtxeqJUGAOcGdVLllQ7easEznP8DFBvDdHATcmp2SHNQDUEWN6MCVPbMgY06NQVqAXxqjTAYSVh+6TRu6bofPmpYC3TZB003AgMBAAECggEBAJAcR2+PA3NBYUYHeFrqBRMS8uX8ZR19kjZ7IgoSLTFaQsP9opRylPSPXhrPVBKAE5leRQAHn4MCSlESwHvMfxo7KFjFTFAc6dffZZpipYQUOc9bGampwJh58/3e/pyBgVMG6J23CPf/HJQtNFSkjd/V9+ayb/9l2dUEL3bC0fAZ/dbx8HsxdLw8wn3fLlWLj68hOMqa2deCZe3JdSVsPbeWqkh56FFsMLug0Nd+Ar4TgRl9/jnhXF0JWiD0LmPUYLhboY7EfUBzN4w1iYbDi1P+3zvoOYsiVKAXox9GMhQ2VzOO2UcSTuizSza2e98mGpabl/GpKmCz+RDFjtkX6eECgYEA2MyCij65eO3aGIm3FUe93DULRBYTfX8qJQSJq2WOWA3mmQlEW6L3O2B5/lG2h+8WmN6iLEs9eHpgycGYp7vAqgrANEn16ACVcuyx0scFtrZfZ+kmHMzFfiUWxJjVYk/6YngsGVBLdw6ueM42C8TTP67X9tU5TdVGoGWuqEj4W98CgYEAwFqwprXOch5Pqk/RPbb49r0Ou03K/UbciWnWWKzUhFFNS8MdlQPoDvQZbMwHLeWsa2VhaKITK3x5biLQb3U+0GLOn6lTvEyrEUH+ucREyLgVYTRAvwBPtnvlrzpyxPk2HnslQjju8WrvvLLBMKWUjlTrTOzhaHT21gz3pHMiOakCgYEAhLmfaXdBITGshb054sNLDtdCkGpbgEcrzAHdLps769iGxkYQHXHFngpQZUwtTUcoNGqIKknd1jZFrv7gsD+XkgKG7PwimehRlkwmCX5ilxtLiVgJRzRt6+5U5AMVD90a0tHzXYP0z2yjj73fBJF5KtGl0a10KZxaYrQdm1UhB00CgYBZZgzx/k9rtHC8LAqIj1CYhHejT92G53c6Gkl3vyOqN4sgKhfGmSEySfrDGPRBPZxr8ZtbIPCd5mUdberH0osWGMYFaJI1UsCy7aQwvGpniz7MhZeN7dweaOjwDs8mgtjHQ96mL4XGCDhR0BZ/wIURvZ/6iaGdhbbu9unlsWj3uQKBgQCmZYdsbbZkd3ev6f8rwyvMz+DrCQyYpY44cegBYuJgrZiQnL2fJioeN7ixX0UM48SfwsZEIrzshP/LGAwnc2MdjxKUl4jLN8SEe0NAjXOnz9Zaw740+aOmLpXcLWdP4uM2gIhWsvW1tEkQZCXmm7c9s/RsU8Pmzv+YL3+fSijOzA==";//支付宝开发者应用私钥
+
+    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";//支付宝支付公钥
+
+
+
     @Resource
     private StoreClient storeClient;
 
@@ -69,6 +82,9 @@
 
     @Autowired
     private ICoursePackagePaymentConfigService coursePackagePaymentConfigService;
+
+    @Autowired
+    private CourseCounsumService courseCounsumService;
 
     @Autowired
     private TCoursePackageDiscountService coursePackageDiscountService;
@@ -96,14 +112,19 @@
     @Resource
     private CoursePackageStudentMapper cpsMapper;
 
+    @Autowired
+    private ICoursePackageOrderStudentService coursePackageOrderStudentService;
 
-    private String aliAppid = "2021004105665036";//支付宝appid
+    @Autowired
+    private ICoursePackageOrderService coursePackageOrderService;
 
-    private String appPrivateKey = "MIIEvwIBADANBgkqhkiG9w0BAQEFAASCBKkwggSlAgEAAoIBAQCi5i9nW/hGLJ3A06cZxTQdviFC7THpdSihoTYGLr9q006hu0V26ecBMY/o4w5bvIX0Ok/yofmZsVcCJpAPvbXL/uqVrIjnRRxXiaeBFThlxoBUTdunvbUSDYfzlEhJr5NvUKI6H6lz2niXlQGx4qy8Hau4ccWit9kM8jwUvsBVQoFgJA+xrjMvooA7YLopQtpOD+UJr5thApTSf1xrnr1W12yolTLEH15JmNV372cqXrYUuqnY0QsaPtxeqJUGAOcGdVLllQ7easEznP8DFBvDdHATcmp2SHNQDUEWN6MCVPbMgY06NQVqAXxqjTAYSVh+6TRu6bofPmpYC3TZB003AgMBAAECggEBAJAcR2+PA3NBYUYHeFrqBRMS8uX8ZR19kjZ7IgoSLTFaQsP9opRylPSPXhrPVBKAE5leRQAHn4MCSlESwHvMfxo7KFjFTFAc6dffZZpipYQUOc9bGampwJh58/3e/pyBgVMG6J23CPf/HJQtNFSkjd/V9+ayb/9l2dUEL3bC0fAZ/dbx8HsxdLw8wn3fLlWLj68hOMqa2deCZe3JdSVsPbeWqkh56FFsMLug0Nd+Ar4TgRl9/jnhXF0JWiD0LmPUYLhboY7EfUBzN4w1iYbDi1P+3zvoOYsiVKAXox9GMhQ2VzOO2UcSTuizSza2e98mGpabl/GpKmCz+RDFjtkX6eECgYEA2MyCij65eO3aGIm3FUe93DULRBYTfX8qJQSJq2WOWA3mmQlEW6L3O2B5/lG2h+8WmN6iLEs9eHpgycGYp7vAqgrANEn16ACVcuyx0scFtrZfZ+kmHMzFfiUWxJjVYk/6YngsGVBLdw6ueM42C8TTP67X9tU5TdVGoGWuqEj4W98CgYEAwFqwprXOch5Pqk/RPbb49r0Ou03K/UbciWnWWKzUhFFNS8MdlQPoDvQZbMwHLeWsa2VhaKITK3x5biLQb3U+0GLOn6lTvEyrEUH+ucREyLgVYTRAvwBPtnvlrzpyxPk2HnslQjju8WrvvLLBMKWUjlTrTOzhaHT21gz3pHMiOakCgYEAhLmfaXdBITGshb054sNLDtdCkGpbgEcrzAHdLps769iGxkYQHXHFngpQZUwtTUcoNGqIKknd1jZFrv7gsD+XkgKG7PwimehRlkwmCX5ilxtLiVgJRzRt6+5U5AMVD90a0tHzXYP0z2yjj73fBJF5KtGl0a10KZxaYrQdm1UhB00CgYBZZgzx/k9rtHC8LAqIj1CYhHejT92G53c6Gkl3vyOqN4sgKhfGmSEySfrDGPRBPZxr8ZtbIPCd5mUdberH0osWGMYFaJI1UsCy7aQwvGpniz7MhZeN7dweaOjwDs8mgtjHQ96mL4XGCDhR0BZ/wIURvZ/6iaGdhbbu9unlsWj3uQKBgQCmZYdsbbZkd3ev6f8rwyvMz+DrCQyYpY44cegBYuJgrZiQnL2fJioeN7ixX0UM48SfwsZEIrzshP/LGAwnc2MdjxKUl4jLN8SEe0NAjXOnz9Zaw740+aOmLpXcLWdP4uM2gIhWsvW1tEkQZCXmm7c9s/RsU8Pmzv+YL3+fSijOzA==";//支付宝开发者应用私钥
+    @Autowired
+    private TOrderService orderService;
+    @Autowired
+    private TCoursePackageService coursePackageService;
 
-    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";//支付宝支付公钥
+    @Resource
+    private CoursePackageStudentMapper coursePackageStudentMapper;
 
 
     @Override
@@ -114,6 +135,7 @@
 
     /**
      * 获取课程列表
+     *
      * @param coursePackageList
      * @return
      * @throws Exception
@@ -121,32 +143,32 @@
     @Override
     public List<CoursePackageListVo> queryCourseList(Integer uid, CoursePackageList coursePackageList) throws Exception {
         AppUser appUser = appUserClient.queryAppUser(uid);
-        Map<String, String> geocode = gdMapGeocodingUtil.geocode(coursePackageList.getLon(), coursePackageList.getLat());
-        String provinceCode = geocode.get("provinceCode");
-        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);
-
         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);
             }
         }
-        List<TCoursePackage> list = this.list(wrapper.last(" order by sort desc, insertTime desc"));
+        List<TCoursePackage> list1 = this.list(wrapper.last(" order by sort desc, insertTime desc"));
+        Date currentTime = new Date();
+
+        List<TCoursePackage> list = list1.stream()
+                .filter(coursePackage -> coursePackage.getType() != 2 || currentTime.before(coursePackage.getEndTime()))
+                .collect(Collectors.toList());
+
         List<CoursePackageListVo> listVos = new ArrayList<>();
         for (TCoursePackage coursePackage : list) {
             Store store = storeClient.queryStoreById(coursePackage.getStoreId());
@@ -165,9 +187,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);
                 }
             }
@@ -175,126 +197,125 @@
             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));
-                Double vipPrice = coursePackagePaymentConfig.getCashPayment();
-                for (TCoursePackageDiscount coursePackageDiscount : list2) {
-                    Double num1 = JSON.parseObject(coursePackageDiscount.getContent()).getDouble("discountMember");
-                    if(vipPrice.compareTo(num1) > 0){
-                        vipPrice = num1;
-                    }
+//            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;
                 }
-                coursePackageListVo.setVipPrice(vipPrice);
+            }
+            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));
-                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);
-            }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){
-                        vipPrice = num1;
-                    }
-                }
-                coursePackageListVo.setPaymentPrice(vipPrice);
+            }
+            coursePackageListVo.setPaymentPrice(paymentPrice);
+
+            if (coursePackageListVo.getPaymentPrice() < coursePackageListVo.getVipPrice()) {
                 coursePackageListVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
             }
+
+            if (appUser.getIsVip() == 1) {
+                if (coursePackageListVo.getVipPrice() < coursePackageListVo.getPaymentPrice()) {
+                    coursePackageListVo.setPaymentPrice(coursePackageListVo.getVipPrice());
+                }
+            } else {
+                coursePackageListVo.setVipPrice(null);
+            }
+
 
             Map<String, Double> distance = GeodesyUtil.getDistance(coursePackageList.getLon() + "," + coursePackageList.getLat(), store.getLon() + "," + store.getLat());
             coursePackageListVo.setDistance(distance.get("WGS84") / 1000);
@@ -302,24 +323,43 @@
         }
 
         //销量排行
-        if(ToolUtil.isNotEmpty(coursePackageList.getSalesRanking())){
+        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());
                 }
             });
         }
+
+
+        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());
+                }
+            });
+        }
+
+
         //距离排行
-        if(ToolUtil.isNotEmpty(coursePackageList.getDistanceSort())){
+        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")) {
+            Collections.sort(listVos, new Comparator<CoursePackageListVo>() {
+                public int compare(CoursePackageListVo s1, CoursePackageListVo s2) {
+                    return Double.compare(s2.getDistance(), s1.getDistance());
+                }
+            });
+        }
+
+
         return listVos;
     }
-
 
 
     @Override
@@ -330,20 +370,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);
             }
         }
@@ -358,7 +398,18 @@
             coursePackageListVo.setId(coursePackage.getId());
             coursePackageListVo.setName(coursePackage.getName());
             coursePackageListVo.setStoreName(null != store ? store.getName() : "");
+//            coursePackageListVo.setPayType();
             coursePackageListVo.setCoverDrawing(coursePackage.getCoverDrawing());
+
+            Double cashPayment1 = coursePackagePaymentConfig.getCashPayment();
+            Integer playPaiCoin = coursePackagePaymentConfig.getPlayPaiCoin();
+            if (ToolUtil.isNotEmpty(cashPayment1) && cashPayment1 > 0 && ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin > 0) {
+                coursePackageListVo.setPayType(3);
+            } else if (ToolUtil.isNotEmpty(cashPayment1) && cashPayment1 > 0) {
+                coursePackageListVo.setPayType(1);
+            } else if (ToolUtil.isNotEmpty(playPaiCoin) && playPaiCoin > 0) {
+                coursePackageListVo.setPayType(2);
+            }
 
             // 2.0修改
             String classStartTime = coursePackage.getClassStartTime();
@@ -367,12 +418,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);
@@ -380,13 +430,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;
                     }
                 }
@@ -420,19 +470,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;
                                 }
 
@@ -452,30 +502,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;
                     }
                 }
@@ -489,7 +539,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());
@@ -497,7 +547,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());
@@ -510,199 +560,237 @@
 
     /**
      * 获取课包详情
+     *
      * @param uid
      * @param id
      * @return
      * @throws Exception
      */
     @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);
+    public CoursePackageInfo queryCourseInfo(Integer uid, Integer id, String lon, String lat, Integer stuId) throws Exception {
+        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));
+
+        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.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);
             }
 
-            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);
+            //会员显示原价和支付价(会员价)。非会员显示会员价和支付价(最低)
+//                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;
                 }
             }
-
-            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;
-                                    }
+            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);
-                }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){
-                            vipPrice = num1;
-                        }
-                    }
-                    coursePackagePaymentConfigVo.setPaymentPrice(vipPrice);
+                }
+            }
+            coursePackagePaymentConfigVo.setPaymentPrice(paymentPrice);
+
+
+//                    TCoursePackageDiscount discount = coursePackageDiscountService.getOne(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
+//                            .eq("type", 2).eq("auditStatus", 2));
+//
+//
+//                    //这里是续课优惠
+//                    Double continuingMember = JSON.parseObject(discount.getContent()).getDouble("continuingUser");
+//                    Double vipcontinuingMember = JSON.parseObject(discount.getContent()).getDouble("continuingMember");
+//
+//
+//                    if (coursePackagePaymentConfigVo.getPaymentPrice()>continuingMember){
+//                        coursePackagePaymentConfigVo.setPaymentPrice(continuingMember);
+//                    }
+//                    if (coursePackagePaymentConfigVo.getVipPrice()>vipcontinuingMember){
+//                        coursePackagePaymentConfigVo.setVipPrice(vipcontinuingMember);
+//                    }
+            if (appUser.getIsVip() == 1) {
+                if (coursePackagePaymentConfigVo.getVipPrice() < coursePackagePaymentConfigVo.getPaymentPrice()) {
+                    coursePackagePaymentConfigVo.setPaymentPrice(coursePackagePaymentConfigVo.getVipPrice());
                     coursePackagePaymentConfigVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
                 }
-                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;
+
+            if (coursePackagePaymentConfigVo.getPaymentPrice() < coursePackagePaymentConfigVo.getVipPrice()) {
+                coursePackagePaymentConfigVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
+                coursePackagePaymentConfigVo.setVipPrice(null);
+            }
+
+
+//                }
+//                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){
+//                            vipPrice = num1;
+//                        }
+//                    }
+//                    coursePackagePaymentConfigVo.setPaymentPrice(vipPrice);
+//                    coursePackagePaymentConfigVo.setOriginalPrice(coursePackagePaymentConfig.getCashPayment());
+//                }
+            list.add(coursePackagePaymentConfigVo);
+        });
+        coursePackageInfo.setList(list);
+
+        StudentVo studentVo = new StudentVo();
+        Student student = null;
+        if(null != stuId){
+            student = studentClient.queryStudentById(stuId);
+        }else{
+            student = studentClient.queryDefaultStudent(uid);
+        }
+        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
@@ -711,101 +799,97 @@
     @Override
     public ResultUtil paymentCourse(Integer uid, PaymentCourseVo paymentCourseVo) throws Exception {
         AppUser appUser = appUserClient.queryAppUser(uid);
-        CoursePackageInfo coursePackageInfo = queryCourseInfo(uid, paymentCourseVo.getId(), null, null);
+        CoursePackageInfo coursePackageInfo = queryCourseInfo(uid, paymentCourseVo.getId(), null, null, null);
         //校验是否已经报满
         Integer integer = coursePackagePaymentService.queryCountNumber(paymentCourseVo.getId());
         TCoursePackage course = coursePackageService.getById(paymentCourseVo.getId());
-        if (integer>=course.getMaxSubscribeNumber()){
-            return ResultUtil.error("报名失败,已达最大报名人数");
+        if (course.getType() == 1) {
+
+            if (integer + paymentCourseVo.getStudentIds().split(";").length > course.getMaxSubscribeNumber()) {
+                return ResultUtil.error("报名失败,已达最大报名人数");
+            }
         }
-
-
-
         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("支付方式错误,请刷新后重试");
                     }
                 }
-
                 Double paymentPrice = coursePackagePaymentConfigVo.getPaymentPrice();//支付价
                 paymentPrice = new BigDecimal(students.length).multiply(new BigDecimal(paymentPrice)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
                 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){
-                    return ResultUtil.error("支付金额异常,请刷新后重试");
-                }
-                if(paymentCourseVo.getPayType() == 3 && playPaiCoin.compareTo(paymentCourseVo.getPrice()) != 0){
+
+                if (paymentCourseVo.getPayType() == 3 && playPaiCoin.compareTo(paymentCourseVo.getPrice()) != 0) {
                     return ResultUtil.error("支付金额异常,请刷新后重试");
                 }
             }
         }
-
         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){
-                return ResultUtil.error("优惠券已被核销");
+            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);
+
         }
 
-        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);
@@ -818,65 +902,68 @@
 
     /**
      * 课程微信支付
+     *
      * @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);
+        Long orderId = paymentCourseVo.getOrderId();
+        if(null == orderId){
+            //生成支付订单
+            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.setStatus(1);
+            coursePackageOrder.setState(1);
+            coursePackageOrder.setInsertTime(new Date());
+            coursePackageOrderService.save(coursePackageOrder);
+            orderId = coursePackageOrder.getId();
+        }else{
+            CoursePackageOrder coursePackageOrder = coursePackageOrderService.getById(orderId);
+            code = coursePackageOrder.getCode();
+            coursePackageOrder.setPayType(1);
+            coursePackageOrder.setAppUserId(null);
+            coursePackageOrder.setPayUserType(1);
+            coursePackageOrder.setPayUserId(uid);
+            coursePackageOrderService.updateById(coursePackageOrder);
         }
 
-        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) {
+            String finalCode = code;
             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", finalCode).eq("state", 1));
+                            if (coursePackageOrder1.getPayStatus() == 2) {
                                 break;
                             }
-                            ResultUtil<Map<String, String>> resultUtil = payMoneyUtil.queryWXOrder(code, "");
-                            if(resultUtil.getCode() == 200 && one.getPayStatus() == 1){
+                            ResultUtil<Map<String, String>> resultUtil = payMoneyUtil.queryWXOrder(finalCode, "");
+                            if (resultUtil.getCode() == 200 && coursePackageOrder1.getPayStatus() == 1) {
                                 /**
                                  * SUCCESS—支付成功,
                                  * REFUND—转入退款,
@@ -889,31 +976,29 @@
                                 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()));
+                                if ("SUCCESS".equals(s)) {
+                                    coursePackageOrder1.setPayStatus(2);
+                                    coursePackageOrder1.setOrderNumber(transaction_id);
+                                    coursePackageOrder1.setAppUserId(null);
+                                    coursePackageOrderService.updateById(coursePackageOrder1);
+                                    //修改课时有效期
 
-                                    addPackageStudent(paymentCourseVo.getId(),uid, finalSid,one.getId());
+
+                                    addCoursePackageOrderStudent(coursePackageOrder1.getId(), coursePackagePaymentConfig);
                                     break;
                                 }
-                                if("USERPAYING".equals(s)){
+                                if ("USERPAYING".equals(s)) {
                                     num++;
                                 }
                             }
                         }
-                    }catch (Exception e){
+                    } catch (Exception e) {
                         e.printStackTrace();
                     }
                 }
@@ -922,69 +1007,85 @@
         return weixinpay;
     }
 
-
+    private String smid = "2088330203191220";//平台支付宝商户号
     /**
      * 课程支付宝支付
+     *
      * @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);
-        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);
+        String smid1="";
+        //生成支付订单
+        if (paymentCourseVo.getOrderId()==null){
+            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.setStatus(1);
+            coursePackageOrder.setState(1);
+            coursePackageOrder.setInsertTime(new Date());
+            coursePackageOrderService.save(coursePackageOrder);
+        }else {
+            CoursePackageOrder coursePackageOrder = coursePackageOrderService.getById(paymentCourseVo.getOrderId());
+            code = coursePackageOrder.getCode();
+            coursePackageOrder.setPayType(2);
+            coursePackageOrder.setAppUserId(null);
+            coursePackageOrder.setPayUserType(1);
+            coursePackageOrder.setPayUserId(uid);
+            coursePackageOrderService.updateById(coursePackageOrder);
         }
-
-        Student student = studentClient.queryDefaultStudent(uid);
-        Integer sid=null;
-        if(student!=null){
-            sid=student.getId();
+        // 判断这个课包属于哪个门店 属于哪个运营商 根据运营商 id 获取对应的商户号
+        Integer coursePackageId = paymentCourseVo.getId();
+        TCoursePackage byId = coursePackageService.getById(coursePackageId);
+        Store store = storeClient.queryStoreById(byId.getStoreId());
+        if (store.getOperatorId() == null){
+            smid1 = smid;
+        }else{
+            if (store.getOperatorId()==0){
+                smid1 = smid;
+            }else{
+                smid1 = storeClient.getSMIDByOperatorId(store.getOperatorId());
+            }
         }
-
-        ResultUtil alipay = payMoneyUtil.alipay("购买课程", "购买课程", student.getId().toString(), code, paymentPrice.toString(), "/base/course/aliPaymentCourseCallback");
-        if(alipay.getCode() == 200){
-            Integer finalSid = sid;
+        ResultUtil alipay = payMoneyUtil.alipay(smid1,"购买课程", "购买课程",
+                coursePackagePaymentConfig.getId().toString(),
+                code, paymentPrice.toString(), "/base/course/aliPaymentCourseCallback");
+        if (alipay.getCode() == 200) {
+            String finalCode = code;
             new Thread(new Runnable() {
                 @Override
                 public void run() {
                     try {
+                        Thread.sleep(1000);
                         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);
-                            if(one.getPayStatus() == 2){
+                            CoursePackageOrder coursePackageOrder1 = coursePackageOrderService.getOne(new QueryWrapper<CoursePackageOrder>()
+                                    .eq("code", finalCode).eq("state", 1));
+                            if (coursePackageOrder1.getPayStatus() == 2) {
                                 break;
                             }
-                            AlipayTradeQueryResponse alipayTradeQueryResponse = payMoneyUtil.queryALIOrder(code);
-                            if( one.getPayStatus() == 1){
+                            AlipayTradeQueryResponse alipayTradeQueryResponse = payMoneyUtil.queryALIOrder(finalCode);
+                            if (null != alipayTradeQueryResponse) {
                                 /**
                                  * WAIT_BUYER_PAY(交易创建,等待买家付款)、
                                  * TRADE_CLOSED(未付款交易超时关闭,或支付完成后全额退款)、
@@ -994,46 +1095,51 @@
                                 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);
+                                if ("TRADE_SUCCESS".equals(s)) {
+                                    coursePackageOrder1.setPayStatus(2);
+                                    coursePackageOrder1.setOrderNumber(tradeNo);
+                                    coursePackageOrder1.setAppUserId(null);
+                                    coursePackageOrderService.updateById(coursePackageOrder1);
+                                    addCoursePackageOrderStudent(coursePackageOrder1.getId(), coursePackagePaymentConfig);
+                                    moneyOut(tradeNo,tradeNo,finalCode);
+                                    // 根据课程id 查询这个课程属于哪个门店 属于哪个运营商
+                                    Integer id = paymentCourseVo.getId();
+                                    TCoursePackage byId = coursePackageService.getById(id);
+                                    Integer storeId = byId.getStoreId();
+                                    Store store = storeClient.queryStoreById(storeId);
+                                    Integer operatorId = store.getOperatorId();
+                                    if (operatorId==null){
+                                        String smid ="2088330203191220";
+                                            // 说明是平台的 不走分账
+//                                            payMoneyUtil.confirm(smid,finalCode,tradeNo,paymentPrice.toString());
+                                        payMoneyUtil.confirm1(smid,finalCode,tradeNo,paymentPrice.toString());
+                                        break;
+                                    }else if (operatorId==0){
+                                        String smid ="2088330203191220";
+                                        // 说明是平台的
+                                        payMoneyUtil.confirm1(smid,finalCode,tradeNo,paymentPrice.toString());
+                                        break;
+                                    }else{
+                                        // 当前课程不属于门店 查询这个课程属于哪个门店 属于哪个运营商
+                                        String smidByOperatorId = storeClient.getSMIDByOperatorId(operatorId);
+                                        payMoneyUtil.confirm(smidByOperatorId,finalCode,tradeNo,paymentPrice.toString());
+                                        // 分账处理
+                                        extracted(store, coursePackageOrder1, tradeNo);
+                                        break;
                                     }
-                                    coursePackagePaymentService.updateBatchById(list);
-                                System.out.println("===========到达支付");
-                                    // 2.0
-                                    String[] coupons = coursePackagePaymentConfig.getCouponIds().split(",");
-
-
-
-                                    userCouponClient.sendUserCoupon(new SendCouponReq(uid,coursePackagePaymentConfig.getCouponIds()));
-
-
-                                    moneyOut(tradeNo,tradeNo);
-
-
-
-
-                                    if(student!=null){
-
-                                    }
-                                    addPackageStudent(paymentCourseVo.getId(),uid, finalSid,one.getId());
-                                    break;
                                 }
-                                if("WAIT_BUYER_PAY".equals(s)){
+                                if ("WAIT_BUYER_PAY".equals(s)) {
                                     num++;
                                 }
                             }
                         }
-                    }catch (Exception e){
+                    } catch (Exception e) {
                         e.printStackTrace();
                     }
                 }
@@ -1042,394 +1148,685 @@
         return alipay;
     }
 
-
-    @Autowired
-    private TCoursePackageService coursePackageService;
-    public void moneyOut(String outNum,String tradeNo) throws AlipayApiException {
+    private void extracted(Store store, CoursePackageOrder coursePackageOrder1, String tradeNo) throws Exception {
+        // 分账
+        AlipayClient alipayClient = new DefaultAlipayClient("https://openapi.alipay.com/gateway.do",
+                "2021004105665036",
+                "MIIEvwIBADANBgkqhkiG9w0BAQEFAASCBKkwggSlAgEAAoIBAQCi5i9nW/hGLJ3A06cZxTQdviFC7THpdSihoTYGLr9q006hu0V26ecBMY/o4w5bvIX0Ok/yofmZsVcCJpAPvbXL/uqVrIjnRRxXiaeBFThlxoBUTdunvbUSDYfzlEhJr5NvUKI6H6lz2niXlQGx4qy8Hau4ccWit9kM8jwUvsBVQoFgJA+xrjMvooA7YLopQtpOD+UJr5thApTSf1xrnr1W12yolTLEH15JmNV372cqXrYUuqnY0QsaPtxeqJUGAOcGdVLllQ7easEznP8DFBvDdHATcmp2SHNQDUEWN6MCVPbMgY06NQVqAXxqjTAYSVh+6TRu6bofPmpYC3TZB003AgMBAAECggEBAJAcR2+PA3NBYUYHeFrqBRMS8uX8ZR19kjZ7IgoSLTFaQsP9opRylPSPXhrPVBKAE5leRQAHn4MCSlESwHvMfxo7KFjFTFAc6dffZZpipYQUOc9bGampwJh58/3e/pyBgVMG6J23CPf/HJQtNFSkjd/V9+ayb/9l2dUEL3bC0fAZ/dbx8HsxdLw8wn3fLlWLj68hOMqa2deCZe3JdSVsPbeWqkh56FFsMLug0Nd+Ar4TgRl9/jnhXF0JWiD0LmPUYLhboY7EfUBzN4w1iYbDi1P+3zvoOYsiVKAXox9GMhQ2VzOO2UcSTuizSza2e98mGpabl/GpKmCz+RDFjtkX6eECgYEA2MyCij65eO3aGIm3FUe93DULRBYTfX8qJQSJq2WOWA3mmQlEW6L3O2B5/lG2h+8WmN6iLEs9eHpgycGYp7vAqgrANEn16ACVcuyx0scFtrZfZ+kmHMzFfiUWxJjVYk/6YngsGVBLdw6ueM42C8TTP67X9tU5TdVGoGWuqEj4W98CgYEAwFqwprXOch5Pqk/RPbb49r0Ou03K/UbciWnWWKzUhFFNS8MdlQPoDvQZbMwHLeWsa2VhaKITK3x5biLQb3U+0GLOn6lTvEyrEUH+ucREyLgVYTRAvwBPtnvlrzpyxPk2HnslQjju8WrvvLLBMKWUjlTrTOzhaHT21gz3pHMiOakCgYEAhLmfaXdBITGshb054sNLDtdCkGpbgEcrzAHdLps769iGxkYQHXHFngpQZUwtTUcoNGqIKknd1jZFrv7gsD+XkgKG7PwimehRlkwmCX5ilxtLiVgJRzRt6+5U5AMVD90a0tHzXYP0z2yjj73fBJF5KtGl0a10KZxaYrQdm1UhB00CgYBZZgzx/k9rtHC8LAqIj1CYhHejT92G53c6Gkl3vyOqN4sgKhfGmSEySfrDGPRBPZxr8ZtbIPCd5mUdberH0osWGMYFaJI1UsCy7aQwvGpniz7MhZeN7dweaOjwDs8mgtjHQ96mL4XGCDhR0BZ/wIURvZ/6iaGdhbbu9unlsWj3uQKBgQCmZYdsbbZkd3ev6f8rwyvMz+DrCQyYpY44cegBYuJgrZiQnL2fJioeN7ixX0UM48SfwsZEIrzshP/LGAwnc2MdjxKUl4jLN8SEe0NAjXOnz9Zaw740+aOmLpXcLWdP4uM2gIhWsvW1tEkQZCXmm7c9s/RsU8Pmzv+YL3+fSijOzA==",
+                "json", "GBK",
+                "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAmu8n/4yTHWbn7VOrNc9OsLtDL1bEQ8gC1dHkj8Wy5z0mkaOsjJRIG/28ze12M0V8jdCKuuDr5Z1OPKiqf+XO3ypguEh+mYUVMBM/cZodDFQfTY1TKLWjvQCuaqlA+QUTCK6f7T7stsgyQ1o9Jj0rXZDz6PM4QHSTzjrLIBaeqM5WIBvH+fy/X+QG5Utd+/UT0kc0JyvuKhZ65yVUd/C9VcwJJAPliRsAQNrqYterwAJ9zvw9tF11wj9W0XgJ8Ccu4x3gR1vrlLRJJo/OA97RmxPQ+5hSacWQZCUd1dwiBq+YCrKVHGTj14izRHXrLc0yBlRXo7tBOIqcy3IsvKVthQIDAQAB",
+                "RSA2");
+        AlipayTradeOrderSettleRequest request = new AlipayTradeOrderSettleRequest();
+        String randomCode = UUIDUtil.getRandomCode(16);
+        String proportionByOperatorId = storeClient.getProportionByOperatorId(store.getOperatorId());
+        // 支付宝分账比例
+        String s1 = proportionByOperatorId.split(",")[1];
+        double i = Double.parseDouble(s1);
+        double v = i * 0.01;
+        BigDecimal bigDecimal1 = new BigDecimal(String.valueOf(v));
+        BigDecimal cashPayment = coursePackageOrder1.getCashPayment();
+        // 分账金额
+        BigDecimal bigDecimal2 = cashPayment.multiply(bigDecimal1).setScale(2, RoundingMode.DOWN);
+        request.setBizContent("{" +
+                "  \"out_request_no\":\"" + randomCode + "\"," +
+                "  \"trade_no\":\"" + tradeNo + "\"," +
+                "  \"royalty_parameters\":[" +
+                "    {" +
+                "      \"royalty_type\":\"transfer\"," +
+                "      \"trans_out\":\"" + storeClient.getSMIDByOperatorId(store.getOperatorId()) + "\"," +
+                "      \"trans_out_type\":\"userId\"," +
+                "      \"trans_in_type\":\"userId\"," +
+                "      \"trans_in\":\"" + smid + "\"," +
+                "      \"amount\":" + bigDecimal2 + "," +
+                "      \"desc\":\"平台服务费\"," +
+                "      \"royalty_scene\":\"平台服务费\"," +
+                "    }" +
+                "  ]," +
+                "  \"extend_params\":{" +
+                "    \"royalty_finish\":\"true\"" +
+                "  }," +
+                "  \"royalty_mode\":\"async\"" +
+                "}");
+        AlipayTradeOrderSettleResponse response = alipayClient.execute(request);
+        if (response.isSuccess()) {
+            System.out.println("调用成功");
+        } else {
+            System.out.println("调用失败");
+        }
+    }
+    //分账
+    public void moneyOut(String outNum, String tradeNo,String code) 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();
 //
-
-        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("调用失败");
-        }
+//
+//        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");
+//
+        CoursePackageOrder one = coursePackageOrderService.getOne(new QueryWrapper<CoursePackageOrder>().eq("code", code));
+        TCoursePackage coursePackage = coursePackageService.getById(one.getCoursePackageId());
+        OperatorUser operatorUser = storeClient.queryByStoreId(coursePackage.getStoreId());
+        if (operatorUser!=null) {
+            if(one.getPayType()==2){
 
-//        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");
+            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()));
+//            op.setTransInType("loginName");
+//        op.setTransIn("19522115070");
+            op.setTransIn(operatorUser.getAlipayNum());
+            op.setAmountPercentage(Long.valueOf(operatorUser.getAlipayProportion()));
 
-        List<OpenApiRoyaltyDetailInfoPojo> ops = new ArrayList<>();
-        ops.add(op);
-        model.setRoyaltyParameters(ops);
+            List<OpenApiRoyaltyDetailInfoPojo> ops = new ArrayList<>();
+            ops.add(op);
+            model.setRoyaltyParameters(ops);
 
-        request.setBizModel(model);
+            request.setBizModel(model);
 
 
-        AlipayTradeOrderSettleResponse response1 = alipayClient.execute(request);
-        if(response1.isSuccess()){
-            System.out.println("调用成功");
-        } else {
-            System.out.println("调用失败");
+            AlipayTradeOrderSettleResponse response1 = alipayClient.execute(request);
+            if (response1.isSuccess()) {
+                System.out.println("调用成功");
+            } else {
+                System.out.println("调用失败");
+            }
+            }
         }
     }
 
 
-
-
     /**
      * 玩湃币支付课程
+     *
      * @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);
-        for (String s : split) {
-
-            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());
-            coursePackagePayment.setOriginalPrice(paymentCourseVo.getPrice());
-            coursePackagePayment.setPlayPaiCoin(paymentPrice.intValue());
-            coursePackagePayment.setTotalClassHours(coursePackagePaymentConfig.getClassHours());
-            coursePackagePayment.setLaveClassHours(coursePackagePaymentConfig.getClassHours());
-            coursePackagePayment.setAbsencesNumber(0);
-            coursePackagePayment.setPayUserType(1);
-            coursePackagePayment.setPayStatus(2);
-            coursePackagePayment.setPayUserId(appUser.getId());
-            coursePackagePayment.setStatus(1);
-            coursePackagePayment.setState(1);
-            coursePackagePayment.setInsertTime(new 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());
-        }
-
+    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);
+        Long orderId = paymentCourseVo.getOrderId();
+        if(null == orderId){
+            //生成支付订单
+            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.setPlayPaiCoin(paymentCourseVo.getPrice().intValue());
+            coursePackageOrder.setPayUserType(1);
+            coursePackageOrder.setPayStatus(2);
+            coursePackageOrder.setPayUserId(appUser.getId());
+            coursePackageOrder.setStatus(1);
+            coursePackageOrder.setState(1);
+            coursePackageOrder.setInsertTime(new Date());
+            coursePackageOrderService.save(coursePackageOrder);
+            orderId = coursePackageOrder.getId();
+        }else{
+            CoursePackageOrder coursePackageOrder = coursePackageOrderService.getById(orderId);
+            coursePackageOrder.setPayType(3);
+            coursePackageOrder.setAppUserId(null);
+            coursePackageOrder.setPayUserId(appUser.getId());
+            coursePackageOrder.setPayUserType(1);
+            coursePackageOrder.setPayStatus(2);
+            coursePackageOrderService.updateById(coursePackageOrder);
         }
+
+        addCoursePackageOrderStudent(orderId, coursePackagePaymentConfig);
         return ResultUtil.success();
     }
 
 
-
-
-
-    private void addPackageStudent(Integer courseId, Integer userId, Integer sId,Long paymentId) throws ParseException {
-        // 课包
-        TCoursePackage tCoursePackage = this.baseMapper.selectById(courseId);
-        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());
-        //拿到最后一天的排课记录
-
-        CoursePackageScheduling cs = null;
-        if (collect.size()>0) {
-             cs = coursePackageSchedulingService.getOne(new QueryWrapper<CoursePackageScheduling>().in("id", collect).orderByDesc("classDate").last("limit 1"));
-
+    /**
+     * 购买课程支付成功后的回调处理
+     *
+     * @param code
+     * @param trade_no
+     * @return
+     */
+    @Override
+    public ResultUtil paymentCourseCallback(String code, String trade_no, String attach) throws AlipayApiException {
+        CoursePackageOrder coursePackageOrder1 = coursePackageOrderService.getOne(new QueryWrapper<CoursePackageOrder>()
+                .eq("code", code).eq("state", 1));
+        if (coursePackageOrder1.getPayStatus() == 2) {
+            return ResultUtil.success();
         }
-        int i = -1;
+        coursePackageOrder1.setPayStatus(2);
+        coursePackageOrder1.setOrderNumber(trade_no);
+        coursePackageOrder1.setAppUserId(null);
+        coursePackageOrderService.updateById(coursePackageOrder1);
 
-//        Calendar calendar = Calendar.getInstance();
-//        Date currentDate = calendar.getTime();
-//        calendar.add(Calendar.DAY_OF_MONTH, -1);
-//        Date today = calendar.getTime();
-        Date today = new Date();
+        CoursePackagePaymentConfig coursePackagePaymentConfig = coursePackagePaymentConfigService.getById(attach);
+        addCoursePackageOrderStudent(coursePackageOrder1.getId(), coursePackagePaymentConfig);
+        moneyOut(trade_no,trade_no,code);
+        return ResultUtil.success();
+    }
 
-        //判断最后一天是否超过当前日期
-        if (cs==null||cs.getClassDate().before(new Date())){
-            i = DateUtil.dayOfWeek(new Date())-1;
-        }else {
-            i = DateUtil.dayOfWeek(cs.getClassDate())-1;
-            today = cs.getClassDate();
+
+    /**
+     * 支付成功后添加学员课时数据
+     *
+     * @param coursePackagePaymentConfig
+     */
+    @Override
+    public void addCoursePackageOrderStudent(Long coursePackageOrderId, CoursePackagePaymentConfig coursePackagePaymentConfig) {
+        CoursePackageOrder coursePackageOrder = coursePackageOrderService.getById(coursePackageOrderId);
+        // 发放优惠券
+        userCouponClient.sendUserCoupon(new SendCouponReq(coursePackageOrder.getAppUserId(), coursePackagePaymentConfig.getCouponIds()));
+
+        //开始处理学员课程课时记录和排课数据
+        TCoursePackage coursePackage = coursePackageService.getById(coursePackageOrder.getCoursePackageId());
+        String[] split = coursePackageOrder.getStudentIds().split(";");
+        for (String id : split) {
+            if(coursePackage.getType() == 1){
+                //增加学员课时有效期
+                Student student = studentClient.queryStudentById(Integer.valueOf(id));
+                CoursePackageOrderStudent coursePackageOrderStudent = coursePackageOrderStudentService.getOne(new QueryWrapper<CoursePackageOrderStudent>().eq("studentId", id)
+                        .eq("coursePackageId", coursePackageOrder.getCoursePackageId()).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());
+                    coursePackageOrderStudentService.saveOrUpdate(coursePackageOrderStudent);
+
+                    //更新学员课时有效期
+                    if(null == student.getValidity()){
+                        student.setValidity(calendar.getTime());
+                        addOldPackageStudent(student);
+                    }else if(calendar.getTimeInMillis() > student.getValidity().getTime()){
+                        student.setValidity(calendar.getTime());
+                        addOldPackageStudent(student);
+                    }
+                    studentClient.frozen(student);
+
+                    //开始排课
+                    addPackageStudent(coursePackage, coursePackageOrder.getAppUserId(), Integer.valueOf(id), coursePackageOrderStudent, student.getValidity());
+
+                    //课时记录
+                    CourseCounsum courseCounsum = new CourseCounsum();
+                    courseCounsum.setPaymentId(coursePackageOrderStudent.getId());
+                    courseCounsum.setChangeType(1);
+                    courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
+                    courseCounsum.setInsertTime(new Date());
+                    courseCounsum.setReason("购买课包");
+                    courseCounsumService.save(courseCounsum);
+                    //账单记录
+                    if(coursePackageOrder.getPayType() != 3){
+                        CourseCounsum courseCounsum1 = new CourseCounsum();
+                        courseCounsum1.setPaymentId(coursePackageOrder.getId());
+                        courseCounsum1.setChangeType(3);
+                        courseCounsum1.setInsertTime(new Date());
+                        courseCounsum1.setReason("报名课程;"+coursePackageOrder.getCashPayment());
+                        courseCounsum1.setAppUserId(coursePackageOrder.getAppUserId());
+                        courseCounsumService.save(courseCounsum1);
+                    }
+                } else {
+                    Date useTime = coursePackageOrderStudent.getUseTime();
+                    coursePackageOrderStudent.setTotalClassHours(coursePackageOrderStudent.getTotalClassHours() + coursePackagePaymentConfig.getClassHours());
+                    coursePackageOrderStudent.setLaveClassHours(coursePackageOrderStudent.getLaveClassHours() + coursePackagePaymentConfig.getClassHours());
+                    coursePackageOrderStudent.setStatus(1);
+                    coursePackageOrderStudent.setInsertTime(new Date());
+                    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());
+                    coursePackageOrderStudentService.saveOrUpdate(coursePackageOrderStudent);
+                    //更新学员课时有效期
+                    if(null == student.getValidity()){
+                        student.setValidity(calendar.getTime());
+                        addOldPackageStudent(student);
+                    }else if(calendar.getTimeInMillis() > student.getValidity().getTime()){
+                        student.setValidity(calendar.getTime());
+                        addOldPackageStudent(student);
+                    }
+                    studentClient.frozen(student);
+
+                    //中间断课,没有连续续费的情况需要重新排课
+                    if (useTime.compareTo(new Date()) < 0) {
+                        addPackageStudent(coursePackage, coursePackageOrder.getAppUserId(), Integer.valueOf(id), coursePackageOrderStudent, student.getValidity());
+                    }
+
+                    //课时记录
+                    CourseCounsum courseCounsum = new CourseCounsum();
+                    courseCounsum.setPaymentId(coursePackageOrderStudent.getId());
+                    courseCounsum.setChangeType(1);
+                    courseCounsum.setNum(coursePackagePaymentConfig.getClassHours());
+                    courseCounsum.setInsertTime(new Date());
+                    courseCounsum.setReason("续课");
+                    courseCounsumService.save(courseCounsum);
+                    //账单记录
+                    if(coursePackageOrder.getPayType() != 3){
+                        CourseCounsum courseCounsum1 = new CourseCounsum();
+                        courseCounsum1.setPaymentId(coursePackageOrder.getId());
+                        courseCounsum1.setChangeType(3);
+                        courseCounsum1.setInsertTime(new Date());
+                        courseCounsum1.setReason("续课;"+coursePackageOrder.getCashPayment());
+                        courseCounsum1.setAppUserId(coursePackageOrder.getAppUserId());
+                        courseCounsumService.save(courseCounsum1);
+                    }
+                }
+            }
+            if(coursePackage.getType() == 2){
+                addPackageStudent(coursePackage, coursePackageOrder.getAppUserId(), Integer.valueOf(id), null, null);
+            }
         }
+    }
 
 
-        TCoursePackagePayment pay = coursePackagePaymentService.getById(paymentId);
-        Integer laveClassHours = pay.getLaveClassHours();
-        Integer codeTime = tCoursePackage.getCodeTime();
-        Integer can = 0;
+    /**
+     * 新购买课程后的排课
+     *
+     * @param userId
+     * @param sId
+     * @throws ParseException
+     */
+    private void addPackageStudent(TCoursePackage tCoursePackage, Integer userId, Integer sId, CoursePackageOrderStudent coursePackageOrderStudent, Date validity) {
+        try {
+            //1常规 2假期 3体验
+            if (tCoursePackage.getType() == 1) {
+                //上课星期
+                String classWeeks = tCoursePackage.getClassWeeks();
+                List<Integer> week = week(classWeeks);
+                CoursePackageScheduling one = coursePackageSchedulingService.getOne(new QueryWrapper<CoursePackageScheduling>()
+                        .eq("studentId", sId)
+                        .eq("coursePackageId", tCoursePackage.getId())
+                        .eq("status", 1)
+                        .orderByDesc("classDate")
+                        .last(" limit 0, 1")
+                );
+                if(null != one){
+                    //先检测是否需要继续进行排课
+                    Calendar calendar1 = Calendar.getInstance();
+                    calendar1.setTime(one.getClassDate());
+                    int day_week1 = calendar1.get(Calendar.DAY_OF_WEEK);
+                    day_week1 = day_week1 - 1 == 0 ? 7 : day_week1 - 1;
+                    int week_of_month = calendar1.get(Calendar.WEEK_OF_MONTH);
 
+                    Calendar calendar2 = Calendar.getInstance();
+                    calendar2.setTime(new Date());
+                    int week_of_month1 = calendar2.get(Calendar.WEEK_OF_MONTH);
 
-        int count = 0;
+                    //最后一次的排课时间不在本周,且是一周的最后一天。(如果是本周则表明已经课时用完了)
+                    if(week.get(week.size() - 1).equals(day_week1) && week_of_month != week_of_month1){
+                        return;
+                    }
+                }
 
-        // 本周周几
-//        int i = DateUtil.dayOfWeek(new Date())-1;
+                //上课时段
+                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[] 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;
-        }
+                //剩余课时
+                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;
 
-        for (Date date : dates) {
-            if (count==can){
-                     break;
-                  }
-                int wei =  DateUtil.dayOfWeek(date);
-            if (week.contains(wei)){
-                for (int i1 = 0; i1 < split.length; i1++) {
-                    if (count==can){
+                for (int i = 0; i < num; i++) {
+                    Date time = calendar.getTime();
+
+                    //判断当天是否在排课星期内
+                    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() >= validity.getTime()) {
                         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);
+                    }
+
+                    //检查是否有体验购课
+                    int count = coursePackageSchedulingService.count(new QueryWrapper<CoursePackageScheduling>()
+                            .eq("type", 3)
+                            .eq("appUserId", userId)
+                            .eq("studentId", sId)
+                            .eq("coursePackageId", tCoursePackage.getId())
+                            .eq("status", 1)
+                            .eq("DATE_FORMAT(classDate, '%Y-%m-%d')", format.format(time))
+                    );
+                    //有体验购课,不进行排课
+                    if(count != 0){
+                        calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1);
+                        continue;
+                    }
+
+                    for (int j = 0; j < split.length; j++) {
+                        //剩余数量不足以排课
+                        if (laveClassHours.compareTo(codeTime) < 0) {
+                            break;
+                        }
+
+                        laveClassHours -= codeTime;
+
+                        CoursePackageScheduling coursePackageScheduling = new CoursePackageScheduling();
+                        coursePackageScheduling.setType(tCoursePackage.getType());
+                        coursePackageScheduling.setAppUserId(userId);
+                        coursePackageScheduling.setStudentId(sId);
+                        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());
+                calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1);
+                while (true) {
+                    Date time = calendar.getTime();
+
+                    //判断当天是否在排课星期内
+                    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;
+                    }
+                    for (int j = 0; j < split.length; j++) {
+                        CoursePackageScheduling coursePackageScheduling = new CoursePackageScheduling();
+                        coursePackageScheduling.setType(tCoursePackage.getType());
+                        coursePackageScheduling.setAppUserId(userId);
+                        coursePackageScheduling.setStudentId(sId);
+                        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(null);
+                        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();
+        }
+    }
+
+
+    /**
+     * 课时有效期更新后-更新历史排课数据(因有效期限制的排课数据,还有剩余课时)
+     * @param student
+     */
+    public void addOldPackageStudent(Student student){
+        Integer studentId = student.getId();
+        Date validity = student.getValidity();
+        List<CoursePackageOrderStudent> list = coursePackageOrderStudentService.list(new QueryWrapper<CoursePackageOrderStudent>()
+                .eq("studentId", studentId)
+                .eq("status", 1)
+                .gt("laveClassHours", 0)
+                .eq("state", 1)
+        );
+        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+        SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+        for (CoursePackageOrderStudent coursePackageOrderStudent : list) {
+            TCoursePackage coursePackage = coursePackageService.getById(coursePackageOrderStudent.getCoursePackageId());
+            CoursePackageScheduling one = coursePackageSchedulingService.getOne(new QueryWrapper<CoursePackageScheduling>()
+                    .eq("studentId", studentId)
+                    .eq("coursePackageId", coursePackageOrderStudent.getCoursePackageId())
+                    .eq("status", 1)
+                    .orderByDesc("classDate")
+                    .last(" limit 0, 1")
+            );
+
+            Calendar calendar = Calendar.getInstance();
+            //上课星期
+            String classWeeks = coursePackage.getClassWeeks();
+            List<Integer> week = week(classWeeks);
+
+            Integer laveClassHours = coursePackageOrderStudent.getLaveClassHours();
+            Integer codeTime = coursePackage.getCodeTime();
+            String classStartTime = coursePackage.getClassStartTime();
+            String classEndTime = coursePackage.getClassEndTime();
+            String[] split = classStartTime.split(",");
+            String[] split1 = classEndTime.split(",");
+
+            if(null == one){
+                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);
+            }else{
+                String format = sdf1.format(one.getClassDate());
+                String time = format.substring(format.indexOf(" ") + 1);
+                int n = Arrays.asList(split).indexOf(time);
+                if(n != split.length - 1){
+                    calendar.setTime(one.getClassDate());
+                    //单独处理当天的剩余时间段
+                    n++;
+                    for (int i = n; i < split.length; i++) {
+                        //剩余数量不足以排课
+                        if (laveClassHours.compareTo(codeTime) < 0) {
+                            break;
+                        }
+                        laveClassHours -= codeTime;
+                        CoursePackageScheduling packageScheduling = new CoursePackageScheduling();
+                        packageScheduling.setType(coursePackage.getType());
+                        packageScheduling.setAppUserId(coursePackageOrderStudent.getAppUserId());
+                        packageScheduling.setStudentId(coursePackageOrderStudent.getStudentId());
+                        packageScheduling.setCoursePackageId(coursePackage.getId());
+                        try {
+                            Date parse = sdf.parse(format.format(time) + " " + split[i]);
+                            Date parse1 = sdf.parse(format.format(time) + " " + split1[i]);
+                            packageScheduling.setClassDate(parse);
+                            packageScheduling.setEndDate(parse1);
+                        }catch (Exception e){
+                            e.printStackTrace();
+                        }
+                        packageScheduling.setStatus(1);
+                        coursePackageSchedulingService.save(packageScheduling);
+                        CoursePackageStudent student1 = new CoursePackageStudent();
+                        student1.setAppUserId(coursePackageOrderStudent.getAppUserId());
+                        student1.setStudentId(coursePackageOrderStudent.getStudentId());
+                        student1.setCoursePackageId(coursePackage.getId());
+                        student1.setCoursePackagePaymentId(coursePackageOrderStudent.getId());
+                        student1.setCoursePackageSchedulingId(packageScheduling.getId());
+                        student1.setSignInOrNot(1);
+                        student1.setReservationStatus(1);
+                        student1.setInsertTime(new Date());
+                        coursePackageStudentMapper.insert(student1);
+                    }
+
+                }else{
+                    //先检测是否需要继续进行排课
+                    Calendar calendar1 = Calendar.getInstance();
+                    calendar1.setTime(one.getClassDate());
+                    int day_week1 = calendar1.get(Calendar.DAY_OF_WEEK);
+                    day_week1 = day_week1 - 1 == 0 ? 7 : day_week1 - 1;
+                    int week_of_month = calendar1.get(Calendar.WEEK_OF_MONTH);
+
+                    Calendar calendar2 = Calendar.getInstance();
+                    calendar2.setTime(new Date());
+                    int week_of_month1 = calendar2.get(Calendar.WEEK_OF_MONTH);
+
+                    //最后一次的排课时间不在本周,且是一周的最后一天。(如果是本周则表明已经课时用完了)
+                    if(week.get(week.size() - 1).equals(day_week1) && week_of_month != week_of_month1){
+                        break;
+                    }
+                }
+
+                calendar.setTime(one.getClassDate());
+                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;
+            for (int i = 0; i < num; i++) {
+                Date time1 = calendar.getTime();
+
+                //判断当天是否在排课星期内
+                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() >= validity.getTime()) {
+                    break;
+                }
+                for (int j = 0; j < split.length; j++) {
+                    //剩余数量不足以排课
+                    if (laveClassHours.compareTo(codeTime) < 0) {
+                        break;
+                    }
+
+                    laveClassHours -= codeTime;
+
+                    CoursePackageScheduling packageScheduling = new CoursePackageScheduling();
+                    packageScheduling.setType(coursePackage.getType());
+                    packageScheduling.setAppUserId(coursePackageOrderStudent.getAppUserId());
+                    packageScheduling.setStudentId(coursePackageOrderStudent.getStudentId());
+                    packageScheduling.setCoursePackageId(coursePackage.getId());
+                    try {
+                        Date parse = sdf1.parse(sdf.format(time1) + " " + split[j]);
+                        Date parse1 = sdf1.parse(sdf.format(time1) + " " + split1[j]);
+                        packageScheduling.setClassDate(parse);
+                        packageScheduling.setEndDate(parse1);
+                    }catch (Exception e){
+                        e.printStackTrace();
+                    }
+                    packageScheduling.setStatus(1);
+                    coursePackageSchedulingService.save(packageScheduling);
                     CoursePackageStudent student1 = new CoursePackageStudent();
-                    student1.setAppUserId(userId);
-                    student1.setStudentId(sId);
-                    student1.setCoursePackageId(tCoursePackage.getId());
-                    student1.setCoursePackagePaymentId(paymentId);
-                    student1.setCoursePackageSchedulingId(coursePackageScheduling.getId());
+                    student1.setAppUserId(coursePackageOrderStudent.getAppUserId());
+                    student1.setStudentId(coursePackageOrderStudent.getStudentId());
+                    student1.setCoursePackageId(coursePackage.getId());
+                    student1.setCoursePackagePaymentId(coursePackageOrderStudent.getId());
+                    student1.setCoursePackageSchedulingId(packageScheduling.getId());
                     student1.setSignInOrNot(1);
                     student1.setReservationStatus(1);
                     student1.setInsertTime(new Date());
-                    cpsMapper.insert(student1);
-                    count++;
+                    coursePackageStudentMapper.insert(student1);
                 }
+                //增加日期,用于判断
+                calendar.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1);
             }
         }
-
-
-
-
-//        for (Integer integer : week) {
-//            if (count==can){
-//                break;
-//            }
-//            if(integer<i){
-//                // 找下一周的时间
-//                Calendar instance = Calendar.getInstance();
-//                if (cs==null||cs.getClassDate().before(new Date())){
-//                    instance = Calendar.getInstance();
-//                }else {
-////                    i = DateUtil.dayOfWeek(cs.getClassDate())-1;
-//                    instance.setTime(cs.getClassDate());
-//                }
-//                instance.add(Calendar.DATE,7-(i-integer));
-//                Date time = instance.getTime();
-//
-//                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(time) + " " + split[i1]);
-//                        Date parse1 = format1.parse(format.format(time) + " " + 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(integer>i) {
-//                if (count==can){
-//                    break;
-//                }
-//
-////                Calendar instance = Calendar.getInstance();
-//
-//                Calendar instance = Calendar.getInstance();
-//                if (cs==null||cs.getClassDate().before(new Date())){
-//                    instance = Calendar.getInstance();
-//                }else {
-////                    i = DateUtil.dayOfWeek(cs.getClassDate())-1;
-//                    instance.setTime(cs.getClassDate());
-//                }
-//                instance.add(Calendar.DATE,integer-i);
-//                Date time1 = instance.getTime();
-//                List<Date> list = new ArrayList<>();
-//                list.add(time1);
-//                instance.add(Calendar.DATE,7);
-//                Date time2 = instance.getTime();
-//                list.add(time2);
-//                for (Date time : list) {
-//                    for (int i1 = 0; i1 < split.length; i1++) {
-//                        CoursePackageScheduling coursePackageScheduling = new CoursePackageScheduling();
-//                        coursePackageScheduling.setCoursePackageId(tCoursePackage.getId());
-//                                                    Date parse = format1.parse(format.format(time) + " " + split[i1]);
-//                            Date parse1 = format1.parse(format.format(time) + " " + 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 {
-////                Calendar instance = Calendar.getInstance();
-//                Calendar instance = Calendar.getInstance();
-//                if (cs==null||cs.getClassDate().before(new Date())){
-//                    instance = Calendar.getInstance();
-//                }else {
-////                    i = DateUtil.dayOfWeek(cs.getClassDate())-1;
-//                    instance.setTime(cs.getClassDate());
-//                }
-//                instance.add(Calendar.DATE,7);
-//                Date time = instance.getTime();
-//
-//                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(time) + " " + split[i1]);
-//                        Date parse1 = format1.parse(format.format(time) + " " + 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++;
-//
-//                }
-//            }
-//        }
-        // 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);
-
-
     }
+
 
 
     public static Date[] generateDateArray1(Date startDate, Date endDate) {
@@ -1452,40 +1849,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);
 
@@ -1498,8 +1894,10 @@
 
         return dates;
     }
+
     /**
      * 获取课包管理列表数据
+     *
      * @param queryCoursePackageLists
      * @return
      */
@@ -1515,14 +1913,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;
     }
@@ -1530,16 +1928,16 @@
 
     /**
      * 添加课包
+     *
      * @param coursePackage
      * @return
      */
     @Override
     public Integer addCoursePackage(TCoursePackage coursePackage) {
         try {
-
+            coursePackage.setInsertTime(new Date());
             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");
@@ -1610,97 +2008,104 @@
             }
 
             return coursePackage.getId();
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return null;
         }
     }
 
 
+    @Autowired
+    private ICoursePackageOrderStudentService orderStudentService;
     /**
      * 修改数据
+     *
      * @param coursePackage
      */
     @Override
     public void updateCoursePackageById(TCoursePackage coursePackage) {
-        try {
-            List<CoursePackageStudent> coursePackageStudents = coursePackageStudentService.list(new QueryWrapper<CoursePackageStudent>().eq("coursePackageId", coursePackage.getId()));
-            List<Long> collect = coursePackageStudents.stream().map(CoursePackageStudent::getCoursePackageSchedulingId).collect(Collectors.toList());
+//        try {
+//            List<CoursePackageStudent> coursePackageStudents = coursePackageStudentService.list(new QueryWrapper<CoursePackageStudent>().eq("coursePackageId", coursePackage.getId()));
+//            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) {
+//                coursePackageSchedulingQueryWrapper.notIn("id", collect);
+//            }
+//            coursePackageSchedulingService.remove(coursePackageSchedulingQueryWrapper);
+//            int coursePackageId = orderStudentService.count(new QueryWrapper<CoursePackageOrderStudent>().eq("coursePackageId", coursePackage.getId()));
+//            if (coursePackageId>0) {
+                this.baseMapper.updateById(coursePackage);
 
-            QueryWrapper<CoursePackageScheduling> coursePackageSchedulingQueryWrapper = new QueryWrapper<CoursePackageScheduling>().eq("coursePackageId", coursePackage.getId());
-            if(collect.size() > 0){
-                coursePackageSchedulingQueryWrapper.notIn("id", collect);
-            }
-            coursePackageSchedulingService.remove(coursePackageSchedulingQueryWrapper);
-
-            this.baseMapper.updateById(coursePackage);
-
-            //生成排课数据
-            Date date = null;
-            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){
-                date = sdf1.parse(sdf.format(coursePackageScheduling.getClassDate()) + " 00:00:00");
-            }else{
-                date = sdf1.parse(sdf.format(new Date()) + " 00:00:00");
-            }
-            List<String> list = Arrays.asList(coursePackage.getClassWeeks().split(";"));
-            String classStartTime = coursePackage.getClassStartTime();
-            String[] split = classStartTime.split(":");
-            String classEndTime = coursePackage.getClassEndTime();
-            String[] split1 = classEndTime.split(":");
-            Calendar s = Calendar.getInstance();
-            s.setTime(date);
-            s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 1);
-
-            Calendar e = Calendar.getInstance();
-            e.setTime(date);
-            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{
-                e.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 14);
-            }
-            long timeInMillis = e.getTimeInMillis();
-
-            while (true){
-                int w = s.get(Calendar.DAY_OF_WEEK);
-                WeekEnum weekEnum = WeekEnum.getWeekEnum(w);
-                if(list.contains(weekEnum.getChineseName())){
-                    Calendar classDate = Calendar.getInstance();
-                    classDate.setTime(s.getTime());
-                    classDate.set(Calendar.HOUR_OF_DAY, Integer.valueOf(split[0]));
-                    classDate.set(Calendar.MINUTE, Integer.valueOf(split[1]));
-                    classDate.set(Calendar.SECOND, 0);
-
-                    Calendar endDate = Calendar.getInstance();
-                    endDate.setTime(s.getTime());
-                    endDate.set(Calendar.HOUR_OF_DAY, Integer.valueOf(split1[0]));
-                    endDate.set(Calendar.MINUTE, Integer.valueOf(split1[1]));
-                    endDate.set(Calendar.SECOND, 0);
-
-                    CoursePackageScheduling coursePackageScheduling1 = new CoursePackageScheduling();
-                    coursePackageScheduling1.setCoursePackageId(coursePackage.getId());
-                    coursePackageScheduling1.setClassDate(classDate.getTime());
-                    coursePackageScheduling1.setEndDate(endDate.getTime());
-                    coursePackageScheduling1.setStatus(1);
-                    coursePackageSchedulingService.save(coursePackageScheduling1);
-                }
-                s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 1);
-                if(s.getTimeInMillis() > timeInMillis){
-                    break;
-                }
-            }
-        }catch (Exception e){
-            e.printStackTrace();
-        }
+                //生成排课数据
+//                Date date = null;
+//                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) {
+//                    date = sdf1.parse(sdf.format(coursePackageScheduling.getClassDate()) + " 00:00:00");
+//                } else {
+//                    date = sdf1.parse(sdf.format(new Date()) + " 00:00:00");
+//                }
+//                List<String> list = Arrays.asList(coursePackage.getClassWeeks().split(";"));
+//                String classStartTime = coursePackage.getClassStartTime();
+//                String[] split = classStartTime.split(":");
+//                String classEndTime = coursePackage.getClassEndTime();
+//                String[] split1 = classEndTime.split(":");
+//                Calendar s = Calendar.getInstance();
+//                s.setTime(date);
+//                s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 1);
+//
+//                Calendar e = Calendar.getInstance();
+//                e.setTime(date);
+//                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 {
+//                    e.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 14);
+//                }
+//                long timeInMillis = e.getTimeInMillis();
+//
+//                while (true) {
+//                    int w = s.get(Calendar.DAY_OF_WEEK);
+//                    WeekEnum weekEnum = WeekEnum.getWeekEnum(w);
+//                    if (list.contains(weekEnum.getChineseName())) {
+//                        Calendar classDate = Calendar.getInstance();
+//                        classDate.setTime(s.getTime());
+//                        classDate.set(Calendar.HOUR_OF_DAY, Integer.valueOf(split[0]));
+//                        classDate.set(Calendar.MINUTE, Integer.valueOf(split[1]));
+//                        classDate.set(Calendar.SECOND, 0);
+//
+//                        Calendar endDate = Calendar.getInstance();
+//                        endDate.setTime(s.getTime());
+//                        endDate.set(Calendar.HOUR_OF_DAY, Integer.valueOf(split1[0]));
+//                        endDate.set(Calendar.MINUTE, Integer.valueOf(split1[1]));
+//                        endDate.set(Calendar.SECOND, 0);
+//
+//                        CoursePackageScheduling coursePackageScheduling1 = new CoursePackageScheduling();
+//                        coursePackageScheduling1.setCoursePackageId(coursePackage.getId());
+//                        coursePackageScheduling1.setClassDate(classDate.getTime());
+//                        coursePackageScheduling1.setEndDate(endDate.getTime());
+//                        coursePackageScheduling1.setStatus(1);
+//                        coursePackageSchedulingService.save(coursePackageScheduling1);
+//                    }
+//                    s.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 1);
+//                    if (s.getTimeInMillis() > timeInMillis) {
+//                        break;
+//                    }
+//                }
+//            }
+//        } catch (Exception e) {
+//            e.printStackTrace();
+//        }
     }
+
 
 
     /**
      * 获取课包审核列表
+     *
      * @param page
      * @param queryExamineCoursePackageLists
      * @return
@@ -1714,14 +2119,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;
     }
@@ -1732,28 +2137,33 @@
     }
 
     @Override
-    public Integer getHours(Integer coursePackageId) {
+    public List<Integer> getHours(Integer coursePackageId) {
         return this.baseMapper.getHours(coursePackageId);
     }
 
     @Override
     public ResultUtil paymentCourseCouponList(Integer uid, Integer coursePackagePaymentConfigId) {
-        CoursePackagePaymentConfig coursePackagePaymentConfig = coursePackagePaymentConfigService.getById(coursePackagePaymentConfigId);
-        if(ToolUtil.isEmpty(coursePackagePaymentConfig.getCouponIds())){
-            coursePackagePaymentConfig.setCouponIds("-1");
-        }
-        List<Coupon> coupons = couponClient.getCoupons(coursePackagePaymentConfig.getCouponIds());
+//        CoursePackagePaymentConfig coursePackagePaymentConfig = coursePackagePaymentConfigService.getById(coursePackagePaymentConfigId);
+//        if(ToolUtil.isEmpty(coursePackagePaymentConfig.getCouponIds())){
+//            coursePackagePaymentConfig.setCouponIds("-1");
+//        }
+//        List<Coupon> coupons = couponClient.getCoupons(coursePackagePaymentConfig.getCouponIds());
 
-        for (Coupon coupon : coupons) {
-            Date date1 = coupon.getStartTime(); // 2023-10-01 00:00:00
-            Date date2 = coupon.getEndTime(); // 2023-10-12 00:00:00
+        List<Coupon> coupons = couponClient.queryCouponByUid(uid);
 
-            SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
-            String dateString1 = sdf.format(date1);
-            String dateString2 = sdf.format(date2);
 
-            String result = dateString1 + "-" + dateString2;
-            coupon.setTimePeriod(result);
+        if (CollectionUtil.isNotEmpty(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
+
+                SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
+                String dateString1 = sdf.format(date1);
+                String dateString2 = sdf.format(date2);
+
+                String result = dateString1 + "-" + dateString2;
+                coupon.setTimePeriod(result);
+            }
         }
         return ResultUtil.success(coupons);
     }

--
Gitblit v1.7.1