From 665fefc7dcdb77eba98a7cbc839257cf13f78c8a Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期三, 30 七月 2025 13:12:44 +0800
Subject: [PATCH] 1

---
 src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java |  219 +++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 214 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
index 619b6e9..0bf1a91 100644
--- a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
@@ -1436,7 +1436,7 @@
     @Override
     public R pdaFxprk(GwmsGenerateInventoryDto param, Long userId) {
 
-        if (Cools.isEmpty(param)) {
+        if (Cools.isEmpty(param,param.getMatList())) {
             throw new CoolException("璇锋眰鍙傛暟涓嶈兘涓虹┖锛�" + param);
         }
         if (Cools.isEmpty(param.getBarcode())) {
@@ -1468,6 +1468,7 @@
         // 鐢熸垚宸ヤ綔妗�
         WrkMast wrkMast = new WrkMast();
         wrkMast.setWrkNo(workNo);
+        wrkMast.setWhsType(1); // 杩斾慨鍏ュ簱鏍囪瘑
         wrkMast.setIoTime(new Date());
         wrkMast.setWrkSts(1L); // 宸ヤ綔鐘舵�侊細璁惧涓婅蛋
         wrkMast.setIoType(iotype); // 鍏ュ嚭搴撶姸鎬侊細1.鍏ュ簱
@@ -1547,10 +1548,168 @@
             throw new CoolException(dto.getLocNo() + "鐩爣搴撲綅宸茶鍗犵敤");
         }
 
+        // 涓�妤艰繑淇叆搴撴帹閫乵es鍋氳褰�
+        pushFxrkToMes(param);
+
         // 杩斿洖GWCS鐩爣淇℃伅
-        openServiceImpl.pushStaNoToGwcs(param.getPalletizingNo(), dto.getStaNo(), dto.getWorkNo(), param.getBarcode(), "浜屾ゼ杩斾慨鍏ュ簱鎺ㄩ�乬wcs");
+        openServiceImpl.pushStaNoToGwcs(param.getPalletizingNo(), dto.getStaNo(), dto.getWorkNo(), param.getBarcode(), "涓�妤艰繑淇叆搴撴帹閫乬wcs");
 
         return R.ok("鍙嶄慨鍏ュ簱鎴愬姛");
+    }
+
+    @Override
+    public R pdaBoxIn(BoxInParam param, Long userId) {
+
+        if (Cools.isEmpty(param.getBarcode())) {
+            throw new CoolException("鏉$爜涓嶈兘涓虹┖锛�" + param.getBarcode());
+        }
+
+        if (Cools.isEmpty(param.getAnfme())) {
+            throw new CoolException("璇疯緭鍏ユ暟閲�" + param.getAnfme());
+        }
+        if (Cools.isEmpty(param.getMemo())) {
+            throw new CoolException("璇疯緭鍏ュ娉�");
+        }
+        if (Cools.isEmpty(param.getOld())) {
+            throw new CoolException("璇疯緭鍏ユ柊鏃�" );
+        }
+
+        int zpalletCount = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet", param.getBarcode()));
+        if (zpalletCount > 0) {
+            throw new CoolException("搴撳瓨鎵樼洏鐮佸凡瀛樺湪锛�" + param.getBarcode());
+        }
+
+        int barcodeCount = wrkMastService.selectCount(new EntityWrapper<WrkMast>().eq("barcode", param.getBarcode()));
+        if (barcodeCount > 0) {
+            throw new CoolException("宸ヤ綔妗e凡瀛樺湪璇ユ墭鐩樼爜锛�" + param.getBarcode());
+        }
+
+        LocTypeDto locTypeDto = new LocTypeDto();
+        locTypeDto.setLocType1((short) 1);
+        int iotype = 1; //绌虹
+
+        // 鏍规嵁婧愮珯鐐瑰鎵惧簱浣�
+        StartupDto dto = commonService.getLocNo(iotype, param.getPalletizingNo(), locTypeDto, 0);
+
+        int workNo = dto.getWorkNo();
+        Date now = new Date();
+        // 鐢熸垚宸ヤ綔妗�
+        WrkMast wrkMast = new WrkMast();
+        wrkMast.setWrkNo(workNo);
+        wrkMast.setIoTime(new Date());
+        wrkMast.setWrkSts(1L); // 宸ヤ綔鐘舵�侊細璁惧涓婅蛋
+        wrkMast.setIoType(iotype); // 鍏ュ嚭搴撶姸鎬侊細1.鍏ュ簱
+        wrkMast.setIoPri(13D); // 浼樺厛绾�
+        wrkMast.setCrnNo(dto.getCrnNo());
+        wrkMast.setSourceStaNo(param.getPalletizingNo());
+        wrkMast.setStaNo(dto.getStaNo());
+        wrkMast.setLocNo(dto.getLocNo());
+        wrkMast.setBarcode(param.getBarcode()); // 鎵樼洏鐮�
+        wrkMast.setFullPlt("Y"); // 婊℃澘锛歒
+        wrkMast.setPicking("N"); // 鎷f枡
+        wrkMast.setExitMk("N"); // 閫�鍑�
+        wrkMast.setEmptyMk("Y"); // 绌烘澘
+        wrkMast.setLinkMis("Y");
+        wrkMast.setCtnType(1); // 瀹瑰櫒绫诲瀷
+        // 鎿嶄綔浜哄憳鏁版嵁
+        wrkMast.setAppeTime(now);
+        wrkMast.setAppeUser(userId);
+        wrkMast.setModiTime(now);
+        wrkMast.setModiUser(userId);
+        wrkMastService.insert(wrkMast);
+
+        if (!Cools.isEmpty(param.getBatch())) {
+                WrkDetl wrkDetl = new WrkDetl();
+                wrkDetl.setMatnr("绌虹");
+                wrkDetl.setSuppCode(param.getOld());
+                wrkDetl.setAnfme(param.getAnfme());
+                wrkDetl.setWrkNo(wrkMast.getWrkNo());
+                wrkDetl.setWrkNo(wrkMast.getWrkNo());
+                wrkDetl.setBatch(param.getBatch()); // 灏哄
+                wrkDetl.setZpallet(param.getBarcode()); // 鎵樼洏鐮�
+                wrkDetl.setBarcode(param.getBarcode());
+                wrkDetl.setMemo(param.getMemo()); //澶囨敞
+                wrkDetl.setAnfme(param.getAnfme());
+                wrkDetl.setIoTime(now);
+                wrkDetl.setAppeTime(now);
+                wrkDetl.setAppeUser(userId);
+                wrkDetl.setModiUser(userId);
+                wrkDetl.setModiTime(now);
+                if (!wrkDetlService.insert(wrkDetl)) {
+                    throw new CoolException("淇濆瓨宸ヤ綔鏄庣粏澶辫触");
+                }
+        }
+
+        // 鏇存柊鐩爣搴撲綅鐘舵��
+        LocMast locMast = locMastService.selectById(dto.getLocNo());
+        if (locMast.getLocSts().equals("O")) {
+            locMast.setLocSts("S"); // S.鍏ュ簱棰勭害
+            locMast.setModiTime(now);
+            if (!locMastService.updateById(locMast)) {
+                throw new CoolException("鏀瑰彉搴撲綅鐘舵�佸け璐�");
+            }
+        } else {
+            throw new CoolException(dto.getLocNo() + "鐩爣搴撲綅宸茶鍗犵敤");
+        }
+
+        // 杩斿洖GWCS鐩爣淇℃伅
+        openServiceImpl.pushStaNoToGwcs(param.getPalletizingNo(), dto.getStaNo(), dto.getWorkNo(), param.getBarcode(), "涓�妤肩┖绠卞叆搴撴帹閫乬wcs");
+
+        return R.ok("绌虹鍏ュ簱鎴愬姛");
+    }
+
+    private void pushFxrkToMes(GwmsGenerateInventoryDto param) {
+
+        for (GwmsGenerateInventoryDto.MatList matList : param.getMatList()){
+            matList.setOutOrIn("in");
+            matList.setStockType("杩斾慨鍏ュ簱");
+        }
+
+        boolean success = false;
+        // 鑾峰彇璇锋眰澶�
+        Map<String,Object> headers = new HashMap<>();
+        headers.put("Content-Type","application/json;charset=UTF-8");
+
+        // 鏋勯�犺姹備綋
+        String body = JSON.toJSONString(param);
+        String response = "";
+        try {
+            response = new HttpHandler.Builder()
+                    .setUri(MesConstant.MES_CC_IP_PORT)
+                    .setPath(MesConstant.MES_CC_FXRK_URL)
+                    .setHeaders(headers)
+                    .setJson(body)
+                    .build()
+                    .doGet();
+            if (!Cools.isEmpty(response)) {
+                JSONObject jsonObject1 = JSONObject.parseObject(response);
+                int code = (int) jsonObject1.get("code");
+                boolean state  = jsonObject1.getBoolean("state");
+                if (code == 200 && state) {
+                    success = true;
+                }
+            } else {
+                log.error("杩斾慨鍏ュ簱鎺ㄩ�乵es璁板綍澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_FXRK_URL, body, response);
+            }
+        } catch (Exception e) {
+            log.error("杩斾慨鍏ュ簱鎺ㄩ�乵es璁板綍寮傚父锛歿}", e.getMessage());
+        } finally {
+            try {
+                // 淇濆瓨鎺ュ彛鏃ュ織
+                apiLogService.save(
+                        "杩斾慨鍏ュ簱鎺ㄩ�乵es璁板綍",
+                        MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_FXRK_URL,
+                        null,
+                        "127.0.0.1",
+                        body,
+                        response,
+                        success
+                );
+            } catch (Exception e) {
+                log.error("", e);
+            }
+        }
+
     }
 
     @Override
@@ -1760,6 +1919,27 @@
        return R.ok("璋冩暣鎴愬姛");
     }
 
+    @Override
+    public R pdaFhhd(PdaDhhdParam param, Long userId) {
+
+        String orderNo = param.getOrderNo();
+
+        Order order = orderService.selectByNo(orderNo);
+        if (order == null) {
+            return R.parse("鍗曟嵁缂栧彿涓嶅瓨鍦細" + orderNo);
+        } else if (!order.getSettle().equals(4L)) {
+            return R.parse("鍗曟嵁鐘舵�佷笉涓�4.宸插畬鎴�");
+        }
+
+        order.setSettle(5L);
+        order.setUpdateBy(userId);
+        order.setUpdateTime(new Date());
+
+        orderService.updateById(order);
+
+        return R.ok("鍙戣揣鏍稿鎴愬姛");
+    }
+
     // 鍚屾鐩樼偣寮傚父璋冩暣缁撴灉缁檓es
     void kctzPushMes(JSONObject jsonObject) {
         // 鎺ュ彛璇锋眰缁撴灉
@@ -1850,7 +2030,7 @@
      * 璋冩暣搴撳瓨鏄庣粏
      */
     @Transactional
-    void insertLocDetl(String locNo, String barcode, List<PdtzParam.MatList> matList) {
+    public void insertLocDetl(String locNo, String barcode, List<PdtzParam.MatList> matList) {
         Date now = new Date();
         for (PdtzParam.MatList mat : matList) {
             LocDetl locDetl = new LocDetl();
@@ -1914,7 +2094,7 @@
                 }
                 throw new CoolException(msg);
             } else {
-                log.error("杩斾慨鍝佸叆搴撶粰mes鎺ㄩ�佸緟鍒ゅけ璐ワ紒锛侊紒url锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_IP_PORT, body, response);
+                log.error("杩斾慨鍝佸叆搴撶粰mes鎺ㄩ�佸緟鍒ゅけ璐ワ紒锛侊紒url锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_DP_URL, body, response);
                 throw new CoolException("杩斾慨鍝佸叆搴撶粰mes鎺ㄩ�佸緟鍒ゅけ璐�");
             }
         } catch (Exception e) {
@@ -1924,7 +2104,7 @@
                 // 淇濆瓨鎺ュ彛鏃ュ織
                 apiLogService.save(
                         "杩斾慨鍝佸叆搴撶粰mes鎺ㄩ�佸緟鍒�",
-                        MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_IP_PORT,
+                        MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_DP_URL,
                         null,
                         "127.0.0.1",
                         body,
@@ -2035,4 +2215,33 @@
         }
         return result;
     }
+
+    @Override
+    public List<Map<String, Object>> pdaGetMemo() {
+        List<Integer> tagIds = Arrays.asList(7, 8,9);
+        List<Map<String, Object>> raw = matMapper.getBoxMemoMap(tagIds);
+
+        // 鐢� Map<String, List<String>> 鍒嗙粍
+        Map<String, List<String>> grouped = new HashMap<>();
+        for (Map<String, Object> row : raw) {
+            String tagId = String.valueOf(row.get("tag_id"));
+            String memo = String.valueOf(row.get("memo"));
+            if (memo == null || "null".equalsIgnoreCase(memo)) continue;
+
+            grouped.computeIfAbsent(tagId, k -> new ArrayList<>()).add(memo);
+        }
+
+        // 杞垚 List<Map<String, Object>> 缁撴瀯杩斿洖
+        List<Map<String, Object>> result = new ArrayList<>();
+        for (Map.Entry<String, List<String>> entry : grouped.entrySet()) {
+            Map<String, Object> item = new HashMap<>();
+            item.put("tagId", entry.getKey());
+            item.put("memos", entry.getValue());
+            result.add(item);
+        }
+
+        return result;
+    }
+
+
 }

--
Gitblit v1.9.1