| | |
| | | import com.alibaba.fastjson.JSONObject;
|
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
| | | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
| | | import com.zy.asrs.framework.common.Cools;
|
| | | import com.zy.asrs.framework.common.R;
|
| | | import com.zy.asrs.framework.exception.CoolException;
|
| | | import com.zy.asrs.wms.apis.wcs.entity.domain.SystemProperties;
|
| | |
| | | import javax.annotation.Resource;
|
| | | import java.util.*;
|
| | | import java.util.stream.Collectors;
|
| | | import java.util.stream.DoubleStream;
|
| | |
|
| | | @Slf4j
|
| | | @Service
|
| | |
| | |
|
| | | @Autowired
|
| | | private PlatformService platformService;
|
| | |
|
| | | @Resource
|
| | | private SystemProperties systemProperties;
|
| | | @Autowired
|
| | | private MobileService mobileService;
|
| | |
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @Override
|
| | | @Transactional(rollbackFor = Exception.class)
|
| | | public R containerArrivedNotify(ContainerArrivedParam arrivedParam, String taskType, Long hostId){
|
| | | public R containerArrivedNotify(ContainerArrivedParam arrivedParam, String taskType, Long hostId) {
|
| | | Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getBarcode, arrivedParam.getContainerCode()));
|
| | | if (task == null) {
|
| | | return R.error("任务不存在!!");
|
| | | }
|
| | | log.info("容器到达接收,任务号:{},当前状态:{},上报状态:{}",task.getTaskNo(),task.getTaskSts$(),TaskStsType.WCS_CONTAINER_RECEIVE.desc);
|
| | | log.info("容器到达接收,任务号:{},当前状态:{},上报状态:{}, 接收参数:{}", task.getTaskNo(), task.getTaskSts$(), TaskStsType.WCS_CONTAINER_RECEIVE.desc, JSONObject.toJSONString(arrivedParam));
|
| | |
|
| | | taskType = task.getTaskType() > 100 ? "outStock":"inStock";
|
| | | taskType = task.getTaskType() > 100 ? "outStock" : "inStock";
|
| | |
|
| | | if (taskType.equals("inStock")) {
|
| | | if (task.getTaskSts() == 198) {
|
| | | return R.error("播种中!!");
|
| | | }
|
| | | if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_IN.id ) {
|
| | | if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_IN.id) {
|
| | | //DONE 根据ESS返回的容器编码修改任务档中的输送线起始位置节点,及任务档容器到达状态
|
| | | taskService.update(new LambdaUpdateWrapper<Task>()
|
| | | .set(Task::getTaskSts, TaskStsType.WCS_CONTAINER_RECEIVE.id)
|
| | |
| | | .set(Task::getOriginSite, arrivedParam.getSlotCode())
|
| | | .eq(Task::getBarcode, arrivedParam.getContainerCode()));
|
| | | } else {
|
| | | log.warn("{}没有下发任务",task.getTaskNo());
|
| | | R.error(task.getTaskNo()+"没有下发任务");
|
| | | log.warn("{}没有下发任务", task.getTaskNo());
|
| | | R.error(task.getTaskNo() + "没有下发任务");
|
| | | }
|
| | | } else {
|
| | | if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_ARRIVED.id
|
| | | || task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TASK_DONE.id ) {
|
| | | // 到达拣选位,控制播种墙亮灯
|
| | | List<CacheSite> cacheSites = cacheSiteService.list(new LambdaQueryWrapper<CacheSite>().eq(CacheSite::getBarcode, task.getBarcode()));
|
| | | if(cacheSites.size() == 0) {
|
| | | log.error("条码:{},未找到播种墙亮灯",task.getBarcode());
|
| | | throw new CoolException("未找到播种墙");
|
| | | }
|
| | | for (CacheSite cacheSite:cacheSites) {
|
| | | // 获取任务明细数量
|
| | | List<TaskDetl> taskDetlByTaskId = taskDetlService.getTaskDetlByTaskId(task.getId());
|
| | | double sum = taskDetlByTaskId.stream().mapToDouble(TaskDetl::getAnfme).sum();
|
| | | SlapLightControlParam slapLightControlParam = new SlapLightControlParam();
|
| | | slapLightControlParam
|
| | | .setControllerCode(cacheSite.getMemo())
|
| | | .setTagCode(cacheSite.getSiteNo())
|
| | | .setColor("GREEN")
|
| | | .setIndex(cacheSite.getIndex())
|
| | | .setMode("LIGHT")
|
| | | .setDisplay(sum + "");
|
| | | // 发起亮灯请求
|
| | | log.info("任务{}到达拣选位,播种墙亮灯下发",task.getTaskNo(), JSONObject.toJSONString(slapLightControlParam));
|
| | | CommonReponse response = HttpEssUtils.post("到达拣选位,播种墙亮灯", HttpEssUtils.PLT_SEND_COMMAND, slapLightControlParam);
|
| | | if (response.getCode().equals(0)) {
|
| | | log.info("任务{}到达拣选位,播种墙{}亮灯成功",task.getTaskNo(),cacheSite.getSiteNo());
|
| | | } else {
|
| | | log.info("任务{}到达拣选位,播种墙{}亮灯失败",task.getTaskNo(),cacheSite.getSiteNo());
|
| | | }
|
| | | }
|
| | | || task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TASK_DONE.id) {
|
| | |
|
| | |
|
| | | boolean update = taskService.update(new LambdaUpdateWrapper<Task>()
|
| | | .set(Task::getTaskSts, TaskStsType.WAVE_SEED.id)
|
| | | .set(Task::getOriginSite, arrivedParam.getSlotCode())
|
| | |
| | | if (!update) {
|
| | | throw new CoolException("容器到达任务更新失败!!");
|
| | | }
|
| | |
|
| | | } else if(task.getTaskSts().equals(TaskStsType.UPDATED_OUT.id)) {
|
| | | } else if (task.getTaskSts().equals(TaskStsType.UPDATED_OUT.id)) {
|
| | | ConveyorStarParam conveyorStarParam = new ConveyorStarParam();
|
| | | conveyorStarParam.setSlotCode(task.getOriginSite())
|
| | | .setContainerCode(task.getBarcode())
|
| | | .setDirection("200");
|
| | | // 出库完成,清除输送线条码,取下箱子
|
| | | CommonReponse response = HttpEssUtils.post("清除输送线条码", HttpEssUtils.CONVEYOR_START, conveyorStarParam);
|
| | | if (response.getCode().equals(200)) {
|
| | | log.info("{}出库完成,清除{}输送线条码{}成功",task.getTaskNo(),task.getOriginSite(),task.getBarcode());
|
| | | }
|
| | | CommonReponse response = HttpEssUtils.post("清除输送线条码", HttpEssUtils.CONVEYOR_START, conveyorStarParam);
|
| | | if (response.getCode().equals(200)) {
|
| | | log.info("{}出库完成,清除{}输送线条码{}成功", task.getTaskNo(), task.getOriginSite(), task.getBarcode());
|
| | | }
|
| | | }
|
| | | }
|
| | |
|
| | |
| | | .eq(Task::getTaskNo, callbackParam.getTaskCode()));
|
| | | if (!Collections.isEmpty(list)) {
|
| | | list.forEach(task -> {
|
| | | log.info("容器执行状态上报,任务号:{},当前状态:{},上报状态:{}",task.getTaskNo(),task.getTaskSts$(),callbackParam.getEventType());
|
| | | log.info("容器执行状态上报,任务号:{},当前状态:{},上报状态:{}", task.getTaskNo(), task.getTaskSts$(), callbackParam.getEventType());
|
| | | if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_ALLOCATED.event)) {
|
| | | return;
|
| | | }
|
| | | // ESS只能配置一个状态上报接口,根据任务号判断是入库任务或出库任务
|
| | | String taskType = task.getTaskType() > 100 ? "outStock":"inStock";
|
| | | String taskType = task.getTaskType() > 100 ? "outStock" : "inStock";
|
| | | TaskStsType taskStsType = null;
|
| | | if (taskType.equals("inStock")) { //入库任务
|
| | | if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_TOTE_LOAD.event)) { //上报取箱状态
|
| | | // if (task.getTaskSts() == TaskStsType.WCS_CONVEYOR_START.id) {
|
| | | taskStsType = TaskStsType.WCS_TOTE_LOAD;
|
| | | taskStsType = TaskStsType.WCS_TOTE_LOAD;
|
| | | // } else {
|
| | | // String errMsg = "任务编号:" + task.getTaskNo() + "状态为不匹配," + "不能执行:" + TaskStsType.WCS_TOTE_LOAD.desc + "任务";
|
| | | // log.error(errMsg);
|
| | |
| | | // }
|
| | | } else if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_TOTE_UNLOAD.event)) { //上报放箱状态
|
| | | // if (task.getTaskSts() == TaskStsType.WCS_TOTE_LOAD.id) {
|
| | | taskStsType = TaskStsType.WCS_TOTE_UNLOAD;
|
| | | taskStsType = TaskStsType.WCS_TOTE_UNLOAD;
|
| | | // } else {
|
| | | // String errMsg = "任务编号:" + task.getTaskNo() + "状态为不匹配," + "不能执行:" + TaskStsType.WCS_TOTE_UNLOAD.desc + "任务";
|
| | | // log.error(errMsg);
|
| | |
| | | // }
|
| | | } else if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_STATUS.event)) { //TODO 需确认上报任务中,任务完成是哪个事件,目前暂定task事件
|
| | | // if (task.getTaskSts() == TaskStsType.WCS_TOTE_UNLOAD.id) {
|
| | | taskStsType = TaskStsType.WCS_PUTAWAY_SUCESS;
|
| | | taskStsType = TaskStsType.WCS_PUTAWAY_SUCESS;
|
| | | // } else {
|
| | | // String errMsg = "任务编号:" + task.getTaskNo() + "状态为不匹配," + "不能执行:" + TaskStsType.WCS_PUTAWAY_SUCESS.desc + "任务";
|
| | | // log.error(errMsg);
|
| | |
| | | } else { //出库任务
|
| | | if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_TOTE_LOAD.event)) { //上报取箱状态
|
| | | // if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT.id ) {
|
| | | taskStsType = TaskStsType.WCS_EXECUTE_OUT_TOTE_LOAD;
|
| | | taskStsType = TaskStsType.WCS_EXECUTE_OUT_TOTE_LOAD;
|
| | | // } else {
|
| | | // String errMsg = "任务编号:" + task.getTaskNo() + "状态为不匹配," + "不能执行:" + TaskStsType.WCS_EXECUTE_OUT_TOTE_LOAD.desc + "任务";
|
| | | // log.error(errMsg);
|
| | |
| | | // }
|
| | | } else if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_TOTE_UNLOAD.event)) { //上报放箱状态
|
| | | // if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TOTE_LOAD.id) {
|
| | | taskStsType = TaskStsType.WCS_EXECUTE_OUT_TOTE_UNLOAD;
|
| | | taskStsType = TaskStsType.WCS_EXECUTE_OUT_TOTE_UNLOAD;
|
| | | // } else {
|
| | | // String errMsg = "任务编号:" + task.getTaskNo() + "状态为不匹配," + "不能执行:" + TaskStsType.WCS_EXECUTE_OUT_TOTE_UNLOAD.desc + "任务";
|
| | | // log.error(errMsg);
|
| | |
| | | // }
|
| | | } else if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_STATUS.event)) { //上报完成状态
|
| | | // if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TOTE_UNLOAD.id || task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TASK_DONE.id) {
|
| | | //出库任务完成,修改状态为容器到达,定时任务生成播种波次
|
| | | taskStsType = TaskStsType.WCS_EXECUTE_OUT_TASK_DONE;
|
| | | //出库任务完成,修改状态为容器到达,定时任务生成播种波次
|
| | | taskStsType = TaskStsType.WCS_EXECUTE_OUT_TASK_DONE;
|
| | | // } else {
|
| | | // String errMsg = "任务编号:" + task.getTaskNo() + "状态为不匹配," + "不能执行:" + TaskStsType.WCS_EXECUTE_OUT_TASK_DONE.desc + "任务";
|
| | | // log.error(errMsg);
|
| | |
| | | */
|
| | | @Override
|
| | | @Transactional(rollbackFor = Exception.class)
|
| | | public synchronized R containerConveryor(String code) throws Exception{
|
| | | public synchronized R containerConveryor(String code) throws Exception {
|
| | | Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getBarcode, code));
|
| | | if (Objects.isNull(task)) {
|
| | | throw new CoolException("容器码任务不存在!!");
|
| | | } |
| | | }
|
| | | try {
|
| | | ConveyorStarParam conveyorStarParam = new ConveyorStarParam();
|
| | | conveyorStarParam.setSlotCode(task.getOriginSite())
|
| | |
| | | }
|
| | | }
|
| | | } catch (Exception ex) {
|
| | | log.error("UNK", ex);
|
| | | log.error("UNK", ex);
|
| | | }
|
| | | return R.ok();
|
| | | }
|
| | |
| | | public R slapLightLogic(Map<String, Object> request) {
|
| | | String taskNo = request.get("taskNo").toString();
|
| | | String orderNo = request.get("orderNo").toString();
|
| | |
|
| | | String siteNo = Objects.isNull(request.get("siteNo")) ? null : request.get("siteNo").toString();
|
| | | List<CacheSite> performs = cacheSiteService.list(new LambdaQueryWrapper<CacheSite>().eq(CacheSite::getOrderNo, orderNo));
|
| | | if (Objects.isNull(performs.stream().findFirst().get().getPlatformId())) {
|
| | | throw new CoolException("请打印明细,并绑定目标集货区");
|
| | | }
|
| | |
|
| | | //* 1. 判断当前容器是否还有物料未拣,未拣完闪灯,拣完通知容器流动,并灭灯
|
| | | SlapLightControlParam slapParam = new SlapLightControlParam();
|
| | | MultiValueMap<String, Object> params = new LinkedMultiValueMap<>();
|
| | | Order one = orderService.getOne(new LambdaQueryWrapper<Order>().eq(Order::getOrderNo, orderNo));
|
| | | if (Objects.isNull(one)) {
|
| | | throw new CoolException("当前订单明细不存在!!");
|
| | | }
|
| | |
|
| | | if (Cools.isEmpty(slapParam)) {
|
| | | return null;
|
| | | }
|
| | |
|
| | | //判断当前任务是否还有物料未拣
|
| | | if (!checked(orderNo, taskNo)) {
|
| | | log.info("未完成闪灯请求地址:{},请求参数:{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam));
|
| | | //调用三方接口,闪灯不做操作
|
| | | // 设置请求参数
|
| | | throw new CoolException("当前任务未完成,不能执行此操作!!");
|
| | | mobileService.sowLightMange(siteNo, one, "LIGHT");
|
| | | // throw new CoolException("当前任务未完成,不能执行此操作!!");
|
| | | // params.add("params", JSONObject.toJSONString(slapParam));
|
| | | } else {
|
| | | //调用三方接口,灭灯通知容器流动, 传灭灯参数
|
| | | //todo 判断当前订单是否完成,完成灭灯,未完成保持拣货状态亮灯
|
| | | Order one = orderService.getOne(new LambdaQueryWrapper<Order>().eq(Order::getOrderNo, orderNo));
|
| | | if (Objects.isNull(one)) {
|
| | | throw new CoolException("当前订单明细不存在!!");
|
| | | }
|
| | |
|
| | | // //获取播种已完成的订单明细
|
| | | // List<OrderDetl> detlList = orderDetls.stream().filter(detl -> {
|
| | | // return detl.getPickStatus() == OrderPickStatus.ORDER_PICK_STATUS_DONE.val;
|
| | | // }).collect(Collectors.toList());
|
| | |
|
| | | //判断数量是否与订单明细的需求量相同,相同则订单完成
|
| | | if (one.getPickStatus() == OrderPickStatus.ORDER_PICK_STATUS_DONE.val) {
|
| | |
|
| | | List<WaveSeed> seeds = waveSeedService.list(new LambdaQueryWrapper<WaveSeed>().eq(WaveSeed::getOrderNo, orderNo));
|
| | | if (Objects.isNull(seeds)) {
|
| | | throw new CoolException("数据错误:播种数据不存在!!");
|
| | | }
|
| | | Double tolAnfme = seeds.stream().mapToDouble(WaveSeed::getAnfme).sum();
|
| | | Double toDouble = seeds.stream().mapToDouble(WaveSeed::getWorkQty).sum();
|
| | | if (toDouble.compareTo(tolAnfme) >= 0) {
|
| | | //播种完成,释放绑定站点
|
| | | List<CacheSite> cacheSites = cacheSiteService.list(new LambdaQueryWrapper<CacheSite>().eq(CacheSite::getOrderNo, orderNo));
|
| | | List<CacheSite> cacheSites = cacheSiteService.list(new LambdaQueryWrapper<CacheSite>()
|
| | | .eq(!Objects.isNull(siteNo), CacheSite::getSiteNo, siteNo)
|
| | | .eq(CacheSite::getOrderNo, orderNo));
|
| | | for (CacheSite cacheSite : cacheSites) {
|
| | | if (!cacheSite.getSiteStatus().equals(CacheSiteStatusType.O.id)) {
|
| | | cacheSite.setSiteStatus(CacheSiteStatusType.O.id);
|
| | |
| | | }
|
| | | }
|
| | | }
|
| | | //订单完成,灭灯
|
| | | mobileService.sowLightMange(siteNo, one, "DARK");
|
| | | log.info("完成灭灯请求地址:{},请求参数:{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam));
|
| | | } else {
|
| | | //订单未完成,继续亮灯
|
| | | mobileService.sowLightMange(siteNo, one, "LIGHT");
|
| | | log.info("继续亮灯请求地址:{},请求参数:{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam));
|
| | |
|
| | | }
|
| | | params.add("params", JSONObject.toJSONString(slapParam));
|
| | | log.info("完成灭灯请求地址:{},请求参数:{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam));
|
| | |
| | | try {
|
| | | containerConveryor(task.getBarcode());
|
| | | } catch (Exception e) {
|
| | | log.error("执行异常:UNK", e);
|
| | | log.error("执行异常:UNK", e);
|
| | | throw new CoolException(e.getMessage());
|
| | | }
|
| | |
|
| | | return R.ok();
|
| | | }
|
| | |
|
| | |
| | | //判断任务需求总量是否等播种总数量
|
| | | if (taskNum == seedNum) {
|
| | | return true;
|
| | | } else {
|
| | | } else {
|
| | | return false;
|
| | | }
|
| | | }
|