From da012358699d5881a4e1c72ed3b9275b3da49a17 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期一, 17 一月 2022 13:15:31 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |  296 ++++++++++++++++++++++++++++++++++------------------------
 1 files changed, 174 insertions(+), 122 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 3603a5e..75eeaa1 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -133,16 +133,22 @@
                         log.error("宸ヤ綔妗d腑宸插瓨鍦ㄨ绔欑姸鎬佷负锛� 2.璁惧涓婅蛋 锛夌殑鏁版嵁,宸ヤ綔鍙�={}", wrkMast.getWrkNo());
                         continue;
                     }
-                    // 鑾峰彇鍏ュ簱閫氱煡妗�
-                    List<WaitPakin> waitPakins = waitPakinMapper.selectList(new EntityWrapper<WaitPakin>().eq("zpallet", barcode).eq("io_status", "N"));
-                    if (waitPakins.isEmpty()) {
-                        log.error("鏃犳鍏ュ簱鏉$爜鏁版嵁銆傛潯鐮佸彿={}", barcode);
-                        continue;
-                    }
+//                    // 鑾峰彇鍏ュ簱閫氱煡妗�
+//                    List<WaitPakin> waitPakins = waitPakinMapper.selectList(new EntityWrapper<WaitPakin>().eq("zpallet", barcode).eq("io_status", "N"));
+//                    if (waitPakins.isEmpty()) {
+//                        log.error("鏃犳鍏ュ簱鏉$爜鏁版嵁銆傛潯鐮佸彿={}", barcode);
+//                        continue;
+//                    }
 
                     try {
 
+                        LocTypeDto locTypeDto = new LocTypeDto(staProtocol);
+
                         SearchLocParam param = new SearchLocParam();
+                        param.setBarcode(barcode);
+                        param.setIoType(1);
+                        param.setSourceStaNo(inSta.getStaNo());
+                        param.setLocType1(locTypeDto.getLocType1());
                         String response = new HttpHandler.Builder()
                                 .setUri(wmsUrl)
                                 .setPath("/rpc/pakin/loc/v1")
@@ -152,71 +158,79 @@
                         JSONObject jsonObject = JSON.parseObject(response);
                         if (jsonObject.getInteger("code").equals(200)) {
                             StartupDto dto = jsonObject.getObject("data", StartupDto.class);
-                            // todo
 
+                            barcodeThread.setBarcode("");
+                            staProtocol.setWorkNo(dto.getWorkNo().shortValue());
+                            staProtocol.setStaNo(dto.getStaNo().shortValue());
+                            devpThread.setPakMk(staProtocol.getSiteId(), false);
+                            boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
+                            if (!result) {
+                                throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触");
+                            }
                         } else {
                             log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", wmsUrl+"/rpc/pakin/loc/v1", JSON.toJSONString(param), response);
                         }
 
 
-                        // 妫�绱㈠簱浣�
-                        LocTypeDto locTypeDto = new LocTypeDto(staProtocol);
-                        List<String> matNos = waitPakins.stream().map(WaitPakin::getMatnr).distinct().collect(Collectors.toList());
-                        StartupDto startupDto = commonService.getLocNo(1, 1, inSta.getStaNo(), matNos, locTypeDto, 0);
-                        // 宸ヤ綔鍙�
-                        int workNo = startupDto.getWorkNo();
-                        // 鎻掑叆宸ヤ綔鏄庣粏妗�
-                        wrkDetlService.createWorkDetail(workNo, waitPakins, barcode);
-
-                        // 鎻掑叆宸ヤ綔涓绘。
-                        wrkMast = new WrkMast();
-                        wrkMast.setWrkNo(workNo);
-                        wrkMast.setIoTime(new Date());
-                        wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵�侊細2.璁惧涓婅蛋
-                        wrkMast.setIoType(1); // 鍏ュ嚭搴撶姸鎬侊細1.鍏ュ簱
-                        wrkMast.setIoPri(10D); // 浼樺厛绾э細10
-                        wrkMast.setCrnNo(startupDto.getCrnNo());
-                        wrkMast.setSourceStaNo(startupDto.getSourceStaNo());
-                        wrkMast.setStaNo(startupDto.getStaNo());
-                        wrkMast.setLocNo(startupDto.getLocNo());
-                        wrkMast.setBarcode(barcode); // 鎵樼洏鐮�
-                        wrkMast.setFullPlt("Y"); // 婊℃澘锛歒
-                        wrkMast.setPicking("N"); // 鎷f枡
-                        wrkMast.setExitMk("N"); // 閫�鍑�
-                        wrkMast.setEmptyMk("N"); // 绌烘澘
-                        wrkMast.setLinkMis("N");
-                        // 鎿嶄綔浜哄憳鏁版嵁
-                        wrkMast.setAppeTime(new Date());
-                        wrkMast.setModiTime(new Date());
-                        Integer insert = wrkMastMapper.insert(wrkMast);
-                        if (insert == 0) {
-                            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
-                        }
-                        // 鏇存柊鐩爣搴撲綅鐘舵��
-                        LocMast locMast = locMastService.selectById(startupDto.getLocNo());
-                        locMast.setLocSts("S"); // S.鍏ュ簱棰勭害
-                        locMast.setModiTime(new Date());
-                        if (!locMastService.updateById(locMast)){
-                            throw new CoolException("鏀瑰彉搴撲綅鐘舵�佸け璐�");
-                        }
-                        // 灏嗗叆搴撻�氱煡妗d慨鏀逛负宸插惎鍔�
-                        if (wrkMastMapper.updateWaitPakInStep1(barcode) == 0) {
-                            throw new CoolException("淇敼鍏ュ簱閫氱煡妗g姸鎬佷负宸插惎鍔ㄥけ璐�");
-                        }
-
-                        // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
-
-                        // 鏇存柊绔欑偣淇℃伅 涓� 涓嬪彂plc鍛戒护
-                        barcodeThread.setBarcode("");
-                        staProtocol.setWorkNo((short) workNo);
-                        staProtocol.setStaNo(startupDto.getStaNo().shortValue());
-                        devpThread.setPakMk(staProtocol.getSiteId(), false);
-                        boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
-                        if (!result) {
-                            throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触");
-                        }
+//                        // 妫�绱㈠簱浣�
+//                        LocTypeDto locTypeDto = new LocTypeDto(staProtocol);
+//                        List<String> matNos = waitPakins.stream().map(WaitPakin::getMatnr).distinct().collect(Collectors.toList());
+//                        StartupDto startupDto = commonService.getLocNo(1, 1, inSta.getStaNo(), matNos, locTypeDto, 0);
+//                        // 宸ヤ綔鍙�
+//                        int workNo = startupDto.getWorkNo();
+//                        // 鎻掑叆宸ヤ綔鏄庣粏妗�
+//                        wrkDetlService.createWorkDetail(workNo, waitPakins, barcode);
+//
+//                        // 鎻掑叆宸ヤ綔涓绘。
+//                        wrkMast = new WrkMast();
+//                        wrkMast.setWrkNo(workNo);
+//                        wrkMast.setIoTime(new Date());
+//                        wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵�侊細2.璁惧涓婅蛋
+//                        wrkMast.setIoType(1); // 鍏ュ嚭搴撶姸鎬侊細1.鍏ュ簱
+//                        wrkMast.setIoPri(10D); // 浼樺厛绾э細10
+//                        wrkMast.setCrnNo(startupDto.getCrnNo());
+//                        wrkMast.setSourceStaNo(startupDto.getSourceStaNo());
+//                        wrkMast.setStaNo(startupDto.getStaNo());
+//                        wrkMast.setLocNo(startupDto.getLocNo());
+//                        wrkMast.setBarcode(barcode); // 鎵樼洏鐮�
+//                        wrkMast.setFullPlt("Y"); // 婊℃澘锛歒
+//                        wrkMast.setPicking("N"); // 鎷f枡
+//                        wrkMast.setExitMk("N"); // 閫�鍑�
+//                        wrkMast.setEmptyMk("N"); // 绌烘澘
+//                        wrkMast.setLinkMis("N");
+//                        // 鎿嶄綔浜哄憳鏁版嵁
+//                        wrkMast.setAppeTime(new Date());
+//                        wrkMast.setModiTime(new Date());
+//                        Integer insert = wrkMastMapper.insert(wrkMast);
+//                        if (insert == 0) {
+//                            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
+//                        }
+//                        // 鏇存柊鐩爣搴撲綅鐘舵��
+//                        LocMast locMast = locMastService.selectById(startupDto.getLocNo());
+//                        locMast.setLocSts("S"); // S.鍏ュ簱棰勭害
+//                        locMast.setModiTime(new Date());
+//                        if (!locMastService.updateById(locMast)){
+//                            throw new CoolException("鏀瑰彉搴撲綅鐘舵�佸け璐�");
+//                        }
+//                        // 灏嗗叆搴撻�氱煡妗d慨鏀逛负宸插惎鍔�
+//                        if (wrkMastMapper.updateWaitPakInStep1(barcode) == 0) {
+//                            throw new CoolException("淇敼鍏ュ簱閫氱煡妗g姸鎬佷负宸插惎鍔ㄥけ璐�");
+//                        }
+//
+//                        // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
+//
+//                        // 鏇存柊绔欑偣淇℃伅 涓� 涓嬪彂plc鍛戒护
+//                        barcodeThread.setBarcode("");
+//                        staProtocol.setWorkNo((short) workNo);
+//                        staProtocol.setStaNo(startupDto.getStaNo().shortValue());
+//                        devpThread.setPakMk(staProtocol.getSiteId(), false);
+//                        boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
+//                        if (!result) {
+//                            throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触");
+//                        }
 
                     } catch (Exception e) {
+                        e.printStackTrace();
                         TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
                     }
 
@@ -648,8 +662,9 @@
                             wrkMast.setUpdMk("Y");
                             wrkMastMapper.updateById(wrkMast);
                             // 鐢熸垚宸ヤ綔妗c�佹敼鍙樻祬搴撲綅鐨勬簮搴�/鐩爣搴� 搴撲綅鐘舵�併�佷笅鍙戝爢鍨涙満鍛戒护锛堢珛椹墽琛�)
-                            moveLocForDeepLoc(slave, shallowLoc);
+//                            moveLocForDeepLoc(slave, shallowLoc);
                         }
+                        log.error("{}浠诲姟鍑哄簱澶辫触锛屾祬搴撲綅鍫靛锛�", wrkMast.getWrkNo());
                         continue;
                     }
                 }
@@ -933,58 +948,95 @@
                 // 绔欑偣鏉′欢鍒ゆ柇
                 if (staProtocol.isAutoing() && staProtocol.isLoading() && staProtocol.isInEnable()
                         && staProtocol.isEmptyMk() && (staProtocol.getWorkNo() == 0 || staProtocol.getWorkNo() == 9999 || staProtocol.getWorkNo() == 9990 || staProtocol.getWorkNo() == 9997) && staProtocol.isPakMk()) {
-                    // 妫�绱㈠簱浣�
-                    LocTypeDto locTypeDto = new LocTypeDto(staProtocol);
-                    StartupDto startupDto = commonService.getLocNo(1, 10, emptyInSta.getStaNo(), null, locTypeDto, 0);
-                    // 宸ヤ綔鍙�
-                    int workNo = startupDto.getWorkNo();
 
                     try {
-                        // 鎻掑叆宸ヤ綔涓绘。
-                        WrkMast wrkMast = new WrkMast();
-                        wrkMast.setWrkNo(workNo);
-                        wrkMast.setIoTime(new Date());
-                        wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵�侊細2.璁惧涓婅蛋
-                        wrkMast.setIoType(10); // 鍏ュ嚭搴撶姸鎬侊細10.绌烘澘鍏ュ簱
-                        wrkMast.setIoPri(10D); // 浼樺厛绾э細10
-                        wrkMast.setCrnNo(startupDto.getCrnNo());
-                        wrkMast.setSourceStaNo(startupDto.getSourceStaNo());
-                        wrkMast.setStaNo(startupDto.getStaNo());
-                        wrkMast.setLocNo(startupDto.getLocNo());
-                        wrkMast.setFullPlt("N"); // 婊℃澘
-                        wrkMast.setPicking("N"); // 鎷f枡
-                        wrkMast.setExitMk("N"); // 閫�鍑�
-                        wrkMast.setEmptyMk("Y"); // 绌烘澘
-                        wrkMast.setLinkMis("N");
-//                    wrkMast.setCtnType(sourceStaNo.getCtnType()); // 瀹瑰櫒绫诲瀷
-                        // 鎿嶄綔浜哄憳鏁版嵁
-                        wrkMast.setAppeTime(new Date());
-                        wrkMast.setModiTime(new Date());
-                        Integer insert = wrkMastMapper.insert(wrkMast);
-                        if (insert == 0) {
-                            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
-                        }
-                        // 鏇存柊鐩爣搴撲綅鐘舵��
-                        LocMast locMast = locMastService.selectById(startupDto.getLocNo());
-                        locMast.setLocSts("S"); // S.鍏ュ簱棰勭害
-                        locMast.setModiTime(new Date());
-                        if (!locMastService.updateById(locMast)){
-                            throw new CoolException("鏀瑰彉搴撲綅鐘舵�佸け璐�");
-                        }
-                        // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
+                        LocTypeDto locTypeDto = new LocTypeDto(staProtocol);
 
-                        // 鏇存柊绔欑偣淇℃伅 涓� 涓嬪彂plc鍛戒护
-                        staProtocol.setWorkNo((short) workNo);
-                        staProtocol.setStaNo(startupDto.getStaNo().shortValue());
-                        devpThread.setPakMk(staProtocol.getSiteId(), false);
-                        boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
-                        if (!result) {
-                            throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触");
+                        SearchLocParam param = new SearchLocParam();
+                        param.setIoType(10);
+                        param.setSourceStaNo(emptyInSta.getStaNo());
+                        param.setLocType1(locTypeDto.getLocType1());
+                        String response = new HttpHandler.Builder()
+                                .setUri(wmsUrl)
+                                .setPath("/rpc/pakin/loc/v1")
+                                .setJson(JSON.toJSONString(param))
+                                .build()
+                                .doPost();
+                        JSONObject jsonObject = JSON.parseObject(response);
+                        if (jsonObject.getInteger("code").equals(200)) {
+                            StartupDto dto = jsonObject.getObject("data", StartupDto.class);
+
+                            // 鏇存柊绔欑偣淇℃伅 涓� 涓嬪彂plc鍛戒护
+                            staProtocol.setWorkNo(dto.getWorkNo().shortValue());
+                            staProtocol.setStaNo(dto.getStaNo().shortValue());
+                            devpThread.setPakMk(staProtocol.getSiteId(), false);
+                            boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
+                            if (!result) {
+                                throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触");
+                            }
+                        } else {
+                            log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", wmsUrl+"/rpc/pakin/loc/v1", JSON.toJSONString(param), response);
                         }
                     } catch (Exception e) {
                         e.printStackTrace();
                         TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
                     }
+
+
+
+
+//                    // 妫�绱㈠簱浣�
+//                    LocTypeDto locTypeDto = new LocTypeDto(staProtocol);
+//                    StartupDto startupDto = commonService.getLocNo(1, 10, emptyInSta.getStaNo(), null, locTypeDto, 0);
+//                    // 宸ヤ綔鍙�
+//                    int workNo = startupDto.getWorkNo();
+//
+//                    try {
+//                        // 鎻掑叆宸ヤ綔涓绘。
+//                        WrkMast wrkMast = new WrkMast();
+//                        wrkMast.setWrkNo(workNo);
+//                        wrkMast.setIoTime(new Date());
+//                        wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵�侊細2.璁惧涓婅蛋
+//                        wrkMast.setIoType(10); // 鍏ュ嚭搴撶姸鎬侊細10.绌烘澘鍏ュ簱
+//                        wrkMast.setIoPri(10D); // 浼樺厛绾э細10
+//                        wrkMast.setCrnNo(startupDto.getCrnNo());
+//                        wrkMast.setSourceStaNo(startupDto.getSourceStaNo());
+//                        wrkMast.setStaNo(startupDto.getStaNo());
+//                        wrkMast.setLocNo(startupDto.getLocNo());
+//                        wrkMast.setFullPlt("N"); // 婊℃澘
+//                        wrkMast.setPicking("N"); // 鎷f枡
+//                        wrkMast.setExitMk("N"); // 閫�鍑�
+//                        wrkMast.setEmptyMk("Y"); // 绌烘澘
+//                        wrkMast.setLinkMis("N");
+////                    wrkMast.setCtnType(sourceStaNo.getCtnType()); // 瀹瑰櫒绫诲瀷
+//                        // 鎿嶄綔浜哄憳鏁版嵁
+//                        wrkMast.setAppeTime(new Date());
+//                        wrkMast.setModiTime(new Date());
+//                        Integer insert = wrkMastMapper.insert(wrkMast);
+//                        if (insert == 0) {
+//                            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
+//                        }
+//                        // 鏇存柊鐩爣搴撲綅鐘舵��
+//                        LocMast locMast = locMastService.selectById(startupDto.getLocNo());
+//                        locMast.setLocSts("S"); // S.鍏ュ簱棰勭害
+//                        locMast.setModiTime(new Date());
+//                        if (!locMastService.updateById(locMast)){
+//                            throw new CoolException("鏀瑰彉搴撲綅鐘舵�佸け璐�");
+//                        }
+//                        // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
+//
+//                        // 鏇存柊绔欑偣淇℃伅 涓� 涓嬪彂plc鍛戒护
+//                        staProtocol.setWorkNo((short) workNo);
+//                        staProtocol.setStaNo(startupDto.getStaNo().shortValue());
+//                        devpThread.setPakMk(staProtocol.getSiteId(), false);
+//                        boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
+//                        if (!result) {
+//                            throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触");
+//                        }
+//                    } catch (Exception e) {
+//                        e.printStackTrace();
+//                        TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
+//                    }
 
                 }
 
@@ -1257,21 +1309,21 @@
                     throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
                 }
                 // 宸ヤ綔妗f槑缁嗕繚瀛�
-                List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", sourceLocNo));
-                for (LocDetl locDetl : locDetls) {
-                    WrkDetl wrkDetl = new WrkDetl();
-                    wrkDetl.setWrkNo(workNo);
-                    wrkDetl.setIoTime(new Date());
-                    wrkDetl.setAnfme(locDetl.getAnfme());
-                    VersionUtils.setWrkDetl(wrkDetl, locDetl); // 鐗堟湰鎺у埗
-                    wrkDetl.setAppeTime(new Date());
-                    wrkDetl.setModiTime(new Date());
-                    if (!wrkDetlService.insert(wrkDetl)) {
-                        throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
-                    }
-                }
+//                List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", sourceLocNo));
+//                for (LocDetl locDetl : locDetls) {
+//                    WrkDetl wrkDetl = new WrkDetl();
+//                    wrkDetl.setWrkNo(workNo);
+//                    wrkDetl.setIoTime(new Date());
+//                    wrkDetl.setAnfme(locDetl.getAnfme());
+//                    VersionUtils.setWrkDetl(wrkDetl, locDetl); // 鐗堟湰鎺у埗
+//                    wrkDetl.setAppeTime(new Date());
+//                    wrkDetl.setModiTime(new Date());
+//                    if (!wrkDetlService.insert(wrkDetl)) {
+//                        throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+//                    }
+//                }
                 // 淇敼婧愬簱浣嶇姸鎬�
-                if (sourceLoc.getLocSts().equals("D") || sourceLoc.getLocSts().equals("F")) {
+                if (sourceLoc.getLocSts().equals("D")) {
                     sourceLoc.setLocSts("R"); // R.鍑哄簱棰勭害
                     sourceLoc.setModiTime(new Date());
                     if (!locMastService.updateById(sourceLoc)){

--
Gitblit v1.9.1