|  |  |  | 
|---|
|  |  |  | import com.zy.asrs.wms.asrs.entity.enums.LocStsType; | 
|---|
|  |  |  | import com.zy.asrs.wms.asrs.entity.enums.TaskStsType; | 
|---|
|  |  |  | import com.zy.asrs.wms.asrs.service.*; | 
|---|
|  |  |  | import io.jsonwebtoken.lang.Collections; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | import org.slf4j.LoggerFactory; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.scheduling.annotation.Scheduled; | 
|---|
|  |  |  | import org.springframework.stereotype.Component; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  | import org.springframework.transaction.interceptor.TransactionAspectSupport; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.Collection; | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Slf4j | 
|---|
|  |  |  | @Component | 
|---|
|  |  |  | public class TaskTimer { | 
|---|
|  |  |  | public static Logger logger = LoggerFactory.getLogger(TaskTimer.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TaskService taskService; | 
|---|
|  |  |  | 
|---|
|  |  |  | private CacheSiteService cacheSiteService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 入库执行任务 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Scheduled(cron = "0/3 * * * * ? ") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void inExecute() { | 
|---|
|  |  |  | 
|---|
|  |  |  | executeTask11(task); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 53://拣料再入库 | 
|---|
|  |  |  | case 57: | 
|---|
|  |  |  | executeTask53(task); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * // fixme 舍弃 | 
|---|
|  |  |  | * 1. 定时拉取需要执行回库任务列表数据, | 
|---|
|  |  |  | * 2. 删除原始库位明细,原始库位状态置成O.空库 | 
|---|
|  |  |  | * 3. | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //    @Scheduled(cron = "0/3 * * * * ? ") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void rollbackStock() { | 
|---|
|  |  |  | //获取需要执行回库的任务,更新库存信息 | 
|---|
|  |  |  | List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>().eq(Task::getTaskType, 53).eq(Task::getTaskSts, TaskStsType.WCS_CONVEYOR_START.id)); | 
|---|
|  |  |  | if (tasks.isEmpty()) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tasks.forEach(task -> { | 
|---|
|  |  |  | //删除原始库位明细,状态置为O.空库 | 
|---|
|  |  |  | executeTask103(task); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | //todo 需添加一个任务状态或临时状态,否则会一直轮循,程序报错(库位状态不处于R.出库预约) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Scheduled(cron = "0/10 * * * * ? ") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void outExecute() { | 
|---|
|  |  |  | 
|---|
|  |  |  | executeTask101(task); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 103://拣料 | 
|---|
|  |  |  | case 107: | 
|---|
|  |  |  | executeTask103(task); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | 
|---|
|  |  |  | task.setTaskSts(TaskStsType.UPDATED_OUT.id);//200.库存更新完成 | 
|---|
|  |  |  | if (!taskService.updateById(task)) { | 
|---|
|  |  |  | throw new CoolException("库存更新失败"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | //CacheSite 释放已被占用的通道 //fixme 播种功能完成后,需要将这里注释掉 | 
|---|
|  |  |  | List<TaskDetl> detls = taskDetlService.list(new LambdaQueryWrapper<TaskDetl>().eq(TaskDetl::getTaskId, task.getId())); | 
|---|
|  |  |  | if (!Collections.isEmpty(detls)) { | 
|---|
|  |  |  | List<Long> waveIds = detls.stream().map(TaskDetl::getWaveId).collect(Collectors.toList()); | 
|---|
|  |  |  | List<Order> orders = orderService.list(new LambdaQueryWrapper<Order>().in(Order::getWaveId, waveIds)); | 
|---|
|  |  |  | List<Long> orderIds = orders.stream().map(Order::getId).collect(Collectors.toList()); | 
|---|
|  |  |  | cacheSiteService.update(new LambdaUpdateWrapper<CacheSite>() | 
|---|
|  |  |  | .in(CacheSite::getOrderId, orderIds) | 
|---|
|  |  |  | .set(CacheSite::getSiteStatus, 0) | 
|---|
|  |  |  | .set(CacheSite::getOrderId, null) | 
|---|
|  |  |  | .set(CacheSite::getOrderNo, null)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | 
|---|
|  |  |  | //入库 | 
|---|
|  |  |  | private void executeTask1(Task task) { | 
|---|
|  |  |  | Long hostId = task.getHostId(); | 
|---|
|  |  |  | //fixme 暂时关闭HOSTID | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getTargetLoc()).eq(Loc::getHostId, hostId)); | 
|---|
|  |  |  | //        Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getTargetLoc())); | 
|---|
|  |  |  | if (loc == null) { | 
|---|
|  |  |  | throw new CoolException("库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (!locDetlService.save(locDetl)) { | 
|---|
|  |  |  | throw new CoolException("插入库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //fixme 暂时关闭HOSTID,后续打开机构ID | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //添加库存明细扩展字段 | 
|---|
|  |  |  | //            List<TaskDetlField> detlFields = taskDetlFieldService.list(new LambdaQueryWrapper<TaskDetlField>().eq(TaskDetlField::getDetlId, taskDetl.getId()).eq(TaskDetlField::getHostId, hostId)); | 
|---|
|  |  |  | List<TaskDetlField> detlFields = taskDetlFieldService.list(new LambdaQueryWrapper<TaskDetlField>().eq(TaskDetlField::getDetlId, taskDetl.getId())); | 
|---|
|  |  |  | List<TaskDetlField> detlFields = taskDetlFieldService.list(new LambdaQueryWrapper<TaskDetlField>().eq(TaskDetlField::getDetlId, taskDetl.getId()).eq(TaskDetlField::getHostId, hostId)); | 
|---|
|  |  |  | for (TaskDetlField detlField : detlFields) { | 
|---|
|  |  |  | LocDetlField locDetlField = new LocDetlField(); | 
|---|
|  |  |  | locDetlField.setDetlId(locDetl.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //fixme 暂时关闭HOSTID,后续打开机构ID | 
|---|
|  |  |  | //组托通知档转历史档 | 
|---|
|  |  |  | //        List<WaitPakin> waitPakins = waitPakinService.list(new LambdaQueryWrapper<WaitPakin>().eq(WaitPakin::getBarcode, task.getBarcode()).eq(WaitPakin::getHostId, hostId)); | 
|---|
|  |  |  | List<WaitPakin> waitPakins = waitPakinService.list(new LambdaQueryWrapper<WaitPakin>().eq(WaitPakin::getBarcode, task.getBarcode())); | 
|---|
|  |  |  | List<WaitPakin> waitPakins = waitPakinService.list(new LambdaQueryWrapper<WaitPakin>().eq(WaitPakin::getBarcode, task.getBarcode()).eq(WaitPakin::getHostId, hostId)); | 
|---|
|  |  |  | if (waitPakins.isEmpty()) { | 
|---|
|  |  |  | throw new CoolException("组托通知档不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 拣料再入库,根据任务目标库位,生成新库存信息 | 
|---|
|  |  |  | * @param task | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //拣料再入库 | 
|---|
|  |  |  | private void executeTask53(Task task) { | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void executeTask53(Task task) { | 
|---|
|  |  |  | Long hostId = task.getHostId(); | 
|---|
|  |  |  | //fixme | 
|---|
|  |  |  | //        Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getTargetLoc()).eq(Loc::getHostId, hostId)); | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getTargetLoc())); | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getTargetLoc()).eq(Loc::getHostId, hostId)); | 
|---|
|  |  |  | if (loc == null) { | 
|---|
|  |  |  | throw new CoolException("库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | loc.setLocStsId(LocStsType.F.val()); | 
|---|
|  |  |  | loc.setUpdateTime(new Date()); | 
|---|
|  |  |  | loc.setBarcode(task.getBarcode()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!locService.updateById(loc)) { | 
|---|
|  |  |  | throw new CoolException("库位状态更新失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new CoolException("任务明细不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //添加库存明细 | 
|---|
|  |  |  | //修改库存明细 | 
|---|
|  |  |  | for (TaskDetl taskDetl : taskDetls) { | 
|---|
|  |  |  | double anfme = taskDetl.getStock() - taskDetl.getAnfme(); | 
|---|
|  |  |  | if (anfme <= 0) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LocDetl  locdetl =  locDetlService.getOne(new LambdaQueryWrapper<LocDetl>() | 
|---|
|  |  |  | .eq(LocDetl::getLocId, loc.getId()) | 
|---|
|  |  |  | .eq(LocDetl::getBatch, taskDetl.getBatch()) | 
|---|
|  |  |  | .eq(LocDetl::getMatId, taskDetl.getMatId())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | LocDetl locDetl = new LocDetl(); | 
|---|
|  |  |  | locDetl.setLocId(loc.getId()); | 
|---|
|  |  |  | locDetl.setLocNo(loc.getLocNo()); | 
|---|
|  |  |  | locDetl.setMatId(taskDetl.getMatId()); | 
|---|
|  |  |  | locDetl.setMatnr(taskDetl.getMat$().getMatnr()); | 
|---|
|  |  |  | locDetl.setOrderNo(taskDetl.getOrderNo()); | 
|---|
|  |  |  | locDetl.setBatch(taskDetl.getBatch()); | 
|---|
|  |  |  | locDetl.setAnfme(anfme); | 
|---|
|  |  |  | locDetl.setHostId(hostId); | 
|---|
|  |  |  | if (!locDetlService.save(locDetl)) { | 
|---|
|  |  |  | throw new CoolException("插入库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<LocDetlField> detlFields = locDetlFieldService.list(new LambdaQueryWrapper<LocDetlField>().eq(LocDetlField::getDetlId, locdetl.getId()).eq(LocDetlField::getHostId, hostId)); | 
|---|
|  |  |  | if (!detlFields.isEmpty()) { | 
|---|
|  |  |  | if (!locDetlFieldService.removeBatchByIds(detlFields)) { | 
|---|
|  |  |  | throw new CoolException("删除明细扩展字段失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //添加库存明细扩展字段 | 
|---|
|  |  |  | //fixme 注释 | 
|---|
|  |  |  | //            List<TaskDetlField> detlFields = taskDetlFieldService.list(new LambdaQueryWrapper<TaskDetlField>().eq(TaskDetlField::getDetlId, taskDetl.getId()).eq(TaskDetlField::getHostId, hostId)); | 
|---|
|  |  |  | List<TaskDetlField> detlFields = taskDetlFieldService.list(new LambdaQueryWrapper<TaskDetlField>().eq(TaskDetlField::getDetlId, taskDetl.getId())); | 
|---|
|  |  |  | for (TaskDetlField detlField : detlFields) { | 
|---|
|  |  |  | LocDetlField locDetlField = new LocDetlField(); | 
|---|
|  |  |  | locDetlField.setDetlId(locDetl.getId()); | 
|---|
|  |  |  | locDetlField.setFieldId(detlField.getFieldId()); | 
|---|
|  |  |  | locDetlField.setName(detlField.getName()); | 
|---|
|  |  |  | locDetlField.setValue(detlField.getValue()); | 
|---|
|  |  |  | locDetlField.setHostId(hostId); | 
|---|
|  |  |  | if (!locDetlFieldService.save(locDetlField)) { | 
|---|
|  |  |  | throw new CoolException("插入明细扩展字段失败"); | 
|---|
|  |  |  | if (!locDetlService.removeById(locdetl)) { | 
|---|
|  |  |  | throw new CoolException("库存明细删除失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | LocDetl  locdetl =  locDetlService.getOne(new LambdaQueryWrapper<LocDetl>() | 
|---|
|  |  |  | .eq(LocDetl::getLocId, loc.getId()) | 
|---|
|  |  |  | .eq(LocDetl::getBatch, taskDetl.getBatch()) | 
|---|
|  |  |  | .eq(LocDetl::getMatId, taskDetl.getMatId())); | 
|---|
|  |  |  | locdetl.setWorkQty(0.0); | 
|---|
|  |  |  | locdetl.setAnfme(anfme); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!locDetlService.updateById(locdetl)) { | 
|---|
|  |  |  | throw new CoolException("库存明细更新失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 更新任务明细,更新库存明细 | 
|---|
|  |  |  | * @param task | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //出库 | 
|---|
|  |  |  | private void executeTask101(Task task) { | 
|---|
|  |  |  | Long hostId = task.getHostId(); | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new CoolException("库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (loc.getLocStsId() != LocStsType.R.val()) { | 
|---|
|  |  |  | logger.error("库位:" + loc.getLocNo() + ",状态不处于R.出库预约"); | 
|---|
|  |  |  | throw new CoolException("库位状态不处于R.出库预约"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<TaskDetl> taskDetls = taskDetlService.getTaskDetlByTaskId(task.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 将原有库存明细删除 | 
|---|
|  |  |  | * 库存状态设置为空库状态 | 
|---|
|  |  |  | * @param task | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //拣料出库 | 
|---|
|  |  |  | private void executeTask103(Task task) { | 
|---|
|  |  |  | Long hostId = task.getHostId(); | 
|---|