|
@@ -111,6 +111,7 @@ public class TeacherAttendanceServiceImpl extends BaseServiceImpl<Long, TeacherA
|
|
teacherAttendance.setClassGroupId(currentCourseDetail.getClassId());
|
|
teacherAttendance.setClassGroupId(currentCourseDetail.getClassId());
|
|
teacherAttendance.setRemark(teacherSignOutDto.getTeacherAttendanceInfo().getRemark());
|
|
teacherAttendance.setRemark(teacherSignOutDto.getTeacherAttendanceInfo().getRemark());
|
|
int advanceSignMinutes = Integer.parseInt(sysConfigDao.findConfigValue(SysConfigService.ADVANCE_SIGN_IN_MINUTES));
|
|
int advanceSignMinutes = Integer.parseInt(sysConfigDao.findConfigValue(SysConfigService.ADVANCE_SIGN_IN_MINUTES));
|
|
|
|
+ int offlineSignInEarlyForwardTime = Integer.parseInt(sysConfigDao.findConfigValue(SysConfigService.OFFLINE_SIGN_IN_EARLY_FORWARD_TIME));
|
|
|
|
|
|
CourseSchedule courseSchedule = courseScheduleDao.get(teacherAttendance.getCourseScheduleId());
|
|
CourseSchedule courseSchedule = courseScheduleDao.get(teacherAttendance.getCourseScheduleId());
|
|
teacherAttendance.setGroupType(courseSchedule.getGroupType());
|
|
teacherAttendance.setGroupType(courseSchedule.getGroupType());
|
|
@@ -124,13 +125,16 @@ public class TeacherAttendanceServiceImpl extends BaseServiceImpl<Long, TeacherA
|
|
throw new BizException("明天的课程不能进行签到");
|
|
throw new BizException("明天的课程不能进行签到");
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ School school = schoolDao.get(courseSchedule.getSchoolId());
|
|
|
|
+
|
|
String classDate = DateUtil.format(courseSchedule.getClassDate(), DateUtil.DEFAULT_PATTERN);
|
|
String classDate = DateUtil.format(courseSchedule.getClassDate(), DateUtil.DEFAULT_PATTERN);
|
|
String startClassTime = DateUtil.format(courseSchedule.getStartClassTime(), DateUtil.EXPANDED_TIME_FORMAT);
|
|
String startClassTime = DateUtil.format(courseSchedule.getStartClassTime(), DateUtil.EXPANDED_TIME_FORMAT);
|
|
String endClassTime = DateUtil.format(courseSchedule.getEndClassTime(), DateUtil.EXPANDED_TIME_FORMAT);
|
|
String endClassTime = DateUtil.format(courseSchedule.getEndClassTime(), DateUtil.EXPANDED_TIME_FORMAT);
|
|
//上课时间
|
|
//上课时间
|
|
Date classStartDateTime = DateUtil.stringToDate(classDate + " " + startClassTime, DateUtil.EXPANDED_DATE_TIME_FORMAT);
|
|
Date classStartDateTime = DateUtil.stringToDate(classDate + " " + startClassTime, DateUtil.EXPANDED_DATE_TIME_FORMAT);
|
|
Date classEndDateTime = DateUtil.stringToDate(classDate + " " + endClassTime, DateUtil.EXPANDED_DATE_TIME_FORMAT);
|
|
Date classEndDateTime = DateUtil.stringToDate(classDate + " " + endClassTime, DateUtil.EXPANDED_DATE_TIME_FORMAT);
|
|
- Date classEndDateAdd60Minutes = DateUtil.addMinutes(classEndDateTime, 180);
|
|
|
|
|
|
+ Date classEndDateAdd60Minutes = DateUtil.addMinutes(classEndDateTime, 60);
|
|
|
|
+ Date add60Minutes = DateUtil.addMinutes(classStartDateTime, offlineSignInEarlyForwardTime * -1);
|
|
Date add20Minutes = DateUtil.addMinutes(classStartDateTime, advanceSignMinutes * -1);
|
|
Date add20Minutes = DateUtil.addMinutes(classStartDateTime, advanceSignMinutes * -1);
|
|
if(teacherAttendance.getSignInTime() == null && teacherSignOutDto.getTeacherAttendanceInfo().getStatus().equals(SignStatusEnum.SIGN_IN.getCode())){
|
|
if(teacherAttendance.getSignInTime() == null && teacherSignOutDto.getTeacherAttendanceInfo().getStatus().equals(SignStatusEnum.SIGN_IN.getCode())){
|
|
|
|
|
|
@@ -138,8 +142,6 @@ public class TeacherAttendanceServiceImpl extends BaseServiceImpl<Long, TeacherA
|
|
throw new BizException("未获取到您的位置");
|
|
throw new BizException("未获取到您的位置");
|
|
}
|
|
}
|
|
|
|
|
|
- School school = schoolDao.get(courseSchedule.getSchoolId());
|
|
|
|
-
|
|
|
|
//是否在范围内
|
|
//是否在范围内
|
|
boolean isInScore = true;
|
|
boolean isInScore = true;
|
|
if(StringUtils.isBlank(school.getLongitudeLatitude())){
|
|
if(StringUtils.isBlank(school.getLongitudeLatitude())){
|
|
@@ -165,24 +167,25 @@ public class TeacherAttendanceServiceImpl extends BaseServiceImpl<Long, TeacherA
|
|
throw new BizException("该课程已结束,不能进行签到!");
|
|
throw new BizException("该课程已结束,不能进行签到!");
|
|
}
|
|
}
|
|
|
|
|
|
- YesOrNoEnum yesOrNoEnum = YesOrNoEnum.NO;
|
|
|
|
|
|
+ boolean enableIgnoreAttendanceTime = false;
|
|
if(Objects.nonNull(courseSchedule.getSchoolId())){
|
|
if(Objects.nonNull(courseSchedule.getSchoolId())){
|
|
- yesOrNoEnum = courseScheduleService.enableOnlyNormalAttendance(currentCourseDetail.getStartClassTime(),
|
|
|
|
- user.getId().longValue(),
|
|
|
|
- true,
|
|
|
|
|
|
+ enableIgnoreAttendanceTime = courseScheduleService.enableIgnoreAttendanceTime(currentCourseDetail.getStartClassTime(),
|
|
|
|
+ user.getId(),
|
|
currentCourseDetail.getSchoolId().intValue());
|
|
currentCourseDetail.getSchoolId().intValue());
|
|
}
|
|
}
|
|
teacherAttendance.setSignInTime(date);
|
|
teacherAttendance.setSignInTime(date);
|
|
teacherAttendance.setSignInStatus(YesOrNoEnum.YES);
|
|
teacherAttendance.setSignInStatus(YesOrNoEnum.YES);
|
|
result.put("signInStatus",0);
|
|
result.put("signInStatus",0);
|
|
- if(yesOrNoEnum == YesOrNoEnum.YES){
|
|
|
|
- //连堂课
|
|
|
|
- }else if(DateUtil.minutesBetween(date,add20Minutes) >= 0){
|
|
|
|
|
|
+ if(!isInScore){
|
|
|
|
+ teacherAttendance.setSignInStatus(YesOrNoEnum.NO);
|
|
|
|
+ }else if(enableIgnoreAttendanceTime){
|
|
|
|
+ //连堂课,可忽略正常时间签到范围
|
|
|
|
+ }else if(date.compareTo(add20Minutes) <= 0&&date.compareTo(add60Minutes)>=0){
|
|
//正常签到范围(开始前60分钟 ~ 开始之前20分钟)
|
|
//正常签到范围(开始前60分钟 ~ 开始之前20分钟)
|
|
if(!isInScore){
|
|
if(!isInScore){
|
|
teacherAttendance.setSignInStatus(YesOrNoEnum.NO);
|
|
teacherAttendance.setSignInStatus(YesOrNoEnum.NO);
|
|
}
|
|
}
|
|
- }else if(DateUtil.minutesBetween(add20Minutes,date) > 0){
|
|
|
|
|
|
+ }else if(date.compareTo(add20Minutes) > 0&&date.compareTo(add60Minutes) < 0){
|
|
if(StringUtils.isEmpty(teacherAttendance.getRemark())&&!teacherSignOutDto.isNotRturnErrorInfo()){
|
|
if(StringUtils.isEmpty(teacherAttendance.getRemark())&&!teacherSignOutDto.isNotRturnErrorInfo()){
|
|
//当前为异常签到,请填写原因!
|
|
//当前为异常签到,请填写原因!
|
|
result.put("status",2);
|
|
result.put("status",2);
|
|
@@ -201,17 +204,42 @@ public class TeacherAttendanceServiceImpl extends BaseServiceImpl<Long, TeacherA
|
|
}
|
|
}
|
|
return result;
|
|
return result;
|
|
}else if(teacherAttendance.getSignOutTime() == null && teacherSignOutDto.getTeacherAttendanceInfo().getStatus().equals(SignStatusEnum.SIGN_OUT.getCode())){
|
|
}else if(teacherAttendance.getSignOutTime() == null && teacherSignOutDto.getTeacherAttendanceInfo().getStatus().equals(SignStatusEnum.SIGN_OUT.getCode())){
|
|
|
|
+ //是否在范围内
|
|
|
|
+ boolean isInScore = false;
|
|
|
|
+ if(StringUtils.isBlank(school.getLongitudeLatitude())){
|
|
|
|
+ if(teacherSignOutDto.getTeacherAttendanceInfo().getUpdate().equals(YesOrNoEnum.YES.getCode())){
|
|
|
|
+ school.setLongitudeLatitude(teacherSignOutDto.getTeacherAttendanceInfo().getSignInLongitudeLatitude());
|
|
|
|
+ schoolDao.update(school);
|
|
|
|
+ }
|
|
|
|
+ }else if(StringUtils.isNotBlank(teacherSignOutDto.getTeacherAttendanceInfo().getSignOutLongitudeLatitude())){
|
|
|
|
+ SysConfig sysConfig = sysConfigService.findByParamName(SysConfigService.ATTENDANCE_RANGE);
|
|
|
|
+ double attendanceRange = Double.valueOf(sysConfig.getParanValue());
|
|
|
|
+ double distance = MapUtil.distance(teacherSignOutDto.getTeacherAttendanceInfo().getSignInLongitudeLatitude(),
|
|
|
|
+ school.getLongitudeLatitude());
|
|
|
|
+ if(distance<=attendanceRange){
|
|
|
|
+ isInScore=true;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
//正常签退范围(结束后1小时内)
|
|
//正常签退范围(结束后1小时内)
|
|
teacherAttendance.setSignOutTime(date);
|
|
teacherAttendance.setSignOutTime(date);
|
|
teacherAttendance.setSignOutAttachments(teacherSignOutDto.getCourseHomeworkInfo().getAttachments());
|
|
teacherAttendance.setSignOutAttachments(teacherSignOutDto.getCourseHomeworkInfo().getAttachments());
|
|
ClassGroup classGroup = classGroupDao.get(courseSchedule.getClassGroupId());
|
|
ClassGroup classGroup = classGroupDao.get(courseSchedule.getClassGroupId());
|
|
teacherAttendance.setCurrentClassTimes(classGroup.getCurrentClassTimes() + 1);
|
|
teacherAttendance.setCurrentClassTimes(classGroup.getCurrentClassTimes() + 1);
|
|
- if(DateUtil.minutesBetween(classEndDateTime,date) >= 0 && DateUtil.minutesBetween(date,classEndDateAdd60Minutes) >= 0){
|
|
|
|
|
|
+ if(!isInScore){
|
|
|
|
+ teacherAttendance.setSignOutStatus(YesOrNoEnum.NO);
|
|
|
|
+ result.put("signOutStatus",1);
|
|
|
|
+ }else if(date.compareTo(classEndDateTime) >= 0 && date.compareTo(classEndDateAdd60Minutes) <= 0){
|
|
teacherAttendance.setSignOutStatus(YesOrNoEnum.YES);
|
|
teacherAttendance.setSignOutStatus(YesOrNoEnum.YES);
|
|
- result.put("signInStatus",0);
|
|
|
|
- }else if(DateUtil.minutesBetween(classEndDateAdd60Minutes,date) > 0){
|
|
|
|
|
|
+ result.put("signOutStatus",0);
|
|
|
|
+ }else if(date.compareTo(classEndDateAdd60Minutes) > 0){
|
|
|
|
+ if(StringUtils.isEmpty(teacherAttendance.getSignOutRemark())&&!teacherSignOutDto.isNotRturnErrorInfo()){
|
|
|
|
+ //当前为异常签退,请填写原因!
|
|
|
|
+ result.put("status",2);
|
|
|
|
+ return result;
|
|
|
|
+ }
|
|
teacherAttendance.setSignOutStatus(YesOrNoEnum.NO);
|
|
teacherAttendance.setSignOutStatus(YesOrNoEnum.NO);
|
|
- result.put("signInStatus",1);
|
|
|
|
|
|
+ result.put("signOutStatus",1);
|
|
}else {
|
|
}else {
|
|
throw new BizException("签退时间异常");
|
|
throw new BizException("签退时间异常");
|
|
}
|
|
}
|