From 5d433b6fd3b9c08666bd6eb0f3264f57440d739b Mon Sep 17 00:00:00 2001
From: pang.jiabao <pang_jiabao@163.com>
Date: 星期日, 18 八月 2024 09:38:42 +0800
Subject: [PATCH] 空托回流

---
 src/main/java/com/zy/asrs/controller/OpenController.java    |    9 ++++
 src/main/java/com/zy/asrs/task/GhjtScheduler.java           |    2 
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java |   63 ++++++++++++++++++++++++++++++-
 src/main/java/com/zy/asrs/entity/param/KthlParam.java       |   21 ++++++++++
 src/main/java/com/zy/asrs/service/OpenService.java          |    5 ++
 5 files changed, 97 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index 429f7db..a27b489 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -50,6 +50,15 @@
         return R.ok(openService.fxprk(param));
     }
 
+    @PostMapping("/kthl")
+    @AppAuth(memo = "绌烘墭鐩樺洖娴�(浜屾ゼ娴佸埌涓�妤�)")
+    public synchronized R kthl(@RequestHeader(required = false) String appkey,
+                                @RequestBody KthlParam param,
+                                HttpServletRequest request) {
+        auth(appkey, param, request);
+        return openService.kthl(param);
+    }
+
     @PostMapping("/zxrk")
     @AppAuth(memo = "GWCS鍒拌揪鍫嗗灈鏈哄叆搴撶珯鐐硅姹俍WCS鎵ц")
     public synchronized R crnExecute(@RequestHeader(required = false) String appkey,
diff --git a/src/main/java/com/zy/asrs/entity/param/KthlParam.java b/src/main/java/com/zy/asrs/entity/param/KthlParam.java
new file mode 100644
index 0000000..ac2ce29
--- /dev/null
+++ b/src/main/java/com/zy/asrs/entity/param/KthlParam.java
@@ -0,0 +1,21 @@
+package com.zy.asrs.entity.param;
+
+import lombok.Data;
+
+/**
+ * @author pang.jiabao
+ * @description 绌烘墭鍥炴祦
+ * @createDate 2024/8/17 15:41
+ */
+@Data
+public class KthlParam {
+    /**
+     * 绔欑偣
+     */
+    private Integer palletizingNo;
+
+    /**
+     * 鎵樼洏鐮�
+     */
+    private String barcode;
+}
diff --git a/src/main/java/com/zy/asrs/service/OpenService.java b/src/main/java/com/zy/asrs/service/OpenService.java
index d0677fe..e66902b 100644
--- a/src/main/java/com/zy/asrs/service/OpenService.java
+++ b/src/main/java/com/zy/asrs/service/OpenService.java
@@ -26,6 +26,11 @@
     String fxprk(FxprkParam param);
 
     /**
+     * 绌烘墭鍥炴祦
+     */
+    R kthl(KthlParam param);
+
+    /**
      *GWMS鍒拌揪鐩爣绔欑偣璇锋眰ZWCS鎵ц鍏ュ簱
      */
     String crnExecute(CrnExecuteParam param);
diff --git a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
index aad5f36..33730fb 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -42,6 +42,9 @@
 @Service
 public class OpenServiceImpl implements OpenService {
 
+    // 浜屾ゼ鍫嗗灈鏈哄搴斿叆搴撶珯鐐�
+    private static final int[] secondFloorIn = new int[]{0,2061,2064,2067,2070,2073,2076};
+
     @Autowired
     private OrderService orderService;
     @Autowired
@@ -1043,7 +1046,10 @@
         StartupDto dto = commonService.getLocNo(1, param.getPalletizingNo(), locTypeDto, 0);
 
         // 杩斿洖GWCS鐩爣淇℃伅
-        pushStaNoToGwcs(param.getPalletizingNo(), dto.getStaNo(), dto.getWorkNo(),param.getBarcode());
+        boolean result = pushStaNoToGwcs(param.getPalletizingNo(), dto.getStaNo(), dto.getWorkNo(), param.getBarcode());
+//        if (!result) {
+//            throw new CoolException("鍏ュ簱鍥炴帹鍏ュ簱鐮佸ご缁橤WCS澶辫触");
+//        }
 
         int workNo = dto.getWorkNo();
         Date now = new Date();
@@ -1110,6 +1116,58 @@
             throw new CoolException(dto.getLocNo() + "鐩爣搴撲綅宸茶鍗犵敤");
         }
         return "鍏ュ簱鎴愬姛";
+    }
+
+    @Override
+    @Transactional
+    public R kthl(KthlParam param) {
+
+        // 鑾峰彇妯″紡涓虹數鑴戞ā寮忥紝鏃犱换鍔$殑鍫嗗灈鏈哄垪琛�:闃叉鍒嗛厤鍒板爢鍨涙満涓嶅彲鐢�
+        List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<BasCrnp>().eq("crn_sts",3)
+                .eq("wrk_no",0).eq("in_enable","Y").eq("out_enable","Y"));
+        if (basCrnps.isEmpty()) {
+            // 閮芥湁浠诲姟鍒欒幏鍙栫數鑴戞ā寮忕殑鍫嗗灈鏈哄垪琛�
+            basCrnps = basCrnpService.selectList(new EntityWrapper<BasCrnp>().eq("crn_sts",3).eq("in_enable","Y")
+                    .eq("out_enable","Y"));
+        }
+        if (basCrnps.isEmpty()) {
+            throw new CoolException("娌℃湁鍙敤鍫嗗灈鏈�,鍫嗗灈鏈哄仠姝㈡垨寮傚父鎴栫鐢�");
+        }
+        // 鍙敤鍫嗗灈鏈哄垪琛�
+        List<Integer> crnNoList = basCrnps.stream().map(BasCrnp::getCrnNo).collect(Collectors.toList());
+        Integer crnNo = crnNoList.get(0);
+
+        int workNo = commonService.getWorkNo(5);
+        Date now = new Date();
+        // 鐢熸垚宸ヤ綔妗�
+        WrkMast wrkMast = new WrkMast();
+        wrkMast.setWrkNo(workNo);
+        wrkMast.setIoTime(new Date());
+        wrkMast.setWrkSts(1L); //
+        wrkMast.setIoType(3); // 绔欏埌绔�
+        wrkMast.setIoPri(14D); // 浼樺厛绾�
+        wrkMast.setCrnNo(crnNo);
+        wrkMast.setSourceStaNo(secondFloorIn[crnNo]);
+        wrkMast.setStaNo(3013);
+        wrkMast.setLocNo("");
+        wrkMast.setBarcode(param.getBarcode()); // 鎵樼洏鐮�
+        wrkMast.setFullPlt("N"); // 婊℃澘锛歒
+        wrkMast.setPicking("N"); // 鎷f枡
+        wrkMast.setExitMk("N"); // 閫�鍑�
+        wrkMast.setEmptyMk("Y"); // 绌烘澘
+        wrkMast.setLinkMis("Y");
+        wrkMast.setCtnType(1); // 瀹瑰櫒绫诲瀷
+        // 鎿嶄綔浜哄憳鏁版嵁
+        wrkMast.setAppeTime(now);
+        wrkMast.setModiTime(now);
+        boolean res = wrkMastService.insert(wrkMast);
+        if (!res) {
+            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
+        }
+        // 杩斿洖GWCS鐩爣淇℃伅
+        pushStaNoToGwcs(wrkMast.getSourceStaNo(),wrkMast.getStaNo(),workNo,param.getBarcode());
+
+        return R.ok("绌烘墭鍥炴祦璇锋眰鎴愬姛");
     }
 
     @Override
@@ -1593,7 +1651,7 @@
         return wrkDetls.size() > 1 ? 0 : 1; // 涓�鏉¤褰曞氨鏄竴鍗�
     }
 
-    public void pushStaNoToGwcs(Integer palletizingNo, Integer staNo, Integer workNo,String barcode) {
+    public boolean pushStaNoToGwcs(Integer palletizingNo, Integer staNo, Integer workNo,String barcode) {
         boolean success = false;
         // 鑾峰彇璇锋眰澶�
         Map<String, Object> headers = getHeaders();
@@ -1644,6 +1702,7 @@
                 log.error("", e);
             }
         }
+        return success;
     }
 
     Map<String, Object> getHeaders(){
diff --git a/src/main/java/com/zy/asrs/task/GhjtScheduler.java b/src/main/java/com/zy/asrs/task/GhjtScheduler.java
index 8a2d017..15b27c5 100644
--- a/src/main/java/com/zy/asrs/task/GhjtScheduler.java
+++ b/src/main/java/com/zy/asrs/task/GhjtScheduler.java
@@ -35,7 +35,7 @@
     @Scheduled(cron = "0/2 * * * * ? ")
     public void ckrwPushGwcs() {
         // 鏌ヨ鐘舵�佷负13鐨勫伐浣滄。
-        List<WrkMast> wrkMasts = wrkMastMapper.selectList(new EntityWrapper<WrkMast>().in("io_type", 101,103,107,110).eq("wrk_sts", 13));
+        List<WrkMast> wrkMasts = wrkMastMapper.selectList(new EntityWrapper<WrkMast>().in("io_type", 101,103,107,110,3).eq("wrk_sts", 13));
         for (WrkMast wrkMast : wrkMasts) {
             try {
                 ghjtHandler.startCkrwPushGwcs(wrkMast);

--
Gitblit v1.9.1