|  | @@ -74,11 +74,12 @@ public class StudentServeServiceImpl implements StudentServeService {
 | 
											
												
													
														|  |          //本周无课学员编号集合
 |  |          //本周无课学员编号集合
 | 
											
												
													
														|  |          Set<Integer> noClassStudentIds=new HashSet<>();
 |  |          Set<Integer> noClassStudentIds=new HashSet<>();
 | 
											
												
													
														|  |          for (Map.Entry<Integer, List<StudentServeDto>> studentCoursesEntry : studentCoursesMap.entrySet()) {
 |  |          for (Map.Entry<Integer, List<StudentServeDto>> studentCoursesEntry : studentCoursesMap.entrySet()) {
 | 
											
												
													
														|  | -            if(CollectionUtils.isEmpty(studentCoursesEntry.getValue())){
 |  | 
 | 
											
												
													
														|  | 
 |  | +            List<StudentServeDto> haveCourseStudents = studentCoursesEntry.getValue().stream().filter(e -> Objects.nonNull(e.getCourseStartTime())).collect(Collectors.toList());
 | 
											
												
													
														|  | 
 |  | +            if(CollectionUtils.isEmpty(haveCourseStudents)){
 | 
											
												
													
														|  |                  noClassStudentIds.add(studentCoursesEntry.getKey());
 |  |                  noClassStudentIds.add(studentCoursesEntry.getKey());
 | 
											
												
													
														|  |                  continue;
 |  |                  continue;
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  | -            StudentServeDto studentServeDto = studentCoursesEntry.getValue().stream().min(Comparator.comparing(StudentServeDto::getCourseStartTime)).get();
 |  | 
 | 
											
												
													
														|  | 
 |  | +            StudentServeDto studentServeDto = haveCourseStudents.stream().min(Comparator.comparing(StudentServeDto::getCourseStartTime)).get();
 | 
											
												
													
														|  |              if(Objects.isNull(studentServeDto.getCourseStartTime())){
 |  |              if(Objects.isNull(studentServeDto.getCourseStartTime())){
 | 
											
												
													
														|  |                  noClassStudentIds.add(studentCoursesEntry.getKey());
 |  |                  noClassStudentIds.add(studentCoursesEntry.getKey());
 | 
											
												
													
														|  |                  continue;
 |  |                  continue;
 | 
											
										
											
												
													
														|  | @@ -87,8 +88,9 @@ public class StudentServeServiceImpl implements StudentServeService {
 | 
											
												
													
														|  |                  dontServeInCurrentWeekStudentIds.add(studentCoursesEntry.getKey());
 |  |                  dontServeInCurrentWeekStudentIds.add(studentCoursesEntry.getKey());
 | 
											
												
													
														|  |                  continue;
 |  |                  continue;
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  | -            if(GroupType.PRACTICE.equals(studentServeDto.getGroupType())||
 |  | 
 | 
											
												
													
														|  | -                    (GroupType.MUSIC.equals(studentServeDto.getGroupType())&&TeachModeEnum.OFFLINE.equals(studentServeDto.getTeachMode()))){
 |  | 
 | 
											
												
													
														|  | 
 |  | +            long count = haveCourseStudents.stream().filter(e -> GroupType.PRACTICE.equals(e.getGroupType()) ||
 | 
											
												
													
														|  | 
 |  | +                    (GroupType.MUSIC.equals(e.getGroupType()) && TeachModeEnum.OFFLINE.equals(e.getTeachMode()))).count();
 | 
											
												
													
														|  | 
 |  | +            if(count>0){
 | 
											
												
													
														|  |                  haveClassStudentIds.add(studentCoursesEntry.getKey());
 |  |                  haveClassStudentIds.add(studentCoursesEntry.getKey());
 | 
											
												
													
														|  |              }else{
 |  |              }else{
 | 
											
												
													
														|  |                  noClassStudentIds.add(studentCoursesEntry.getKey());
 |  |                  noClassStudentIds.add(studentCoursesEntry.getKey());
 | 
											
										
											
												
													
														|  | @@ -109,23 +111,23 @@ public class StudentServeServiceImpl implements StudentServeService {
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          List<StudentExtracurricularExercisesSituation> results=new ArrayList<>();
 |  |          List<StudentExtracurricularExercisesSituation> results=new ArrayList<>();
 | 
											
												
													
														|  | -        for (StudentServeDto serviceStudent : serviceStudents) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        for (Map.Entry<Integer, List<StudentServeDto>> studentCoursesEntry : studentCoursesMap.entrySet()) {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -            if(dontServeInCurrentWeekStudentIds.contains(serviceStudent.getUserId())){
 |  | 
 | 
											
												
													
														|  | 
 |  | +            if(dontServeInCurrentWeekStudentIds.contains(studentCoursesEntry.getKey())){
 | 
											
												
													
														|  |                  continue;
 |  |                  continue;
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              StudentExtracurricularExercisesSituation studentExtracurricularExercisesSituation=new StudentExtracurricularExercisesSituation();
 |  |              StudentExtracurricularExercisesSituation studentExtracurricularExercisesSituation=new StudentExtracurricularExercisesSituation();
 | 
											
												
													
														|  | -            studentExtracurricularExercisesSituation.setStudentId(serviceStudent.getUserId());
 |  | 
 | 
											
												
													
														|  | -            studentExtracurricularExercisesSituation.setTeacherId(serviceStudent.getTeacherId());
 |  | 
 | 
											
												
													
														|  | 
 |  | +            studentExtracurricularExercisesSituation.setStudentId(studentCoursesEntry.getKey());
 | 
											
												
													
														|  | 
 |  | +            studentExtracurricularExercisesSituation.setTeacherId(studentCoursesEntry.getValue().get(0).getTeacherId());
 | 
											
												
													
														|  |              studentExtracurricularExercisesSituation.setExpectExercisesNum(1);
 |  |              studentExtracurricularExercisesSituation.setExpectExercisesNum(1);
 | 
											
												
													
														|  |              studentExtracurricularExercisesSituation.setWeekOfYear(nowDate.get(DateUtil.weekFields.weekOfYear()));
 |  |              studentExtracurricularExercisesSituation.setWeekOfYear(nowDate.get(DateUtil.weekFields.weekOfYear()));
 | 
											
												
													
														|  |              studentExtracurricularExercisesSituation.setMonday(DateUtil.stringToDate(monDayDate.toString(), "yyyy-MM-dd"));
 |  |              studentExtracurricularExercisesSituation.setMonday(DateUtil.stringToDate(monDayDate.toString(), "yyyy-MM-dd"));
 | 
											
												
													
														|  |              studentExtracurricularExercisesSituation.setSunday(DateUtil.stringToDate(sunDayDate.toString(), "yyyy-MM-dd"));
 |  |              studentExtracurricularExercisesSituation.setSunday(DateUtil.stringToDate(sunDayDate.toString(), "yyyy-MM-dd"));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -            if(haveClassStudentIds.contains(serviceStudent.getUserId())){
 |  | 
 | 
											
												
													
														|  | 
 |  | +            if(haveClassStudentIds.contains(studentCoursesEntry.getKey())){
 | 
											
												
													
														|  |                  studentExtracurricularExercisesSituation.setServeType("HOMEWORK");
 |  |                  studentExtracurricularExercisesSituation.setServeType("HOMEWORK");
 | 
											
												
													
														|  | -                List<StudentServeCourseHomeworkDto> studentHomeworks = studentHomeworkMap.get(serviceStudent.getUserId());
 |  | 
 | 
											
												
													
														|  | 
 |  | +                List<StudentServeCourseHomeworkDto> studentHomeworks = studentHomeworkMap.get(studentCoursesEntry.getKey());
 | 
											
												
													
														|  |                  if(CollectionUtils.isEmpty(studentHomeworks)){
 |  |                  if(CollectionUtils.isEmpty(studentHomeworks)){
 | 
											
												
													
														|  |                      studentExtracurricularExercisesSituation.setActualExercisesNum(0);
 |  |                      studentExtracurricularExercisesSituation.setActualExercisesNum(0);
 | 
											
												
													
														|  |                      studentExtracurricularExercisesSituation.setExercisesReplyNum(0);
 |  |                      studentExtracurricularExercisesSituation.setExercisesReplyNum(0);
 | 
											
										
											
												
													
														|  | @@ -161,9 +163,9 @@ public class StudentServeServiceImpl implements StudentServeService {
 | 
											
												
													
														|  |                  }
 |  |                  }
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -            if(noClassStudentIds.contains(serviceStudent.getUserId())){
 |  | 
 | 
											
												
													
														|  | 
 |  | +            if(noClassStudentIds.contains(studentCoursesEntry.getKey())){
 | 
											
												
													
														|  |                  studentExtracurricularExercisesSituation.setServeType("EXERCISE");
 |  |                  studentExtracurricularExercisesSituation.setServeType("EXERCISE");
 | 
											
												
													
														|  | -                List<ExtracurricularExercisesReply> studentExercises = studentExercisesMap.get(serviceStudent.getUserId());
 |  | 
 | 
											
												
													
														|  | 
 |  | +                List<ExtracurricularExercisesReply> studentExercises = studentExercisesMap.get(studentCoursesEntry.getKey());
 | 
											
												
													
														|  |                  if(CollectionUtils.isEmpty(studentExercises)){
 |  |                  if(CollectionUtils.isEmpty(studentExercises)){
 | 
											
												
													
														|  |                      studentExtracurricularExercisesSituation.setActualExercisesNum(0);
 |  |                      studentExtracurricularExercisesSituation.setActualExercisesNum(0);
 | 
											
												
													
														|  |                      studentExtracurricularExercisesSituation.setExercisesReplyNum(0);
 |  |                      studentExtracurricularExercisesSituation.setExercisesReplyNum(0);
 |