From 619bb4fa99082700aa90f440c23904bc3d5d6ccd Mon Sep 17 00:00:00 2001
From: Junjie <540245094@qq.com>
Date: 星期二, 12 十二月 2023 19:54:45 +0800
Subject: [PATCH] #拣料回库

---
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |  232 +++++++++++++++++++++++++++++++++-------------------------
 1 files changed, 132 insertions(+), 100 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
index b30418f..ccdf575 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -450,27 +450,27 @@
                             continue;
                         }
 
-                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
-                        boolean flag = false;
-                        String th = "";
-                        List<String> innerLoc = Utils.getGroupInnerLoc(wrkMast.getSourceLocNo());
-                        for (String loc : innerLoc) {
-                            LocMast locMast = locMastService.selectById(loc);
-                            if (locMast == null) {
-                                continue;
-                            }
-
-                            if (!locMast.getLocSts().equals("F")) {
-                                flag = true;
-                                th = loc + "搴撲綅瀛樺湪鏈洖搴撲换鍔�";
-                                break;
-                            }
-                        }
-                        if (flag) {
-                            News.info(th);
-                            continue;
-                        }
-                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
+//                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
+//                        boolean flag = false;
+//                        String th = "";
+//                        List<String> innerLoc = Utils.getGroupInnerLoc(wrkMast.getSourceLocNo());
+//                        for (String loc : innerLoc) {
+//                            LocMast locMast = locMastService.selectById(loc);
+//                            if (locMast == null) {
+//                                continue;
+//                            }
+//
+//                            if (!locMast.getLocSts().equals("F")) {
+//                                flag = true;
+//                                th = loc + "搴撲綅瀛樺湪鏈洖搴撲换鍔�";
+//                                break;
+//                            }
+//                        }
+//                        if (flag) {
+//                            News.info(th);
+//                            continue;
+//                        }
+//                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
 
                         // 淇濆瓨宸ヤ綔涓绘。鍘嗗彶妗�
                         if (wrkMastMapper.saveWrkMastLog(wrkMast.getWrkNo()) == 0) {
@@ -478,35 +478,51 @@
                             continue;
                         }
 
-                        String sourceLocNo = wrkMast.getSourceLocNo().trim();
-                        LiftStaProtocol liftStaProtocol = NyLiftUtils.getLiftStaByLev(pickSta.getLiftNo(), Utils.getLev(sourceLocNo));//鑾峰彇鍥炲簱鎻愬崌鏈虹洰鏍囩珯
-                        if (liftStaProtocol == null) {
-                            continue;
-                        }
+                        try {
+                            LocMast locMast = locMastService.selectById(wrkMast.getSourceLocNo());//婧愬簱浣�
+                            SearchLocParam param = new SearchLocParam();
+                            param.setWrkNo(wrkMast.getWrkNo());
+                            param.setBarcode(wrkMast.getBarcode());
+                            param.setIoType(wrkMast.getIoType());
+                            param.setSourceStaNo(pickSta.getStaNo());
+                            param.setLocType1(locMast.getLocType1());
+                            String response = new HttpHandler.Builder()
+                                    .setUri(wmsUrl)
+                                    .setPath("/rpc/pakin/loc/v2")
+                                    .setJson(JSON.toJSONString(param))
+                                    .build()
+                                    .doPost();
+                            JSONObject jsonObject = JSON.parseObject(response);
+                            Integer code = jsonObject.getInteger("code");
+                            if (code.equals(200)) {
+                                StartupDto dto = jsonObject.getObject("data", StartupDto.class);
 
-                        // 鏇存柊宸ヤ綔妗f暟鎹姸鎬�
-                        wrkMast.setIoType(wrkMast.getIoType() - 50); // 鍏ュ嚭搴撶被鍨�: 103->53,104->54,107->57
-                        wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵��: 2.璁惧涓婅蛋
-                        wrkMast.setSourceStaNo(pickSta.getBackSta()); // 婧愮珯
-//                            wrkMast.setStaNo(dto.getStaNo()); // 鐩爣绔�
-//                            wrkMast.setCrnNo(dto.getCrnNo());
-                        wrkMast.setStaNo(liftStaProtocol.getStaNo());//鐩爣绔�
-                        wrkMast.setLocNo(sourceLocNo); // 鐩爣搴撲綅 = 鍑哄簱鏃剁殑婧愬簱浣�
-                        wrkMast.setShuttleNo(null); // 绌挎杞︽竻绌�
-                        wrkMast.setLiftNo(null);// 鎻愬崌鏈烘竻绌�
-                        wrkMast.setModiTime(new Date());
-                        if (wrkMastMapper.updateById(wrkMast) == 0) {
-                            News.info(wrkMast.getWrkNo() + "鏇存柊宸ヤ綔妗f暟鎹姸鎬佸け璐�");
-                            continue;
-                        }
+                                //鑾峰彇鍥炲簱鎻愬崌鏈虹洰鏍囩珯
+                                LiftStaProtocol liftStaProtocol = NyLiftUtils.getLiftStaByLev(pickSta.getLiftNo(), Utils.getLev(dto.getLocNo()));
+                                if (liftStaProtocol == null) {
+                                    News.info(wrkMast.getWrkNo() + "鑾峰彇鍥炲簱鎻愬崌鏈虹洰鏍囩珯澶辫触");
+                                    continue;
+                                }
 
-                        // 淇敼搴撲綅鐘舵�� Q.鎷f枡/鐩樼偣/骞舵澘鍐嶅叆搴�
-                        LocMast locMast = locMastService.selectById(sourceLocNo);
-                        locMast.setLocSts("Q");
-                        locMast.setModiTime(new Date());
-                        if (!locMastService.updateById(locMast)) {
-                            News.info("淇敼搴撲綅鐘舵�佸け璐�");
-                            continue;
+                                // 鏇存柊宸ヤ綔妗f暟鎹姸鎬�
+                                wrkMast.setIoType(wrkMast.getIoType() - 50); // 鍏ュ嚭搴撶被鍨�: 103->53,104->54
+                                wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵��: 2.璁惧涓婅蛋
+                                wrkMast.setSourceStaNo(dto.getSourceStaNo()); // 婧愮珯
+                                wrkMast.setStaNo(liftStaProtocol.getStaNo());//鐩爣绔�
+                                wrkMast.setLocNo(dto.getLocNo()); // 鐩爣搴撲綅
+                                wrkMast.setShuttleNo(null); // 绌挎杞︽竻绌�
+                                wrkMast.setLiftNo(null);// 鎻愬崌鏈烘竻绌�
+                                wrkMast.setModiTime(new Date());
+                                if (wrkMastMapper.updateById(wrkMast) == 0) {
+                                    News.info(wrkMast.getWrkNo() + "鏇存柊宸ヤ綔妗f暟鎹姸鎬佸け璐�");
+                                    continue;
+                                }
+                            } else if (code == 500) {
+                                News.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", wmsUrl + "/rpc/pakin/loc/v1", JSON.toJSONString(param), response);
+                            }
+                        } catch (Exception e) {
+                            e.printStackTrace();
+                            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
                         }
                     }
                 }
@@ -554,27 +570,27 @@
                             continue;
                         }
 
-                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
-                        boolean flag = false;
-                        String th = "";
-                        List<String> innerLoc = Utils.getGroupInnerLoc(wrkMast.getSourceLocNo());
-                        for (String loc : innerLoc) {
-                            LocMast locMast = locMastService.selectById(loc);
-                            if (locMast == null) {
-                                continue;
-                            }
-
-                            if (!locMast.getLocSts().equals("F")) {
-                                flag = true;
-                                th = loc + "搴撲綅瀛樺湪鏈洖搴撲换鍔�";
-                                break;
-                            }
-                        }
-                        if (flag) {
-                            News.info(th);
-                            continue;
-                        }
-                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
+//                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
+//                        boolean flag = false;
+//                        String th = "";
+//                        List<String> innerLoc = Utils.getGroupInnerLoc(wrkMast.getSourceLocNo());
+//                        for (String loc : innerLoc) {
+//                            LocMast locMast = locMastService.selectById(loc);
+//                            if (locMast == null) {
+//                                continue;
+//                            }
+//
+//                            if (!locMast.getLocSts().equals("F")) {
+//                                flag = true;
+//                                th = loc + "搴撲綅瀛樺湪鏈洖搴撲换鍔�";
+//                                break;
+//                            }
+//                        }
+//                        if (flag) {
+//                            News.info(th);
+//                            continue;
+//                        }
+//                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
 
                         // 淇濆瓨宸ヤ綔涓绘。鍘嗗彶妗�
                         if (wrkMastMapper.saveWrkMastLog(wrkMast.getWrkNo()) == 0) {
@@ -582,39 +598,55 @@
                             continue;
                         }
 
-                        String sourceLocNo = wrkMast.getSourceLocNo().trim();
-                        LiftStaProtocol liftStaProtocol = NyLiftUtils.getLiftStaByLev(pickSta.getLiftNo(), Utils.getLev(sourceLocNo));//鑾峰彇鍥炲簱鎻愬崌鏈虹洰鏍囩珯
-                        if (liftStaProtocol == null) {
-                            continue;
-                        }
+                        try {
+                            LocMast locMast = locMastService.selectById(wrkMast.getSourceLocNo());//婧愬簱浣�
+                            SearchLocParam param = new SearchLocParam();
+                            param.setWrkNo(wrkMast.getWrkNo());
+                            param.setBarcode(wrkMast.getBarcode());
+                            param.setIoType(wrkMast.getIoType());
+                            param.setSourceStaNo(pickSta.getStaNo());
+                            param.setLocType1(locMast.getLocType1());
+                            String response = new HttpHandler.Builder()
+                                    .setUri(wmsUrl)
+                                    .setPath("/rpc/pakin/loc/v2")
+                                    .setJson(JSON.toJSONString(param))
+                                    .build()
+                                    .doPost();
+                            JSONObject jsonObject = JSON.parseObject(response);
+                            Integer code = jsonObject.getInteger("code");
+                            if (code.equals(200)) {
+                                StartupDto dto = jsonObject.getObject("data", StartupDto.class);
 
-                        // 鏇存柊宸ヤ綔妗f暟鎹姸鎬�
-                        wrkMast.setIoType(wrkMast.getIoType() - 50); // 鍏ュ嚭搴撶被鍨�: 103->53,104->54,107->57
-                        wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵��: 2.璁惧涓婅蛋
-                        wrkMast.setSourceStaNo(pickSta.getBackSta()); // 婧愮珯
-//                            wrkMast.setStaNo(dto.getStaNo()); // 鐩爣绔�
-//                            wrkMast.setCrnNo(dto.getCrnNo());
-                        wrkMast.setStaNo(liftStaProtocol.getStaNo());//鐩爣绔�
-                        wrkMast.setLocNo(sourceLocNo); // 鐩爣搴撲綅 = 鍑哄簱鏃剁殑婧愬簱浣�
-                        wrkMast.setShuttleNo(null); // 绌挎杞︽竻绌�
-                        wrkMast.setLiftNo(null);// 鎻愬崌鏈烘竻绌�
-                        wrkMast.setModiTime(new Date());
-                        if (wrkMastMapper.updateById(wrkMast) == 0) {
-                            News.info(wrkMast.getWrkNo() + "鏇存柊宸ヤ綔妗f暟鎹姸鎬佸け璐�");
-                            continue;
-                        }
+                                //鑾峰彇鍥炲簱鎻愬崌鏈虹洰鏍囩珯
+                                LiftStaProtocol liftStaProtocol = NyLiftUtils.getLiftStaByLev(pickSta.getLiftNo(), Utils.getLev(dto.getLocNo()));
+                                if (liftStaProtocol == null) {
+                                    News.info(wrkMast.getWrkNo() + "鑾峰彇鍥炲簱鎻愬崌鏈虹洰鏍囩珯澶辫触");
+                                    continue;
+                                }
 
-                        // 淇敼搴撲綅鐘舵�� Q.鎷f枡/鐩樼偣/骞舵澘鍐嶅叆搴�
-                        LocMast locMast = locMastService.selectById(sourceLocNo);
-                        locMast.setLocSts("Q");
-                        locMast.setModiTime(new Date());
-                        if (!locMastService.updateById(locMast)) {
-                            News.info("淇敼搴撲綅鐘舵�佸け璐�");
-                            continue;
-                        }
+                                // 鏇存柊宸ヤ綔妗f暟鎹姸鎬�
+                                wrkMast.setIoType(wrkMast.getIoType() - 50); // 鍏ュ嚭搴撶被鍨�: 103->53,104->54
+                                wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵��: 2.璁惧涓婅蛋
+                                wrkMast.setSourceStaNo(dto.getSourceStaNo()); // 婧愮珯
+                                wrkMast.setStaNo(liftStaProtocol.getStaNo());//鐩爣绔�
+                                wrkMast.setLocNo(dto.getLocNo()); // 鐩爣搴撲綅
+                                wrkMast.setShuttleNo(null); // 绌挎杞︽竻绌�
+                                wrkMast.setLiftNo(null);// 鎻愬崌鏈烘竻绌�
+                                wrkMast.setModiTime(new Date());
+                                if (wrkMastMapper.updateById(wrkMast) == 0) {
+                                    News.info(wrkMast.getWrkNo() + "鏇存柊宸ヤ綔妗f暟鎹姸鎬佸け璐�");
+                                    continue;
+                                }
 
-                        staProtocol.setStaNo(pickSta.getBackSta().shortValue());//鍐欏叆鐩爣绔�
-                        MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
+                                staProtocol.setStaNo(dto.getSourceStaNo().shortValue());//鍐欏叆鐩爣绔�
+                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
+                            } else if (code == 500) {
+                                News.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", wmsUrl + "/rpc/pakin/loc/v1", JSON.toJSONString(param), response);
+                            }
+                        } catch (Exception e) {
+                            e.printStackTrace();
+                            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
+                        }
                     }
                 }
 
@@ -697,7 +729,7 @@
                             param.setLocType1(locMast.getLocType1());
                             String response = new HttpHandler.Builder()
                                     .setUri(wmsUrl)
-                                    .setPath("/rpc/pakin/loc/v1")
+                                    .setPath("/rpc/pakin/loc/v2")
                                     .setJson(JSON.toJSONString(param))
                                     .build()
                                     .doPost();

--
Gitblit v1.9.1