|
@@ -171,7 +171,7 @@ public class AttendanceServiceImpl extends ServiceImpl<AttendanceMapper, Attenda
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
- }
|
|
|
+
|
|
|
|
|
|
|
|
|
|
|
@@ -296,6 +296,7 @@ public class AttendanceServiceImpl extends ServiceImpl<AttendanceMapper, Attenda
|
|
|
}
|
|
|
lit.add(at);
|
|
|
}
|
|
|
+ }
|
|
|
List<Vacation> vacation = vacationMapper.vacation(userid, date);//获取当前用户的假期数据
|
|
|
List< Map<String,Object>> oneWork = attendanceMapper.getOneWork(userid, date);
|
|
|
map.put("date",attendances);
|
|
@@ -323,104 +324,130 @@ public class AttendanceServiceImpl extends ServiceImpl<AttendanceMapper, Attenda
|
|
|
int year = calendar.get(calendar.YEAR);//年份
|
|
|
int month = calendar.get(calendar.MONTH) + 1;//月份
|
|
|
int actualMaximum = calendar.getActualMaximum(Calendar.DAY_OF_MONTH);
|
|
|
-
|
|
|
- String eds="0";
|
|
|
- AttendanceRule attendanceRules = attendanceRuleService.UserRule(userid);
|
|
|
- if (attendanceRules!=null){
|
|
|
- eds="1";
|
|
|
- }else {
|
|
|
- List<UserDept> depNamesByUserIds = userShiftMapper.getDepNamesByUserIds(Arrays.asList(userid.split(",")));
|
|
|
- List<String>deps=new ArrayList<>();
|
|
|
- depNamesByUserIds.forEach(st->{
|
|
|
- deps.add(st.getId());
|
|
|
- });
|
|
|
- AttendanceRule attendanceRule1 = attendanceRuleService.UserRules(deps);
|
|
|
- if (attendanceRule1!=null){
|
|
|
- attendanceRules=attendanceRule1;
|
|
|
- eds="1";
|
|
|
+ AttendanceRule attendanceRule = attendanceRuleService.UserRule(userid);
|
|
|
+ if (attendanceRule!=null){
|
|
|
+ for (int i = 1; i <= actualMaximum; i++) {
|
|
|
+ String aDate = String.valueOf(year) + "-" + month + "-" + i;//循环拼接所有天数进行查询是否正常
|
|
|
+ List<Attendance> acs = attendanceMapper.queryList(userid, aDate);
|
|
|
+ String jqw = "";
|
|
|
+ StatutoryLeave one = statutoryLeaveService.getOne(date);
|
|
|
+ if (one != null) {
|
|
|
+ jqw = one.getType();
|
|
|
}
|
|
|
- }
|
|
|
-
|
|
|
- for (int i = 1; i <= actualMaximum; i++){
|
|
|
- String aDate = String.valueOf(year) + "-" + month + "-" + i;//循环拼接所有天数进行查询是否正常
|
|
|
- List<Attendance> acs = attendanceMapper.queryList(userid, aDate);
|
|
|
- if (eds.equals("1")){
|
|
|
- if (attendanceRules.getType().equals("1")){//判断规则类型1,固定时间上下班
|
|
|
- String state="1";
|
|
|
- String[] split = attendanceRules.getWorkDay().split(",");//获取工作日
|
|
|
- Date da = DateUtils.str2Date(aDate, sdf);
|
|
|
- for (String day:split){
|
|
|
- if (day.equals(String.valueOf(da.getDay()))){
|
|
|
- state="2";
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- if (state.equals("2")){//在工作日内
|
|
|
- if (acs!=null&&acs.size()>1){//判断打卡记录是否有上下班
|
|
|
- if (exitprio(acs).equals("1")){//判断打卡记录是否异常,1,异常
|
|
|
- sum="1";
|
|
|
- break;
|
|
|
- }else {
|
|
|
- Date startDate = DateUtils.str2Date("2021-10-21 "+sdt.format(attendanceRules.getStartDate()), sd);
|
|
|
- Date endDate = DateUtils.str2Date("2021-10-21 "+sdt.format(attendanceRules.getEndDate()), sd);
|
|
|
- Date usStartDate = DateUtils.str2Date("2021-10-21 "+sdt.format(acs.get(0).getUsDate()), sd);
|
|
|
- Date usEndDate = DateUtils.str2Date("2021-10-21 "+sdt.format(acs.get(acs.size() - 1).getUsDate()), sd);
|
|
|
- if (usStartDate.getTime()>startDate.getTime()||usEndDate.getTime()<endDate.getTime()){
|
|
|
- sum="1";
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- }else {
|
|
|
- sum="1";
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
|
|
|
- }else if (attendanceRules.getType().equals("2")){//规则类型 2,按班次上下班
|
|
|
- List<Map<String,Object>> oneUserShift = userShiftMapper.getOneUserShift(userid, aDate,"");
|
|
|
- if (oneUserShift!=null&&oneUserShift.size()>0){
|
|
|
- if (acs!=null&&acs.size()>1){//判断打卡记录是否有上下班
|
|
|
- if (exitprio(acs).equals("1")){//判断打卡记录是否异常,1,异常
|
|
|
- sum="1";
|
|
|
- break;
|
|
|
- }else {
|
|
|
- Date startDate = DateUtils.str2Date("2021-10-21 "+oneUserShift.get(0).get("startDate"), sd);
|
|
|
- Date endDate = DateUtils.str2Date("2021-10-21 "+oneUserShift.get(0).get("endDate"), sd);
|
|
|
- Date usStartDate = DateUtils.str2Date("2021-10-21 "+sdt.format(acs.get(0).getUsDate()), sd);
|
|
|
- Date usEndDate = DateUtils.str2Date("2021-10-21 "+sdt.format(acs.get(acs.size() - 1).getUsDate()), sd);
|
|
|
- if (usStartDate.getTime()>startDate.getTime()||usEndDate.getTime()<endDate.getTime()){
|
|
|
- sum="1";
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- }else {
|
|
|
- sum="1";
|
|
|
- break;
|
|
|
- }
|
|
|
+ if (attendanceRule.getType().equals("1")) {//判断规则类型1,固定时间上下班
|
|
|
+ if (jqw.equals("1")) {//优先判断是否存在法定节假日
|
|
|
+ if (acs != null && acs.size() > 1) {//判断打卡记录是否有上下班
|
|
|
+ if (exitprio(acs).equals("1")) {//判断打卡记录是否异常,1,异常
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
+ } else {
|
|
|
+ Date startDate = DateUtils.str2Date("2021-10-21 " + sdt.format(attendanceRule.getStartDate()), sd);
|
|
|
+ Date endDate = DateUtils.str2Date("2021-10-21 " + sdt.format(attendanceRule.getEndDate()), sd);
|
|
|
+ Date usStartDate = DateUtils.str2Date("2021-10-21 " + sdt.format(acs.get(0).getUsDate()), sd);
|
|
|
+ Date usEndDate = DateUtils.str2Date("2021-10-21 " + sdt.format(acs.get(acs.size() - 1).getUsDate()), sd);
|
|
|
+ if (usStartDate.getTime() > startDate.getTime() || usEndDate.getTime() < endDate.getTime()) {
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
}
|
|
|
- }else if (attendanceRules.getType().equals("3")){//规则类型 3,自由上下班
|
|
|
- String states="1";
|
|
|
- String[] split = attendanceRules.getWorkDay().split(",");//获取工作日
|
|
|
- Date da = DateUtils.str2Date(aDate, sdf);
|
|
|
- for (String day:split){
|
|
|
- if (day.equals(String.valueOf(da.getDay()))){
|
|
|
- states="2";
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ } else if (jqw.equals("")) {
|
|
|
+ String state = "1";
|
|
|
+ String[] split = attendanceRule.getWorkDay().split(",");//获取工作日
|
|
|
+ Date da = DateUtils.str2Date(aDate, sdf);
|
|
|
+ for (String day : split) {
|
|
|
+ if (day.equals(String.valueOf(da.getDay()))) {
|
|
|
+ state = "2";
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (state.equals("2")) {//在工作日内
|
|
|
+ if (acs != null && acs.size() > 1) {//判断打卡记录是否有上下班
|
|
|
+ if (exitprio(acs).equals("1")) {//判断打卡记录是否异常,1,异常
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
+ } else {
|
|
|
+ Date startDate = DateUtils.str2Date("2021-10-21 " + sdt.format(attendanceRule.getStartDate()), sd);
|
|
|
+ Date endDate = DateUtils.str2Date("2021-10-21 " + sdt.format(attendanceRule.getEndDate()), sd);
|
|
|
+ Date usStartDate = DateUtils.str2Date("2021-10-21 " + sdt.format(acs.get(0).getUsDate()), sd);
|
|
|
+ Date usEndDate = DateUtils.str2Date("2021-10-21 " + sdt.format(acs.get(acs.size() - 1).getUsDate()), sd);
|
|
|
+ if (usStartDate.getTime() > startDate.getTime() || usEndDate.getTime() < endDate.getTime()) {
|
|
|
+ sum = "1";
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
|
- if (states.equals("2")) {//在工作日内
|
|
|
- if (acs != null && acs.size() > 1) {//判断打卡记录是否有上下班
|
|
|
- if (exitprio(acs).equals("1")) {//判断打卡记录是否异常,1,异常
|
|
|
- sum = "1";
|
|
|
- break;
|
|
|
- }
|
|
|
- } else {
|
|
|
+ } else {
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else if (attendanceRule.getType().equals("2")) {//规则类型 2,按班次上下班
|
|
|
+ List<Map<String, Object>> oneUserShift = userShiftMapper.getOneUserShift(userid, aDate, "");
|
|
|
+ if (oneUserShift != null && oneUserShift.size() > 0) {
|
|
|
+ if (oneUserShift.get(0).get("id").equals("0")) {
|
|
|
+
|
|
|
+ } else {
|
|
|
+ if (acs != null && acs.size() > 1) {//判断打卡记录是否有上下班
|
|
|
+ if (exitprio(acs).equals("1")) {//判断打卡记录是否异常,1,异常
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
+ } else {
|
|
|
+ Date startDate = DateUtils.str2Date("2021-10-21 " + oneUserShift.get(0).get("startDate"), sd);
|
|
|
+ Date endDate = DateUtils.str2Date("2021-10-21 " + oneUserShift.get(0).get("endDate"), sd);
|
|
|
+ Date usStartDate = DateUtils.str2Date("2021-10-21 " + sdt.format(acs.get(0).getUsDate()), sd);
|
|
|
+ Date usEndDate = DateUtils.str2Date("2021-10-21 " + sdt.format(acs.get(acs.size() - 1).getUsDate()), sd);
|
|
|
+ if (usStartDate.getTime() > startDate.getTime() || usEndDate.getTime() < endDate.getTime()) {
|
|
|
sum = "1";
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
|
+ } else {
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else if (attendanceRule.getType().equals("3")) {//规则类型 3,自由上下班
|
|
|
+ if (jqw.equals("1")) {//优先判断是否存在法定节假日
|
|
|
+ if (acs != null && acs.size() > 1) {//判断打卡记录是否有上下班
|
|
|
+ if (exitprio(acs).equals("1")) {//判断打卡记录是否异常,1,异常
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
}
|
|
|
+ } else {
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
}
|
|
|
+ } else if (jqw.equals("")) {
|
|
|
+ String states = "1";
|
|
|
+ String[] split = attendanceRule.getWorkDay().split(",");//获取工作日
|
|
|
+ Date da = DateUtils.str2Date(aDate, sdf);
|
|
|
+ for (String day : split) {
|
|
|
+ if (day.equals(String.valueOf(da.getDay()))) {
|
|
|
+ states = "2";
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if (states.equals("2")) {
|
|
|
+ if (acs != null && acs.size() > 1) {//判断打卡记录是否有上下班
|
|
|
+ if (exitprio(acs).equals("1")) {//判断打卡记录是否异常,1,异常
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ sum = "1";
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
return sum;
|
|
|
}
|