package com.zhgd.xmgl.task; import cn.hutool.core.date.DateUnit; import cn.hutool.core.date.DateUtil; import com.zhgd.xmgl.modules.safety.entity.InspectRecord; import com.zhgd.xmgl.modules.safety.entity.ProjectSubItem; import com.zhgd.xmgl.modules.safety.service.IInspectRecordService; import com.zhgd.xmgl.modules.safety.service.IProjectSubItemService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import java.util.ArrayList; import java.util.Arrays; import java.util.Date; import java.util.List; /** * @description: 视频监控定时任务 **/ @Slf4j @Component public class SlippageTask { @Autowired private IProjectSubItemService projectSubItemService; @Autowired private IInspectRecordService inspectRecordService; /** * 每天凌晨计算项目进度是否逾期、临期 */ @Scheduled(cron = "0 0 2 * * ?") private void projectSubItem() { List states = Arrays.asList(3, 6, 7); List change = new ArrayList<>(); List list = projectSubItemService.list(); list.stream().forEach(l -> { if (l.getState() < 3 && DateUtil.between(new Date(), l.getPlanEndTime(), DateUnit.DAY, false) <= 15) { l.setState(4); change.add(l); } if (!states.contains(l.getState()) && DateUtil.between(l.getPlanEndTime(), new Date(), DateUnit.DAY, false) > 0) { l.setState(5); change.add(l); } }); if (change.size() > 0) { projectSubItemService.updateBatchById(change); } log.info("=========定时修改项目进度状态任务执行成功========"); } /** * 每天凌晨计算安全质量临期 */ @Scheduled(cron = "0 0 1 * * ?") private void inspectRecord() { List states = Arrays.asList(1, 4); List change = new ArrayList<>(); List list = inspectRecordService.list(); list.stream().forEach(l -> { if (!states.contains(l.getState()) && DateUtil.between(new Date(), l.getDeadline(), DateUnit.DAY, false) <= 15) { l.setSlippageState(2); change.add(l); } if (!states.contains(l.getState()) && DateUtil.between(l.getDeadline(), new Date(), DateUnit.DAY, false) > 0) { l.setSlippageState(3); change.add(l); } }); if (change.size() > 0) { inspectRecordService.updateBatchById(change); } log.info("=========定时修改项目进度状态任务执行成功========"); } }