From f88cfa02e36752e4acad7adc4b045155e8e50f21 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期五, 08 十二月 2023 09:16:29 +0800 Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/PlayPai --- cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageSchedulingServiceImpl.java | 68 ++++++++++++++++++++++++++------- 1 files changed, 53 insertions(+), 15 deletions(-) diff --git a/cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageSchedulingServiceImpl.java b/cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageSchedulingServiceImpl.java index 41847eb..42a3aad 100644 --- a/cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageSchedulingServiceImpl.java +++ b/cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageSchedulingServiceImpl.java @@ -5,6 +5,8 @@ import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.dsh.course.controller.CoursePackagePaymentController; import com.dsh.course.entity.*; +import com.dsh.course.feignclient.account.StudentClient; +import com.dsh.course.feignclient.account.model.Student; import com.dsh.course.mapper.CoursePackageSchedulingMapper; import com.dsh.course.mapper.CoursePackageStudentMapper; import com.dsh.course.model.QueryCoursePackageSchedulingList; @@ -44,6 +46,9 @@ @Resource private CoursePackageStudentMapper coursePackageStudentMapper; + + @Resource + private StudentClient studentClient; /** @@ -158,6 +163,15 @@ .gt("useTime", "now()") .gt("laveClassHours", 0) ); + + List<CoursePackageOrder> list1 = coursePackageOrderService.list(new QueryWrapper<CoursePackageOrder>() + .eq("payStatus", 2) + .eq("status", 1) + .eq("state", 1) + .gt("laveClassHours", 0) + .orderByAsc("insertTime") + ); + for (CoursePackageOrderStudent coursePackageOrderStudent : list) { CoursePackageScheduling coursePackageScheduling = this.getOne(new QueryWrapper<CoursePackageScheduling>() .eq("appUserId", coursePackageOrderStudent.getAppUserId()) @@ -167,6 +181,8 @@ .orderByDesc("classDate") .last(" limit 0, 1") ); + Student student = studentClient.queryStudentById(coursePackageScheduling.getStudentId()); + Date validity = student.getValidity(); TCoursePackage coursePackage = coursePackageService.getById(coursePackageScheduling.getCoursePackageId()); //上课星期 String classWeeks = coursePackage.getClassWeeks(); @@ -216,7 +232,7 @@ continue; } //大于有效期不进行排课 - if (start.getTimeInMillis() >= useTime.getTime()) { + if (start.getTimeInMillis() >= validity.getTime()) { break; } for (int j = 0; j < split.length; j++) { @@ -313,6 +329,8 @@ TCoursePackage coursePackage = coursePackageService.getById(coursePackageOrderStudent.getCoursePackageId()); Integer codeTime = coursePackage.getCodeTime(); Integer laveClassHours = coursePackageOrderStudent.getLaveClassHours(); + Student student = studentClient.queryStudentById(coursePackageOrderStudent.getStudentId()); + Date validity = student.getValidity(); Calendar calendar = Calendar.getInstance(); calendar.setTime(new Date()); @@ -335,7 +353,7 @@ //从第二天开始 Calendar startTime = Calendar.getInstance(); startTime.setTime(new Date()); - startTime.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1); + startTime.set(Calendar.DAY_OF_YEAR, startTime.get(Calendar.DAY_OF_YEAR) + 1); startTime.set(Calendar.HOUR_OF_DAY, 0); startTime.set(Calendar.MINUTE, 0); startTime.set(Calendar.SECOND, 0); @@ -365,7 +383,7 @@ } //大于有效期不进行排课 - if (startTime.getTimeInMillis() >= useTime.getTime()) { + if (startTime.getTimeInMillis() >= validity.getTime()) { break; } SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); @@ -405,12 +423,26 @@ } }else{ - Date classDate = coursePackageScheduling.getClassDate(); - if(codeTime.compareTo(laveClassHours) > 0 && calendar.getTimeInMillis() > classDate.getTime()){ + Date classDate = new Date(); + + if (coursePackageScheduling!=null){ + classDate = coursePackageScheduling.getClassDate(); + } + + int count = this.count(new QueryWrapper<CoursePackageScheduling>() + .eq("appUserId", coursePackageOrderStudent.getAppUserId()) + .eq("studentId", coursePackageOrderStudent.getStudentId()) + .eq("coursePackageId", coursePackageOrderStudent.getCoursePackageId()) + .eq("status", 1) + ); + + Integer number = laveClassHours - count; + if((number.compareTo(codeTime) > 0 && calendar.getTimeInMillis() > classDate.getTime())||coursePackageScheduling==null){ //从第二天开始 Calendar startTime = Calendar.getInstance(); - startTime.setTime(new Date()); - startTime.set(Calendar.DAY_OF_YEAR, calendar.get(Calendar.DAY_OF_YEAR) + 1); +// startTime.setTime(coursePackageScheduling.getClassDate()); + startTime.setTime(classDate); + startTime.set(Calendar.DAY_OF_YEAR, startTime.get(Calendar.DAY_OF_YEAR) + 1); startTime.set(Calendar.HOUR_OF_DAY, 0); startTime.set(Calendar.MINUTE, 0); startTime.set(Calendar.SECOND, 0); @@ -422,13 +454,13 @@ String classWeeks = coursePackage.getClassWeeks(); List<Integer> week = week(classWeeks); //新剩余课时 - laveClassHours += classNumber; + number += classNumber; //判断最后一天是否所有时段都已排完 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd"); - String format = sdf.format(coursePackageScheduling.getClassDate()); - String time = format.substring(format.indexOf(" ")); + String format = sdf.format(classDate); + String time = format.substring(0,format.indexOf(" ") + 1); String classStartTime = coursePackage.getClassStartTime(); String classEndTime = coursePackage.getClassEndTime(); String[] split = classStartTime.split(","); @@ -439,10 +471,10 @@ n++; for (int i = n; i < split.length; i++) { //剩余数量不足以排课 - if (laveClassHours.compareTo(codeTime) < 0) { + if (number.compareTo(codeTime) < 0) { break; } - laveClassHours -= codeTime; + number -= codeTime; CoursePackageScheduling packageScheduling = new CoursePackageScheduling(); packageScheduling.setType(coursePackage.getType()); packageScheduling.setAppUserId(coursePackageOrderStudent.getAppUserId()); @@ -479,16 +511,16 @@ } //大于有效期不进行排课 - if (startTime.getTimeInMillis() >= useTime.getTime()) { + if (startTime.getTimeInMillis() >= validity.getTime()) { break; } for (int j = 0; j < split.length; j++) { //剩余数量不足以排课 - if (laveClassHours.compareTo(codeTime) < 0) { + if (number.compareTo(codeTime) < 0) { break; } - laveClassHours -= codeTime; + number -= codeTime; CoursePackageScheduling packageScheduling = new CoursePackageScheduling(); packageScheduling.setType(coursePackage.getType()); @@ -524,6 +556,12 @@ coursePackageOrderStudent.setUseTime(useTime); coursePackageOrderStudent.setStatus(1); coursePackageOrderStudentService.updateById(coursePackageOrderStudent); + if(null == student.getValidity()){ + student.setValidity(useTime); + }else if(student.getValidity().getTime() < useTime.getTime()){ + student.setValidity(useTime); + } + studentClient.frozen(student); }catch (Exception e){ e.printStackTrace(); } -- Gitblit v1.7.1