From 5833f3f3aa5313fa1170cd9ab0c5857f964ba96c Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期六, 16 八月 2025 13:20:12 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/ghjtasrs' into ghjtasrs

---
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java |   60 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 60 insertions(+), 0 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 b5d4fad..6b0c862 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -34,6 +34,7 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
+import java.text.SimpleDateFormat;
 import java.util.*;
 import java.util.concurrent.TimeUnit;
 import java.util.stream.Collectors;
@@ -109,6 +110,9 @@
 
     @Resource
     private OrderMapper orderMapper;
+
+    @Resource
+    private OrderDetlMapper orderDetlMapper;
 
     @Resource
     private BasCrnpMapper basCrnpMapper;
@@ -1517,6 +1521,7 @@
         gwmsGenerateInventoryDto.setWarehouseType(4);
         gwmsGenerateInventoryDto.setBarcode(wrkMast.getBarcode());
         gwmsGenerateInventoryDto.setPalletizingNo(wrkMast.getStaNo());
+        gwmsGenerateInventoryDto.setGroupOrderNumber(wrkMast.getMemo());
         List<GwmsGenerateInventoryDto.MatList> matLists = new ArrayList<>();
         for (WrkDetl wrkDetl : wrkDetls) {
             boolean flag = true;
@@ -2266,5 +2271,60 @@
         return crnStn;
     }
 
+    @Override
+    @Transactional
+    public R groupOrderConfirm(GroupOrderConfirmParam param) {
+        // 1. 鏌ヨ鍗曟嵁鏄惁瀛樺湪
+        Order order = orderMapper.selectOrderByOrderNo(param.getGroupOrderNumber());
+        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+
+        if (order == null) {
+            // 1.1 涓嶅瓨鍦紝鏂板缓鍗曟嵁
+            order = new Order();
+            order.setOrderNo(param.getGroupOrderNumber());
+            order.setStatus(Integer.valueOf(param.getGroupStatus()));
+            order.setOrderTime(sdf.format(new Date()));
+            order.setCreateTime(new Date());
+            order.setSettle(1L);
+            order.setDocType(25L);
+            orderMapper.insert(order);
+        } else {
+            // 1.2 瀛樺湪锛屾洿鏂板崟鎹姸鎬�
+            order.setStatus(Integer.valueOf(param.getGroupStatus()));
+            orderMapper.updateById(order);
+        }
+
+        // 2. 涓�涓�瀵瑰簲閬嶅巻
+        List<GroupOrderConfirmParam.PackageGroupNo> pkgList = param.getPackageGroupNos();
+        List<GroupOrderConfirmParam.VolumeNumber> volList = param.getVolumeNumbers();
+
+        int size = Math.min(pkgList.size(), volList.size()); // 闃叉瓒婄晫
+        for (int i = 0; i < size; i++) {
+            GroupOrderConfirmParam.PackageGroupNo pg = pkgList.get(i);
+            GroupOrderConfirmParam.VolumeNumber vn = volList.get(i);
+
+            // 鏌ヨ鏄惁宸插瓨鍦ㄨ detl
+            OrderDetl detl = orderDetlMapper.selectByOrderNoAndPkgGroupNoAndVolumeNo(
+                    param.getGroupOrderNumber(), pg.getPackageGroupNo(), vn.getVolumeNumber()
+            );
+
+            if (detl == null) {
+                detl = new OrderDetl();
+                detl.setOrderId(order.getId());
+                detl.setOrderNo(param.getGroupOrderNumber());
+                detl.setCreateTime(new Date());
+                detl.setAnfme(1.0);
+                detl.setBrand(pg.getPackageGroupNo());   // 鍖呰缁勫彿
+                detl.setModel(vn.getVolumeNumber());     // 鍗峰彿
+                orderDetlMapper.insert(detl);
+            }
+        }
+
+        return R.ok("缁勮揣纭鎴愬姛");
+    }
+
+
+
+
     /*...........................涓婇ザ姹熼摐..............浠ヤ笂.............寰愬伐姹変簯...........................*/
 }

--
Gitblit v1.9.1