From 65e54b6d197856b889481098caecceaa04d26691 Mon Sep 17 00:00:00 2001
From: pang.jiabao <pang_jiabao@163.com>
Date: 星期一, 28 四月 2025 11:09:01 +0800
Subject: [PATCH] 获取货物到达出库口大屏显示物料信息

---
 src/main/resources/mapper/OrderMapper.xml                   |    3 
 src/main/java/com/zy/asrs/entity/OutLocInfoParam.java       |   18 ++++
 src/main/java/com/zy/asrs/controller/OpenController.java    |   13 +++
 src/main/java/com/zy/asrs/mapper/OrderMapper.java           |    4 
 src/main/java/com/zy/asrs/entity/OutLocInfoDto.java         |   93 +++++++++++++++++++++++
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java |   56 +++++++++++++
 src/main/java/com/zy/asrs/service/OpenService.java          |    4 +
 7 files changed, 188 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index 93e089d..0281bfa 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -5,6 +5,7 @@
 import com.core.common.Cools;
 import com.core.common.R;
 import com.core.exception.CoolException;
+import com.zy.asrs.entity.OutLocInfoParam;
 import com.zy.asrs.entity.param.*;
 import com.zy.asrs.service.OpenService;
 import com.zy.common.web.BaseController;
@@ -201,6 +202,18 @@
         return openService.getCrnLaneWayInfo();
     }
 
+    @PostMapping("/getOutLocInfoByBarcode")
+    @AppAuth(memo = "鏍规嵁鎵樼洏鐮侊紝鑾峰彇鍑哄簱鐗╂枡淇℃伅杩涜澶у睆鏄剧ず")
+    public synchronized R getOutLocInfoByBarcode(@RequestHeader(required = false) String appkey,
+                                            @RequestBody OutLocInfoParam param,
+                                            HttpServletRequest request) {
+        auth(appkey, param, request);
+        if (Cools.isEmpty(param) || Cools.isEmpty(param.getBarcode())) {
+            return R.parse("鎵樼洏鐮佷笉鑳戒负绌�");
+        }
+        return openService.getOutLocInfoByBarcode(param.getBarcode());
+    }
+
 
     /*@PostMapping("/order/matSync/default/v1")
     @AppAuth(memo = "鍟嗗搧淇℃伅鍚屾鎺ュ彛")
diff --git a/src/main/java/com/zy/asrs/entity/OutLocInfoDto.java b/src/main/java/com/zy/asrs/entity/OutLocInfoDto.java
new file mode 100644
index 0000000..fc490c0
--- /dev/null
+++ b/src/main/java/com/zy/asrs/entity/OutLocInfoDto.java
@@ -0,0 +1,93 @@
+package com.zy.asrs.entity;
+
+import lombok.Data;
+
+import java.util.List;
+
+/**
+ * @author pang.jiabao
+ * @description 鑾峰彇鍑哄簱鐗╂枡淇℃伅杩涜澶у睆鏄剧ず鍑哄弬
+ * @createDate 2025/4/27 15:56
+ */
+@Data
+public class OutLocInfoDto {
+
+    /**
+     * 宸ヤ綔鍙�
+     */
+    private Integer wrkNo;
+
+    /**
+     * 鏈ㄧ淇℃伅
+     */
+    private List<Material> materialList;
+
+    @Data
+    public static class Material {
+
+        /**
+         * 鍖呰缁勫彿
+         */
+        private String packageGroupNo;
+
+        /**
+         * 鏈ㄧ浣嶇疆
+         */
+        private String boxPos;
+
+        /**
+         * 鍗蜂俊鎭�
+         */
+        private List<MaterialDetail> materialDetailList;
+
+        /**
+         * 璁㈠崟鍙�
+         */
+        private String orderNo;
+
+        /**
+         * 瀹㈡埛鍚嶇О
+         */
+        private String customerName;
+
+        /**
+         * 璁㈠崟澶囨敞
+         */
+        private String memo;
+
+        /**
+         * 璁㈠崟鏄庣粏鎬绘暟
+         */
+        private Integer sum;
+
+        /**
+         * 鏈鐞嗚鍗曟槑缁嗘暟
+         */
+        private Integer toShipQuantity;
+
+        /**
+         * 宸ヤ綔涓鍗曟槑缁嗘暟
+         */
+        private Integer workQuantity;
+
+        @Data
+        public static class MaterialDetail {
+
+            /**
+             * 鍗峰彿
+             */
+            private String rollNo;
+
+            /**
+             * 绠卞彿
+             */
+            private String boxNo;
+
+            /**
+             * 瑙勬牸
+             */
+            private String specs;
+        }
+
+    }
+}
diff --git a/src/main/java/com/zy/asrs/entity/OutLocInfoParam.java b/src/main/java/com/zy/asrs/entity/OutLocInfoParam.java
new file mode 100644
index 0000000..2c019f1
--- /dev/null
+++ b/src/main/java/com/zy/asrs/entity/OutLocInfoParam.java
@@ -0,0 +1,18 @@
+package com.zy.asrs.entity;
+
+import lombok.Data;
+
+/**
+ * @author pang.jiabao
+ * @description 鏍规嵁鎵樼洏鐮侊紝鑾峰彇鍑哄簱鐗╂枡淇℃伅杩涜澶у睆鏄剧ず鍏ュ弬
+ * @createDate 2025/4/27 14:13
+ */
+@Data
+public class OutLocInfoParam {
+
+    /**
+     * 鎵樼洏鐮�
+     */
+    private String barcode;
+
+}
diff --git a/src/main/java/com/zy/asrs/mapper/OrderMapper.java b/src/main/java/com/zy/asrs/mapper/OrderMapper.java
index 8cdf6be..1354c61 100644
--- a/src/main/java/com/zy/asrs/mapper/OrderMapper.java
+++ b/src/main/java/com/zy/asrs/mapper/OrderMapper.java
@@ -44,7 +44,7 @@
     List<String> selectOrderNosByOrderNoLike(@Param("orderNo") String orderNo);
 
     /**
-     * 鑾峰彇鏈畬鎴愯鍗曠粺璁′俊鎭�
+     * 鑾峰彇鏈畬鎴愯鍗曠粺璁′俊鎭�(orderNo涓虹┖鍒欐煡璇㈡墍鏈�)
      */
-    List<OrderStatisticsDto> getUnfulfilledOrders();
+    List<OrderStatisticsDto> getUnfulfilledOrders(@Param("orderNo") String orderNo);
 }
diff --git a/src/main/java/com/zy/asrs/service/OpenService.java b/src/main/java/com/zy/asrs/service/OpenService.java
index 4f8c1e0..3327d99 100644
--- a/src/main/java/com/zy/asrs/service/OpenService.java
+++ b/src/main/java/com/zy/asrs/service/OpenService.java
@@ -95,6 +95,10 @@
      */
     R getCrnLaneWayInfo();
 
+    /**
+     * 鏍规嵁鎵樼洏鐮侊紝鑾峰彇鍑哄簱鐗╂枡淇℃伅杩涜澶у睆鏄剧ず
+     */
+    R getOutLocInfoByBarcode(String barcode);
 
     /**
      * 娣诲姞鍏ュ簱鍗�
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 13537f8..dc18ea9 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -1969,7 +1969,7 @@
     @Override
     public R getUnfulfilledOrders() {
         // 鑾峰彇鏈畬鎴愯鍗曠粺璁′俊鎭�
-        List<OrderStatisticsDto> unfulfilledOrders = orderMapper.getUnfulfilledOrders();
+        List<OrderStatisticsDto> unfulfilledOrders = orderMapper.getUnfulfilledOrders("");
         return R.ok(unfulfilledOrders);
     }
 
@@ -1979,6 +1979,60 @@
         return R.ok(crnLaneWayInfo);
     }
 
+    @Override
+    public R getOutLocInfoByBarcode(String barcode) {
+
+        // 鏍规嵁鎵樼洏鐮佽幏鍙栦换鍔′富妗�
+        WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>().eq("barcode", barcode));
+        // 鏍规嵁浠诲姟涓绘。鑾峰彇宸ヤ綔妗f槑缁�
+        List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("wrk_no", wrkMast.getWrkNo()));
+        // 鎻愬彇鍖呰缁勫彿
+        List<String> brandList = wrkDetls.stream().map(WrkDetl::getBrand).distinct().collect(Collectors.toList());
+        OutLocInfoDto outLocInfoDto = new OutLocInfoDto();
+        outLocInfoDto.setWrkNo(wrkMast.getWrkNo());
+        List<OutLocInfoDto.Material> materialList = new ArrayList<>();
+        for (String brand : brandList) {
+            // 涓�涓湪绠�
+            OutLocInfoDto.Material material = new OutLocInfoDto.Material();
+            material.setPackageGroupNo(brand); // 鍖呰缁勫彿
+            // 鎸夊寘瑁呯粍鍙疯繃婊�
+            List<WrkDetl> wrkDetls1 = wrkDetls.stream().filter(wrkDetl -> Objects.equals(wrkDetl.getBrand(), brand)).collect(Collectors.toList());
+            // 鍗蜂俊鎭�
+            List<OutLocInfoDto.Material.MaterialDetail> materialDetailList = new ArrayList<>();
+            for (WrkDetl wrkDetl : wrkDetls1) {
+                OutLocInfoDto.Material.MaterialDetail materialDetail = new OutLocInfoDto.Material.MaterialDetail();
+                materialDetail.setRollNo(wrkDetl.getModel());
+                materialDetail.setBoxNo(wrkDetl.getUnit());
+                materialDetail.setSpecs(wrkDetl.getMatnr());
+                material.setBoxPos(wrkDetl.getOrigin()); // 鎵樼洏涓婃湪绠变綅缃�
+                materialDetailList.add(materialDetail);
+            }
+            // 璁㈠崟淇℃伅
+            WrkDetl wrkDetl = wrkDetls1.get(0);
+            if (wrkDetl != null && wrkDetl.getOrderNo() != null) {
+                Order order = orderService.selectOne(new EntityWrapper<Order>().eq("order_no", wrkDetl.getOrderNo()));
+                if (order != null) {
+                    material.setOrderNo(order.getOrderNo());
+                    material.setMemo(order.getMemo());
+                    material.setCustomerName(order.getCstmrName());
+                    List<OrderStatisticsDto> unfulfilledOrders = orderMapper.getUnfulfilledOrders(order.getOrderNo());
+                    if (unfulfilledOrders.size() == 1) {
+                        OrderStatisticsDto orderStatisticsDto = unfulfilledOrders.get(0);
+                        material.setSum(orderStatisticsDto.getSum());
+                        material.setToShipQuantity(orderStatisticsDto.getToShipQuantity());
+                        material.setWorkQuantity(orderStatisticsDto.getWorkQuantity());
+                    }
+                }
+            }
+
+            material.setMaterialDetailList(materialDetailList);
+            materialList.add(material);
+        }
+        outLocInfoDto.setMaterialList(materialList);
+
+        return R.ok(outLocInfoDto);
+    }
+
     /**
      * 鍒涘缓妗佹灦鐞嗚揣鍑哄簱鐨勫伐浣滄。
      */
diff --git a/src/main/resources/mapper/OrderMapper.xml b/src/main/resources/mapper/OrderMapper.xml
index 4f69b06..e359a06 100644
--- a/src/main/resources/mapper/OrderMapper.xml
+++ b/src/main/resources/mapper/OrderMapper.xml
@@ -127,6 +127,9 @@
         where
             mo.doc_type = 21
           and mo.settle in(1, 2)
+        <if test="orderNo != ''">
+            and mo.order_no = #{orderNo}
+        </if>
         GROUP BY
             mo.order_no
     </select>

--
Gitblit v1.9.1