From 4ee77a0ee732b1d760b08d986ab308dc8d89f6be Mon Sep 17 00:00:00 2001
From: 44323 <443237572@qq.com>
Date: 星期三, 01 十一月 2023 10:43:54 +0800
Subject: [PATCH] 支付会员购买bug

---
 cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackagePaymentController.java |  840 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 769 insertions(+), 71 deletions(-)

diff --git a/cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackagePaymentController.java b/cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackagePaymentController.java
index 737901c..99037d0 100644
--- a/cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackagePaymentController.java
+++ b/cloud-server-course/src/main/java/com/dsh/course/controller/CoursePackagePaymentController.java
@@ -54,6 +54,11 @@
 import java.math.BigDecimal;
 import java.text.ParseException;
 import java.text.SimpleDateFormat;
+import java.time.Instant;
+import java.time.LocalDateTime;
+import java.time.LocalTime;
+import java.time.ZoneId;
+import java.time.temporal.ChronoUnit;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -140,7 +145,7 @@
         Integer studentId = packagePayment.getStudentId();
         // 添加学员上课记录
         CoursePackageStudent coursePackageStudent = new CoursePackageStudent();
-        TCoursePackagePayment one = packagePaymentService.getOne(new QueryWrapper<TCoursePackagePayment>().eq("studentId", packagePayment)
+        TCoursePackagePayment one = packagePaymentService.getOne(new QueryWrapper<TCoursePackagePayment>().eq("studentId", packagePayment.getStudentId())
                 .orderByDesc("insertTime")
                 .last("LIMIT 1"));
 
@@ -179,8 +184,6 @@
             String[] end = value1.split(",");
             for (int i = 0; i < star.length; i++) {
     //                int index = star[i].indexOf(",");
-    //
-    //
     //                String result = value.substring(0, index).trim();
                 String classStartTime = star[i];
                 String[] split = classStartTime.split(":");
@@ -198,7 +201,7 @@
 
                 Calendar e = Calendar.getInstance();
                 e.setTime(date);
-                e.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 13);
+                e.set(Calendar.DAY_OF_YEAR, s.get(Calendar.DAY_OF_YEAR) + 14);
                 long timeInMillis = e.getTimeInMillis();
 
                 while (true){
@@ -229,7 +232,7 @@
                                 .eq("coursePackageId", coursePackage.getId())
                                 .eq("classDate", classDate.getTime())
                                 .eq("endDate", endDate.getTime()));
-                        if (list.size()+1>coursePackage.getMaxSubscribeNumber()){
+                        if (list1.size()+1>coursePackage.getMaxSubscribeNumber()){
                             // 当前课包预约人数已满
                             return 5001;
                         }
@@ -264,6 +267,13 @@
     public Object changeState(@RequestBody CoursePackagePayDTO dto){
 
         return packagePaymentService.changeState(dto);
+    }
+    @GetMapping("/coursePackagePayment/courseStore/{appUserId}/{coursePackageId}")
+    public List<TCoursePackagePayment> getByUserIdAndCoursePackageId(@PathVariable("appUserId") Integer appUserId,@PathVariable("coursePackageId") Integer coursePackageId){
+        List<TCoursePackagePayment> list = packagePaymentService.list(new QueryWrapper<TCoursePackagePayment>()
+                .eq("appUserId", appUserId)
+                .eq("coursePackageId", coursePackageId));
+        return list;
     }
     /**
      * 获取购课记录
@@ -367,18 +377,31 @@
                 }
             }
         }
-
         List<RegisterOrderVO> res = packagePaymentService.listAllRegister(query);
+        // 该运营商下没有门店
+        if (query.getStoresIds()!=null){
+            if (query.getStoresIds().size()==0){
+                List<RegisterOrderVO> registerOrderVOS = new ArrayList<>();
+                return registerOrderVOS;
+            }
+        }else{
+            List<RegisterOrderVO> registerOrderVOS = new ArrayList<>();
+            return registerOrderVOS;
+        }
+
         List<RegisterOrderVO> result = new ArrayList<>();
-        for (RegisterOrderVO re : res) {
-            if(re.getSalesName()==null){
+        Iterator<RegisterOrderVO> iterator = res.iterator();
+        while (iterator.hasNext()) {
+            RegisterOrderVO re = iterator.next();
+
+            if (re.getSalesName() == null) {
                 re.setSalesName("无");
             }
-            if(re.getPayType()!=null){
-                if (re.getPayType() == 3){
-                    re.setPayMoneyAndType(re.getPlayPaiCoin()+"玩湃币");
-                }else{
-                    re.setPayMoneyAndType("¥"+re.getMoney());
+            if (re.getPayType() != null) {
+                if (re.getPayType() == 3) {
+                    re.setPayMoneyAndType(re.getPlayPaiCoin() + "玩湃币");
+                } else {
+                    re.setPayMoneyAndType("¥" + re.getMoney());
                 }
             }
             Store store = storeClient.queryStoreById(re.getStoreId());
@@ -388,6 +411,11 @@
             re.setPayUser(appUser.getName());
             re.setPhone(appUser.getPhone());
             re.setStoreName(store.getName());
+            // 在这里添加条件来删除不满足要求的元素
+
+            if (query.getInsertType() !=null && appUser.getInsertType() != query.getInsertType()) {
+                iterator.remove(); // 使用迭代器的 remove 方法删除元素
+            }
         }
         return res;
     }
@@ -416,8 +444,10 @@
                 resp.setTotalCourseNums(tCoursePackagePayment.getTotalClassHours());
                 resp.setResidueNums(tCoursePackagePayment.getLaveClassHours());
                 resp.setDeductionNums(tCoursePackagePayment.getTotalClassHours()-tCoursePackagePayment.getLaveClassHours());
+                if (tCoursePackage.getValidDays()!=null){
                 String afterDayDate = DateUtil.getAfterDayDate2(tCoursePackage.getInsertTime(),tCoursePackage.getValidDays() + "");
                 resp.setPeriodOfValidity(afterDayDate);
+                }
                 resps.add(resp);
             }
         }
@@ -731,27 +761,53 @@
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
     })
-    public ResultUtil<List<AppUserVideoResponse>> queryAfterSourceList( CourseOfAfterRequest search){
-        try {
+    public ResultUtil<List<AppUserVideoResponse>> queryAfterSourceList( CourseOfAfterRequest search) throws Exception {
+//        try {
             Integer appUserId = tokenUtil.getUserIdFormRedis();
 
             if(null == appUserId){
                 return ResultUtil.tokenErr();
             }
-            List<Integer> courseIds = new ArrayList<>();
-            QueryWrapper<TCoursePackagePayment> queryWrapper = new QueryWrapper<TCoursePackagePayment>().eq("appUserId", appUserId)
-                    .groupBy("coursePackageId");
+//
+//            List<Integer> courseIds = new ArrayList<>();
+//            QueryWrapper<TCoursePackagePayment> queryWrapper = new QueryWrapper<TCoursePackagePayment>().eq("appUserId", appUserId)
+//                    .groupBy("coursePackageId");
+//            if (ToolUtil.isNotEmpty(search.getCourseTypeId())){
+//                queryWrapper.eq("coursePackageId",search.getCourseTypeId());
+//            }
+//            List<TCoursePackagePayment> tCoursePackagePayments = packagePaymentService.list(queryWrapper);
+//            if (tCoursePackagePayments.size() > 0 ){
+//                courseIds = tCoursePackagePayments.stream().map(TCoursePackagePayment::getCoursePackageId).collect(Collectors.toList());
+//            }
+
+
+            QueryWrapper<CoursePackageStudent> queryWrapper1 = new QueryWrapper<CoursePackageStudent>().eq("appUserId", appUserId);
             if (ToolUtil.isNotEmpty(search.getCourseTypeId())){
-                queryWrapper.eq("coursePackageId",search.getCourseTypeId());
+                queryWrapper1.eq("coursePackageId",search.getCourseTypeId());
             }
-            List<TCoursePackagePayment> tCoursePackagePayments = packagePaymentService.list(queryWrapper);
-            if (tCoursePackagePayments.size() > 0 ){
-                courseIds = tCoursePackagePayments.stream().map(TCoursePackagePayment::getCoursePackageId).collect(Collectors.toList());
+
+            List<CoursePackageStudent> list = coursePackageStudentService.list(queryWrapper1);
+            List<Long> longs = new ArrayList<>();
+            for (CoursePackageStudent coursePackageStudent : list) {
+                longs.add(coursePackageStudent.getCoursePackageSchedulingId());
             }
-            return ResultUtil.success(packagePaymentService.queryAfterVideo(search,courseIds));
-        }catch (Exception e){
-            return ResultUtil.runErr();
-        }
+
+            System.out.println("======longs========"+longs);
+           List<CoursePackageScheduling> coursePackageSchedulings = coursePackageSchedulingService.list(new QueryWrapper<CoursePackageScheduling>().in("id",longs).isNotNull("courseId"));
+           List<AppUserVideoResponse> coursePackageSchedulings1 = coursePackageSchedulingService.queryAll(longs);
+
+
+
+
+            return ResultUtil.success(coursePackageSchedulings1);
+
+
+
+
+
+//        }catch (Exception e){
+//            return ResultUtil.runErr();
+//        }
     }
 
     /**
@@ -1033,6 +1089,10 @@
     }
 
 
+    @Autowired
+    private  TCoursePackageService packageService;
+    @Autowired
+    CoursePackageStudentService studentService ;
     /**
      * 课程用于支付进行扣减
      * @param paymentDeductionClassHour
@@ -1046,58 +1106,202 @@
                     .eq("status", 1).eq("state", 1).gt("laveClassHours", 0));
             Integer classHour = paymentDeductionClassHour.getClassHour();
             for (TCoursePackagePayment coursePackagePayment : list) {
-                if(coursePackagePayment.getLaveClassHours().compareTo(classHour) >= 0){
+                if (coursePackagePayment.getLaveClassHours().compareTo(classHour) >= 0) {
                     coursePackagePayment.setLaveClassHours(coursePackagePayment.getLaveClassHours() - classHour);
+                    coursePackagePayment.setAppUserId(null);
                     packagePaymentService.updateById(coursePackagePayment);
 
-                    // 2.0 少于3课时 推送
-                    if(coursePackagePayment.getLaveClassHours()<=3){
-                        Integer appUserId = coursePackagePayment.getAppUserId();
 
-                        //调用推送
-                        HttpHeaders headers = new HttpHeaders();
-                        // 以表单的方式提交
-                        headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
-                        String s1 = appUserId + "_" + "Three";
-                        //定时修改排课状态
-                        String s = internalRestTemplate.getForObject("http://mb-cloud-gateway/netty/sendMsgToClient?id="+s1, String.class);
-                        JSONObject jsonObject1 = JSON.parseObject(s, JSONObject.class);
-                        if(jsonObject1.getIntValue("code") != 200){
-                            System.err.println(jsonObject1.getString("msg"));
+                    coursePackageSchedulingService.remove(new QueryWrapper<CoursePackageScheduling>().eq("courseId", coursePackagePayment.getCoursePackageId()));
+                    coursePackageStudentService.remove(new QueryWrapper<CoursePackageStudent>().eq("coursePackageId", coursePackagePayment.getCoursePackageId()));
+
+
+
+
+                    Student student = studentClient.queryStudentById(coursePackagePayment.getStudentId());
+
+                    TCoursePackage tCoursePackage = packageService.getById(coursePackagePayment.getCoursePackageId());
+                    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");
+                    // 本周周几
+                    int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date()) - 1;
+                    for (Integer integer : week) {
+                        if (integer < i) {
+                            // 找下一周的时间
+                            Calendar instance = Calendar.getInstance();
+                            instance.add(Calendar.DATE, 7 - (i - integer));
+                            Date time = instance.getTime();
+
+                            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(student.getAppUserId());
+                                student1.setStudentId(student.getId());
+                                student1.setCoursePackageId(tCoursePackage.getId());
+                                student1.setCoursePackagePaymentId(coursePackagePayment.getId());
+                                student1.setCoursePackageSchedulingId(coursePackageScheduling.getId());
+                                student1.setSignInOrNot(1);
+                                student1.setReservationStatus(1);
+                                student1.setInsertTime(new Date());
+                                studentService.save(student1);
+
+                            }
+
+                        } else if (integer > i) {
+                            Calendar instance = Calendar.getInstance();
+                            instance.add(Calendar.DATE, integer - i);
+                            Date time1 = instance.getTime();
+                            List<Date> list6 = new ArrayList<>();
+                            list6.add(time1);
+                            instance.add(Calendar.DATE, 7);
+                            Date time2 = instance.getTime();
+                            list6.add(time2);
+                            for (Date time : list6) {
+                                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(student.getAppUserId());
+                                    student1.setStudentId(student.getId());
+                                    student1.setCoursePackageId(tCoursePackage.getId());
+                                    student1.setCoursePackagePaymentId(coursePackagePayment.getId());
+                                    student1.setCoursePackageSchedulingId(coursePackageScheduling.getId());
+                                    student1.setSignInOrNot(1);
+                                    student1.setReservationStatus(1);
+                                    student1.setInsertTime(new Date());
+                                    studentService.save(student1);
+                                }
+                            }
+
+                        } else {
+                            Calendar instance = Calendar.getInstance();
+                            instance.add(Calendar.DATE, 7);
+                            Date time = instance.getTime();
+
+                            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(student.getAppUserId());
+                                student1.setStudentId(student.getId());
+                                student1.setCoursePackageId(tCoursePackage.getId());
+                                student1.setCoursePackagePaymentId(coursePackagePayment.getId());
+                                student1.setCoursePackageSchedulingId(coursePackageScheduling.getId());
+                                student1.setSignInOrNot(1);
+                                student1.setReservationStatus(1);
+                                student1.setInsertTime(new Date());
+                                studentService.save(student1);
+                            }
                         }
                     }
 
-                    CancelledClasses cancelledClasses = new CancelledClasses();
-                    cancelledClasses.setType(2);
-                    cancelledClasses.setVoucher(paymentDeductionClassHour.getCode());
-                    cancelledClasses.setCoursePackageId(coursePackagePayment.getCoursePackageId());
-                    cancelledClasses.setCoursePackagePaymentId(coursePackagePayment.getId());
-                    cancelledClasses.setCancelledClassesNumber(classHour);
-                    cancelledClasses.setInsertTime(new Date());
-                    cancelledClassesService.save(cancelledClasses);
-                    break;
-                }else{
-                    CancelledClasses cancelledClasses = new CancelledClasses();
-                    cancelledClasses.setType(2);
-                    cancelledClasses.setVoucher(paymentDeductionClassHour.getCode());
-                    cancelledClasses.setCoursePackageId(coursePackagePayment.getCoursePackageId());
-                    cancelledClasses.setCoursePackagePaymentId(coursePackagePayment.getId());
-                    cancelledClasses.setCancelledClassesNumber(coursePackagePayment.getLaveClassHours());
-                    cancelledClasses.setInsertTime(new Date());
-                    cancelledClassesService.save(cancelledClasses);
 
-                    coursePackagePayment.setLaveClassHours(0);
-                    packagePaymentService.updateById(coursePackagePayment);
+                        // 2.0 少于3课时 推送
+                        if (coursePackagePayment.getLaveClassHours() <= 3) {
+                            Integer appUserId = coursePackagePayment.getAppUserId();
 
-                    classHour -= cancelledClasses.getCancelledClassesNumber();
+                            //调用推送
+                            HttpHeaders headers = new HttpHeaders();
+                            // 以表单的方式提交
+                            headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
+                            String s1 = appUserId + "_" + "Three";
+                            //定时修改排课状态
+                            String s = internalRestTemplate.getForObject("http://mb-cloud-gateway/netty/sendMsgToClient?id=" + s1, String.class);
+                            JSONObject jsonObject1 = JSON.parseObject(s, JSONObject.class);
+                            if (jsonObject1.getIntValue("code") != 200) {
+                                System.err.println(jsonObject1.getString("msg"));
+                            }
+                        }
+
+                        CancelledClasses cancelledClasses = new CancelledClasses();
+                        cancelledClasses.setType(2);
+                        cancelledClasses.setVoucher(paymentDeductionClassHour.getCode());
+                        cancelledClasses.setCoursePackageId(coursePackagePayment.getCoursePackageId());
+                        cancelledClasses.setCoursePackagePaymentId(coursePackagePayment.getId());
+                        cancelledClasses.setCancelledClassesNumber(classHour);
+                        cancelledClasses.setInsertTime(new Date());
+                        cancelledClassesService.save(cancelledClasses);
+                        break;
+                    }else{
+                        CancelledClasses cancelledClasses = new CancelledClasses();
+                        cancelledClasses.setType(2);
+                        cancelledClasses.setVoucher(paymentDeductionClassHour.getCode());
+                        cancelledClasses.setCoursePackageId(coursePackagePayment.getCoursePackageId());
+                        cancelledClasses.setCoursePackagePaymentId(coursePackagePayment.getId());
+                        cancelledClasses.setCancelledClassesNumber(coursePackagePayment.getLaveClassHours());
+                        cancelledClasses.setInsertTime(new Date());
+                        cancelledClassesService.save(cancelledClasses);
+
+                        coursePackagePayment.setLaveClassHours(0);
+                        packagePaymentService.updateById(coursePackagePayment);
+
+                        classHour -= cancelledClasses.getCancelledClassesNumber();
+                    }
                 }
-            }
+
+
         }catch (Exception e){
             e.printStackTrace();
         }
     }
 
-
+    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;
+            }
+        }
+        return integers;
+    }
     /**
      * 取消赛事回退支付课时
      * @param paymentDeductionClassHour
@@ -1243,15 +1447,15 @@
         return packagePaymentService.save(packagePayment);
     }
 
-
+    @ResponseBody
     @PostMapping("/base/coursePack/obtainStudentClassDetails")
     public List<RecordAppoint> obtainStudentClassDetailsData(@RequestBody WeeksOfCourseRest stuId){
-        try {
-            return packagePaymentService.obtainStuClassDetails(stuId.getStuId(),stuId.getAppUserId());
-        }catch (Exception e){
-            e.printStackTrace();
-            throw new RuntimeException();
-        }
+//        try {
+            return packagePaymentService.obtainStuClassDetails(stuId.getStuId(),stuId.getAppUserId(),stuId.getPageNum());
+//        }catch (Exception e){
+//            e.printStackTrace();
+//            throw new RuntimeException();
+//        }
     }
 
 
@@ -1455,7 +1659,7 @@
             String time1 = courseDetailReq.getTime();
 
             // 找出门店的所有课程 排出体验
-            List<TCoursePackage> list = tcpService.list(new LambdaQueryWrapper<TCoursePackage>().eq(TCoursePackage::getStoreId, courseDetailReq.getStoreId()).ne(TCoursePackage::getType, 3).like(TCoursePackage::getClassWeeks,week));
+            List<TCoursePackage> list = tcpService.list(new LambdaQueryWrapper<TCoursePackage>().eq(TCoursePackage::getStoreId, courseDetailReq.getStoreId()).ne(TCoursePackage::getType, 3).eq(TCoursePackage::getState,1).like(TCoursePackage::getClassWeeks,week));
             List<Integer> collect = list.stream().map(TCoursePackage::getId).collect(Collectors.toList());
             if(collect.size()==0){
                 collect.add(-1);
@@ -1558,4 +1762,498 @@
         return a;
     }
 
+
+    @ResponseBody
+    @PostMapping("/coursePackagePayment/queryCourseData")
+    public List<Map<String,Object>> queryCourseData(@RequestBody List<Integer> ids){
+        // 找出课程类型  找出剩余的课时数
+        List<TCoursePackageType> list = coursePackageTypeService.list();
+        if(ids.size()==0){
+            ids.add(-1);
+        }
+        List<TCoursePackagePayment> list1 = packagePaymentService.listOne(ids);
+        List<Integer> collect = list1.stream().map(TCoursePackagePayment::getCoursePackageId).collect(Collectors.toList());
+        if(collect.size()==0){
+            collect.add(-1);
+        }
+        List<TCoursePackage> list2 = tcpService.list(new LambdaQueryWrapper<TCoursePackage>().in(TCoursePackage::getId, collect));
+        for (TCoursePackagePayment tCoursePackagePayment : list1) {
+            for (TCoursePackage tCoursePackage : list2) {
+                if(tCoursePackagePayment.getCoursePackageId().equals(tCoursePackage.getId())){
+                    tCoursePackagePayment.setType(tCoursePackage.getType());
+                }
+            }
+        }
+
+
+        List<Map<String,Object>> mapList = new ArrayList<>();
+        for (TCoursePackageType tCoursePackageType : list) {
+            HashMap<String, Object> map = new HashMap<>();
+            map.put("name",tCoursePackageType.getName());
+            int a =0;
+            for (TCoursePackagePayment tCoursePackagePayment : list1) {
+                if(tCoursePackagePayment.getType().equals(tCoursePackageType.getId())){
+                    a += tCoursePackagePayment.getLaveClassHours();
+                }
+            }
+            map.put("value",a);
+            mapList.add(map);
+        }
+
+
+        return mapList;
+    }
+
+
+
+    @ResponseBody
+    @PostMapping("/coursePackagePayment/coursePt")
+    HashMap<String, Object> coursePt(@RequestBody List<Integer> userPt){
+        if(userPt.size()==0){
+            userPt.add(-1);
+        }
+        HashMap<String, Object> map = new HashMap<>();
+        List<TCoursePackagePayment> tCoursePackagePayments = packagePaymentService.listOne(userPt);
+        int sum = tCoursePackagePayments.stream().mapToInt(TCoursePackagePayment::getTotalClassHours).sum();
+        int sum1 = tCoursePackagePayments.stream().mapToInt(TCoursePackagePayment::getLaveClassHours).sum();
+        map.put("allCourse",sum-sum1);
+
+        //所有课包
+        List<TCoursePackage> coursePackages = tcpService.list();
+
+
+        // 年
+        List<CoursePackageStudent> list = cspsService.list(new LambdaQueryWrapper<CoursePackageStudent>().in(CoursePackageStudent::getAppUserId, userPt));
+
+
+        for (CoursePackageStudent coursePackageStudent : list) {
+            for (TCoursePackage coursePackage : coursePackages) {
+                if(coursePackageStudent.getCoursePackageId().equals(coursePackage.getId())){
+                    if(ToolUtil.isEmpty(coursePackage.getNeedNum())){
+                        coursePackageStudent.setNeedNum(0);
+                    }else {
+                        coursePackageStudent.setNeedNum(coursePackage.getNeedNum());
+                    }
+                }
+            }
+        }
+
+        ArrayList<Object> integers = new ArrayList<>();
+        int year = cn.hutool.core.date.DateUtil.year(new Date());
+        for (int i = 0; i < 10; i++) {
+            integers.add(year-i);
+        }
+        List<Object> collect = integers.stream().sorted().collect(Collectors.toList());
+        // 年
+        ArrayList<Integer> years = new ArrayList<>();
+        for (Object o : collect) {
+            String s = o.toString();
+            List<CoursePackageStudent> collect1 = list.stream().filter(e -> e.getInsertTime().toString().contains(s)).filter(student -> student.getNeedNum() != null).collect(Collectors.toList());
+            int sum2 = collect1.stream().mapToInt(CoursePackageStudent::getNeedNum).sum();
+            years.add(sum2);
+        }
+
+        map.put("yearData",years);
+
+
+
+        ArrayList<Integer> months = new ArrayList<>();
+
+        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+
+
+        // 月
+        for (int i = 1; i <= 12; i++) {
+            String m=i+"";
+            if(i<10){
+                m="0"+i;
+            }
+            String s = year + "-" + m;
+            List<CoursePackageStudent> collect1 = list.stream().filter(e -> format.format(e.getInsertTime()).contains(s)).filter(student -> student.getNeedNum() != null).collect(Collectors.toList());
+            int sum2 = collect1.stream().mapToInt(CoursePackageStudent::getNeedNum).sum();
+            months.add(sum2);
+        }
+        map.put("monthData",months);
+
+        // 周
+        // 获取最近四周
+        LocalDateTime minNow = LocalDateTime.now().with(LocalTime.MIN);
+        LocalDateTime maxNow = LocalDateTime.now().with(LocalTime.MAX);
+        // 周度数据
+        LocalDateTime s1 = minNow.minusDays(6);
+        LocalDateTime s2 = maxNow;
+
+        LocalDateTime s3 = minNow.minusDays(13);
+        LocalDateTime s4 = maxNow.minusDays(6);
+
+
+        LocalDateTime s5 = minNow.minusDays(20);
+        LocalDateTime s6 = maxNow.minusDays(13);
+
+        LocalDateTime s7 = minNow.minusDays(27);
+        LocalDateTime s8 = maxNow.minusDays(20);
+        ArrayList<Object> weekData = new ArrayList<>();
+
+        int count  = 0;
+
+        int count1 = 0;
+
+        int count2 = 0;
+
+        int count3 = 0;
+        for (CoursePackageStudent coursePackageStudent : list) {
+            if (coursePackageStudent.getNeedNum()==null){
+                continue;
+            }
+            // 如果到课状态为否 则不计算
+            if (coursePackageStudent.getSignInOrNot() != 0) {
+                Date insertTime = coursePackageStudent.getInsertTime();
+                Instant instant = insertTime.toInstant();
+                ZoneId zoneId = ZoneId.systemDefault();
+                LocalDateTime dateTime = instant.atZone(zoneId).toLocalDateTime();
+                if (dateTime.isAfter(s1) && dateTime.isBefore(s2)){
+
+                    count+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s3) && dateTime.isBefore(s4)){
+                    count1+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s5) && dateTime.isBefore(s6)){
+                    count2+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s7) && dateTime.isBefore(s8)){
+                    count3+=coursePackageStudent.getNeedNum();
+                }
+
+            }
+        }
+        weekData.add(count3);
+        weekData.add(count2);
+        weekData.add(count1);
+        weekData.add(count);
+
+        map.put("weekData",weekData);
+
+
+        LocalDateTime currentDateTime = LocalDateTime.now();
+        List<Integer> amountByDay = new ArrayList<>(Collections.nCopies(7,0));
+        for (CoursePackageStudent coursePackageStudent : list) {
+            Date insertTime = coursePackageStudent.getInsertTime();
+            // 将 Date 转换为 LocalDateTime
+            LocalDateTime insertDateTime = LocalDateTime.ofInstant(insertTime.toInstant(), ZoneId.systemDefault());
+            // 计算日期与当前日期的差距
+            long daysDifference = ChronoUnit.DAYS.between(insertDateTime.toLocalDate(), currentDateTime.toLocalDate());
+            // 如果日期在七天内,累加金额
+            if (daysDifference >= 0 && daysDifference < 7) {
+                int index = (int) (6 - daysDifference); // 计算对应的索引位置
+                Integer needNum = coursePackageStudent.getNeedNum();
+                if (needNum!=null){
+                    int i = amountByDay.get(index) + needNum;
+                    amountByDay.set(index, i);
+                }
+
+            }
+        }
+        map.put("dayData", amountByDay);
+
+        return map;
+
+    }
+    @ResponseBody
+    @PostMapping("/coursePackagePayment/courseYys")
+    HashMap<String, Object> courseYys(@RequestBody List<Integer> userPt){
+        if(userPt.size()==0){
+            userPt.add(-1);
+        }
+        HashMap<String, Object> map = new HashMap<>();
+        List<TCoursePackagePayment> tCoursePackagePayments = packagePaymentService.listOne(userPt);
+        int sum = tCoursePackagePayments.stream().mapToInt(TCoursePackagePayment::getTotalClassHours).sum();
+        int sum1 = tCoursePackagePayments.stream().mapToInt(TCoursePackagePayment::getLaveClassHours).sum();
+        map.put("allCourse",sum-sum1);
+
+        //所有课包
+        List<TCoursePackage> coursePackages = tcpService.list();
+
+
+        // 年
+        List<CoursePackageStudent> list = cspsService.list(new LambdaQueryWrapper<CoursePackageStudent>().in(CoursePackageStudent::getAppUserId, userPt));
+
+
+        for (CoursePackageStudent coursePackageStudent : list) {
+            for (TCoursePackage coursePackage : coursePackages) {
+                if(coursePackageStudent.getCoursePackageId().equals(coursePackage.getId())){
+                    if(ToolUtil.isEmpty(coursePackage.getNeedNum())){
+                        coursePackageStudent.setNeedNum(0);
+                    }else {
+                        coursePackageStudent.setNeedNum(coursePackage.getNeedNum());
+                    }
+                }
+            }
+        }
+
+        ArrayList<Object> integers = new ArrayList<>();
+        int year = cn.hutool.core.date.DateUtil.year(new Date());
+        for (int i = 0; i < 10; i++) {
+            integers.add(year-i);
+        }
+        List<Object> collect = integers.stream().sorted().collect(Collectors.toList());
+        // 年
+        ArrayList<Integer> years = new ArrayList<>();
+        for (Object o : collect) {
+            String s = o.toString();
+            List<CoursePackageStudent> collect1 = list.stream().filter(e -> e.getInsertTime().toString().contains(s)).filter(student -> student.getNeedNum() != null).collect(Collectors.toList());
+            int sum2 = collect1.stream().mapToInt(CoursePackageStudent::getNeedNum).sum();
+            years.add(sum2);
+        }
+
+        map.put("yearData",years);
+
+
+
+        ArrayList<Integer> months = new ArrayList<>();
+
+        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+
+
+        // 月
+        for (int i = 1; i <= 12; i++) {
+            String m=i+"";
+            if(i<10){
+                m="0"+i;
+            }
+            String s = year + "-" + m;
+            List<CoursePackageStudent> collect1 = list.stream().filter(e -> format.format(e.getInsertTime()).contains(s)).filter(student -> student.getNeedNum() != null).collect(Collectors.toList());
+            int sum2 = collect1.stream().mapToInt(CoursePackageStudent::getNeedNum).sum();
+            months.add(sum2);
+        }
+        map.put("monthData",months);
+
+        // 周
+        // 获取最近四周
+        LocalDateTime minNow = LocalDateTime.now().with(LocalTime.MIN);
+        LocalDateTime maxNow = LocalDateTime.now().with(LocalTime.MAX);
+        // 周度数据
+        LocalDateTime s1 = minNow.minusDays(6);
+        LocalDateTime s2 = maxNow;
+
+        LocalDateTime s3 = minNow.minusDays(13);
+        LocalDateTime s4 = maxNow.minusDays(6);
+
+
+        LocalDateTime s5 = minNow.minusDays(20);
+        LocalDateTime s6 = maxNow.minusDays(13);
+
+        LocalDateTime s7 = minNow.minusDays(27);
+        LocalDateTime s8 = maxNow.minusDays(20);
+        ArrayList<Object> weekData = new ArrayList<>();
+
+        int count  = 0;
+
+        int count1 = 0;
+
+        int count2 = 0;
+
+        int count3 = 0;
+        for (CoursePackageStudent coursePackageStudent : list) {
+            if (coursePackageStudent.getNeedNum()==null){
+                continue;
+            }
+            // 如果到课状态为否 则不计算
+            if (coursePackageStudent.getSignInOrNot() != 0) {
+                Date insertTime = coursePackageStudent.getInsertTime();
+                Instant instant = insertTime.toInstant();
+                ZoneId zoneId = ZoneId.systemDefault();
+                LocalDateTime dateTime = instant.atZone(zoneId).toLocalDateTime();
+                if (dateTime.isAfter(s1) && dateTime.isBefore(s2)){
+
+                    count+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s3) && dateTime.isBefore(s4)){
+                    count1+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s5) && dateTime.isBefore(s6)){
+                    count2+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s7) && dateTime.isBefore(s8)){
+                    count3+=coursePackageStudent.getNeedNum();
+                }
+
+            }
+        }
+        weekData.add(count3);
+        weekData.add(count2);
+        weekData.add(count1);
+        weekData.add(count);
+
+        map.put("weekData",weekData);
+
+
+        LocalDateTime currentDateTime = LocalDateTime.now();
+        List<Integer> amountByDay = new ArrayList<>(Collections.nCopies(7,0));
+        for (CoursePackageStudent coursePackageStudent : list) {
+            Date insertTime = coursePackageStudent.getInsertTime();
+            // 将 Date 转换为 LocalDateTime
+            LocalDateTime insertDateTime = LocalDateTime.ofInstant(insertTime.toInstant(), ZoneId.systemDefault());
+            // 计算日期与当前日期的差距
+            long daysDifference = ChronoUnit.DAYS.between(insertDateTime.toLocalDate(), currentDateTime.toLocalDate());
+            // 如果日期在七天内,累加金额
+            if (daysDifference >= 0 && daysDifference < 7) {
+                int index = (int) (6 - daysDifference); // 计算对应的索引位置
+                Integer needNum = coursePackageStudent.getNeedNum();
+                if (needNum!=null){
+                    int i = amountByDay.get(index) + needNum;
+                    amountByDay.set(index, i);
+                }
+
+            }
+        }
+        map.put("dayData", amountByDay);
+
+        return map;
+
+    }
+    @ResponseBody
+    @PostMapping("/coursePackagePayment/courseStore")
+    HashMap<String, Object> courseStore(@RequestBody List<Integer> userPt){
+        if(userPt.size()==0){
+            userPt.add(-1);
+        }
+        HashMap<String, Object> map = new HashMap<>();
+        List<TCoursePackagePayment> tCoursePackagePayments = packagePaymentService.listOne(userPt);
+        int sum = tCoursePackagePayments.stream().mapToInt(TCoursePackagePayment::getTotalClassHours).sum();
+        int sum1 = tCoursePackagePayments.stream().mapToInt(TCoursePackagePayment::getLaveClassHours).sum();
+        map.put("allCourse",sum-sum1);
+
+        //所有课包
+        List<TCoursePackage> coursePackages = tcpService.list();
+
+
+        // 年
+        List<CoursePackageStudent> list = cspsService.list(new LambdaQueryWrapper<CoursePackageStudent>().in(CoursePackageStudent::getAppUserId, userPt));
+
+
+        for (CoursePackageStudent coursePackageStudent : list) {
+            for (TCoursePackage coursePackage : coursePackages) {
+                if(coursePackageStudent.getCoursePackageId().equals(coursePackage.getId())){
+                    if(ToolUtil.isEmpty(coursePackage.getNeedNum())){
+                        coursePackageStudent.setNeedNum(0);
+                    }else {
+                        coursePackageStudent.setNeedNum(coursePackage.getNeedNum());
+                    }
+                }
+            }
+        }
+
+        ArrayList<Object> integers = new ArrayList<>();
+        int year = cn.hutool.core.date.DateUtil.year(new Date());
+        for (int i = 0; i < 10; i++) {
+            integers.add(year-i);
+        }
+        List<Object> collect = integers.stream().sorted().collect(Collectors.toList());
+        // 年
+        ArrayList<Integer> years = new ArrayList<>();
+        for (Object o : collect) {
+            String s = o.toString();
+            List<CoursePackageStudent> collect1 = list.stream().filter(e -> e.getInsertTime().toString().contains(s)).filter(student -> student.getNeedNum() != null).collect(Collectors.toList());
+            int sum2 = collect1.stream().mapToInt(CoursePackageStudent::getNeedNum).sum();
+            years.add(sum2);
+        }
+
+        map.put("yearData",years);
+
+
+
+        ArrayList<Integer> months = new ArrayList<>();
+
+        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+
+
+        // 月
+        for (int i = 1; i <= 12; i++) {
+            String m=i+"";
+            if(i<10){
+                m="0"+i;
+            }
+            String s = year + "-" + m;
+            List<CoursePackageStudent> collect1 = list.stream().filter(e -> format.format(e.getInsertTime()).contains(s)).filter(student -> student.getNeedNum() != null).collect(Collectors.toList());
+            int sum2 = collect1.stream().mapToInt(CoursePackageStudent::getNeedNum).sum();
+            months.add(sum2);
+        }
+        map.put("monthData",months);
+
+        // 周
+        // 获取最近四周
+        LocalDateTime minNow = LocalDateTime.now().with(LocalTime.MIN);
+        LocalDateTime maxNow = LocalDateTime.now().with(LocalTime.MAX);
+        // 周度数据
+        LocalDateTime s1 = minNow.minusDays(6);
+        LocalDateTime s2 = maxNow;
+
+        LocalDateTime s3 = minNow.minusDays(13);
+        LocalDateTime s4 = maxNow.minusDays(6);
+
+
+        LocalDateTime s5 = minNow.minusDays(20);
+        LocalDateTime s6 = maxNow.minusDays(13);
+
+        LocalDateTime s7 = minNow.minusDays(27);
+        LocalDateTime s8 = maxNow.minusDays(20);
+        ArrayList<Object> weekData = new ArrayList<>();
+
+        int count  = 0;
+
+        int count1 = 0;
+
+        int count2 = 0;
+
+        int count3 = 0;
+        for (CoursePackageStudent coursePackageStudent : list) {
+            if (coursePackageStudent.getNeedNum()==null){
+                continue;
+            }
+            // 如果到课状态为否 则不计算
+            if (coursePackageStudent.getSignInOrNot() != 0) {
+                Date insertTime = coursePackageStudent.getInsertTime();
+                Instant instant = insertTime.toInstant();
+                ZoneId zoneId = ZoneId.systemDefault();
+                LocalDateTime dateTime = instant.atZone(zoneId).toLocalDateTime();
+                if (dateTime.isAfter(s1) && dateTime.isBefore(s2)){
+
+                    count+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s3) && dateTime.isBefore(s4)){
+                    count1+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s5) && dateTime.isBefore(s6)){
+                    count2+=coursePackageStudent.getNeedNum();
+                }else if(dateTime.isAfter(s7) && dateTime.isBefore(s8)){
+                    count3+=coursePackageStudent.getNeedNum();
+                }
+
+            }
+        }
+        weekData.add(count3);
+        weekData.add(count2);
+        weekData.add(count1);
+        weekData.add(count);
+
+        map.put("weekData",weekData);
+
+
+        LocalDateTime currentDateTime = LocalDateTime.now();
+        List<Integer> amountByDay = new ArrayList<>(Collections.nCopies(7,0));
+        for (CoursePackageStudent coursePackageStudent : list) {
+            Date insertTime = coursePackageStudent.getInsertTime();
+            // 将 Date 转换为 LocalDateTime
+            LocalDateTime insertDateTime = LocalDateTime.ofInstant(insertTime.toInstant(), ZoneId.systemDefault());
+            // 计算日期与当前日期的差距
+            long daysDifference = ChronoUnit.DAYS.between(insertDateTime.toLocalDate(), currentDateTime.toLocalDate());
+            // 如果日期在七天内,累加金额
+            if (daysDifference >= 0 && daysDifference < 7) {
+                int index = (int) (6 - daysDifference); // 计算对应的索引位置
+                Integer needNum = coursePackageStudent.getNeedNum();
+                if (needNum!=null){
+                    int i = amountByDay.get(index) + needNum;
+                    amountByDay.set(index, i);
+                }
+
+            }
+        }
+        map.put("dayData", amountByDay);
+
+        return map;
+
+    }
 }

--
Gitblit v1.7.1