From 8f45f14bda4601c6d65ce33d7052c9b2682306fd Mon Sep 17 00:00:00 2001
From: pan <antony1029@163.com>
Date: 星期五, 28 十一月 2025 21:22:04 +0800
Subject: [PATCH] Merge branch 'master' of http://115.159.85.185:8098/r/ZhongRui/ALDbanyunxiangmu

---
 项目代码/WMS无仓储版/WIDESEA_WMSServer/WIDESEA_AllocateService/AllocateService.cs |   47 ++++++++++++++++++++++++++++++++++-------------
 1 files changed, 34 insertions(+), 13 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS\346\227\240\344\273\223\345\202\250\347\211\210/WIDESEA_WMSServer/WIDESEA_AllocateService/AllocateService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS\346\227\240\344\273\223\345\202\250\347\211\210/WIDESEA_WMSServer/WIDESEA_AllocateService/AllocateService.cs"
index eca04d4..1908f29 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS\346\227\240\344\273\223\345\202\250\347\211\210/WIDESEA_WMSServer/WIDESEA_AllocateService/AllocateService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS\346\227\240\344\273\223\345\202\250\347\211\210/WIDESEA_WMSServer/WIDESEA_AllocateService/AllocateService.cs"
@@ -99,7 +99,7 @@
             {
                 if (businessType == BusinessTypeEnum.澶栭儴浠撳簱璋冩櫤浠�)
                 {
-                    allocateOrder.OrderType = InOrderTypeEnum.Allocat.ObjToInt();
+                    allocateOrder.OrderType = InOrderTypeEnum.AllocatInbound.ObjToInt();
                     var inboundOrders = ConvertToInboundOrders(allocateOrder);
                     await _inboundService.InbounOrderService.ReceiveInboundOrder(inboundOrders, 1);
                 }
@@ -107,7 +107,7 @@
                 {
                     if (businessType == BusinessTypeEnum.鏅轰粨璋冨閮ㄤ粨搴�)
                     {
-                        allocateOrder.OrderType = InOrderTypeEnum.Allocat.ObjToInt();
+                        allocateOrder.OrderType = InOrderTypeEnum.AllocatOutbound.ObjToInt();
                     }
                     else if (businessType == BusinessTypeEnum.鏅轰粨璋冩櫤浠�)
                     {
@@ -279,6 +279,11 @@
 
         public List<Dt_InboundOrder> ConvertToInboundOrders(Dt_AllocateOrder allocateOrder)
         {
+            var distinctDetails = allocateOrder.Details
+                .GroupBy(d => d.Barcode)
+                .Select(g => g.First())
+                .ToList();
+
             return new List<Dt_InboundOrder>()
             {
                 new Dt_InboundOrder(){
@@ -293,9 +298,9 @@
                    IsBatch=allocateOrder.IsBatch,
                    FactoryArea=allocateOrder.FactoryArea,
                    Remark=allocateOrder.Remark,
-                   Details=allocateOrder.Details.Select(detail=>new Dt_InboundOrderDetail
+                   Details=distinctDetails.Select(detail=>new Dt_InboundOrderDetail
                    {
-                       OrderId= detail.OrderId,
+                       OrderId= 0,
                        MaterielCode=detail.MaterielCode,
                        MaterielName="",
                        BatchNo=detail.BatchNo,
@@ -305,6 +310,7 @@
                        OrderDetailStatus=detail.OrderDetailStatus,
                        Unit=detail.Unit,
                        RowNo=0,
+                       lineNo=detail.LineNo,
                        SupplyCode=detail.SupplyCode,
                        WarehouseCode=detail.WarehouseCode,
                        Barcode=detail.Barcode,
@@ -318,6 +324,18 @@
 
         public Dt_OutboundOrder ConvertToOutboundOrders(Dt_AllocateOrder allocateOrder)
         {
+
+            var distinctDetails = allocateOrder.Details
+    .GroupBy(d => string.IsNullOrEmpty(d.Barcode)
+        ? $"{d.MaterielCode}_{d.BatchNo}_{d.SupplyCode}_{d.WarehouseCode}"
+        : d.Barcode)
+    .Select(g => new
+    {
+        Detail = g.First(),
+        //姹囨�诲垎缁勫唴鐨勬暟閲�
+        Qty = g.Sum(x => x.BarcodeQty ?? x.OrderQuantity)
+    }).ToList();
+
             return new Dt_OutboundOrder()
             {
                 WarehouseId = allocateOrder.WarehouseId,
@@ -332,20 +350,23 @@
                 Remark = allocateOrder.Remark,
                 DepartmentCode = "",
                 DepartmentName = "",
-                Details = allocateOrder.Details.Select(detail => new Dt_OutboundOrderDetail
+                Details = distinctDetails.Select(item => new Dt_OutboundOrderDetail
                 {
-                    OrderId = detail.OrderId,
-                    MaterielCode = detail.MaterielCode,
+                    OrderId = 0,
+                    MaterielCode = item.Detail.MaterielCode,
                     MaterielName = "",
-                    BatchNo = detail.BatchNo,
-                    OrderQuantity = detail.OrderQuantity,
+                    BatchNo = item.Detail.BatchNo,
+                    OrderQuantity = item.Detail.OrderQuantity,
+                    BarcodeQty = (decimal)item.Detail.BarcodeQty,
+                    BarcodeUnit = item.Detail.BarcodeUnit,
                     LockQuantity = 0,
+                    lineNo = item.Detail.LineNo,
                     OverOutQuantity = 0,
-                    OrderDetailStatus = detail.OrderDetailStatus,
-                    Unit = detail.Unit,
+                    OrderDetailStatus = item.Detail.OrderDetailStatus,
+                    Unit = item.Detail.Unit,
                     RowNo = 0,
-                    SupplyCode = detail.SupplyCode,
-                    WarehouseCode = detail.WarehouseCode,
+                    SupplyCode = item.Detail.SupplyCode,
+                    WarehouseCode = item.Detail.WarehouseCode,
 
                 }).ToList()
             };

--
Gitblit v1.9.3