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 9776730..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.getStandby1(),  //  supp -> po
-                            orderDetl.getAnfme(),          //    浣欐枡 -> 鍓╀綑浣欐枡缁熶竴鏃堕棿鎴虫爣璁�
-                            orderDetl.getStandby2(),   //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.getStandby1(),  //  supp -> po
-                            orderDetl.getAnfme(),   //鏁存枡
-                            orderDetl.getStandby2(),   //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