You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

90 lines
4.8 KiB
Java

11 months ago
package com.engine.jucailinkq.attendance.attendanceanalysis.job;
2 years ago
11 months ago
import com.engine.jucailinkq.attendance.attendanceanalysis.wrapper.AttendanceAnalysisWrapper;
import com.engine.jucailinkq.attendance.attendanceplan.service.AttendancePlanService;
import com.engine.jucailinkq.attendance.attendanceplan.service.impl.AttendancePlanServiceImpl;
import com.engine.jucailinkq.attendance.workflow.service.AllowanceService;
import com.engine.jucailinkq.attendance.workflow.service.impl.AllowanceServiceImpl;
12 months ago
import com.engine.common.util.*;
11 months ago
import com.engine.jucailinkq.common.util.CommonUtil;
import com.engine.jucailinkq.common.util.DateUtil;
import com.engine.jucailinkq.common.util.DbTools;
2 years ago
import com.google.common.collect.Maps;
2 years ago
import lombok.extern.slf4j.Slf4j;
import weaver.general.Util;
import weaver.interfaces.schedule.BaseCronJob;
1 year ago
import java.time.ZoneOffset;
import java.util.Comparator;
2 years ago
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
@Slf4j
public class AttendanceAnalysisJob extends BaseCronJob {
2 years ago
private AttendancePlanService basicsetService = ServiceUtil.getService(AttendancePlanServiceImpl.class);
2 years ago
private AttendanceAnalysisWrapper attendanceAnalysisService = ServiceUtil.getService(AttendanceAnalysisWrapper.class);
1 year ago
1 year ago
private AllowanceService allowanceService = ServiceUtil.getService(AllowanceServiceImpl.class);
1 year ago
private String executeDate;
2 years ago
@Override
public void execute() {
12 months ago
log.debug("********AttendanceAnalysisJob start********");
2 years ago
10 months ago
String queryUserSql = "select id,departmentid,subcompanyid1 from hrmresource where status <> '5' and status <> '4' and status <> '7'";
2 years ago
List<Map<String,Object>> userList = DbTools.getSqlToList(queryUserSql);
1 year ago
String beforeFourDayDate = DateUtil.getCurrentDateMinusDay(4);
12 months ago
String nowDate = DateUtil.getCurrentDate();
1 year ago
if (executeDate != null && !"".equals(executeDate)){
nowDate = executeDate;
beforeFourDayDate = DateUtil.beforeDay(executeDate,4);
}
1 year ago
String sql = "select id,userid,signdate,signtime from hrmschedulesign where isincom=1 and signdate >= ? and signdate <= ? order by signdate,signtime";
1 year ago
List<Map<String,Object>> dataList = DbTools.getSqlToList(sql,beforeFourDayDate,nowDate);
1 year ago
//补打卡记录
12 months ago
sql = "select id,bdkry userid,dkrq signdate,dksj signtime from uf_jcl_kq_bdkjl where dkrq >= ? and dkrq <= ? and jlzt=1 order by dkrq,dksj";
1 year ago
List<Map<String,Object>> makeUpList = DbTools.getSqlToList(sql,beforeFourDayDate,nowDate);
if (makeUpList.size() > 0){
dataList.addAll(makeUpList);
}
dataList = dataList.stream().sorted(Comparator.comparing(e->DateUtil.getTime(e.get("signdate")+" "+e.get("signtime")).toInstant(ZoneOffset.of("+8")).toEpochMilli())).collect(Collectors.toList());
2 years ago
Map<String, List<Map<String,Object>>> collect = dataList.stream().collect(Collectors.groupingBy(e -> Util.null2String(e.get("userid"))));
sql = "select sjzt,sgsj,ygid,rq from uf_jcl_kq_cqjg where rq>=? and rq<=?";
List<Map<String,Object>> attendaceResult = DbTools.getSqlToList(sql,DateUtil.beforeDay(nowDate,2),DateUtil.beforeDay(nowDate,1));
Map<String,List<Map<String,Object>>> attendaceGroupById = attendaceResult.stream().collect(Collectors.groupingBy(e->e.get("ygid").toString()));
2 years ago
12 months ago
//初始化扩展类
CommonUtil.initExtensionClassHolder();
2 years ago
for (Map<String,Object> userMap:userList){
String userId = Util.null2String(userMap.get("id"));
1 year ago
//日期对应的打卡数据
Map<String,Map<String,Object>> clockInTimeMap = Maps.newHashMap();
2 years ago
/**获得人员考勤项目*/
Map<String,Object> paramMap = Maps.newHashMap();
1 year ago
paramMap.put("startDate",beforeFourDayDate);
paramMap.put("endDate",nowDate);
2 years ago
paramMap.put("resourceId",userId);
Map<String,Object> dataMap = basicsetService.getAttendanceItemsByPerson(paramMap);
List<Map<String,Object>> attendanceItems = (List<Map<String,Object>>)dataMap.get("data");
1 year ago
/**
*
*/
Map<String,Object> workHourdataMap = basicsetService.getWorkHoursItemByPerson(paramMap);
List<Map<String,Object>> workHourItems = (List<Map<String,Object>>)workHourdataMap.get("data");
2 years ago
attendanceAnalysisService.attendanceAnalysis(userId,nowDate,collect.get(userMap.get("id")),attendanceItems,workHourItems,clockInTimeMap,attendaceGroupById.get(userId));
2 years ago
}
1 year ago
Map<String,Object> param = Maps.newHashMap();
param.put("startDate",DateUtil.beforeDay(nowDate,1));
param.put("endDate",nowDate);
1 year ago
allowanceService.addAllowanceRecords(param);
12 months ago
log.debug("********AttendanceAnalysisJob end********");
2 years ago
}
}