From dfed6fe975deaabb6c7ac424d7c0b7119543abba Mon Sep 17 00:00:00 2001 From: L <L@123> Date: 星期一, 13 十月 2025 13:26:26 +0800 Subject: [PATCH] * --- src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java | 122 ++++++++++++++++++---------------------- 1 files changed, 55 insertions(+), 67 deletions(-) diff --git a/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java b/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java index c554e12..0be1ef1 100644 --- a/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java +++ b/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java @@ -1,15 +1,19 @@ package com.zy.asrs.task; import com.alibaba.fastjson.JSON; +import com.zy.asrs.entity.BasArmMastSign; import com.zy.asrs.entity.BasArmRules; import com.zy.asrs.entity.OrderDetl; import com.zy.asrs.entity.param.OrderToLine; +import com.zy.asrs.service.BasArmMastSignService; import com.zy.asrs.service.BasArmRulesService; import com.zy.asrs.service.OrderDetlService; import com.zy.asrs.service.OrderService; import com.zy.asrs.service.impl.OrderDetlServiceImpl; import com.zy.asrs.task.core.ReturnT; import com.zy.asrs.task.handler.OrderToLineHandler; +import com.zy.asrs.utils.GroupedLockerOptimizerUtils; +import com.zy.asrs.utils.ToSortLineUtils; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; @@ -30,7 +34,8 @@ private BasArmRulesService basArmRulesService; @Autowired private OrderToLineHandler orderToLineHandler; - + @Autowired + private BasArmMastSignService basArmMastSignService; @Scheduled(cron = "0/3 * * * * ? ") private void orderToSortLine() { @@ -43,77 +48,60 @@ //閬嶅巻鍗曟嵁 for (String orderNo : orderNos) { - List<OrderDetl> orderDetls = orderDetlService.selectByOrderNo(orderNo); - OrderToLine orderToLine = new OrderToLine(); - orderToLine.setOrderNo(orderNo); //鍗曟嵁缂栧彿 - orderToLine.setCreateTime(System.currentTimeMillis()); //鍒涘缓鏃堕棿 - - Long bindingTag = System.currentTimeMillis();//娣锋惌鏍囪 - - List<OrderToLine.MatList> matLists = new ArrayList<>(); - List<OrderToLine.MatList> matListsRemainder = new ArrayList<>(); - List<OrderDetl> orderDetlsRemainder = new ArrayList<>(); - - for (OrderDetl orderDetl : orderDetls) { - Integer number = basArmRulesService.getNumber(orderDetl.getWeight(),orderDetl.getVolume(),orderDetl.getManLength(),orderDetl.getWidth(),orderDetl.getHeight()); - if (number == null) { - BasArmRules basArmRules = new BasArmRules(); - basArmRules.setMaterialHeight(orderDetl.getHeight()); - basArmRules.setMaterialWeight(orderDetl.getWeight()); - basArmRules.setMaterialLength(orderDetl.getManLength()); - basArmRules.setMaterialWidth(orderDetl.getWidth()); - basArmRulesService.insert(basArmRules); - return; - } else if (number == 0){ - return; - } - Double anfme = orderDetl.getAnfme(); - Double remainder = anfme % number; //鍙栦綑 浣欐暟娣锋惌 - if(remainder != 0){ - // 缁勮鐗╂枡淇℃伅 - OrderToLine.MatList matMix = new OrderToLine.MatList( - orderDetl.getMatnr(), // matnr -> sku - orderDetl.getSupp(), // supp -> po - orderDetl.getAnfme(), // 浣欐枡 -> 鍓╀綑浣欐枡缁熶竴鏃堕棿鎴虫爣璁� - orderDetl.getSku(), //barcode -> upc 鏉$爜 - 1, - null, //origin -> supplier 璐ф簮 - bindingTag //浣欐枡鏍囪鐩稿悓 - ); -// matListsRemainder.add(matMix); -// orderDetlsRemainder.add(orderDetl); - matLists.add(matMix); - } else { - Double ctns = anfme - remainder; - // 缁勮鐗╂枡淇℃伅 - OrderToLine.MatList mat = new OrderToLine.MatList( - orderDetl.getMatnr(), // matnr -> sku - orderDetl.getSupp(), // supp -> po - orderDetl.getAnfme(), //鏁存枡 - orderDetl.getSku(), //barcode -> upc - 1, - null, //origin -> supplier 璐ф簮 - System.currentTimeMillis() - ); - matLists.add(mat); - } - } -// // 鏅鸿兘鍒嗙粍浣欐枡 -// if (matListsRemainder.size() > 0) { -// groupRemainders(orderDetlsRemainder, orderDetlsRemainder.size(), orderDetls.size(), matLists); -// } - orderToLine.setMatList(matLists); try{ - ReturnT<String> returnT = orderToLineHandler.start(orderToLine); - if (!returnT.isSuccess()) { - log.error("涓嬪彂鍗曟嵁澶辫触===>"+ JSON.toJSON(orderToLine)); + List<OrderDetl> orderDetls = orderDetlService.selectByOrderNo(orderNo); + List<GroupedLockerOptimizerUtils.Item> items = new ArrayList<>(); + for (OrderDetl orderDetl:orderDetls){ + Integer number = basArmRulesService.getNumber(orderDetl.getWeight(),orderDetl.getVolume(),orderDetl.getManLength(),orderDetl.getWidth(),orderDetl.getHeight()); + if (number == null) { + BasArmRules basArmRules = new BasArmRules(); + basArmRules.setMaterialHeight(orderDetl.getHeight()); + basArmRules.setMaterialWeight(orderDetl.getWeight()); + basArmRules.setMaterialLength(orderDetl.getManLength()); + basArmRules.setMaterialWidth(orderDetl.getWidth()); + basArmRulesService.insert(basArmRules); + return; + } else if (number == 0){ + return; + } + String name = ToSortLineUtils.MergerParameter(orderDetl.getMatnr(),orderDetl.getStandby1(),orderDetl.getStandby2()); + int maxCapacity = number; + int stock = orderDetl.getAnfme().intValue(); + items.add(new GroupedLockerOptimizerUtils.Item(name, maxCapacity, stock)); + } + + OrderToLine orderToLine = new OrderToLine(); + orderToLine.setOrderNo(orderNo); //鍗曟嵁缂栧彿 + orderToLine.setCreateTime(System.currentTimeMillis()); //鍒涘缓鏃堕棿 + OrderToLine orderToLineR = ToSortLineUtils.GetOrderToLine(items, orderToLine); + + try{ + ReturnT<String> returnT = orderToLineHandler.start(orderToLineR); + if (!returnT.isSuccess()) { + log.error("涓嬪彂鍗曟嵁澶辫触===>"+ JSON.toJSON(orderToLineR)); + } else { + try{ + for (OrderToLine.MatList matList:orderToLineR.getMatList()){ + BasArmMastSign basArmMastSign = new BasArmMastSign(); + basArmMastSign.setMatnr(matList.getSku()); + basArmMastSign.setOrderNo(orderToLineR.getOrderNo()); + basArmMastSign.setSku(matList.getSku()); + basArmMastSign.setPo(matList.getPo()); + basArmMastSign.setUpc(matList.getUpc()); + basArmMastSign.setSupplier(matList.getSupplier()); + basArmMastSign.setStatus(0); + basArmMastSign.setCreateTime(matList.getBindingTags()); + basArmMastSignService.insert(basArmMastSign); + } + }catch (Exception e){} + } + } catch (Exception e){ + log.error("涓嬪彂鍗曟嵁寮傚父===>"+e.getMessage()); } } catch (Exception e){ - log.error("涓嬪彂鍗曟嵁寮傚父===>"+e.getMessage()); + log.error("涓嬪彂鍗曟嵁寮傚父,璺宠浆涓嬩竴涓鍗�===>"+e.getMessage()); } - } - } -- Gitblit v1.9.1