From 2b13134f6e3bd5997c0424c0ba9fd7aa460ea1d2 Mon Sep 17 00:00:00 2001
From: zhangc <zc@123>
Date: 星期五, 10 一月 2025 11:43:59 +0800
Subject: [PATCH] 优化定时任务间隔及字段命名,调整环境配置

---
 src/main/java/com/zy/asrs/task/handler/AutoReplenishmentHandler.java |  244 +++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 187 insertions(+), 57 deletions(-)

diff --git a/src/main/java/com/zy/asrs/task/handler/AutoReplenishmentHandler.java b/src/main/java/com/zy/asrs/task/handler/AutoReplenishmentHandler.java
index 3f5d2cd..451c395 100644
--- a/src/main/java/com/zy/asrs/task/handler/AutoReplenishmentHandler.java
+++ b/src/main/java/com/zy/asrs/task/handler/AutoReplenishmentHandler.java
@@ -1,11 +1,15 @@
 package com.zy.asrs.task.handler;
 
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
+import com.core.common.Cools;
+import com.core.common.DateUtils;
+import com.core.common.SnowflakeIdWorker;
 import com.core.exception.CoolException;
 import com.zy.asrs.entity.*;
 import com.zy.asrs.service.*;
 import com.zy.asrs.task.AbstractHandler;
 import com.zy.asrs.task.core.ReturnT;
+import com.zy.asrs.utils.Utils;
 import com.zy.common.model.enums.WorkNoType;
 import com.zy.common.service.CommonService;
 import org.springframework.beans.BeanUtils;
@@ -13,10 +17,8 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
-import java.util.Date;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
+import java.util.*;
+import java.util.stream.Collectors;
 
 @Service
 public class AutoReplenishmentHandler extends AbstractHandler<String> {
@@ -27,6 +29,9 @@
     private LocDetlService locDetlService;
     @Autowired
     private LocMastService locMastService;
+
+    @Autowired
+    private AgvLocMastService agvLocMastService;
     @Autowired
     private CommonService commonService;
     @Autowired
@@ -35,23 +40,43 @@
     private WrkDetlService wrkDetlService;
     @Autowired
     private OrderService orderService;
+    @Autowired
+    private SnowflakeIdWorker snowflakeIdWorker;
 
+
+    @Transactional
+    public ReturnT<String> create(Mat mat, double anfme) {
+        //鍒涘缓涓�涓柊鐨勮嚜鍔ㄨˉ璐у崟鎹�
+        Order order = createOrder();
+        orderService.insert(order);
+        OrderDetl orderDetl = createOrderDetl(order);
+        orderDetl.setMatnr(mat.getMatnr());
+        orderDetl.setMaktx(mat.getMaktx());
+        orderDetl.setSpecs(mat.getSpecs());
+        orderDetl.setAnfme(anfme);
+        orderDetl.setQty(0.0);
+
+
+        orderDetlService.insert(orderDetl);
+
+        return SUCCESS;
+    }
 
     @Transactional
     public ReturnT<String> start(Order order) {
         Date now = new Date();
 
         Set<String> locNos = pakoutLoc(order);
-        for (String locNo : locNos){
+        for (String locNo : locNos) {
             LocMast locMast = locMastService.selectByLoc(locNo);
-            if(!"F".equals(locMast.getLocSts())){
+            if (!"F".equals(locMast.getLocSts())) {
                 throw new CoolException("搴撲綅鐘舵�佸凡鍙樻洿");
             }
             //鐢熸垚宸ヤ綔妗�
-            WrkMast wrkMast = createWrkMast(locNo,locMast.getBarcode(),now);
+            WrkMast wrkMast = createWrkMast(locNo, locMast.getBarcode(), now);
             //鐢熸垚宸ヤ綔妗f槑缁�
             List<LocDetl> locDetls = locDetlService.selectByLocNo(locNo);
-            createWrkDetl(locDetls, wrkMast,order.getOrderNo(),now);
+            createWrkDetl(locDetls, wrkMast, order.getOrderNo(), now);
             //淇敼搴撲綅鐘舵��
             locMast.setLocSts("R");
             locMastService.updateByLocNo(locMast);
@@ -59,79 +84,176 @@
         order.setSettle(2L);
         orderService.updateById(order);
 
-
         return SUCCESS;
     }
 
-    private Set<String> pakoutLoc(Order order){
+    private Order createOrder() {
+        Date now = new Date();
+        return new Order(
+                String.valueOf(snowflakeIdWorker.nextId()),    // 缂栧彿[闈炵┖]
+                "AUTO" + snowflakeIdWorker.nextId(),    // 璁㈠崟缂栧彿
+                DateUtils.convert(now),    // 鍗曟嵁鏃ユ湡
+                21L,    // 鍗曟嵁绫诲瀷 21.鑷姩琛ヨ揣鍗�
+                null,    // 椤圭洰缂栧彿
+                null,    //
+                null,    // 璋冩嫧椤圭洰缂栧彿
+                null,    // 鍒濆绁ㄦ嵁鍙�
+                null,    // 绁ㄦ嵁鍙�
+                null,    // 瀹㈡埛缂栧彿
+                null,    // 瀹㈡埛
+                null,    // 鑱旂郴鏂瑰紡
+                null,    // 鎿嶄綔浜哄憳
+                null,    // 鍚堣閲戦
+                null,    // 浼樻儬鐜�
+                null,    // 浼樻儬閲戦
+                null,    // 閿�鍞垨閲囪喘璐圭敤鍚堣
+                null,    // 瀹炰粯閲戦
+                null,    // 浠樻绫诲瀷
+                null,    // 涓氬姟鍛�
+                null,    // 缁撶畻澶╂暟
+                null,    // 閭垂鏀粯绫诲瀷
+                null,    // 閭垂
+                null,    // 浠樻鏃堕棿
+                null,    // 鍙戣揣鏃堕棿
+                null,    // 鐗╂祦鍚嶇О
+                null,    // 鐗╂祦鍗曞彿
+                1L,    // 璁㈠崟鐘舵��
+                1,    // 鐘舵��
+                9999L,    // 娣诲姞浜哄憳
+                now,    // 娣诲姞鏃堕棿
+                9999L,    // 淇敼浜哄憳
+                now,    // 淇敼鏃堕棿
+                null    // 澶囨敞
+        );
+
+    }
+
+    private OrderDetl createOrderDetl(Order order) {
+        Date now = new Date();
+        OrderDetl orderDetl = new OrderDetl();
+
+        orderDetl.setOrderId(order.getId());
+        orderDetl.setOrderNo(order.getOrderNo());
+        orderDetl.setCreateBy(order.getCreateBy());
+        orderDetl.setCreateTime(now);
+        orderDetl.setUpdateBy(order.getCreateBy());
+        orderDetl.setUpdateTime(now);
+        orderDetl.setStatus(1);
+        orderDetl.setQty(0.0D);
+
+        return orderDetl;
+    }
+
+    private Set<String> pakoutLoc(Order order) {
         //闇�瑕佸嚭搴撶殑搴撲綅
         Set<String> locNos = new HashSet<>();
         //鏍规嵁璁㈠崟鐢熸垚鍥涢」搴撳嚭搴撳伐浣滄。
         List<OrderDetl> orderDetlList = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", order.getOrderNo()));
 
-        for(OrderDetl orderDetl : orderDetlList){
-            if(orderDetl.getAnfme() - orderDetl.getQty() <= 0){
+        for (OrderDetl orderDetl : orderDetlList) {
+            if (orderDetl.getAnfme() - orderDetl.getQty() <= 0) {
                 continue;
             }
 
             String matnr = orderDetl.getMatnr();
-            String batch = orderDetl.getBatch();
-            String csocode = orderDetl.getThreeCode();
-            String isocode = orderDetl.getDeadTime();
 
-            Double orderAnfme = orderDetl.getAnfme();
+            double orderAnfme = orderDetl.getAnfme();
 
             //List<String> locNosSearch = locDetlService.selectLocNo(matnr);
-            Set<String> locNosSearch = locDetlService.selectLocNo(matnr, batch, csocode, isocode);
+            Set<String> locNosSearch = locDetlService.selectLocNos(matnr);
 
-            for(String locNo : locNosSearch){
-                List<LocDetl> locDetls = locDetlService.selectByLocNo(locNo);
-                locNos.add(locNo);
-                for (LocDetl locDetl :locDetls){
-                    if(matnr.equals(locDetl.getMatnr())){
-                        orderAnfme -= locDetl.getAnfme();
+            //杩囨护搴撲綅璐х墿涓洪珮璐х墿
+            locNosSearch = locNosSearch.stream().filter(locNo -> {
+                LocMast locMast = locMastService.selectByLoc(locNo);
+                if (locMast.getLocType1() == 3) {
+                    return false;
+                } else {
+                    //涓旀娴嬭搴撲綅鏄惁鍚病鏈夎揣鏋剁爜鐨勭墿鏂欙紝濡傛湁鏈夊垯涓嶅厑璁稿嚭搴�
+//                    LocDetl locDetl = locDetlService.selectOne(new EntityWrapper<LocDetl>().eq("loc_no", locNo)
+//                            .andNew().eq("supp_code", "").or().isNull("supp_code"));
+
+                    if (Cools.isEmpty(locDetlService.selectByLocWithoutContainer(locNo))) {
+                        return true;
+                    } else {
+                        return false;
                     }
                 }
-                if(orderAnfme <= 0){
+            }).collect(Collectors.toSet());
+
+            //閲嶆柊鎺掑簭
+            Set<String> resort = resort(locNosSearch);
+
+            for (String locNo : resort) {
+                List<LocDetl> locDetls = locDetlService.selectByLocNo(locNo);
+                locNos.add(locNo);
+                for (LocDetl locDetl : locDetls) {
+                    if (matnr.equals(locDetl.getMatnr())) {
+                        orderAnfme -= locDetl.getAnfme();
+                    } else {
+                        OrderDetl odNew = createOrderDetl(order);
+                        odNew.setMatnr(locDetl.getMatnr());
+                        odNew.setMaktx(locDetl.getMaktx());
+                        odNew.setBatch(locDetl.getBatch());
+                        odNew.setThreeCode(locDetl.getThreeCode());
+                        odNew.setDeadTime(locDetl.getDeadTime());
+                        odNew.setSpecs(locDetl.getSpecs());
+                        odNew.setAnfme(0.0);
+                        odNew.setQty(locDetl.getAnfme());
+                        orderDetlService.insert(odNew);
+                    }
+                }
+                if (orderAnfme <= 0) {
                     orderDetl.setQty(orderDetl.getAnfme() - orderAnfme);
                     orderDetlService.updateById(orderDetl);
                     break;
                 }
             }
+            if (orderAnfme > 0) {
+                orderDetl.setAnfme(orderDetl.getAnfme() - orderAnfme);
+                orderDetl.setQty(orderDetl.getAnfme());
+                orderDetlService.updateById(orderDetl);
+            }
         }
-
-//        orderDetlList.forEach(orderDetl -> {
-//
-//            if(orderDetl.getAnfme() - orderDetl.getQty() <= 0){
-//                cont
-//            }
-//
-//            String matnr = orderDetl.getMatnr();
-//            Double orderAnfme = orderDetl.getAnfme();
-//
-//            List<String> locNosSearch = locDetlService.selectLocNo(matnr);
-//
-//            for(String locNo : locNosSearch){
-//                List<LocDetl> locDetls = locDetlService.selectByLocNo(locNo);
-//                locNos.add(locNo);
-//                for (LocDetl locDetl :locDetls){
-//                    if(matnr.equals(locDetl.getMatnr())){
-//                        orderAnfme -= locDetl.getAnfme();
-//                    }
-//                }
-//                if(orderAnfme <= 0){
-//                    orderDetl.setQty(orderDetl.getAnfme() - orderAnfme);
-//                    orderDetlService.updateById(orderDetl);
-//                    break;
-//                }
-//            }
-//
-//        });
 
         return locNos;
     }
 
-    private WrkMast createWrkMast(String locNo,String barCode,Date now){
+    //鏍规嵁娣辨祬搴撲綅杩涜閲嶆柊鎺掑簭
+    private Set<String> resort(Set<String> locNos) {
+        Set<String> locNosResort = new LinkedHashSet<>();
+
+        for (String locNoSearch : locNos) {
+            LocMast locMast = locMastService.selectById(locNoSearch);
+            if (!"F".equals(locMast.getLocSts())) {
+                continue;
+            }
+
+            List<String> groupOuterLoc = Utils.getGroupOuterLoc(locNoSearch);
+
+            if (Cools.isEmpty(groupOuterLoc)) {
+                locNosResort.add(locNoSearch);
+            } else {
+                groupOuterLoc.add(locNoSearch);
+                //濡傛灉鏄繁搴撲綅锛屽垯鍏堟壘澶栦晶鐨勫簱浣�
+                for (String locNoOut : groupOuterLoc) {
+                    LocMast locMastOuter = locMastService.selectById(locNoOut);
+                    //澶栦晶濡傛灉鏄嫞鏂欙紝鍒欏唴娴嬩笉鍏佽鍑�
+                    if ("P".equals(locMastOuter.getLocSts()) || "Q".equals(locMastOuter.getLocSts()) || "S".equals(locMastOuter.getLocSts())) {
+                        break;
+                    }
+
+                    if (!"F".equals(locMastOuter.getLocSts())) {
+                        continue;
+                    }
+                    locNosResort.add(locNoOut);
+
+                }
+            }
+        }
+        return locNosResort;
+    }
+
+    private WrkMast createWrkMast(String locNo, String barCode, Date now) {
         int ioType = 101;
         int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(ioType));
         WrkMast wrkMast = new WrkMast();
@@ -155,18 +277,26 @@
         wrkMast.setAppeTime(now);
         //wrkMast.setModiUser(userId);
         wrkMast.setModiTime(now);
-
+        Integer pltType = null;
+        if (!Cools.isEmpty(locNo) && Cools.isEmpty(pltType)) {
+            AgvLocMast agvLocMast = agvLocMastService.selectById(locNo);
+            if (agvLocMast != null) {
+                pltType = agvLocMast.getPltType();
+            }
+        }
+        wrkMast.setPltType(pltType);
+        //琛ヨ揣鏍囪瘑
         wrkMast.setMk("Y");
         if (!wrkMastService.insert(wrkMast)) {
-            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐ワ紝鍑哄簱搴撲綅鍙凤細"+locNo);
+            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐ワ紝鍑哄簱搴撲綅鍙凤細" + locNo);
         }
         return wrkMast;
     }
 
-    private void createWrkDetl(List<LocDetl> locDetls, WrkMast wrkMast,String orderNo, Date now){
+    private void createWrkDetl(List<LocDetl> locDetls, WrkMast wrkMast, String orderNo, Date now) {
         locDetls.forEach(locDetl -> {
             WrkDetl wrkDetl = new WrkDetl();
-            BeanUtils.copyProperties(locDetl,wrkDetl);
+            BeanUtils.copyProperties(locDetl, wrkDetl);
             wrkDetl.setZpallet(wrkMast.getBarcode());
             wrkDetl.setIoTime(now);
             wrkDetl.setWrkNo(wrkMast.getWrkNo());

--
Gitblit v1.9.1