From 4b6b6a8b4e08e7abf4b4af3e39f8e4f988bd3977 Mon Sep 17 00:00:00 2001
From: heshaofeng <heshaofeng@hnkhzn.com>
Date: 星期四, 20 十一月 2025 09:08:24 +0800
Subject: [PATCH] 提交

---
 项目代码/WMS无仓储版/WIDESEA_WMSServer/WIDESEA_InboundService/InboundOrderService.cs |   55 ++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 48 insertions(+), 7 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_InboundService/InboundOrderService.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_InboundService/InboundOrderService.cs"
index 7e48a6a..336932c 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_InboundService/InboundOrderService.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_InboundService/InboundOrderService.cs"
@@ -186,7 +186,8 @@
                     _unitOfWorkManage.BeginTran();
                     foreach (var item in deletePurchaseOrderDetails)
                     {
-                        _inboundOrderDetailRepository.DeleteAndMoveIntoHty(item, OperateTypeEnum.鑷姩鍒犻櫎);
+                        _inboundOrderDetailRepository.DeleteData(item);
+                        //_inboundOrderDetailRepository.DeleteAndMoveIntoHty(item, OperateTypeEnum.鑷姩鍒犻櫎);
                     }
 
                     _inboundOrderDetailRepository.UpdateData(updateInboundOrderDetails);
@@ -223,11 +224,13 @@
                     }
                     //Db.DeleteNav(inboundOrder).Include(x => x.Details).ExecuteCommand();
                     _unitOfWorkManage.BeginTran();
-                    BaseDal.DeleteAndMoveIntoHty(inboundOrder, OperateTypeEnum.鑷姩鍒犻櫎);
+                    //BaseDal.DeleteAndMoveIntoHty(inboundOrder, OperateTypeEnum.鑷姩鍒犻櫎);
                     foreach (var item in inboundOrder.Details)
                     {
-                        _inboundOrderDetailRepository.DeleteAndMoveIntoHty(item, OperateTypeEnum.鑷姩鍒犻櫎);
+                        _inboundOrderDetailRepository.DeleteData(item);
+                        //_inboundOrderDetailRepository.DeleteAndMoveIntoHty(item, OperateTypeEnum.鑷姩鍒犻櫎);
                     }
+                    BaseDal.DeleteData(inboundOrder);
                     _unitOfWorkManage.CommitTran();
                 }
                 return WebResponseContent.Instance.OK();
@@ -422,12 +425,12 @@
 
             WebResponseContent content = new WebResponseContent();
             try
-            {
+            {                                           
                 (bool, string, object?) result2 = ModelValidate.ValidateModelData(materielGroupDTO);
                 if (!result2.Item1) return content = WebResponseContent.Instance.Error(result2.Item2);
 
-                var code = _warehouseAreaRepository.Db.Queryable<Dt_WarehouseArea>().Where(x => x.Code == materielGroupDTO.WarehouseCode).Select(x => x.Code).First();
-                if (string.IsNullOrEmpty(code))
+                bool code = _warehouseAreaRepository.Db.Queryable<Dt_WarehouseArea>().Where(x => x.Id == materielGroupDTO.WarehouseCode).Any();
+                if (!code)
                 {
                     return content = WebResponseContent.Instance.Error($"浠撳簱涓病鏈夎{materielGroupDTO.WarehouseCode}缂栧彿銆�");
                 }
@@ -451,13 +454,14 @@
                 {
                     if (stockInfo == null)
                     {
-                        stockInfo = new Dt_StockInfo() { PalletType = PalletTypeEnum.Empty.ObjToInt(), StockStatus = StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt(), PalletCode = materielGroupDTO.PalletCode,LocationType=1 };
+                        stockInfo = new Dt_StockInfo() { PalletType = PalletTypeEnum.Empty.ObjToInt(), StockStatus = StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt(), PalletCode = materielGroupDTO.PalletCode,LocationType= materielGroupDTO.WarehouseCode.ObjToInt() };
                         stockInfo.Details = new List<Dt_StockInfoDetail>();
                     }
                     else
                     {
                         stockInfo.PalletType = PalletTypeEnum.Empty.ObjToInt();
                         stockInfo.StockStatus = StockStatusEmun.缁勭洏鏆傚瓨.ObjToInt();
+                        stockInfo.LocationType = materielGroupDTO.WarehouseCode.ObjToInt();
                     }
 
                     _unitOfWorkManage.BeginTran();
@@ -625,5 +629,42 @@
             }
         }
 
+        public WebResponseContent UndoPalletGroup(string palletCode)
+        {
+            if (string.IsNullOrWhiteSpace(palletCode))
+            {
+                return WebResponseContent.Instance.Error("鎵樼洏鍙蜂笉鑳戒负绌�");
+            }
+           var stock= _stockRepository.Db.Queryable<Dt_StockInfo>().Includes(o=>o.Details).First(x => x.PalletCode == palletCode && x.StockStatus==3);
+            if (stock == null)
+            {
+                return WebResponseContent.Instance.Error($"鏈壘鍒版墭鐩樺彿{palletCode}瀵瑰簲鐨勫簱瀛樿褰�");
+            }
+            //  鑾峰彇搴撳瓨璇︽儏鍏宠仈鐨勬墍鏈夊叆搴撳崟鍙�
+            var relatedOrderNos = stock.Details.Select(d => d.OrderNo).First();
+            //  鏌ヨ鎵�鏈夊叧鑱旂殑鍏ュ簱鍗曪紙鍚鎯咃級
+            var inboundOrders = _inboundOrderRepository.Db.Queryable<Dt_InboundOrder>()
+                .Includes(x => x.Details) 
+                .Where(x => relatedOrderNos==x.InboundOrderNo)
+                .First();
+
+            var barcodes = stock.Details.Select(d => d.Barcode).ToList();
+
+            
+                // 鍖归厤搴撳瓨鏉$爜瀵瑰簲鐨勫叆搴撳崟鏄庣粏
+                var matchedInboundDetails = inboundOrders.Details
+                    ?.Where(d => barcodes.Contains(d.Barcode))
+                    .ToList();
+            foreach (var detail in matchedInboundDetails)
+            {
+                detail.ReceiptQuantity = 0;
+                detail.OrderDetailStatus = 0;
+                _inboundOrderDetailRepository.UpdateData(detail);
+            }
+            _stockDetailRepository.DeleteData(stock.Details);
+            _stockRepository.DeleteData(stock);
+
+            return WebResponseContent.Instance.OK();
+        }
     }
 }

--
Gitblit v1.9.3