From 825eecad93210119f76dda5348088a055107b721 Mon Sep 17 00:00:00 2001
From: zc <zc>
Date: 星期二, 30 七月 2024 18:10:07 +0800
Subject: [PATCH] 订单只传递一种物料的时候,订单皆苦的批量出库查询接口数据返回不对

---
 src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java |    1 
 src/main/java/com/zy/asrs/controller/MobileController.java  |   19 ++++-----
 src/main/java/com/zy/asrs/controller/OutController.java     |   52 ++++++++++++++++++++++----
 3 files changed, 54 insertions(+), 18 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/MobileController.java b/src/main/java/com/zy/asrs/controller/MobileController.java
index 4200c10..5e78714 100644
--- a/src/main/java/com/zy/asrs/controller/MobileController.java
+++ b/src/main/java/com/zy/asrs/controller/MobileController.java
@@ -189,22 +189,21 @@
     @RequestMapping("/pakout/query/auth")
     @ManagerAuth
     @Deprecated
-    public R pakoutQuery(@RequestParam(required = false) String barcode,
-                         @RequestParam(required = false) Integer staNo,
-                         @RequestParam(required = false) String matnr) {
-        if (Cools.isEmpty(barcode) && Cools.isEmpty(matnr)) {
+    public R pakoutQuery(@RequestParam String barcode) {
+        if (Cools.isEmpty(barcode)) {
             return R.ok();
         }
+        System.out.println(barcode);
         if (!Cools.isEmpty(barcode)) {
             List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("zpallet", barcode));
             return R.ok().add(wrkDetls);
         }
-        if (!Cools.isEmpty(matnr)) {
-            if (!Cools.isEmpty(staNo)) {
-                List<WrkDetl> wrkDetls = wrkDetlService.selectPakoutQuery(staNo, matnr);
-                return R.ok().add(wrkDetls);
-            }
-        }
+//        if (!Cools.isEmpty(matnr)) {
+//            if (!Cools.isEmpty(staNo)) {
+//                List<WrkDetl> wrkDetls = wrkDetlService.selectPakoutQuery(staNo, matnr);
+//                return R.ok().add(wrkDetls);
+//            }
+//        }
         return R.ok();
     }
 
diff --git a/src/main/java/com/zy/asrs/controller/OutController.java b/src/main/java/com/zy/asrs/controller/OutController.java
index 671d359..e3a151b 100644
--- a/src/main/java/com/zy/asrs/controller/OutController.java
+++ b/src/main/java/com/zy/asrs/controller/OutController.java
@@ -53,21 +53,57 @@
     @PostMapping("/out/pakout/preview/auth")
     @ManagerAuth
     public R pakoutPreview(@RequestBody List<Long> ids) {
+//        if (Cools.isEmpty(ids)) {
+//            return R.parse(BaseRes.PARAM);
+//        }
+//        List<OrderDetl> orderDetls = orderDetlService.selectBatchIds(ids);
+//        //鐢ㄦ埛纭鍑哄叆搴撻兘浠gno涓哄噯锛岄偅涔堜笉鑰冭檻鏁伴噺浜�
+//        List<LocDto> locDtos = new ArrayList<>();
+//        if (orderDetls != null && !orderDetls.isEmpty()) {
+//            List<LocDetl> locDetls = locDetlService.queryStock(orderDetls.get(0).getSPgNO());
+//            for (LocDetl locDetl : locDetls) {
+//                LocDto locDto = new LocDto(locDetl.getLocNo(), locDetl.getMatnr(), locDetl.getMaktx(), locDetl.getBatch(), orderDetls.get(0).getOrderNo(),
+//                        locDetl.getAnfme());
+//                List<Integer> staNos = staDescService.queryOutStaNosByLocNo(locDetl.getLocNo(), 101);
+//                locDto.setStaNos(staNos);
+//                locDto.setZpallet(locDetl.getZpallet());
+//                locDto.setSPgNO(orderDetls.get(0).getSPgNO());
+//                locDtos.add(locDto);
+//            }
+//        }
+//        return R.ok().add(locDtos);
+
         if (Cools.isEmpty(ids)) {
             return R.parse(BaseRes.PARAM);
         }
         List<OrderDetl> orderDetls = orderDetlService.selectBatchIds(ids);
-        //鐢ㄦ埛纭鍑哄叆搴撻兘浠gno涓哄噯锛岄偅涔堜笉鑰冭檻鏁伴噺浜�
         List<LocDto> locDtos = new ArrayList<>();
-        if (orderDetls != null && !orderDetls.isEmpty()) {
+
+        Set<String> exist = new HashSet<>();
+
+        for (OrderDetl orderDetl : orderDetls) {
+            double issued = Optional.of(orderDetl.getAnfme() - orderDetl.getWorkQty()).orElse(0.0D);
+            if (issued <= 0.0D) { continue; }
             List<LocDetl> locDetls = locDetlService.queryStock(orderDetls.get(0).getSPgNO());
             for (LocDetl locDetl : locDetls) {
-                LocDto locDto = new LocDto(locDetl.getLocNo(), locDetl.getMatnr(), locDetl.getMaktx(), locDetl.getBatch(), orderDetls.get(0).getOrderNo(),
-                        locDetl.getAnfme());
-                List<Integer> staNos = staDescService.queryOutStaNosByLocNo(locDetl.getLocNo(), 101);
-                locDto.setStaNos(staNos);
-                locDto.setZpallet(locDetl.getZpallet());
-                locDto.setSPgNO(orderDetls.get(0).getSPgNO());
+                if (locDetl.getMatnr().equals(orderDetl.getMatnr())){
+                    if (issued > 0) {
+                        LocDto locDto = new LocDto(locDetl.getLocNo(), locDetl.getMatnr(), locDetl.getMaktx(), locDetl.getBatch(), orderDetl.getOrderNo(),
+                                issued >= locDetl.getAnfme() ? locDetl.getAnfme() : issued);
+                        List<Integer> staNos = staDescService.queryOutStaNosByLocNo(locDetl.getLocNo(), issued >= locDetl.getAnfme() ? 101 : 103);
+                        locDto.setStaNos(staNos);
+                        locDtos.add(locDto);
+                        exist.add(locDetl.getLocNo());
+                        // 鍓╀綑寰呭嚭鏁伴噺閫掑噺
+                        issued = issued - locDetl.getAnfme();
+                    } else {
+                        break;
+                    }
+                }
+            }
+            if (issued > 0) {
+                LocDto locDto = new LocDto(null, orderDetl.getMatnr(), orderDetl.getMaktx(), orderDetl.getBatch(), orderDetl.getOrderNo(), issued);
+                locDto.setLack(Boolean.TRUE);
                 locDtos.add(locDto);
             }
         }
diff --git a/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
index 4ea5c76..d995b8a 100644
--- a/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
@@ -326,6 +326,7 @@
         // 鐢熸垚宸ヤ綔妗f槑缁�
         for (LocDto locDto : taskDto.getLocDtos()) {
             if (locDto.getAnfme()==null || locDto.getAnfme() <= 0.0D) { continue; }
+            log.info(locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch());
             OrderDetl orderDetl = orderDetlService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch());
             if (orderDetl == null) {
                 orderDetl = orderDetlService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), null);

--
Gitblit v1.9.1