From 39375b057d1c775b4e063e8fa2eeaf8c4627812c Mon Sep 17 00:00:00 2001
From: 1 <1>
Date: 星期三, 15 十月 2025 09:16:10 +0800
Subject: [PATCH] #
---
src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java | 127 ++++++++++++++++++++----------------------
1 files changed, 60 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..c01130e 100644
--- a/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java
+++ b/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java
@@ -1,15 +1,20 @@
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.OptimizedLockerPackingUtils;
+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 +35,8 @@
private BasArmRulesService basArmRulesService;
@Autowired
private OrderToLineHandler orderToLineHandler;
-
+ @Autowired
+ private BasArmMastSignService basArmMastSignService;
@Scheduled(cron = "0/3 * * * * ? ")
private void orderToSortLine() {
@@ -43,77 +49,64 @@
//閬嶅巻鍗曟嵁
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<>();
+ List<OptimizedLockerPackingUtils.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));
+ items.add(new OptimizedLockerPackingUtils.Item(name, maxCapacity, stock));
+ }
+
+ OrderToLine orderToLine = new OrderToLine();
+ orderToLine.setOrderNo(orderNo); //鍗曟嵁缂栧彿
+ orderToLine.setCreateTime(System.currentTimeMillis()); //鍒涘缓鏃堕棿
+// OrderToLine orderToLineR = ToSortLineUtils.GetOrderToLineGro(items, orderToLine);
+ OrderToLine orderToLineR = ToSortLineUtils.GetOrderToLineOpt(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(orderNo);
+ basArmMastSign.setSku(matList.getSku());
+ basArmMastSign.setPo(matList.getPo());
+ basArmMastSign.setUpc(matList.getUpc());
+ basArmMastSign.setSupplier(matList.getSupplier());
+ basArmMastSign.setStatus(0);
+ basArmMastSign.setAnfme(matList.getCtns());
+ 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