| | |
| | | ||Objects.isNull(ywPatrolScheme.getStartDate()) |
| | | ||Objects.isNull(ywPatrolScheme.getEndDate()) |
| | | ||Objects.isNull(ywPatrolScheme.getCircleType()) |
| | | ||StringUtils.isBlank(ywPatrolScheme.getStartTime()) |
| | | ||StringUtils.isBlank(ywPatrolScheme.getEndTime()) |
| | | || (!Constants.equalsInteger(ywPatrolScheme.getCircleType(),Constants.ZERO) &&StringUtils.isBlank(ywPatrolScheme.getCircleDays())) |
| | | ){ |
| | | throw new BusinessException(ResponseStatus.BAD_REQUEST); |
| | | } |
| | | if(StringUtils.isBlank(ywPatrolScheme.getStartTime())){ |
| | | ywPatrolScheme.setStartTime("00:00:00"); |
| | | } |
| | | if(StringUtils.isBlank(ywPatrolScheme.getEndTime())){ |
| | | ywPatrolScheme.setEndTime("23:59:59"); |
| | | } |
| | | LoginUserInfo loginUserInfo = ywPatrolScheme.getLoginUserInfo(); |
| | | ywPatrolScheme.setCreateDate(new Date()); |
| | |
| | | public void createThreeDaysData(YwPatrolScheme ywPatrolScheme){ |
| | | //循环生成三天内的数据 |
| | | for (int i = 0; i < 3; i++) { |
| | | Date schemeDate = DateUtil.getXDayAfterDate(new Date(),i); |
| | | Date schemeDate = DateUtil.getXDayAfterDate( |
| | | DateUtil.StringToDate( |
| | | DateUtil.getDate(new Date(),"yyyy-MM-dd"),"yyyy-MM-dd"),i); |
| | | this.createTask(schemeDate,ywPatrolScheme); |
| | | } |
| | | } |
| | | |
| | | |
| | | @Override |
| | | public void timerAuto(){ |
| | | List<YwPatrolScheme> ywPatrolSchemeList = ywPatrolSchemeMapper.selectList(new QueryWrapper<YwPatrolScheme>().lambda() |
| | | .eq(YwPatrolScheme::getIsdeleted,Constants.ZERO) |
| | | .eq(YwPatrolScheme::getStatus,Constants.ZERO) |
| | | .apply(" START_DATE <= now() and END_DATE>= now() ") |
| | | ); |
| | | if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(ywPatrolSchemeList)){ |
| | | for (YwPatrolScheme ywPatrolScheme:ywPatrolSchemeList) { |
| | | this.createTask(new Date(),ywPatrolScheme); |
| | | } |
| | | } |
| | | } |
| | | |
| | | |
| | | |
| | | /** |
| | | * 根据日期生成任务 |
| | |
| | | * @param ywPatrolScheme |
| | | */ |
| | | public void createTask(Date schemeDate,YwPatrolScheme ywPatrolScheme){ |
| | | if(ywPatrolScheme.getStartDate().getTime() > schemeDate.getTime() |
| | | || ywPatrolScheme.getEndDate().getTime() < schemeDate.getTime() ){ |
| | | if(!(ywPatrolScheme.getStartDate().getTime() <= schemeDate.getTime() |
| | | && ywPatrolScheme.getEndDate().getTime() >= schemeDate.getTime()) ){ |
| | | return; |
| | | } |
| | | if(Constants.equalsInteger(ywPatrolScheme.getCircleType(),Constants.ONE)){ |
| | |
| | | return; |
| | | } |
| | | List<String> weeks = Arrays.asList(ywPatrolScheme.getCircleDays().split(",")); |
| | | String weekStr = weeks.stream().filter(i->Constants.equalsInteger(Integer.valueOf(i),week.getNumber())).findFirst().get(); |
| | | if(StringUtils.isBlank(weekStr)){ |
| | | if(weeks.stream().filter(i->Constants.equalsInteger(Integer.valueOf(i),week.getNumber())).collect(Collectors.toList()).size()<=Constants.ZERO){ |
| | | return; |
| | | } |
| | | }else{ |
| | | |
| | | }else if(Constants.equalsInteger(ywPatrolScheme.getCircleType(),Constants.TWO)){ |
| | | //每月根据日期生成 根据日期获取是哪天 |
| | | List<String> days = Arrays.asList(ywPatrolScheme.getCircleDays().split(",")); |
| | | String dayStr = DateUtil.getFomartDate(schemeDate,"dd"); |
| | | Optional<String> optional = days.stream().filter(i->StringUtils.equals(i,dayStr)).findAny(); |
| | | if(Objects.isNull(optional)){ |
| | | Integer dayStr = Integer.valueOf(DateUtil.getFomartDate(schemeDate,"dd")); |
| | | if(days.stream().filter(i->i.equals(dayStr.toString())).collect(Collectors.toList()).size()<=Constants.ZERO){ |
| | | return; |
| | | } |
| | | } |
| | |
| | | |
| | | @Override |
| | | public void deleteById(Integer id, LoginUserInfo user) { |
| | | //判断是否有进行中或已超期的任务 |
| | | if(ywPatrolTaskMapper.selectCount(new QueryWrapper<YwPatrolTask>().lambda() |
| | | .eq(YwPatrolTask::getSchemeId,id) |
| | | .in(YwPatrolTask::getStatus,Constants.ONE,Constants.THREE,Constants.TWO) |
| | | )>Constants.ZERO){ |
| | | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"存在进行中/已完成的任务,无法进行删除"); |
| | | } |
| | | if(ywPatrolTaskMapper.selectCount(new QueryWrapper<YwPatrolTask>().lambda() |
| | | .eq(YwPatrolTask::getSchemeId,id) |
| | | .eq(YwPatrolTask::getStatus,Constants.ZERO) |
| | | .le(YwPatrolTask::getEndDate,"now()") |
| | | )>Constants.ZERO){ |
| | | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"存在已超期的任务,无法进行删除"); |
| | | } |
| | | ywPatrolSchemeMapper.deleteById(id); |
| | | } |
| | | |
| | |
| | | .eq(YwPatrolScheme::getIsdeleted,Constants.ZERO) |
| | | .like(StringUtils.isNotBlank(model.getTitle()),YwPatrolScheme::getTitle,model.getTitle()) |
| | | //查询有时段交集的数据 |
| | | .apply(Objects.nonNull(model.getStartDate())&&Objects.nonNull(model.getEndDate()), |
| | | " t.START_DATE <= '"+Utils.Date.getStart(pageWrap.getModel().getEndDate())+"' and t.END_DATE >= '"+Utils.Date.getStart(pageWrap.getModel().getStartDate())+"' " |
| | | ) |
| | | // .ge(Objects.nonNull(model.getStartDate()),YwDeviceRecord::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getStartDate())) |
| | | // .le(Objects.nonNull(model.getEndDate()),YwDeviceRecord::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getEndDate())) |
| | | /* .apply(Objects.nonNull(model.getStartDate())&&Objects.nonNull(model.getEndDate()), |
| | | " t.START_DATE <= '"+pageWrap.getModel().getEndDate()+"' or t.END_DATE >= '"+pageWrap.getModel().getStartDate()+"' " |
| | | )*/ |
| | | .ge( model.getStartDate()!=null,YwPatrolScheme::getStartDate, Utils.Date.getStart(pageWrap.getModel().getStartDate())) |
| | | .le(Objects.nonNull(model.getEndDate()),YwPatrolScheme::getStartDate, Utils.Date.getStart(pageWrap.getModel().getEndDate())) |
| | | .ge(Objects.nonNull(model.getStartDateSec()),YwPatrolScheme::getEndDate, Utils.Date.getStart(pageWrap.getModel().getStartDateSec())) |
| | | .le(Objects.nonNull(model.getEndDateSec()),YwPatrolScheme::getEndDate, Utils.Date.getStart(pageWrap.getModel().getEndDateSec())) |
| | | .orderByDesc(YwPatrolScheme::getCreateDate) |
| | | ; |
| | | IPage<YwPatrolScheme> iPage = ywPatrolSchemeMapper.selectJoinPage(page,YwPatrolScheme.class,queryWrapper); |