From 67cbba6a2fcba931216ea3cb6d0080f8db10dab7 Mon Sep 17 00:00:00 2001
From: pang.jiabao <pang_jiabao@163.com>
Date: 星期一, 19 八月 2024 17:05:28 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java |  377 +++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 316 insertions(+), 61 deletions(-)

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 a9da271..c3f4301 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -14,6 +14,7 @@
 import com.zy.asrs.entity.result.StockVo;
 import com.zy.asrs.entity.result.ZphjcdgzVo;
 import com.zy.asrs.entity.result.ZphjcdwcVo;
+import com.zy.asrs.mapper.MatMapper;
 import com.zy.asrs.mapper.TagMapper;
 import com.zy.asrs.service.*;
 import com.zy.asrs.utils.MatUtils;
@@ -30,6 +31,7 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import javax.annotation.Resource;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -39,6 +41,12 @@
 @Slf4j
 @Service
 public class OpenServiceImpl implements OpenService {
+
+    // 浜屾ゼ鍫嗗灈鏈哄搴斿叆搴撶珯鐐�
+    private static final int[] secondFloorIn = new int[]{0,2061,2064,2067,2070,2073,2076};
+    // 鍫嗗灈鏈哄搴斾竴妤煎嚭搴撶珯鐐�
+    private static final int[] secondFloorOut = new int[]{0,3002,3003,3006,3008,3009,3012};
+
 
     @Autowired
     private OrderService orderService;
@@ -84,6 +92,9 @@
     private LocMastService locMastService;
     @Autowired
     private ApiLogService apiLogService;
+
+    @Resource
+    private MatMapper matMapper;
 
     @Override
     @Transactional
@@ -986,31 +997,62 @@
     }
 
     @Override
+    public void updateBarcode() {
+        List<LocMast> locMasts = locMastService.selectList(new EntityWrapper<LocMast>().eq("loc_sts", "D"));
+        for (int i = 0; i < locMasts.size(); i ++) {
+            LocMast locMast = locMasts.get(i);
+            locMast.setBarcode("a"+i);
+            locMastService.updateById(locMast);
+        }
+        System.out.println("鏇存柊瀹屼簡" + locMasts.size());
+    }
+
+    @Override
     @Transactional
-    public R gwmsGenerateInventory(GwmsGenerateInventoryDto param) {
-
-        if (Cools.isEmpty(param)) {
-            throw new CoolException("璇锋眰鍙傛暟鏈夎锛�" + param);
+    public void prodCheck(List<ProdCheckParam> param) {
+        if (param.isEmpty()) {
+            throw new CoolException("璇锋眰鍙傛暟涓嶈兘涓虹┖");
         }
-        int zpalletCount = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet", param.getBarcode()));
-        if (zpalletCount > 0) {
-            throw new CoolException("搴撳瓨鎵樼洏鐮佸凡瀛樺湪锛�" + param.getBarcode());
-        }
+        for (ProdCheckParam checkParam : param) {
+            // 鏇存柊搴撳瓨鏄庣粏鏄惁鍚堟牸
+            LocDetl locDetl = locDetlService.selectOne(new EntityWrapper<LocDetl>().eq("brand", checkParam.getPackageGroupNo())
+                    .eq("unit", checkParam.getBoxNo()).eq("model", checkParam.getRollNo()));
+            // 鏇存柊鍟嗗搧琛ㄦ槸鍚﹀悎鏍�
+            Mat mat = matService.selectOne(new EntityWrapper<Mat>().eq("brand", checkParam.getPackageGroupNo())
+                    .eq("unit", checkParam.getBoxNo()).eq("model", checkParam.getRollNo()));
+            if (locDetl == null || mat == null) {
+                throw new CoolException("鏇存柊鏄惁鍚堟牸鐗╂枡涓嶅瓨鍦細" + checkParam);
+            }
 
-        int barcodeCount = wrkMastService.selectCount(new EntityWrapper<WrkMast>().eq("barcode", param.getBarcode()));
-        if (barcodeCount > 0) {
-            throw new CoolException("宸ヤ綔妗e凡瀛樺湪璇ユ墭鐩樼爜锛�" + param.getBarcode());
+            locDetl.setThreeCode(checkParam.getQualified());
+            mat.setThreeCode(checkParam.getQualified());
+
+            locDetlService.update(locDetl,new EntityWrapper<LocDetl>().eq("brand", checkParam.getPackageGroupNo())
+                    .eq("unit", checkParam.getBoxNo()).eq("model", checkParam.getRollNo()));
+            matService.update(mat,(new EntityWrapper<Mat>().eq("brand", checkParam.getPackageGroupNo())
+                    .eq("unit", checkParam.getBoxNo()).eq("model", checkParam.getRollNo())));
+        }
+    }
+
+    @Override
+    @Transactional
+    public String fxprk(FxprkParam param) {
+
+        // 鏍规嵁鍖呰缁勫彿鑾峰彇鍒版湪绠卞嵎淇℃伅
+        List<Mat> list = matService.selectList(new EntityWrapper<Mat>().in("brand", param.getBoxList().stream().map(FxprkParam.Box::getPackageGroupNo).collect(Collectors.toList())));
+        if (list.isEmpty()) {
+            throw new CoolException("娌℃湁鏌ヨ鍒拌鍖呰缁勫彿淇℃伅锛�" + param.getBoxList().toString());
         }
 
         LocTypeDto locTypeDto = new LocTypeDto();
-        locTypeDto.setLocType1((short)1);
-
-        // 鏍规嵁婧愮珯鐐瑰鎵惧簱浣�
-//        StartupDto dto = commonService.getLocNo(1, 1, param.getPalletizingNo(), null,null,null, locTypeDto);
-        StartupDto dto = commonService.getLocNo(1, param.getPalletizingNo(), locTypeDto,0);
+        locTypeDto.setLocType1((short) 1);
+        StartupDto dto = commonService.getLocNo(1, param.getPalletizingNo(), locTypeDto, 0);
 
         // 杩斿洖GWCS鐩爣淇℃伅
-        pushStaNoToGwcs(param.getPalletizingNo(),dto.getStaNo(),dto.getWorkNo());
+        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();
@@ -1040,46 +1082,230 @@
             throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
         }
 
-        List<GwmsGenerateInventoryDto.MatList> matList = param.getMatList();
-        for (GwmsGenerateInventoryDto.MatList obj :matList) {
+        for (Mat obj : list) {
             WrkDetl wrkDetl = new WrkDetl();
+            wrkDetl.sync(obj);
             wrkDetl.setWrkNo(wrkMast.getWrkNo());
-            obj.getRolls().forEach(roll -> {
-//                Mat mat = matService.selectByMatnr(roll.getSpecs());
-//                if (mat == null) {
-//                    mat = new Mat();
-//                    mat.setTagId(6L);
-//                    mat.setMatnr(roll.getSpecs());
-//                    mat.setMaktx(roll.getSpecs());
-//                    mat.setSpecs(roll.getSpecs());
-//                    mat.setStatus(1);
-//                    mat.setCreateTime(now);
-//                    mat.setUpdateTime(now);
-//                    if (!matService.insert(mat)) {
-//                        throw new CoolException("鐗╂枡瀵煎叆澶辫触锛�");
-//                    }
-//                }
-                wrkDetl.setWrkNo(wrkMast.getWrkNo());
-                wrkDetl.setMatnr(roll.getSpecs()); // 瑙勬牸
-                wrkDetl.setMaktx(roll.getSpecs()); //瑙勬牸
-                wrkDetl.setBatch(roll.getBoxNo()); // 绠卞彿
-                wrkDetl.setModel(roll.getRollNo()); // 鍗峰彿
-                wrkDetl.setBrand(obj.getPackageGroupNo()); // 鍖呰缁勫彿
-                wrkDetl.setZpallet(param.getBarcode()); // 鎵樼洏鍚�
-                wrkDetl.setOrigin(obj.getBoxPos()); // 鏈ㄧ鍦ㄦ墭鐩樹綅缃�
-                wrkDetl.setWeight(roll.getNetWeight()); // 鍑�閲�
-                wrkDetl.setVolume(roll.getGrossWeight()); // 姣涢噸
-                wrkDetl.setPrice(roll.getLength());
-                wrkDetl.setSpecs(String.valueOf(roll.getSplices()));
-                wrkDetl.setAnfme(1.0);
-                wrkDetl.setIoTime(now);
-                wrkDetl.setAppeTime(now);
-                wrkDetl.setModiTime(now);
-                if (!wrkDetlService.insert(wrkDetl)) {
-                    throw new CoolException("淇濆瓨宸ヤ綔鏄庣粏澶辫触");
+            wrkDetl.setAnfme(1.0);
+            // 閲嶆柊瀹氫綅鏈ㄧ浣嶇疆
+            for (FxprkParam.Box box :param.getBoxList()) {
+                if (box.getPackageGroupNo().equals(obj.getBrand())) {
+                    if (!box.getBoxPos().equals(obj.getOrigin())) {
+                        wrkDetl.setOrigin(box.getBoxPos());
+                        wrkDetl.setZpallet(param.getBarcode());
+                        wrkDetl.setBarcode(param.getBarcode());
+                        matMapper.updateBoxPos(box.getPackageGroupNo(), box.getBoxPos(),param.getBarcode());
+                    }
+                    break;
                 }
-            });
+            }
+            wrkDetl.setIoTime(now);
+            wrkDetl.setAppeTime(now);
+            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() + "鐩爣搴撲綅宸茶鍗犵敤");
+        }
+        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(secondFloorOut[crnNo]);
+        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(param.getPalletizingNo(),wrkMast.getSourceStaNo(),workNo,param.getBarcode());
+
+        return R.ok("绌烘墭鍥炴祦璇锋眰鎴愬姛");
+    }
+
+    @Override
+    public R tb(TbParam param) {
+        List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("barcode", param.getBarcode()));
+        if (wrkDetls.isEmpty()) {
+            return R.parse("鏃犵墿鏂欐槑缁嗕俊鎭�");
+        }
+        List<String> collect = wrkDetls.stream().map(WrkDetl::getUnit).distinct().collect(Collectors.toList());
+        return R.ok(collect);
+    }
+
+    @Override
+    public R dd(TbParam param) {
+        List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("barcode", param.getBarcode()));
+        if (wrkDetls.isEmpty()) {
+            return R.parse("鏃犵墿鏂欐槑缁嗕俊鎭�");
+        }
+        List<DdParam> collect = wrkDetls.stream().map(wrkDetl -> {
+            DdParam ddParam = new DdParam();
+            ddParam.setBoxPos(wrkDetl.getOrigin());
+            ddParam.setBoxType(wrkDetl.getColor());
+            return ddParam;
+        }).distinct().collect(Collectors.toList());
+
+        return R.ok(collect);
+    }
+
+    @Override
+    @Transactional
+    public R gwmsGenerateInventory(GwmsGenerateInventoryDto param) {
+
+        if (Cools.isEmpty(param)) {
+            throw new CoolException("璇锋眰鍙傛暟鏈夎锛�" + param);
+        }
+        if (!Cools.isEmpty(param.getBarcode())) {
+            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;
+        if (Cools.isEmpty(param.getMatList())) {
+            iotype = 10;
+        }
+        // 鏍规嵁婧愮珯鐐瑰鎵惧簱浣�
+//        StartupDto dto = commonService.getLocNo(1, 1, param.getPalletizingNo(), null,null,null, locTypeDto);
+        StartupDto dto = commonService.getLocNo(iotype, param.getPalletizingNo(), locTypeDto,0);
+
+        // 杩斿洖GWCS鐩爣淇℃伅
+        pushStaNoToGwcs(param.getPalletizingNo(),dto.getStaNo(),dto.getWorkNo(),param.getBarcode());
+
+
+        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("N"); // 绌烘澘
+        wrkMast.setLinkMis("Y");
+        wrkMast.setCtnType(1); // 瀹瑰櫒绫诲瀷
+        // 鎿嶄綔浜哄憳鏁版嵁
+        wrkMast.setAppeTime(now);
+        wrkMast.setModiTime(now);
+        boolean res = wrkMastService.insert(wrkMast);
+        if (!res) {
+            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
+        }
+
+        if (!Cools.isEmpty(param.getMatList())) {
+            List<GwmsGenerateInventoryDto.MatList> matList = param.getMatList();
+            for (GwmsGenerateInventoryDto.MatList obj :matList) {
+                WrkDetl wrkDetl = new WrkDetl();
+                wrkDetl.setWrkNo(wrkMast.getWrkNo());
+                obj.getRolls().forEach(roll -> {
+                    wrkDetl.setWrkNo(wrkMast.getWrkNo());
+                    wrkDetl.setMatnr(roll.getSpecs()); // 瑙勬牸
+                    wrkDetl.setMaktx(roll.getSpecs()); //瑙勬牸
+                    wrkDetl.setUnit(roll.getBoxNo()); // 绠卞彿
+                    wrkDetl.setModel(roll.getRollNo()); // 鍗峰彿
+                    wrkDetl.setBrand(obj.getPackageGroupNo()); // 鍖呰缁勫彿
+                    wrkDetl.setZpallet(param.getBarcode()); // 鎵樼洏鐮�
+                    wrkDetl.setBarcode(param.getBarcode());
+                    wrkDetl.setOrigin(obj.getBoxPos()); // 鏈ㄧ鍦ㄦ墭鐩樹綅缃�
+                    wrkDetl.setColor(obj.getBoxType()); // 鏈ㄧ绫诲瀷
+                    wrkDetl.setManu(obj.getRollType()); // 绠¤姱绫诲瀷
+                    wrkDetl.setSku(obj.getWideInWidth()); // 瀹炴祴瀹藉箙
+                    wrkDetl.setItemNum(obj.getThickness()); // 鐢熺當鍘氬害
+                    wrkDetl.setManuDate(roll.getFqTime()); // 鍒嗗垏涓嬫枡鏃堕棿
+                    wrkDetl.setWeight(roll.getNetWeight()); // 鍑�閲�
+                    wrkDetl.setVolume(roll.getGrossWeight()); // 姣涢噸
+                    wrkDetl.setLength(roll.getLength()); // 闀垮害
+                    wrkDetl.setSpecs(String.valueOf(roll.getSplices())); // 鎺ュご
+                    wrkDetl.setAnfme(1.0);
+//                    wrkDetl.setThreeCode(null); // 閫氳繃mes鎴杄xcel瀵煎叆妫�娴嬫槸鍚﹀悎鏍� 0涓嶅悎鏍硷紝1 鍚堟牸
+                    wrkDetl.setIoTime(now);
+                    wrkDetl.setAppeTime(now);
+                    wrkDetl.setModiTime(now);
+                    if (!wrkDetlService.insert(wrkDetl)) {
+                        throw new CoolException("淇濆瓨宸ヤ綔鏄庣粏澶辫触");
+                    }
+
+                    // 鐗╂枡琛ㄥ浠戒竴浠�
+                    Mat mat = new Mat();
+                    mat.sync(wrkDetl);
+                    mat.setTagId(6L);
+                    mat.setCreateTime(now);
+                    mat.setUpdateTime(now);
+                    if (!matService.insert(mat)) {
+                        throw new CoolException("澶囦唤鐗╂枡琛ㄥけ璐�");
+                    }
+
+                });
+            }
+        }
+
 
         // 鏇存柊鐩爣搴撲綅鐘舵��
         LocMast locMast = locMastService.selectById(dto.getLocNo());
@@ -1108,6 +1334,9 @@
         }
 
         wrkMast.setWrkSts(2L);
+        if(wrkMast.getIoType() == 10){
+            wrkMast.setBarcode(param.getBarcode());
+        }
         wrkMastService.updateById(wrkMast);
 
         return "璇锋眰鎴愬姛";
@@ -1224,11 +1453,19 @@
             throw new CoolException("宸ヤ綔妗e綋鍓嶇姸鎬佷笉绗﹀悎锛屼换鍔″彿锛�" + param.getWorkNo() + "锛屽伐浣滄。鐘舵�侊細" + wrkMast.getWrkSts());
         }
 
+        List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("wrk_no", param.getWorkNo()));
+
+        // 鏄惁闇�瑕佸鏍�(鍑哄簱鍗曢渶澶嶆牳)
+        boolean flag = false;
+        if (!wrkDetls.isEmpty()) {
+            flag = wrkDetls.stream().anyMatch(wrkDetl -> wrkDetl.getOrderNo() != null);
+        }
+
         // 鍒拌揪鍑哄簱鍙g‘璁や负1锛屾洿鏂板伐浣滄。鐘舵�佷负57.鍑哄簱瀹屾垚
         if (param.getOutLocResult() == 1) {
             wrkMast.setWrkSts(20L);
             // 绌烘墭鐩樺埌浣嶇洿鎺ユ洿鏂板伐浣滄。鐘舵�佷负14.宸插嚭搴撴湭纭锛岀┖鎵樻棤闇�澶嶆牳纭
-            if (wrkMast.getIoType() == 110) {
+            if (!flag || wrkMast.getIoType() == 110) {
                 wrkMast.setWrkSts(14L);
             }
             wrkMastService.updateById(wrkMast);
@@ -1237,17 +1474,32 @@
         return "鍑哄簱缁撴灉涓婃姤鎴愬姛";
     }
 
+    @Autowired
+    private BasCrnpService basCrnpService;
+
     @Override
     @Transactional
     public String emptyOutLoc(GhjtApiParam param) {
 //        3102/3009/3008/3006/3003/3002鈫�3047/3112
+        // 鑾峰彇妯″紡涓虹數鑴戞ā寮忥紝鏃犱换鍔$殑鍫嗗灈鏈哄垪琛�:闃叉鍒嗛厤鍒板爢鍨涙満涓嶅彲鐢�
+        List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<BasCrnp>().eq("crn_sts",3)
+                .eq("wrk_no",0));
+        if (basCrnps.isEmpty()) {
+            // 閮芥湁浠诲姟鍒欒幏鍙栫數鑴戞ā寮忕殑鍫嗗灈鏈哄垪琛�
+            basCrnps = basCrnpService.selectList(new EntityWrapper<BasCrnp>().eq("crn_sts",3));
+        }
+        if (basCrnps.isEmpty()) {
+            throw new CoolException("娌℃湁鍙敤鍫嗗灈鏈�,鍫嗗灈鏈哄仠姝㈡垨寮傚父");
+        }
+        // 鍙敤鍫嗗灈鏈哄垪琛�
+        List<Integer> crnNoList = basCrnps.stream().map(BasCrnp::getCrnNo).collect(Collectors.toList());
         // 瀵绘壘绌烘墭鐩樺簱浣嶏紝鍏堟壘娴呭簱浣�
         List<LocMast> locMasts;
             locMasts = locMastService.selectList(new EntityWrapper<LocMast>().eq("loc_sts","D")
-                    .orderAsc(Arrays.asList("row1","lev1","bay1")).in("row1",3,4,6,7,10,11,14,15,18,19,22,23));
+                    .orderAsc(Arrays.asList("row1","lev1","bay1")).in("crn_no",crnNoList).in("row1",3,4,6,7,10,11,14,15,18,19,22,23));
             if (locMasts.isEmpty()) {
                 locMasts = locMastService.selectList(new EntityWrapper<LocMast>().eq("loc_sts","D")
-                        .orderAsc(Arrays.asList("row1","lev1","bay1")).in("row1",1,4,5,8,9,12,13,16,17,20,21,24));
+                        .orderAsc(Arrays.asList("row1","lev1","bay1")).in("crn_no",crnNoList).in("row1",1,4,5,8,9,12,13,16,17,20,21,24));
             }
 
         if (locMasts.isEmpty()) {
@@ -1277,6 +1529,7 @@
         wrkMast.setStaNo(staDesc.getStnNo()); // 鐩爣绔�
         wrkMast.setCrnNo(locMast.getCrnNo());
         wrkMast.setSourceLocNo(locMast.getLocNo()); // 婧愬簱浣�
+        wrkMast.setBarcode(locMast.getBarcode());
         wrkMast.setFullPlt("N"); // 婊℃澘锛歒
         wrkMast.setPicking("N"); // 鎷f枡
         wrkMast.setExitMk("N"); // 閫�鍑�
@@ -1323,13 +1576,13 @@
 
         // 鏌ヨ瑕佹媶鐨勪綅缃紝鍙湁涓�涓�
         List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("wrk_no", wrkMast.getWrkNo()));
-        List<String> collect = wrkDetls.stream().map(WrkDetl::getOrigin).distinct().collect(Collectors.toList());
-        String position = collect.get(0);
+        WrkDetl wrkDetl = wrkDetls.get(0);
 
         // 杩斿洖鎷嗗灈瑙勫垯
         ZphjcdgzVo zphjcdgzVo = new ZphjcdgzVo();
-        zphjcdgzVo.setWorkNo(wrkMast.getWrkNo());
-        zphjcdgzVo.setPosition(position);
+        zphjcdgzVo.setWorkNo(wrkDetl.getWrkNo());
+        zphjcdgzVo.setBoxType(wrkDetl.getColor());
+        zphjcdgzVo.setPosition(wrkDetl.getOrigin());
 
         return R.ok(zphjcdgzVo);
     }
@@ -1427,7 +1680,7 @@
         return wrkDetls.size() > 1 ? 0 : 1; // 涓�鏉¤褰曞氨鏄竴鍗�
     }
 
-    public void pushStaNoToGwcs(Integer palletizingNo, Integer staNo, Integer workNo) {
+    public boolean pushStaNoToGwcs(Integer palletizingNo, Integer staNo, Integer workNo,String barcode) {
         boolean success = false;
         // 鑾峰彇璇锋眰澶�
         Map<String, Object> headers = getHeaders();
@@ -1437,6 +1690,7 @@
         jsonObject.put("workNo", workNo);
         jsonObject.put("staNo", staNo);
         jsonObject.put("sourceStaNo", palletizingNo);
+        jsonObject.put("barcode", barcode);
         String body = jsonObject.toJSONString();
         String response = "";
         try {
@@ -1477,6 +1731,7 @@
                 log.error("", e);
             }
         }
+        return success;
     }
 
     Map<String, Object> getHeaders(){

--
Gitblit v1.9.1