From acad524bfb7f376c09ff8e6600fab207780156e1 Mon Sep 17 00:00:00 2001 From: 44323 <443237572@qq.com> Date: 星期四, 23 十一月 2023 18:46:05 +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/controller/CourseRecordController.java | 64 +++++++++++++++++++++++++++++-- 1 files changed, 59 insertions(+), 5 deletions(-) diff --git a/cloud-server-course/src/main/java/com/dsh/course/controller/CourseRecordController.java b/cloud-server-course/src/main/java/com/dsh/course/controller/CourseRecordController.java index 5416653..863e0e0 100644 --- a/cloud-server-course/src/main/java/com/dsh/course/controller/CourseRecordController.java +++ b/cloud-server-course/src/main/java/com/dsh/course/controller/CourseRecordController.java @@ -3,15 +3,25 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.dsh.course.entity.CancelledClasses; +import com.dsh.course.entity.CourseCounsum; import com.dsh.course.entity.CoursePackageStudent; import com.dsh.course.entity.TCoursePackage; +import com.dsh.course.feignclient.model.GetStudentCourse; import com.dsh.course.service.CancelledClassesService; +import com.dsh.course.service.CourseCounsumService; import com.dsh.course.service.CoursePackageStudentService; import com.dsh.course.service.TCoursePackageService; +import com.dsh.course.util.ToolUtil; import io.swagger.annotations.Api; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.time.LocalDateTime; +import java.time.ZoneId; +import java.time.temporal.ChronoUnit; +import java.util.Date; import java.util.List; @Api @@ -32,15 +42,20 @@ - @PostMapping("/courseRecord/queryDeduClassHours") - public Integer getDeductionClassHour(@RequestBody Integer courseId,@RequestBody Integer stuId,@RequestBody Integer appUserId){ + @PostMapping("/base/courseRecord/queryDeduClassHours") + public Integer getDeductionClassHour(@RequestBody GetStudentCourse course){ Integer sult = 0; - TCoursePackage coursePackage = tcpService.getById(courseId); + TCoursePackage coursePackage = tcpService.getById(course.getCourseId()); if (null != coursePackage && coursePackage.getStatus() == 3){ - List<CoursePackageStudent> coursePackageStudents = cosService.queryStuDeduClassHourNums(courseId, stuId, appUserId); + List<CoursePackageStudent> coursePackageStudents = cosService.list(new QueryWrapper<CoursePackageStudent>() + .eq("coursePackageId",course.getCourseId() ) + .eq("studentId",course.getStuId() ) + .eq("appUserId", course.getAppUserId()) + .eq("signInOrNot",1)); + if (coursePackageStudents.size() > 0){ List<CancelledClasses> list = caccService.list(new QueryWrapper<CancelledClasses>() - .eq("coursePackageId",courseId )); + .eq("coursePackageId",course.getCourseId() )); if (list.size() > 0){ for (CancelledClasses cancelledClasses : list) { sult = sult + cancelledClasses.getCancelledClassesNumber(); @@ -51,4 +66,43 @@ return sult; } + @Autowired + private CourseCounsumService courseCounsumService; + + @PostMapping("/base/courseRecord/save") + public void save(@RequestBody CourseCounsum courseCounsum) { + courseCounsumService.save(courseCounsum); + } + + + @PostMapping("/base/courseRecord/cancelCourseData") + public Integer cancelCourseRecordClass(@RequestBody Integer courseRecordId){ + int sult = 0; + CoursePackageStudent packageStudent = cosService.getById(courseRecordId); + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy.MM.dd"); + SimpleDateFormat format = new SimpleDateFormat("yyyy.MM.dd HH:mm"); + String tis = simpleDateFormat.format(new Date()); + + if (ToolUtil.isNotEmpty(packageStudent)){ + TCoursePackage coursePackage = tcpService.getById(packageStudent.getCoursePackageId()); + String startTime = tis +" " + coursePackage.getClassStartTime(); + Date parse = null; + try { + parse = format.parse(startTime); + } catch (ParseException e) { + throw new RuntimeException(e); + } + LocalDateTime localDateTime = parse.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime(); + // 计算时间间隔 + long hours = ChronoUnit.HOURS.between(LocalDateTime.now(), localDateTime); + // 判断是否在前三小时内 + if (hours <= 3 && hours >= 0){ + sult = 1; + }else { + sult = 2; + } + } + return sult; + } + } -- Gitblit v1.7.1