From cbca62b053eb3dc3cc7754aa0062aaf1e04e2cb4 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期四, 22 二月 2024 16:53:36 +0800 Subject: [PATCH] 新增加接口 --- cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageOrderStudentServiceImpl.java | 132 ++++++++++++++++++++++++++++++++++++-------- 1 files changed, 108 insertions(+), 24 deletions(-) diff --git a/cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageOrderStudentServiceImpl.java b/cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageOrderStudentServiceImpl.java index 16c5563..15fd639 100644 --- a/cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageOrderStudentServiceImpl.java +++ b/cloud-server-course/src/main/java/com/dsh/course/service/impl/CoursePackageOrderStudentServiceImpl.java @@ -13,8 +13,11 @@ import com.dsh.course.feignclient.other.StoreClient; import com.dsh.course.feignclient.other.model.Store; import com.dsh.course.mapper.*; +import com.dsh.course.model.DeductionClassHour; +import com.dsh.course.model.DeductionClassHourList; import com.dsh.course.service.ICoursePackageOrderStudentService; import com.dsh.course.service.ICoursePackageSchedulingService; +import com.dsh.course.service.TCoursePackageService; import com.dsh.course.util.DateTimeHelper; import com.dsh.course.util.DateUtil; import com.dsh.course.util.ToolUtil; @@ -50,6 +53,9 @@ @Resource private StoreClient stoClient; + @Autowired + private TCoursePackageService coursePackageService; + @Override @@ -69,7 +75,7 @@ List<CoursePackageScheduling> list = coursePackageSchedulingService.list(new QueryWrapper<CoursePackageScheduling>() .eq("appUserId", appUserId) .eq("studentId", stuId) - .lt("classDate", sdf.format(calendar.getTime())) +// .lt("classDate", sdf.format(calendar.getTime())) .orderByAsc("classDate") ); List<Long> ids = list.stream().map(CoursePackageScheduling::getId).collect(Collectors.toList()); @@ -132,48 +138,73 @@ String[] split = classWeeks.split(";"); List<String> integerList = Arrays.asList(split); String weekOfDate = DateTimeHelper.getWeekOfDate(new Date()); - if (integerList.contains(weekOfDate)) { +// if (integerList.contains(weekOfDate)) { String dat = simpleDateFormat.format(byId.getClassDate()) + " " + dateString1.substring(11); + String ed = simpleDateFormat.format(byId.getEndDate()) + " " + dateString2.substring(11); Date start = null; + Date end = null; try { start = format.parse(dat); + end = format.parse(ed); } catch (ParseException e) { throw new RuntimeException(e); } + + CancelledClasses cancelledClasses = cacMapper.selectOne(new QueryWrapper<CancelledClasses>() + .eq("coursePackageSchedulingId", byId.getId()).last("limit 1")); +// else { +// Date now = new Date(); +// if (now.after(byId.getClassDate()) && now.before(byId.getEndDate())) { +// recordVo.setStatus(2); +// } else { +// recordVo.setStatus(3); +// +// } +// } + //已取消 if (byId.getStatus() == 4) { recordVo.setStatus(4); } else if (coursePackageStudent.getSignInOrNot() == 2) { //已请假 recordVo.setStatus(5); - } else if (start.after(new Date())) { + }else if (ToolUtil.isNotEmpty(cancelledClasses)) { + recordVo.setStatus(3); + // 消课 到课状态0 旷课 + if (coursePackageStudent.getSignInOrNot() == 0) { + recordVo.setStatus(6); + } + + }else if (new Date().after(start)&&new Date().before(end)){ + recordVo.setStatus(2); + }else if (start.after(new Date())) { //待上课 recordVo.setStatus(1); } else { - CancelledClasses cancelledClasses = cacMapper.selectOne(new QueryWrapper<CancelledClasses>() - .eq("coursePackageSchedulingId", byId.getId()).last("limit 1")); - if (ToolUtil.isNotEmpty(cancelledClasses)) { - recordVo.setStatus(3); - // 消课 到课状态0 旷课 - if (coursePackageStudent.getSignInOrNot() == 0) { - recordVo.setStatus(6); - } - - } else { - Date now = new Date(); - if (now.after(byId.getClassDate()) && now.before(byId.getEndDate())) { - recordVo.setStatus(2); - } else { - recordVo.setStatus(3); - - } - } +// CancelledClasses cancelledClasses = cacMapper.selectOne(new QueryWrapper<CancelledClasses>() +// .eq("coursePackageSchedulingId", byId.getId()).last("limit 1")); +// if (ToolUtil.isNotEmpty(cancelledClasses)) { +// recordVo.setStatus(3); +// // 消课 到课状态0 旷课 +// if (coursePackageStudent.getSignInOrNot() == 0) { +// recordVo.setStatus(6); +// } +// +// } else { +// Date now = new Date(); +// if (now.after(byId.getClassDate()) && now.before(byId.getEndDate())) { +// recordVo.setStatus(2); +// } else { +// recordVo.setStatus(3); +// +// } +// } } - } else { - recordVo.setStatus(1); - } +// } else { +// recordVo.setStatus(1); +// } recordVoList.add(recordVo); } @@ -204,4 +235,57 @@ return ids; } + + + /** + * 扣除学员课时 + * @param deductionClassHourList + * @return + */ + @Override + public boolean deductionClassHour(DeductionClassHourList deductionClassHourList) { + try { + List<DeductionClassHour> list = deductionClassHourList.getDeductionClassHourList(); + for (DeductionClassHour deductionClassHour : list) { + CoursePackageOrderStudent coursePackageOrderStudent = this.getById(deductionClassHour.getId()); + Integer laveClassHours = coursePackageOrderStudent.getLaveClassHours(); + coursePackageOrderStudent.setLaveClassHours(coursePackageOrderStudent.getLaveClassHours() - deductionClassHour.getClassHour()); + + //计算需要删除几个排课记录 + TCoursePackage coursePackage = coursePackageService.getById(coursePackageOrderStudent.getCoursePackageId()); + Integer codeTime = coursePackage.getCodeTime(); + //未上的排课数据 + List<CoursePackageScheduling> packageSchedulings = coursePackageSchedulingService.list(new QueryWrapper<CoursePackageScheduling>().eq("studentId", coursePackageOrderStudent.getStudentId()) + .eq("coursePackageId", coursePackageOrderStudent.getCoursePackageId()).eq("status", 1).orderByDesc("classDate")); + //排课使用的总课时 + int classHour = packageSchedulings.size() * codeTime; + //未排课的课时 + int notClass = laveClassHours - classHour; + + //判断是否需要删除排课数据 + if(notClass < deductionClassHour.getClassHour()){ + int clss = deductionClassHour.getClassHour() - notClass; + int n = clss % codeTime; + int l = 0; + //不整除的情况,需要多删除一节排课,回加差额课时。 + if(n != 0){ + n += 1; + l = (codeTime * n) - clss; + coursePackageOrderStudent.setLaveClassHours(l); + } + + //删除已排的课程 + List<CoursePackageScheduling> coursePackageSchedulings = packageSchedulings.subList(0, n); + List<Long> collect = coursePackageSchedulings.stream().map(CoursePackageScheduling::getId).collect(Collectors.toList()); + coursePackageSchedulingService.removeByIds(collect); + } + + this.updateById(coursePackageOrderStudent); + } + return true; + }catch (Exception e){ + e.printStackTrace(); + } + return false; + } } -- Gitblit v1.7.1