From a6e0ea9ce13e791f3edae4edffeb3be3ccb760be Mon Sep 17 00:00:00 2001
From: wangxinhui <wangxinhui@hnkhzn.com>
Date: 星期一, 31 三月 2025 02:14:59 +0800
Subject: [PATCH] 版本更新

---
 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderDetailService.cs |   59 ++++++++++++++++++++++++++++++++++++-----------------------
 1 files changed, 36 insertions(+), 23 deletions(-)

diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderDetailService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderDetailService.cs"
index 1941997..4e89f26 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderDetailService.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderDetailService.cs"
@@ -4,6 +4,7 @@
 using System.Text;
 using System.Threading.Tasks;
 using WIDESEA_Common.LocationEnum;
+using WIDESEA_Common.OrderEnum;
 using WIDESEA_Core;
 using WIDESEA_Core.BaseRepository;
 using WIDESEA_Core.BaseServices;
@@ -14,6 +15,7 @@
 using WIDESEA_IRecordService;
 using WIDESEA_IStockService;
 using WIDESEA_Model.Models;
+using WIDESEA_OutboundRepository;
 
 namespace WIDESEA_OutboundService
 {
@@ -25,14 +27,16 @@
         private readonly IStockService _stockInfoService;
         private readonly IBasicService _basicService;
         private readonly IOutProStockInfoService _outProStockInfoService;
+        private readonly IProOutOrderRepository _proOutOrderRepository;
         private readonly IRecordService _recordService;
-        public ProOutOrderDetailService(IProOutOrderDetailRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, IStockService stockInfoService, IBasicService basicService,IOutProStockInfoService outProStockInfoService, IRecordService recordService) : base(BaseDal)
+        public ProOutOrderDetailService(IProOutOrderDetailRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, IStockService stockInfoService, IBasicService basicService,IOutProStockInfoService outProStockInfoService, IRecordService recordService, IProOutOrderRepository proOutOrderRepository) : base(BaseDal)
         {
             _unitOfWorkManage = unitOfWorkManage;
             _stockInfoService = stockInfoService;
             _basicService = basicService;
             _outProStockInfoService = outProStockInfoService;
             _recordService = recordService;
+            _proOutOrderRepository=proOutOrderRepository;
         }
         /// <summary>
         /// 鍑哄簱搴撳瓨鍒嗛厤鍚庯紝鏇存柊鏁版嵁搴撴暟鎹�
@@ -48,6 +52,12 @@
                     proStockInfoDetails.AddRange(item.proStockInfoDetails);
                 }
                 _stockInfoService.ProStockInfoDetailService.Repository.UpdateData(proStockInfoDetails);
+                Dt_ProOutOrder proOutOrder = _proOutOrderRepository.QueryFirst(x => x.Id == proOutOrderDetails.FirstOrDefault().ProOrderId);
+                if (proOutOrder.ProOrderStatus == OutOrderStatusEnum.鏈紑濮�.ObjToInt())
+                {
+                    proOutOrder.ProOrderStatus = OutOrderStatusEnum.鍑哄簱涓�.ObjToInt();
+                    _proOutOrderRepository.UpdateData(proOutOrder);
+                }
                 BaseDal.UpdateData(proOutOrderDetails);
 
                 List<Dt_OutProStockInfo> addOutStockLockInfos = outProStockInfos.Where(x => x.Id == 0).ToList();
@@ -81,17 +91,18 @@
         /// <summary>
         /// 鍒嗛厤搴撳瓨澶勭悊璐т綅鏁版嵁
         /// </summary>
-        public (List<Dt_ProStockInfo>, List<Dt_ProOutOrderDetail>, List<Dt_OutProStockInfo>, List<Dt_LocationInfo>) AssignProStockOut(int warehouseId, Dt_ProOutOrder proOutOrder)
+        public (List<Dt_ProStockInfo>, List<Dt_ProOutOrderDetail>, List<Dt_OutProStockInfo>, List<Dt_LocationInfo>) AssignProStockOut(List<Dt_ProOutOrderDetail> proOutOrderDetails)
         {
-            List<Dt_ProOutOrderDetail> OutOrderDetails = proOutOrder.Details;
-            if (!OutOrderDetails.Any())
-            {
-                throw new Exception($"鏈壘鍒板嚭搴撳崟鏄庣粏淇℃伅");
-            }
             List<Dt_ProStockInfo> outStocks = new List<Dt_ProStockInfo>();
             List<Dt_OutProStockInfo> outProStockInfos = new List<Dt_OutProStockInfo>();
             List<Dt_LocationInfo> locationInfos = new List<Dt_LocationInfo>();
-            List<Dt_ProOutOrderDetail> groupDetails = OutOrderDetails.GroupBy(x => new { x.SaleOrder, x.PCode, x.PVer, x.PLot, x.DateCode }).Select(x => new Dt_ProOutOrderDetail()
+            //鑾峰彇鎴愬搧璁㈠崟
+            Dt_ProOutOrder proOutOrder = _proOutOrderRepository.QueryFirst(x=>x.Id==proOutOrderDetails.FirstOrDefault().ProOrderId);
+            if (proOutOrder==null)
+            {
+                throw new Exception("鏈壘鍒版垚鍝佽鍗�");
+            }
+            List<Dt_ProOutOrderDetail> groupDetails = proOutOrderDetails.GroupBy(x => new { x.SaleOrder, x.PCode, x.PVer, x.PLot, x.DateCode }).Select(x => new Dt_ProOutOrderDetail()
             {
                 QtyPcs = x.Sum(x => x.QtyPcs) - x.Sum(x => x.OverQtyPcs),
                 SaleOrder = x.Key.SaleOrder,
@@ -104,7 +115,7 @@
             {
                 float needQty = item.QtyPcs;
                 //鏌ユ壘鍙敤搴撳瓨
-                List<Dt_ProStockInfo> stockInfoss = _stockInfoService.ProStockInfoService.GetUseableStocks(warehouseId, item);
+                List<Dt_ProStockInfo> stockInfoss = _stockInfoService.ProStockInfoService.GetUseableStocks(proOutOrder.WarehouseId, item);
                 if (!stockInfoss.Any())
                 {
                     throw new Exception("鏈壘鍒板彲鍒嗛厤搴撳瓨");
@@ -114,12 +125,12 @@
                 item.LockQtyPcs += needQty - residueQuantity;
                 outStocks.AddRange(assignOutStocks);
                 float assignQuantity = needQty - residueQuantity;
-                bool isCanLot = !string.IsNullOrEmpty(item.PLot);
-                bool isCanDate = !string.IsNullOrEmpty(item.DateCode);
-                List<Dt_ProOutOrderDetail> details = OutOrderDetails
+                bool isCanLot = string.IsNullOrEmpty(item.PLot);
+                bool isCanDate = string.IsNullOrEmpty(item.DateCode);
+                List<Dt_ProOutOrderDetail> details = proOutOrderDetails
                     .Where(x => x.SaleOrder == item.SaleOrder && x.PCode == item.PCode && x.PVer == item.PVer
-                    && (isCanLot ? x.PLot == item.PLot : true)
-                    && (isCanDate ? x.DateCode == item.DateCode : true))
+                    && (isCanLot ? isCanLot : x.PLot == item.PLot)
+                    && (isCanDate ? isCanDate : x.DateCode == item.DateCode))
                     .ToList();
 
                 for (int i = 0; i < details.Count; i++)
@@ -127,19 +138,21 @@
                     float orderQuantity = details[i].QtyPcs;
                     for (int j = 0; j < assignOutStocks.Count; j++)
                     {
+                        //鍑哄簱璁㈠崟鏄庣粏宸插垎閰嶆暟閲�
                         float detailAssignQuantity = outProStockInfos.Where(x => x.SaleOrder == item.SaleOrder && x.PCode == item.PCode && x.PVer == item.PVer
-                            && (item.PLot.IsNotEmptyOrNull() ? x.PLot == item.PLot : false)
-                            && (item.DateCode.IsNotEmptyOrNull() ? x.DateCode == item.PLot : false) 
-                            && x.OrderDetailId == details[i].Id).Sum(x => x.AssignQuantity);//鍑哄簱璁㈠崟鏄庣粏宸插垎閰嶆暟閲�
+                            && (isCanLot ? isCanLot : x.PLot == item.PLot)
+                            && (isCanDate ? isCanDate : x.DateCode == item.DateCode)
+                            && x.OrderDetailId == details[i].Id).Sum(x => x.AssignQuantity);
 
                         float palletAssignQuantity = outProStockInfos.Where(x => x.SaleOrder == item.SaleOrder && x.PCode == item.PCode && x.PVer == item.PVer
-                            && (item.PLot.IsNotEmptyOrNull() ? x.PLot == item.PLot : false)
-                            && (item.DateCode.IsNotEmptyOrNull() ? x.DateCode == item.PLot : false 
-                            && x.PalletCode == assignOutStocks[j].PalletCode)).Sum(x => x.AssignQuantity);
+                            && (isCanLot ? isCanLot : x.PLot == item.PLot)
+                            && (isCanDate ? isCanDate : x.DateCode == item.DateCode)
+                            && x.PalletCode == assignOutStocks[j].PalletCode).Sum(x => x.AssignQuantity);
                         //鍑哄簱璇︽儏宸插垎閰嶆暟閲�
                         palletAssignQuantity = outProStockInfos.Where(x => x.SaleOrder == item.SaleOrder && x.PCode == item.PCode && x.PVer == item.PVer
-                            && (item.PLot.IsNotEmptyOrNull() ? x.PLot == item.PLot : false)
-                            && (item.DateCode.IsNotEmptyOrNull() ? x.DateCode == item.PLot : false && x.PalletCode == assignOutStocks[j].PalletCode)).Sum(x => x.AssignQuantity);//鍑哄簱璇︽儏宸插垎閰嶆暟閲�
+                            && (isCanLot ? isCanLot : x.PLot == item.PLot)
+                            && (isCanDate ? isCanDate : x.DateCode == item.DateCode) 
+                            && x.PalletCode == assignOutStocks[j].PalletCode).Sum(x => x.AssignQuantity);//鍑哄簱璇︽儏宸插垎閰嶆暟閲�
                         float palletOutboundQuantity = assignOutStocks[j].proStockInfoDetails.Sum(x => x.OutboundQuantity);
                         if (palletAssignQuantity < palletOutboundQuantity)//濡傛灉鍑哄簱璇︽儏宸插垎閰嶆暟閲忓皬浜庢墭鐩樺凡鍒嗛厤鏁伴噺锛屽垯鍙互缁х画娣诲姞璇ユ墭鐩樺嚭搴撲俊鎭�
                         {
@@ -166,7 +179,7 @@
                 locationInfos.AddRange(_basicService.LocationInfoService.Repository.GetLocationInfos(locationArr));
 
             }
-            return (outStocks, OutOrderDetails, outProStockInfos, locationInfos);
+            return (outStocks, proOutOrderDetails, outProStockInfos, locationInfos);
         }
     }
 }

--
Gitblit v1.9.3