|  |  |  | 
|---|
|  |  |  | package com.zy.asrs.wms.asrs.timer; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.plugins.IgnoreStrategy; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.plugins.InterceptorIgnoreHelper; | 
|---|
|  |  |  | import com.zy.asrs.framework.exception.CoolException; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.zy.asrs.wms.asrs.entity.enums.TaskStsType; | 
|---|
|  |  |  | import com.zy.asrs.wms.asrs.service.*; | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Slf4j | 
|---|
|  |  |  | @Component | 
|---|
|  |  |  | public class TaskTimer { | 
|---|
|  |  |  | public static Logger logger = LoggerFactory.getLogger(TaskTimer.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TaskService taskService; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderDetlService orderDetlService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private CacheSiteService cacheSiteService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Scheduled(cron = "0/30 * * * * ? ") | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 入库执行任务 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Scheduled(cron = "0/3 * * * * ? ") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void inExecute() { | 
|---|
|  |  |  | InterceptorIgnoreHelper.handle(IgnoreStrategy.builder().tenantLine(true).build()); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | 
|---|
|  |  |  | executeTask11(task); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 53://拣料再入库 | 
|---|
|  |  |  | case 57: | 
|---|
|  |  |  | executeTask53(task); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * // fixme 舍弃 | 
|---|
|  |  |  | * 1. 定时拉取需要执行回库任务列表数据, | 
|---|
|  |  |  | * 2. 删除原始库位明细,原始库位状态置成O.空库 | 
|---|
|  |  |  | * 3. | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //    @Scheduled(cron = "0/3 * * * * ? ") | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | @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() { | 
|---|
|  |  |  | InterceptorIgnoreHelper.handle(IgnoreStrategy.builder().tenantLine(true).build()); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | 
|---|
|  |  |  | for (Task task : list) { | 
|---|
|  |  |  | //同步数据 | 
|---|
|  |  |  | switch (task.getTaskType().intValue()) { | 
|---|
|  |  |  | case 101://出库 | 
|---|
|  |  |  | case 101://出库xx | 
|---|
|  |  |  | executeTask101(task); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 103://拣料 | 
|---|
|  |  |  | case 107: | 
|---|
|  |  |  | executeTask103(task); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | throw new CoolException("未知任务类型"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.setTaskSts(TaskStsType.UPDATED_OUT.id);//200.库存更新完成 | 
|---|
|  |  |  | if (!taskService.updateById(task)) { | 
|---|
|  |  |  | throw new CoolException("库存更新失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
|---|
|  |  |  | 
|---|
|  |  |  | //入库 | 
|---|
|  |  |  | private void executeTask1(Task task) { | 
|---|
|  |  |  | Long hostId = task.getHostId(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getTargetLoc()).eq(Loc::getHostId, hostId)); | 
|---|
|  |  |  | if (loc == null) { | 
|---|
|  |  |  | log.info("库位不存在" + "=======>" + task.getTargetLoc()); | 
|---|
|  |  |  | throw new CoolException("库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //组托通知档转历史档 | 
|---|
|  |  |  | List<WaitPakin> waitPakins = waitPakinService.list(new LambdaQueryWrapper<WaitPakin>().eq(WaitPakin::getBarcode, task.getBarcode()).eq(WaitPakin::getHostId, hostId)); | 
|---|
|  |  |  | if (waitPakins.isEmpty()) { | 
|---|
|  |  |  | 
|---|
|  |  |  | for (WaitPakin waitPakin : waitPakins) { | 
|---|
|  |  |  | WaitPakinLog waitPakinLog = new WaitPakinLog(); | 
|---|
|  |  |  | waitPakinLog.sync(waitPakin); | 
|---|
|  |  |  | waitPakinLog.setId(null); | 
|---|
|  |  |  | if (!waitPakinLogService.save(waitPakinLog)) { | 
|---|
|  |  |  | throw new CoolException("组托通知档转历史档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 拣料再入库,根据任务目标库位,生成新库存信息 | 
|---|
|  |  |  | * @param task | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //拣料再入库 | 
|---|
|  |  |  | private void executeTask53(Task task) { | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void executeTask53(Task task) { | 
|---|
|  |  |  | Long hostId = task.getHostId(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 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("删除明细扩展字段失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //添加库存明细扩展字段 | 
|---|
|  |  |  | 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()); | 
|---|
|  |  |  | 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(); | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getOriginLoc()).eq(Loc::getHostId, hostId)); | 
|---|
|  |  |  | //        Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getOriginLoc()).eq(Loc::getHostId, hostId)); | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getOriginLoc())); | 
|---|
|  |  |  | if (loc == null) { | 
|---|
|  |  |  | 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(); | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getOriginLoc()).eq(Loc::getHostId, hostId)); | 
|---|
|  |  |  | //FIXME 暂时注释HOSTID筛选条件 | 
|---|
|  |  |  | //        Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getOriginLoc()).eq(Loc::getHostId, hostId)); | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, task.getOriginLoc())); | 
|---|
|  |  |  | if (loc == null) { | 
|---|
|  |  |  | throw new CoolException("库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (!locService.updateById(loc)) { | 
|---|
|  |  |  | throw new CoolException("库位状态更新失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<LocDetl> detlList = locDetlService.list(new LambdaQueryWrapper<LocDetl>().eq(LocDetl::getLocId, loc.getId()).eq(LocDetl::getHostId, hostId)); | 
|---|
|  |  |  | //删除库存明细 | 
|---|
|  |  |  | for (LocDetl locDetl : detlList) { | 
|---|