package cn.timer.api.controller.kqgl.atttimer;

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Locale;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;

import cn.timer.api.bean.kqgl.AttendanceWeeklySch;
import cn.timer.api.bean.kqgl.PunchCardDetails;
import cn.timer.api.bean.kqgl.PunchRecord;
import cn.timer.api.bean.kqgl.Schedule;
import cn.timer.api.bean.kqmk.KqglAssoBcsz;
import cn.timer.api.bean.kqmk.KqglAssoLeaveRules;
import cn.timer.api.bean.kqmk.KqglAssoMonthPunchSummary;
import cn.timer.api.bean.kqmk.KqglAssoOvertimeBasics;
import cn.timer.api.bean.kqmk.KqglAssoPbmx;
import cn.timer.api.bean.kqmk.KqglAssoRelationSummary;
import cn.timer.api.bean.kqmk.KqglAssoTeshu;
import cn.timer.api.bean.kqmk.KqglAssoZhoupaiban;
import cn.timer.api.bean.kqmk.KqglMainKqz;
import cn.timer.api.bean.qyzx.QyzxEntInfoM;
import cn.timer.api.bean.yggl.YgglMainLzb;
import cn.timer.api.controller.kqgl.ClockInController;
import cn.timer.api.controller.kqgl.ClockInTool;
import cn.timer.api.controller.kqgl.EmptyUtil;
import cn.timer.api.dao.kqgl.AttendanceWeeklySchMapper;
import cn.timer.api.dao.kqgl.PunchCardDetailsMapper;
import cn.timer.api.dao.kqgl.PunchRecordMapper;
import cn.timer.api.dao.kqgl.ScheduleMapper;
import cn.timer.api.dao.kqmk.KqglAssoDkmxMapper;
import cn.timer.api.dao.kqmk.KqglAssoLeaveBalanceMapper;
import cn.timer.api.dao.kqmk.KqglAssoRelationSummaryMapper;
import cn.timer.api.dao.kqmk.KqglAssoTeshuMapper;
import cn.timer.api.dao.kqmk.KqglMainKqzMapper;
import cn.timer.api.dao.qyzx.QyzxEntInfoMMapper;
import cn.timer.api.dto.kqmk.AdditionalDto;
import cn.timer.api.dto.kqmk.AttSchedule;
import cn.timer.api.dto.kqmk.AttSubsidiaryDto;
import cn.timer.api.dto.kqmk.AttendanceCardListDto;
import cn.timer.api.utils.DateUtil;

/**
 * @author lal
 *	考勤报表汇总数据
 */
//@Component
//@Lazy
@Configuration      //1.主要用于标记配置类,兼备Component的效果。
@EnableScheduling   // 2.开启定时任务
public class AttendanceTaskTiming{

	
	@Autowired
	private KqglMainKqzMapper kqglmainkqzmapper;
	@Autowired
	private QyzxEntInfoMMapper qyzxentinfommapper;
	@Autowired
	private KqglAssoLeaveBalanceMapper kqglassoleavebalancemapper;
	@Autowired
	private KqglAssoTeshuMapper kqglassoteshumapper;
	@Autowired
	private PunchCardDetailsMapper punchcarddetailsmapper;
	@Autowired
	private AttendanceWeeklySchMapper attendanceweeklyschmapper;
	@Autowired
	private ScheduleMapper schedulemapper;
	static SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd");
	static SimpleDateFormat sdf2 = new SimpleDateFormat("EEE");

	@Autowired
	private KqglAssoRelationSummaryMapper kqglassorelationsummarymapper;
	@Autowired
	private PunchRecordMapper punchrecordmapper;
	@Autowired
	private KqglAssoDkmxMapper kqglassodkmxmapper;
	
	
	@Autowired
	private ClockInController clockincontroller;

	 //3.添加定时任务 每四小时执行一次
//     @Scheduled(cron = "0 0 */4 * * ?")
	
	//typeid:1-员工  2-考勤组

//	@Scheduled(cron = "0 */5 * * * ?")
//	@Scheduled(cron = "0 50 18 * * ?")
	@Scheduled(cron = "0 0 8,12,16,20 * * ?")//每天上午8、12点,下午16点,20点 执行
	public void AttendanceTask() throws ParseException {

		boolean implement = true;
		//逻辑
		if(implement) {
			
			Calendar c = Calendar.getInstance();    
			c.add(Calendar.MONTH, 0);
			c.set(Calendar.DAY_OF_MONTH,1);//设置为1号,当前日期既为本月第一天 
			Long startDate = DateUtil.getStartTime(0,DateUtil.getStringTime(sdf1.format(c.getTime()),"yyyy-MM-dd")).getTime();
			//获取当前月最后一天
			Calendar ca = Calendar.getInstance();    
			ca.set(Calendar.DAY_OF_MONTH, ca.getActualMaximum(Calendar.DAY_OF_MONTH));  
			Long endDate = DateUtil.getnowEndTime(23,DateUtil.getStringTime(sdf1.format(ca.getTime()),"yyyy-MM-dd")).getTime();
			
			String str = new SimpleDateFormat("yyyy-MM-dd").format(new Date()).toString();//
			String ttstr = new SimpleDateFormat("yyyy-MM").format(new Date()).toString();//
			
//			String yesterday = ClockInTool.requires_extra_times(str,-1,3,1);//前一天
//			String yesterday = str;
			
			String[] rangeArray=ClockInTool.listToString(ClockInTool.getDays(sdf1.format(c.getTime()),str)).split(";");//目前为止所有日期
			String[] range=rangeArray[0].split(",");
			
//			Long endDateyesterday = DateUtil.getnowEndTime(23,DateUtil.getStringTime(yesterday,"yyyy-MM-dd")).getTime();
			
			int year = Calendar.getInstance().get(Calendar.YEAR);
			int month = Calendar.getInstance().get(Calendar.MONTH) + 1;
			int summaryid = 0;//汇总id
			
			
			List<QyzxEntInfoM> orgcodelist = qyzxentinfommapper.selectList(new QueryWrapper<QyzxEntInfoM>());//系统中的所有公司  所有未到期的公司
			for(int t = 0;t<orgcodelist.size();t++){
				int org_code = orgcodelist.get(t).getId();//企业组织代码
				
				List<AdditionalDto> userlist = kqglassoleavebalancemapper.selectAdditionalList(org_code);
				for(AdditionalDto user : userlist) {
					
					YgglMainLzb lzb = YgglMainLzb.builder().build().selectOne(new QueryWrapper<YgglMainLzb>().lambda().eq(YgglMainLzb::getOrgCode, org_code).eq(YgglMainLzb::getJobStatus, 3)
							.eq(YgglMainLzb::getEmpNum, user.getEmpnum()));
					if(lzb == null) {//已离职 的人员不进入计算(已存在的不做任何处理)
						
//						KqglAssoMonthPunchSummary.builder().build().delete(new QueryWrapper<KqglAssoMonthPunchSummary>().lambda().eq(KqglAssoMonthPunchSummary::getBelongYear, year)
//						.eq(KqglAssoMonthPunchSummary::getBelongMonth, month).eq(KqglAssoMonthPunchSummary::getOrgCode, org_code));
						
						KqglAssoMonthPunchSummary sum = KqglAssoMonthPunchSummary.builder().build().selectOne(new QueryWrapper<KqglAssoMonthPunchSummary>().lambda().eq(KqglAssoMonthPunchSummary::getOrgCode, org_code)
								.eq(KqglAssoMonthPunchSummary::getBelongYear, year).eq(KqglAssoMonthPunchSummary::getBelongMonth, month).eq(KqglAssoMonthPunchSummary::getNum, user.getEmpnum()));
						
						if(sum != null) {
							summaryid = sum.getId();
						}else {
							summaryid = 0;
						}
						
						double traveltotal = 0,egresstotal = 0,overtimetotal = 0;
						//出差总时长
						KqglAssoRelationSummary travel = kqglassorelationsummarymapper.SecondaryValue(user.getEmpnum(), 3, ttstr);
						if(travel !=null) { traveltotal = travel.getDuration(); }
						//外出总时长
						KqglAssoRelationSummary egress = kqglassorelationsummarymapper.SecondaryValue(user.getEmpnum(), 4, ttstr);
						if(egress!=null) { egresstotal = egress.getDuration(); }
						//加班总时长
						KqglAssoRelationSummary overtime = kqglassorelationsummarymapper.SecondaryValue(user.getEmpnum(), 1, ttstr);
						if(overtime!= null) { overtimetotal = overtime.getDuration(); }
							//考勤组信息
							KqglMainKqz attgro = kqglmainkqzmapper.getAttendanceGroupInformationByUserid(user.getEmpnum(),org_code); 
							//目前为止打卡记录
							List<PunchCardDetails> attendance = punchcarddetailsmapper.selectAttendanceDays(user.getEmpnum(), startDate, endDate);
							int dkjl = 0;//目前为止打卡次数
							int sbqkcs = 0,xbqkcs = 0,dk=0;
							String[] sblacks = new String[31];//上班缺卡天数
							String[] xblacks = new String[31];//下班缺卡天数
							String[] dkjtts = new String[attendance.size()];//目前打卡日期明细
							int bccs = 0;
							if(attendance.size() > 0) { 
								dkjl = attendance.size();
								for(PunchCardDetails pcd:attendance){
									AttendanceCardListDto attdate = clockincontroller.MethodCall(org_code, user.getEmpnum(), pcd.getData());
									List<AttSchedule> ashss = attdate.getAttsch();//获取今天应打卡时间
									if(EmptyUtil.isNotEmpty(attdate.getAttsch()) && ashss.get(0).getId() != 0) {//班次不为空
										bccs = attdate.getAttsch().size();
									}
									dkjtts[dk] = pcd.getData();
									dk++;
					            	if(bccs == 2 || bccs == 4 || bccs == 6){
					            		if(pcd.getSbdk1() == null){ 
					            			sblacks[sbqkcs] = pcd.getData(); 
					            			sbqkcs++; 
					            		}
					            		if(pcd.getXbdk1() == null){ 
					            			xblacks[xbqkcs] = pcd.getData(); 
					            			xbqkcs++; 
					            		}
					            	}
					            	if(bccs == 4 || bccs == 6){
					            		if(pcd.getSbdk2() == null){ 
					            			sblacks[sbqkcs] = pcd.getData(); 
					            			sbqkcs++; 
					            		}
					            		if(pcd.getXbdk2() == null){ 
					            			xblacks[xbqkcs] = pcd.getData(); 
					            			xbqkcs++; 
					            		}
					            	}
					            	if(bccs == 6){
					            		if(pcd.getSbdk3() == null){ 
					            			sblacks[sbqkcs] = pcd.getData(); 
					            			sbqkcs++; 
					            		}
					            		if(pcd.getXbdk3() == null){ 
					            			xblacks[xbqkcs] = pcd.getData(); 
					            			xbqkcs++; 
					            		}
					            	}
					            }
								
								sblacks = ClockInTool.deleteArrayNull(sblacks);
								sbqkcs= sblacks.length;
								
								xblacks = ClockInTool.deleteArrayNull(xblacks);
								xbqkcs = xblacks.length;
							}
							//具体打卡时间入汇总表(打卡成功才会录入汇总表)
		//					 KqglAssoMonthPunchSummary isyessum = KqglAssoMonthPunchSummary.builder().build().selectOne(new QueryWrapper<KqglAssoMonthPunchSummary>().lambda()
		//							 .eq(KqglAssoMonthPunchSummary::getNum, user.getEmpnum()).eq(KqglAssoMonthPunchSummary::getOrgCode, org_code));
							 String[] ycqts = new String[31];//应上班的具体天数(yyyy-MM-dd)
							 String[] xxts = new String[31];//休息的具体天数(yyyy-MM-dd)
							 List<String> rowData = new ArrayList<String>();
							//休息天数,应出勤天数,实际出勤
							double daysOff = 0,daysOnDuty = 0;//,actualAttDays = 0;
							int zjgzts = 0;//目前为止应该出勤的天数
							//工作时长(分钟)、严重迟到次数、严重迟到时长(分钟)、旷工迟到次数
							double workinghours = 0,seriouslatetimes = 0,seriouslatehours = 0,absenlatetimes = 0;
							// 迟到次数  迟到时长  早退次数  早退时长
						    int latenum = 0,latehours = 0,leanum = 0,leahours = 0;// 迟到次数
						    int answer =0;//班次ID
						    //工作日(转调休)、休息日(转调休)、节假日(转调休)
						    double workingturncompenleave = 0,restturncompenleave = 0,holidayturncompenleave = 0;//工作日(转调休)
						    //工作日(转加班费)、休息日(转加班费)、节假日(转加班费)
						    double workingtransferovertime = 0,resttransferovertime = 0,holidaytransferovertime = 0;
						    int attgroid = 0;
							if(attgro != null){//该员工是否加入到考勤组  排班方式 1:固定排班;2:自由排班;3:自由工时         计算出应出勤,实际出勤,休息天数
								attgroid = attgro.getId();
		//							KqglAssoBcsz shif = KqglAssoBcsz.builder().build();
		//							//休息天数,应出勤天数,实际出勤
		//							double daysOff = 0,daysOnDuty = 0;//,actualAttDays = 0;
		//							int zjgzts = 0;//目前为止应该出勤的天数
								if(attgro.getPbfs() == 1){	//固定排班
									List<KqglAssoTeshu> bxdklist = kqglassoteshumapper.ShouldSpecialDatessetByKqzid(attgro.getId(), ttstr,1);//当前月     必须打卡日期
									int bxdk = bxdklist.size();
									String[] bxdkss = new String[bxdk];////特殊-必须打卡天数(工作日)
									int b = 0;
									for(KqglAssoTeshu bxd : bxdklist) {
										bxdkss[b] = bxd.getTsrq();
										b++;
									}
									List<KqglAssoTeshu> wxdk = kqglassoteshumapper.ShouldSpecialDatessetByKqzid(attgro.getId(), ttstr,2);//当前月     无需打卡日期
									String[] appmaps= new String[wxdk.size()];//特殊-无需打卡天数(休息日)
									int d1 = 0;
									for(KqglAssoTeshu spe:wxdk){
										appmaps[d1] = spe.getTsrq();
										d1++;
									}
									//应打卡周期时间
									List<AttendanceWeeklySch> atwek = attendanceweeklyschmapper.selectAttendanceMadeByUserid(user.getEmpnum(),org_code);
									String[] week= new String[atwek.size()];
									String[] needfig = new String[atwek.size()];//应打卡周期时间
									int e = 0;
									for(AttendanceWeeklySch awek : atwek){
										week[e] = awek.getWekmc();
										needfig[e] = String.valueOf(awek.getType());//获取设置的应打卡周几
										e++;
									}
									String yemo = year + "-" + month;
									sdf1.setLenient(false);
									int y = 0,q = 0;
									 for(int i = 1; i <= ClockInTool.getDaysByYearMonth(year,month); i++){
											Date date1 = sdf1.parse(yemo + "-" + i);
											for(int u=0;u<week.length;u++){
												if(sdf2.format(date1).equals(week[u])){
													q++;
													y++;
													if(Arrays.asList(appmaps).contains(String.valueOf(sdf1.format(date1)))){
														y = y-1;
													}
												}
											}
									 }
									 //全月时间 - 应打卡时间 - 必须打卡时间 + 无需打卡时间
									 int xiuxi = ClockInTool.getDaysByYearMonth(year,month) - q - bxdk + wxdk.size();
									 daysOff = xiuxi;
									 daysOnDuty = y+bxdk;
		//							 String[] range=ClockInTool.listToString(ClockInTool.getDays(sdf1.format(c.getTime()),str)).split(";");//目前为止所有日期
		//							 int zjgzts = 0;//目前为止应该出勤的天数
									//目前为止应出勤天数
									 int w = 0,x=0;
									 int zj = 6;
									 for(String num : range) {
										if(ClockInTool.useArrayUtils(needfig, String.valueOf(ClockInTool.dateToWeek(num)))) {//对比排班应打卡时间
											String[] ycqtst = new String[ycqts.length + zj];
											System.arraycopy(ycqts, 0, ycqtst, 0, ycqts.length);
											ycqtst[w] = num;
											ycqts = ycqtst;
											
											//ycqts[w] = num;
											w++;
											zjgzts++;
										}else {
											String[] xxtst = new String[xxts.length + zj];
											System.arraycopy(xxts, 0, xxtst, 0, xxts.length);
											xxtst[x] = num;
											xxts = xxtst;
											
											//xxts[x] = num;
											x++;
										}
										if(ClockInTool.useArrayUtils(bxdkss, num)) {//检查是否存在 必须打卡名单中
											String[] ycqtst = new String[ycqts.length + zj];
											System.arraycopy(ycqts, 0, ycqtst, 0, ycqts.length);
											ycqtst[w] = num;
											ycqts = ycqtst;
											
											//ycqts[w] = num;
											w++;
											zjgzts++;
											xxts =	ClockInTool.doChinFilters(ClockInTool.deleteArrayNull(xxts), num);//为必须上班的话从休息日期中去除
										}
										if(ClockInTool.useArrayUtils(appmaps, num)) {//检查是否存在 无需打卡名单中
											ycqts = ClockInTool.doChinFilters(ClockInTool.deleteArrayNull(ycqts), num);//为必须休息的话从上班日期中去除
											zjgzts = zjgzts - 1;
											
											String[] xxtst = new String[xxts.length + zj];
											System.arraycopy(xxts, 0, xxtst, 0, xxts.length);
											xxtst[x] = num;
											
											//xxts[x] = num;
											xxts = xxtst;
											x++;
										}
									 }
								}else if(attgro.getPbfs() == 2){	//自由排班
									DateFormat df = new SimpleDateFormat("EEE MMM dd HH:mm:ss zzz yyyy", Locale.US);
									List<Schedule> ycqs = schedulemapper.getAttendanceShouldList(user.getEmpnum(),startDate,endDate);
									int xiuxi = 0,shangban = 0,z=0;
									String[] ziyoupb = new String[ycqs.size()];
									for(Schedule sc : ycqs){
										String data = new SimpleDateFormat("yyyy-MM-dd").format(df.parse(String.valueOf(sc.getData())));// 获得格式化后的日期字符串
										ziyoupb[z] = data;
										z++;
										if(sc.getBcid().equals(0)){
											xiuxi++;
										}else{
											shangban++;
										}
									}
									daysOff = xiuxi;
									daysOnDuty = shangban;
									//目前为止应出勤天数
									int y = 0,x=0;
									for(String num : range) {
										if(ClockInTool.useArrayUtils(ziyoupb, num)) {
											KqglAssoPbmx pbx = KqglAssoPbmx.builder().build().selectOne(new QueryWrapper<KqglAssoPbmx>().lambda().eq(KqglAssoPbmx::getUserid, user.getEmpnum()).eq(KqglAssoPbmx::getData, num).eq(KqglAssoPbmx::getKqzid, attgro.getId()));
											if(pbx!=null && pbx.getBcid()!=0) {
												ycqts[y] = num;
												y++;
												zjgzts++;
											}else {
												xxts[x] = num;
												x++;
											}
										}
									}
								}else{
									List<AttendanceWeeklySch> atwek = attendanceweeklyschmapper.selectAttendanceMadeByUserid(user.getEmpnum(),org_code);
									String[] week= new String[atwek.size()];
									int e = 0;
									String[] ziyoupb = new String[atwek.size()];
									for(AttendanceWeeklySch awek : atwek){
										week[e] = awek.getWekmc();
										ziyoupb[e] = String.valueOf(awek.getType());
										e++;
									}
									String yemo = year + "-" + month;
									sdf1.setLenient(false);
									int y = 0;
									 for(int i = 1; i <= ClockInTool.getDaysByYearMonth(year,month); i++){
											Date date1 = sdf1.parse(yemo + "-" + i);
											for(int u=0;u<week.length;u++){
												if(sdf2.format(date1).equals(week[u])){
													y++;
												}
											}
									 }
									 int xiuxi = ClockInTool.getDaysByYearMonth(year,month) - y;
									 daysOff = xiuxi;
								     daysOnDuty = y;
								     //目前为止应出勤天数
								     int g = 0,x=0;
								     for(String num : range) {
								    	 if(ClockInTool.useArrayUtils(ziyoupb, String.valueOf(ClockInTool.dateToWeek(num)))) {//对比排班应打卡时间
								    		 ycqts[g] = num;	
								    		 g++;
								    		 zjgzts++;
										 }else {
											xxts[x] = num;
											x++;
										 }
								     }
								}
							List<PunchRecord> initial = punchrecordmapper.getMaintenancePunchCardList(startDate,endDate,user.getEmpnum());
		//				    // 迟到次数  迟到时长  早退次数  早退时长
		//				    int latenum = 0,latehours = 0,leanum = 0,leahours = 0;// 迟到次数
						    String[] cdts = new String[31];//迟到的具体天数
						    String[] ztts = new String[31];//早退的具体天数
							if(initial.size() > 0){
								for(PunchRecord prd : initial){
									if(prd.getType() == 1 && prd.getResults() > 0){
										cdts[latenum] = new SimpleDateFormat("yyyy-MM-dd").format(prd.getDktime());
										latenum++;
										latehours += prd.getResults();
									}
									if(prd.getType() == 2 && prd.getResults() > 0){
										ztts[leanum] = new SimpleDateFormat("yyyy-MM-dd").format(prd.getDktime());
										leanum++;
										leahours += prd.getResults();
									}
								}
							}
							AttSubsidiaryDto subs = kqglassodkmxmapper.subsidiary(user.getEmpnum(), ttstr);
		//						//工作时长(分钟)、严重迟到次数、严重迟到时长(分钟)、旷工迟到次数
		//						double workinghours = 0,seriouslatetimes = 0,seriouslatehours = 0,absenlatetimes = 0;
							if(subs != null) {
								workinghours = subs.getGzsctotalgzsc();
								seriouslatetimes = subs.getYzcdcstotal();
								seriouslatehours = subs.getYzcdsctotal();
								absenlatetimes = subs.getKgcdfzstotal();
							}
							//具体请假天数
							List<KqglAssoRelationSummary> leavetotal = kqglassorelationsummarymapper.SpecificLeave(user.getEmpnum(), 2, ttstr);
							String[] leaves = new String[leavetotal.size()];
							int l = 0;
							if(leavetotal.size()>0) {
								for(KqglAssoRelationSummary lea : leavetotal){
									leaves[l] = lea.getAppTime();
									l++;
								} 
							}
							//具体加班天数
							List<KqglAssoRelationSummary> overtitotal = kqglassorelationsummarymapper.SpecificLeave(user.getEmpnum(), 1, ttstr);
							String[] overtimes = new String[overtitotal.size()];
							int o = 0;
							if(overtitotal.size() > 0) {
								for(KqglAssoRelationSummary over : overtitotal) {
									overtimes[o] = over.getAppTime();
									o++;
								}
							}
							//具体出差天数
							List<KqglAssoRelationSummary> trtotal = kqglassorelationsummarymapper.SpecificLeave(user.getEmpnum(), 3, ttstr);
							String[] travels = new String[trtotal.size()];
							int cx = 0;
							if(trtotal.size()>0) {
								for(KqglAssoRelationSummary trt : trtotal) {
									travels[cx] = trt.getAppTime();
									cx++;
								}
							}
							//具体外出天数
							List<KqglAssoRelationSummary> goouttotal = kqglassorelationsummarymapper.SpecificLeave(user.getEmpnum(), 4, ttstr);
							String[] goouts = new String[goouttotal.size()];
							int wc = 0;
							if(goouttotal.size()>0) {
								for(KqglAssoRelationSummary go:goouttotal) {
									goouts[wc] = go.getAppTime();
									wc++;
								}
							}
							//具体补卡天数
							List<KqglAssoRelationSummary> cardtotal = kqglassorelationsummarymapper.SpecificLeave(user.getEmpnum(), 5, ttstr);
							String[] cards = new String[cardtotal.size()]; 
							int bk = 0;
							if(cardtotal.size()>0) {
								for(KqglAssoRelationSummary car : cardtotal) {
									cards[bk] = car.getAppTime();
									bk++;
								}
							}
							
							//排查请假是否在最后一次打卡范围内  查询当月的请假所有日期
							List<KqglAssoRelationSummary> leainv = kqglassorelationsummarymapper.LeaveInvestigation(user.getEmpnum(), 2, ttstr,org_code);
		//					KqglAssoBcsz shif = KqglAssoBcsz.builder().build();
							String beginTime = sdf1.format(new Date());
		//						List<String> rowData = new ArrayList<String>();
							//遍历目前为止所有日期 结合该用户发起的审批进行结合
							//1:加班 2:请假 3:出差 4:外出 5:补卡
							int u = 0;
							for(String num : range) {
								if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(xxts), num) && ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(dkjtts),num)) {
									rowData.add("休息并打卡");
								}else if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(xxts), num)){
									rowData.add("休息");
								}else {
									if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(ycqts), num) && !ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(dkjtts), num) && !ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(leaves), num) && !ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(travels), num) && !ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(goouts), num) && !ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(cards), num)) {
										rowData.add("旷工");
									}else if(!ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(ycqts), num) && !ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(xxts), num)) {//日期不在上班也不在休息里面即为未排班
										rowData.add("未排班");
									}else if(sdf1.parse(beginTime).getTime() < sdf1.parse(num).getTime()) {
										rowData.add("未到班期");
									}else {
										if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(sblacks), num)) {
											rowData.add("上班缺卡");
										}else if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(sblacks), num) && ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(ztts), num)) {
											rowData.add("上班缺卡,下班早退");
										}else if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(cdts), num)) {
											rowData.add("上班迟到");
										}else if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(cdts), num) && ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(xblacks), num)) {
											rowData.add("上班迟到,下班缺卡");
										}else if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(cdts), num) && ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(ztts), num)) {
											rowData.add("上班迟到,下班早退");
//										}else if(Arrays.binarySearch(ClockInTool.deleteArrayNull(xblacks), num) >= 0) {
										}else if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(xblacks),num)) {
											rowData.add("下班缺卡");
										}else if(ClockInTool.useArrayUtils(ClockInTool.deleteArrayNull(ztts), num)) {
											rowData.add("下班早退");
										}else {
											rowData.add("正常");
										}
									}
								}
								
								/******/
								if(ClockInTool.contains(ClockInTool.deleteArrayNull(leaves),num)) {
									KqglAssoRelationSummary lea = KqglAssoRelationSummary.builder().build().selectOne(new QueryWrapper<KqglAssoRelationSummary>().lambda().eq(KqglAssoRelationSummary::getUserId, user.getEmpnum()).eq(KqglAssoRelationSummary::getAppTime, num).eq(KqglAssoRelationSummary::getApprovalType, 2));
									String leavetype = "未知";//请假类型
									String company = "未知";//请假单位
									if(lea != null) {
										KqglAssoLeaveRules rul = KqglAssoLeaveRules.builder().build().selectOne(new QueryWrapper<KqglAssoLeaveRules>().lambda().eq(KqglAssoLeaveRules::getId, lea.getLeaveTypeId()));
										if(rul != null) {
											leavetype = rul.getName();
											//1:按天请假;2:按半天;3:按小时
											if(rul.getCompany() == 1) { company = "天"; }
											else if(rul.getCompany() == 2) { company = "半天"; }
											else { company = "小时"; }
										}
									}
									rowData.remove(u);
									rowData.add(u,lea.getStartTime() +"到"+ lea.getEndTime()+"请"+leavetype+lea.getDuration()+company);
								}
								if(ClockInTool.contains(ClockInTool.deleteArrayNull(travels),num)) {
									KqglAssoRelationSummary lea = KqglAssoRelationSummary.builder().build().selectOne(new QueryWrapper<KqglAssoRelationSummary>().lambda().eq(KqglAssoRelationSummary::getUserId, user.getEmpnum()).eq(KqglAssoRelationSummary::getAppTime, num).eq(KqglAssoRelationSummary::getApprovalType, 3));
									
									rowData.remove(u);
									rowData.add(u,lea.getStartTime() +"到"+ lea.getEndTime()+"出差"+lea.getDuration()+"天");
								}
								if(ClockInTool.contains(ClockInTool.deleteArrayNull(goouts),num)) {
									KqglAssoRelationSummary lea = KqglAssoRelationSummary.builder().build().selectOne(new QueryWrapper<KqglAssoRelationSummary>().lambda().eq(KqglAssoRelationSummary::getUserId, user.getEmpnum()).eq(KqglAssoRelationSummary::getAppTime, num).eq(KqglAssoRelationSummary::getApprovalType, 4));
									rowData.remove(u);
									rowData.add(u,lea.getStartTime() +"到"+ lea.getEndTime()+"外出"+lea.getDuration()+"天");
								}
								if(ClockInTool.contains(ClockInTool.deleteArrayNull(cards),num)) {
									KqglAssoRelationSummary lea = KqglAssoRelationSummary.builder().build().selectOne(new QueryWrapper<KqglAssoRelationSummary>().lambda().eq(KqglAssoRelationSummary::getUserId, user.getEmpnum()).eq(KqglAssoRelationSummary::getAppTime, num).eq(KqglAssoRelationSummary::getApprovalType, 5));
									rowData.remove(u);
									rowData.add(u,"已补卡:"+lea.getStartTime());
								}
								if(ClockInTool.contains(ClockInTool.deleteArrayNull(overtimes),num)) {
									
									String company = "未知",method = "无";//加班单位、加班补偿方式
									
									List<KqglAssoRelationSummary> leas = KqglAssoRelationSummary.builder().build().selectList(new QueryWrapper<KqglAssoRelationSummary>().lambda().eq(KqglAssoRelationSummary::getUserId, user.getEmpnum()).eq(KqglAssoRelationSummary::getAppTime, num).eq(KqglAssoRelationSummary::getApprovalType, 1));
									for(KqglAssoRelationSummary lea : leas) {
										
											//最小加班单位 1:按分钟加班、2:按半小时加班、3:按小时加班、4:按半天加班、5:按天加班
											KqglAssoOvertimeBasics basics = KqglAssoOvertimeBasics.builder().build().selectOne(new QueryWrapper<KqglAssoOvertimeBasics>().lambda().eq(KqglAssoOvertimeBasics::getOrgCode, org_code));
											if(basics.getMinimumUnit() == 1) { company = "分钟"; }
											else if(basics.getMinimumUnit() == 2) { company = "半小时";}
											else if(basics.getMinimumUnit() == 3) { company = "小时";}
											else if(basics.getMinimumUnit() == 4) { company = "半天";}
											else if(basics.getMinimumUnit() == 5) { company = "天";}
											//1:转调休;2:转加班费;3:转调休或加班费
											if(lea.getCompensateId() == 1) { method="转调休"; }
											else if(lea.getCompensateId() == 2) { method="转加班费"; }
											else {method="转调休或加班费";}
											
											rowData.remove(u);
											rowData.add(u,lea.getStartTime() +"到"+ lea.getEndTime()+"加班"+lea.getDuration()+company+"["+method+"]");
										//防止多运算
										if(lea.getOrdernum() == lea.getTotals()) {
											//加班补偿方式 1:转调休;2:转加班费;3:转调休或加班费
											//工作日
											if(ClockInTool.contains(ClockInTool.deleteArrayNull(ycqts),num)) {
												if(lea.getOvertimeTypeId() == 1) {
													if(lea.getCompensateId() == 1 || lea.getCompensateId() == 3) {
														workingturncompenleave = workingturncompenleave + lea.getDuration();
													}else if(lea.getCompensateId() == 2 || lea.getCompensateId() == 4) {
														workingtransferovertime = workingtransferovertime +  + lea.getDuration();
													}
												}
											}
											//休息日
											if(ClockInTool.contains(ClockInTool.deleteArrayNull(xxts),num)) {
												if(lea.getOvertimeTypeId() == 2) {
													if(lea.getCompensateId() == 1 || lea.getCompensateId() == 3) {
														restturncompenleave = restturncompenleave + lea.getDuration();
													}else if(lea.getCompensateId() == 2 || lea.getCompensateId() == 4) {
														resttransferovertime = resttransferovertime + lea.getDuration();
													}
												}
											}
											if(!ClockInTool.contains(ClockInTool.deleteArrayNull(ycqts),num) && !ClockInTool.contains(ClockInTool.deleteArrayNull(xxts),num)) {
												if(lea.getOvertimeTypeId() == 3) {
													if(lea.getCompensateId() == 1 || lea.getCompensateId() == 3) {
		//												holidayturncompenleave++;
														holidayturncompenleave = holidayturncompenleave + lea.getDuration();
													}else if(lea.getCompensateId() == 2 || lea.getCompensateId() == 4) {
		//												holidaytransferovertime++;
														holidaytransferovertime = holidaytransferovertime + lea.getDuration();
													}
												}
											}
										}
									}
								}
								
								/****/
								
								////////
								
								KqglAssoBcsz shif = KqglAssoBcsz.builder().build();
								
								if(attgro.getPbfs() == 1){
									int several = Integer.valueOf(ClockInTool.dateToWeek(num));//
									KqglAssoTeshu tesu = KqglAssoTeshu.builder().build().selectOne(new QueryWrapper<KqglAssoTeshu>().lambda().eq(KqglAssoTeshu::getKqzid, attgro.getId()).eq(KqglAssoTeshu::getTsrq, num));
									if(tesu == null) {
										//获取该员工最新班次
										KqglAssoZhoupaiban gudingpb = KqglAssoZhoupaiban.builder().build().selectOne(new QueryWrapper<KqglAssoZhoupaiban>().lambda().eq(KqglAssoZhoupaiban::getKqzid, attgro.getId())
												.eq(KqglAssoZhoupaiban::getType, several));
										if(gudingpb!=null) {
											shif = shif.selectOne(new QueryWrapper<KqglAssoBcsz>().lambda().eq(KqglAssoBcsz::getId, gudingpb.getBcid()));
										}
									}else {
										if(tesu.getBcid() > 0) {
											shif = shif.selectOne(new QueryWrapper<KqglAssoBcsz>().lambda().eq(KqglAssoBcsz::getId, tesu.getBcid()));
										}
										
									}
									//获取该员工最新班次
									KqglAssoZhoupaiban gudingpb = KqglAssoZhoupaiban.builder().build().selectOne(new QueryWrapper<KqglAssoZhoupaiban>().lambda().eq(KqglAssoZhoupaiban::getKqzid, attgro.getId())
											.eq(KqglAssoZhoupaiban::getType, several));
									if(gudingpb != null) {
										    shif = KqglAssoBcsz.builder().build();
											shif = shif.selectOne(new QueryWrapper<KqglAssoBcsz>().lambda().eq(KqglAssoBcsz::getId, gudingpb.getBcid()));
									}
								}else if(attgro.getPbfs() == 2){
									KqglAssoPbmx pbmxx = KqglAssoPbmx.builder().build().selectOne(new QueryWrapper<KqglAssoPbmx>().lambda().eq(KqglAssoPbmx::getUserid, user.getEmpnum()).eq(KqglAssoPbmx::getData, num).eq(KqglAssoPbmx::getKqzid, attgro.getId()));
									if(pbmxx != null && pbmxx.getBcid() != 0) {
										shif = shif.selectOne(new QueryWrapper<KqglAssoBcsz>().lambda().eq(KqglAssoBcsz::getId, pbmxx.getBcid()));
									}
								}
								
								if(shif != null && shif.getSxbcs() != null) {
									System.out.println(shif.getSxbcs());
									answer = shif.getSxbcs();//1=2次  2=4次  3=6次
									//未打最后一次卡的时候  判断最后一次打卡时间是否在请假范围内    相对应减少下班缺卡次数
									//最后一次应打卡时间
									String latimeclock = "";
									if(answer == 1) {
										latimeclock = num +" "+ shif.getXbdk1();//ClockInTool.dealDateFormat(shif.getXbdk1(),3);
									}else if(answer == 2) {
										latimeclock = num +" "+ shif.getXbdk2();//ClockInTool.dealDateFormat(shif.getXbdk2(),3);
									}else {
										latimeclock = num +" "+ shif.getXbdk3();//ClockInTool.dealDateFormat(shif.getXbdk3(),3);
									}
									for(KqglAssoRelationSummary learel:leainv) {
										boolean adopt = ClockInTool.hourMinuteBetween(latimeclock, learel.getStartTime().substring(0, 16), learel.getEndTime().substring(0, 16),"yyyy-MM-dd HH:mm");
										if(adopt) {
											xbqkcs = xbqkcs-1;
										}
									}
								}
								
								
								u++;
							}
						}else {
							for (String num2 : range) { 
								if (ClockInTool.useArrayUtils(dkjtts, num2)) {
				    				rowData.add("未排班并打卡");
				    			}else{
				    				rowData.add("未排班");
				    			}
							}
							System.err.print("该员工未加入考勤组");
						}
							
						String[] range1=ClockInTool.listToString(rowData).split(";");
						String[] noticesArray=range1[0].split(",");
						noticesArray = ClockInTool.arrycopy(noticesArray);
						for(int ct=noticesArray.length-1;ct<31;ct++) {
							noticesArray[ct] = "";
							if(ct<30) {
								noticesArray = ClockInTool.arrycopy(noticesArray);
							}
						}
						String department = "",position="";
						if(user.getDepartment() != null) {
							department = user.getDepartment();
						}
						if(user.getPosition() != null) {
							position = user.getPosition();
						}
						
						
						
						 KqglAssoMonthPunchSummary summary = KqglAssoMonthPunchSummary.builder().name(user.getEmpname()).num(user.getEmpnum()).dept(department)
								 .post(position).attGroup(attgroid).shift(answer).build();
						 summary.setDaysOnDuty(daysOnDuty);//应出勤天数
						 summary.setActualAttDays(Double.valueOf(dkjl));//实际出勤天数
						 summary.setDaysOff(daysOff);//休息天数
						 summary.setWorkingHours(workinghours);
						 summary.setLateTimes(Double.valueOf(latenum));//迟到次数
						 summary.setLateHours(Double.valueOf(latehours));//迟到时长(分钟)
						 summary.setSeriousLateTimes(seriouslatetimes);//严重迟到次数
						 summary.setSeriousLateHours(seriouslatehours);//严重迟到时长(分钟)
						 summary.setAbsenLateTimes(absenlatetimes);//旷工迟到次数
						 summary.setEarlyLeaveTimes(Double.valueOf(leanum));//早退次数
						 summary.setLengthEarlyLeave(Double.valueOf(leahours));//早退时长(分钟)
						 summary.setNumberWorkCardShortage(Double.valueOf(sbqkcs));//上班缺卡次数
						 summary.setNumberDutyCardShortage(Double.valueOf(xbqkcs < 0 ? 0 : xbqkcs));//下班缺卡次数
						 summary.setLengthBusinessTrip(traveltotal);//出差时长
						 summary.setTimeOut(egresstotal);//外出时长
						 summary.setTotalOvertimeHours(overtimetotal);//加班总时长
						 summary.setBelongYear(ca.get(Calendar.YEAR));
						 summary.setBelongMonth(ca.get(Calendar.MONTH)+1);
						 summary.setOrgCode(org_code);
						 summary.setLastModified(new Date().getTime());
						 
						 int absenteeismdays=0;
						 if(zjgzts-dkjl > 0) { absenteeismdays = zjgzts-dkjl; }
						 summary.setAbsenteeismDays(Double.valueOf(absenteeismdays));//旷工天数
						 
						 summary.setWorkingTurnCompenLeave(workingturncompenleave);//工作日(转调休)
						 summary.setRestTurnCompenLeave(restturncompenleave);//休息日(转调休)
						 summary.setHolidayTurnCompenLeave(holidayturncompenleave);//节假日(转调休)
						 summary.setWorkingTransferOvertime(workingtransferovertime);//工作日(转加班费)
						 summary.setRestTransferOvertime(resttransferovertime);//休息日(转加班费)
						 summary.setHolidayTransferOvertime(holidaytransferovertime);//节假日(转加班费)
						 summary.setDay1(noticesArray[0]);
						 summary.setDay2(noticesArray[1]);
						 summary.setDay3(noticesArray[2]);
						 summary.setDay4(noticesArray[3]);
						 summary.setDay5(noticesArray[4]);
						 summary.setDay6(noticesArray[5]);
						 summary.setDay7(noticesArray[6]);
						 summary.setDay8(noticesArray[7]);
						 summary.setDay9(noticesArray[8]);
						 summary.setDay10(noticesArray[9]);
						 summary.setDay11(noticesArray[10]);
						 summary.setDay12(noticesArray[11]);
						 summary.setDay13(noticesArray[12]);
						 summary.setDay14(noticesArray[13]);
						 summary.setDay15(noticesArray[14]);
						 summary.setDay16(noticesArray[15]);
						 summary.setDay17(noticesArray[16]);
						 summary.setDay18(noticesArray[17]);
						 summary.setDay19(noticesArray[18]);
						 summary.setDay20(noticesArray[19]);
						 summary.setDay21(noticesArray[20]);
						 summary.setDay22(noticesArray[21]);
						 summary.setDay23(noticesArray[22]);
						 summary.setDay24(noticesArray[23]);
						 summary.setDay25(noticesArray[24]);
						 summary.setDay26(noticesArray[25]);
						 summary.setDay27(noticesArray[26]);
						 summary.setDay28(noticesArray[27]);
						 summary.setDay29(noticesArray[28]);
						 summary.setDay30(noticesArray[29]);
						 summary.setDay31(noticesArray[30]);
						 
						 if(summaryid > 0) {
							 summary.setId(summaryid);
							 summary.updateById();
						 }else {
							 summary.insert();
						 }
						 
					}

				}//循环对应公司所有员工
			}//循环所有公司
			
			
			
 		}
	}
}