|  |  |  | 
|---|
|  |  |  | import com.doumee.core.exception.BusinessException; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.HKConstants; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.BaseResponse; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.request.CarChargeAddRequest; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.request.ParkReservationAddRequest; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.request.ParkReservationDelRequest; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.respose.ParkReservationAddResponse; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.metadata.IPage; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | 
|---|
|  |  |  | import com.github.yulichang.wrapper.MPJLambdaWrapper; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.apache.commons.lang3.StringUtils; | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | import org.slf4j.LoggerFactory; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  | import org.springframework.util.CollectionUtils; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RequestBody; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | import java.math.RoundingMode; | 
|---|
|  |  |  | 
|---|
|  |  |  | * @date 2024/06/28 10:03 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Service | 
|---|
|  |  |  | @Slf4j | 
|---|
|  |  |  | public class PlatformJobServiceImpl implements PlatformJobService { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | 
|---|
|  |  |  | .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) | 
|---|
|  |  |  | .leftJoin(PlatformWmsJob.class,PlatformWmsJob::getCarryBillCode,PlatformJob::getBillCode) | 
|---|
|  |  |  | .leftJoin(PlatformBooks.class,PlatformBooks::getJobId,PlatformJob::getId) | 
|---|
|  |  |  | .eq(PlatformJob::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .apply("(  t1.isdeleted = 0 or t.PLATFORM_ID is null  )") | 
|---|
|  |  |  | .eq(pageWrap.getModel().getPlatformGroupId() != null, PlatformJob::getPlatformGroupId, pageWrap.getModel().getPlatformGroupId()) | 
|---|
|  |  |  | .like(pageWrap.getModel().getCarCodeFront() != null, PlatformJob::getCarCodeFront, pageWrap.getModel().getCarCodeFront()) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | List<PlatformWmsDetail> platformWmsDetailList = platformWmsDetailMapper.selectList(new QueryWrapper<PlatformWmsDetail>().lambda() | 
|---|
|  |  |  | .eq(PlatformWmsDetail::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(PlatformWmsDetail::getJobId,platformJob.getId())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(platformWmsDetailList)){ | 
|---|
|  |  |  | platformJob.setTotalNum( | 
|---|
|  |  |  | platformWmsDetailList.stream().map(m->m.getIoQty()).reduce(BigDecimal.ZERO,BigDecimal::add) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | platformWmsJob.setPlatformWmsDetailList(platformWmsDetailList); | 
|---|
|  |  |  | platformJob.setPlatformWmsJob(platformWmsJob); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(Constants.equalsInteger(platformJob.getType(),Constants.platformJobType.zyczh) | 
|---|
|  |  |  | || Constants.equalsInteger(platformJob.getType(),Constants.platformJobType.wxczh)){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer unLockCount = platformWmsDetailList.stream().filter(i->Constants.equalsInteger(i.getLockStatus(),Constants.ZERO)).collect(Collectors.toList()).size(); | 
|---|
|  |  |  | if(Constants.equalsInteger(unLockCount,Constants.ZERO)){ | 
|---|
|  |  |  | platformJob.setLockStatus(Constants.TWO);  //全部上锁 | 
|---|
|  |  |  | }else if(Constants.equalsInteger(unLockCount,platformWmsDetailList.size())){ | 
|---|
|  |  |  | platformJob.setLockStatus(Constants.ZERO);  //未上锁 | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | platformJob.setLockStatus(Constants.ONE);   //部分上锁 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | platformJob.setWaitTime(waitTime); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | platformJob.setWaitTime("等待叫号"); | 
|---|
|  |  |  | platformJob.setWaitTime("预计等待:-小时-分钟"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else if(Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WORKING.getKey()) | 
|---|
|  |  |  | || Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.DONE.getKey())){ | 
|---|
|  |  |  | 
|---|
|  |  |  | .ne(PlatformLog::getParam3,Constants.ZERO+"") | 
|---|
|  |  |  | .orderByDesc(PlatformLog::getCreateDate)); | 
|---|
|  |  |  | platformJob.setWorkTime(platformLogList.stream().map(m->Long.valueOf(m.getParam3())).reduce(Long.valueOf(0),Long::sum)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | //查询前方排队数量 | 
|---|
|  |  |  | this.queryWaitNum(platformJob); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | driverHomeVO.setPlatformJobList(platformJobList); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | .in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey(), | 
|---|
|  |  |  | Constants.PlatformJobStatus.IN_WAIT.getKey(), | 
|---|
|  |  |  | Constants.PlatformJobStatus.CALLED.getKey()) | 
|---|
|  |  |  | .orderByDesc(PlatformJob::getStatus) | 
|---|
|  |  |  | .orderByAsc(PlatformJob::getSignDate) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | //获取所有月台组 | 
|---|
|  |  |  | 
|---|
|  |  |  | .in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey(), | 
|---|
|  |  |  | Constants.PlatformJobStatus.IN_WAIT.getKey(), | 
|---|
|  |  |  | Constants.PlatformJobStatus.CALLED.getKey()) | 
|---|
|  |  |  | .orderByDesc(PlatformJob::getStatus) | 
|---|
|  |  |  | .orderByDesc(PlatformJob::getSignDate)); | 
|---|
|  |  |  | platformGroup.setSignJobList(platformJobSignInList); | 
|---|
|  |  |  | //查询当前月台组下 | 
|---|
|  |  |  | 
|---|
|  |  |  | return platformJob; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Logger logger = LoggerFactory.getLogger(PlatformJobServiceImpl.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void sendInPark(PlatformJob platformJob){ | 
|---|
|  |  |  | log.info("【下发停车场权限】================开始===="+platformJob.getCarCodeFront()); | 
|---|
|  |  |  | if(Constants.equalsInteger(platformJob.getType(),Constants.TWO) | 
|---|
|  |  |  | || Constants.equalsInteger(platformJob.getType(),Constants.THREE) | 
|---|
|  |  |  | || Constants.equalsInteger(platformJob.getType(),Constants.FOUR)){ | 
|---|
|  |  |  | 
|---|
|  |  |  | .lambda() | 
|---|
|  |  |  | .isNotNull(Parks::getHkId) | 
|---|
|  |  |  | .eq(Parks::getIsdeleted,Constants.ZERO)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //取消当前车辆所有权限 | 
|---|
|  |  |  | List<VisitPark> cancelParkList = visitParkMapper.selectList(new QueryWrapper<VisitPark>().lambda() | 
|---|
|  |  |  | .eq(VisitPark::getCarCode,platformJob.getCarCodeFront()) | 
|---|
|  |  |  | .eq(VisitPark::getObjType,Constants.ONE) | 
|---|
|  |  |  | .eq(VisitPark::getHkStatus,Constants.ONE) | 
|---|
|  |  |  | .isNotNull(VisitPark::getHkId) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | log.info("【下发停车场权限】================开始取消当前车辆所有权限===="+JSONObject.toJSONString(cancelParkList)); | 
|---|
|  |  |  | if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(cancelParkList)){ | 
|---|
|  |  |  | for (VisitPark visitPark:cancelParkList) { | 
|---|
|  |  |  | ParkReservationDelRequest param = new ParkReservationDelRequest(); | 
|---|
|  |  |  | param.setReserveOrderNo(visitPark.getHkId()); | 
|---|
|  |  |  | BaseResponse response =  HKService.parkReservationDeletion(param); | 
|---|
|  |  |  | if(response!=null | 
|---|
|  |  |  | && StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE)){ | 
|---|
|  |  |  | visitPark.setHkStatus(Constants.THREE); | 
|---|
|  |  |  | visitPark.setIsdeleted(Constants.ONE); | 
|---|
|  |  |  | visitPark.setRemark("再次下发清空权限"); | 
|---|
|  |  |  | visitPark.setEditDate(new Date()); | 
|---|
|  |  |  | visitParkMapper.updateById(visitPark); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<VisitPark> visitParkList = new ArrayList<>(); | 
|---|
|  |  |  | if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(parksList)){ | 
|---|
|  |  |  | Boolean sendStatus = true; | 
|---|
|  |  |  | 
|---|
|  |  |  | || Constants.equalsInteger(platformJob.getType(),Constants.FOUR)){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<VisitPark> visitParkList = visitParkMapper.selectList(new QueryWrapper<VisitPark>().lambda() | 
|---|
|  |  |  | .eq(VisitPark::getVisitApplyId,platformJob.getId()) | 
|---|
|  |  |  | .eq(VisitPark::getCarCode,platformJob.getCarCodeFront()) | 
|---|
|  |  |  | .eq(VisitPark::getObjType,Constants.ONE) | 
|---|
|  |  |  | .eq(VisitPark::getHkStatus,Constants.ONE) | 
|---|
|  |  |  | .isNotNull(VisitPark::getHkId) | 
|---|
|  |  |  | .apply(" END_TIME > now() ") | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(visitParkList)){ | 
|---|
|  |  |  | for (VisitPark visitPark:visitParkList) { | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = {Exception.class,BusinessException.class}) | 
|---|
|  |  |  | public void platformOverNumber(JobOperateDTO jobOperateDTO){ | 
|---|
|  |  |  | public PlatformJob platformOverNumber(JobOperateDTO jobOperateDTO){ | 
|---|
|  |  |  | if(Objects.isNull(jobOperateDTO) | 
|---|
|  |  |  | || Objects.isNull(jobOperateDTO.getJobId())){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.BAD_REQUEST); | 
|---|
|  |  |  | 
|---|
|  |  |  | //存储操作日志 | 
|---|
|  |  |  | savePlatformLog(Constants.PlatformJobLogType.OVER_NUMBER.getKey(),oldPlatformJob,platformJob, | 
|---|
|  |  |  | Constants.PlatformJobLogType.OVER_NUMBER.getInfo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return platformJob; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | platformLog.setParam2(DateUtil.dateTypeToString(platformLog.getCreateDate(),"yyyy-MM-dd HH:mm:ss")); | 
|---|
|  |  |  | String v = Long.toString((platformLog.getCreateDate().getTime() - DateUtil.StringToDate(lastBeginPlatform.getParam1(),"yyyy-MM-dd HH:mm:ss").getTime() )/ 1000) ; | 
|---|
|  |  |  | platformLog.setParam3(v); | 
|---|
|  |  |  | platformLog.setRemark(platformJobBefor.getPlatformId().toString()); | 
|---|
|  |  |  | }else if(Constants.equalsInteger(objType,Constants.PlatformJobLogType.TRANSFERING.getKey())){ | 
|---|
|  |  |  | //查询最后一次日志是否为异常挂起,异常挂起后可进行转移 如果进行转移那么业务就需要重新进行开始就不需要特殊处理  ,如果不是异常挂起进行数据结束 则直接查询最后一次开始的时间 | 
|---|
|  |  |  | PlatformLog lastPlatformLog = platformLogMapper.selectOne(new QueryWrapper<PlatformLog>().lambda() | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else if(Constants.equalsInteger(objType,Constants.PlatformJobLogType.WORKING.getKey())){ | 
|---|
|  |  |  | platformLog.setParam1(DateUtil.dateTypeToString(platformLog.getCreateDate(),"yyyy-MM-dd HH:mm:ss")); | 
|---|
|  |  |  | platformLog.setParam3("0"); | 
|---|
|  |  |  | platformLog.setParam3("0"); | 
|---|
|  |  |  | platformLog.setRemark(platformJobBefor.getPlatformId().toString()); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | platformLog.setParam3("0"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | platformJobMapper.selectCount(new QueryWrapper<PlatformJob>().lambda() | 
|---|
|  |  |  | .eq(PlatformJob::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .and(i-> | 
|---|
|  |  |  | i.like(PlatformJob::getDoneDate,queryDateStr) | 
|---|
|  |  |  | .or().ne(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey()) | 
|---|
|  |  |  | i.like(PlatformJob::getArriveDate,queryDateStr) | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq(Platform::getStatus,Constants.ZERO) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | for (Platform platform:platformList) { | 
|---|
|  |  |  | PlatformDataListResponse platformDataListResponse  = new PlatformDataListResponse(); | 
|---|
|  |  |  | PlatformDataListResponse platformDataListResponse = new PlatformDataListResponse(); | 
|---|
|  |  |  | platformDataListResponse.setId(platform.getId()); | 
|---|
|  |  |  | platformDataListResponse.setHkId(platform.getHkId()); | 
|---|
|  |  |  | platformDataListResponse.setName(platform.getName()); | 
|---|
|  |  |  | platformDataListResponse.setWorkStatus(Constants.ZERO); | 
|---|
|  |  |  | //查询当前作业车辆 | 
|---|
|  |  |  | PlatformJob platformJob = platformJobMapper.selectOne(new QueryWrapper<PlatformJob>().lambda() | 
|---|
|  |  |  | .eq(PlatformJob::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(PlatformJob::getStatus,Constants.PlatformJobStatus.WORKING.getKey()) | 
|---|
|  |  |  | .orderByDesc(PlatformJob::getWorkTime) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | PlatformJob platformJob = platformJobJoinMapper.selectJoinOne(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() | 
|---|
|  |  |  | .selectAll(PlatformJob.class) | 
|---|
|  |  |  | .selectAs(Platform::getWorkRate, PlatformJob::getWorkRate) | 
|---|
|  |  |  | .selectAs(Platform::getName, PlatformJob::getPlatformName) | 
|---|
|  |  |  | .select(" case when t.total_num is null  then ( select sum(pwd.IO_QTY) from platform_wms_detail pwd where pwd.JOB_ID = t.id  ) else t.total_num end workNum ") | 
|---|
|  |  |  | .select(" ( select pl.CREATE_DATE from platform_log pl where t.id = pl.obj_id and pl.OBJ_TYPE = 5 order by pl.CREATE_DATE desc  limit 1  ) as newStartDate  ") | 
|---|
|  |  |  | .select(" ( select pl.CREATE_DATE from platform_log pl where t.id = pl.obj_id and pl.OBJ_TYPE = 4 order by pl.CREATE_DATE desc  limit 1  ) as newCallDate  ") | 
|---|
|  |  |  | .leftJoin(Platform.class, Platform::getId, PlatformJob::getPlatformId) | 
|---|
|  |  |  | .eq(PlatformJob::getStatus, Constants.PlatformJobStatus.WORKING.getKey()) | 
|---|
|  |  |  | .eq(PlatformJob::getPlatformId, platform.getId()) | 
|---|
|  |  |  | .orderByDesc(PlatformJob::getStatus) | 
|---|
|  |  |  | .orderByDesc(PlatformJob::getStartDate) | 
|---|
|  |  |  | .last(" limit 1") | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if(Objects.nonNull(platformJob)){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (Objects.nonNull(platformJob)) { | 
|---|
|  |  |  | platformDataListResponse.setCarCode(platformJob.getCarCodeFront()); | 
|---|
|  |  |  | platformDataListResponse.setWorkType( | 
|---|
|  |  |  | Constants.equalsInteger(platformJob.getType(),Constants.platformJobType.zycxh) | 
|---|
|  |  |  | ||Constants.equalsInteger(platformJob.getType(),Constants.platformJobType.wxcxh) | 
|---|
|  |  |  | ||Constants.equalsInteger(platformJob.getType(),Constants.platformJobType.sgscxh)?Constants.ZERO:Constants.ONE | 
|---|
|  |  |  | Constants.equalsInteger(platformJob.getType(), Constants.platformJobType.zycxh) | 
|---|
|  |  |  | || Constants.equalsInteger(platformJob.getType(), Constants.platformJobType.wxcxh) | 
|---|
|  |  |  | || Constants.equalsInteger(platformJob.getType(), Constants.platformJobType.sgscxh) ? Constants.ZERO : Constants.ONE | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | platformDataListResponse.setWorkStatus(Constants.ONE); | 
|---|
|  |  |  | //查询作业时长 | 
|---|
|  |  |  | //                Long workTime = this.getWorkTime(platformJob); | 
|---|
|  |  |  | Long min = (System.currentTimeMillis() - platformJob.getNewStartDate().getTime())/1000/60; | 
|---|
|  |  |  | platformDataListResponse.setWorkTime( | 
|---|
|  |  |  | this.getWorkTime(platformJob) | 
|---|
|  |  |  | min | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //计算已作业时长 根据月台工作效率 计算任务量需要时间 | 
|---|
|  |  |  | if (Objects.isNull(platformJob.getWorkNum()) || Objects.isNull(platformJob.getWorkRate())) { | 
|---|
|  |  |  | platformDataListResponse.setFinishTime(null); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | Integer workMinute = platformJob.getWorkNum().multiply(new BigDecimal(60)).divide(platformJob.getWorkRate()).intValue(); | 
|---|
|  |  |  | Date overDate = DateUtil.getXMinuteAfterDate(platformJob.getNewStartDate(), workMinute); | 
|---|
|  |  |  | platformDataListResponse.setFinishTime(overDate); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | platformDataListResponseList.add(platformDataListResponse); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return platformDataListResponseList; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | .selectAll(PlatformJob.class) | 
|---|
|  |  |  | .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) | 
|---|
|  |  |  | .leftJoin(PlatformGroup.class,PlatformGroup::getId,PlatformJob::getPlatformGroupId) | 
|---|
|  |  |  | .in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey()) | 
|---|
|  |  |  | .in(PlatformJob::getStatus,Constants.PlatformJobStatus.IN_WAIT.getKey()) | 
|---|
|  |  |  | .in(PlatformJob::getStatus,Constants.PlatformJobStatus.CALLED.getKey()) | 
|---|
|  |  |  | .in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey(), | 
|---|
|  |  |  | Constants.PlatformJobStatus.IN_WAIT.getKey(),Constants.PlatformJobStatus.CALLED.getKey()) | 
|---|
|  |  |  | .eq(PlatformJob::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .isNotNull(PlatformJob::getCarCodeFront) | 
|---|
|  |  |  | .orderByDesc(PlatformJob::getCreateDate) | 
|---|
|  |  |  | 
|---|
|  |  |  | List<PlatformJob> platformJobList = platformJobJoinMapper.selectJoinList(PlatformJob.class,new MPJLambdaWrapper<PlatformJob>() | 
|---|
|  |  |  | .selectAll(PlatformJob.class) | 
|---|
|  |  |  | .selectAs(Platform::getWorkRate,PlatformJob::getWorkRate) | 
|---|
|  |  |  | .selectAs(Platform::getName,PlatformJob::getPlatformName) | 
|---|
|  |  |  | .select(" case when t.total_num is null  then ( select sum(pwd.IO_QTY) from platform_wms_detail pwd where pwd.JOB_ID = t.id  ) else t.total_num end workNum ") | 
|---|
|  |  |  | .select(" ( select pl.CREATE_DATE from platform_log pl where t.id = pl.obj_id and pl.OBJ_TYPE = 5 order by pl.CREATE_DATE desc  limit 1  ) as newStartDate  ") | 
|---|
|  |  |  | .select(" ( select pl.CREATE_DATE from platform_log pl where t.id = pl.obj_id and pl.OBJ_TYPE = 4 order by pl.CREATE_DATE desc  limit 1  ) as newCallDate  ") | 
|---|
|  |  |  | .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) | 
|---|
|  |  |  | 
|---|
|  |  |  | .orderByDesc(PlatformJob::getStatus) | 
|---|
|  |  |  | .orderByAsc(PlatformJob::getSignDate) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if(CollectionUtils.isEmpty(platformJobList)){ | 
|---|
|  |  |  | if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(platformJobList)){ | 
|---|
|  |  |  | for (PlatformJob platformJob:platformJobList) { | 
|---|
|  |  |  | if(Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())){ | 
|---|
|  |  |  | //计算已作业时长 根据月台工作效率 计算任务量需要时间 | 
|---|
|  |  |  | if(Objects.isNull(platformJob.getTotalNum()) || Objects.isNull(platformJob.getWorkRate())){ | 
|---|
|  |  |  | if(Objects.isNull(platformJob.getWorkNum()) || Objects.isNull(platformJob.getWorkRate())){ | 
|---|
|  |  |  | platformJob.setOptTime(0L); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | Integer workMinute = platformJob.getTotalNum().multiply(new BigDecimal(60)).divide(platformJob.getWorkRate()).intValue(); | 
|---|
|  |  |  | Integer workMinute = platformJob.getWorkNum().multiply(new BigDecimal(60)).divide(platformJob.getWorkRate()).intValue(); | 
|---|
|  |  |  | Date overDate = DateUtil.getXMinuteAfterDate(platformJob.getNewStartDate(),workMinute); | 
|---|
|  |  |  | platformJob.setOptTime(overDate.getTime()/1000); | 
|---|
|  |  |  | platformJob.setOptTime(overDate.getTime()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else if(Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.CALLED.getKey())){ | 
|---|
|  |  |  | //计算已叫号时间 | 
|---|