From 06f5f3e474bb8d9e255a899b62d16f671cfdb940 Mon Sep 17 00:00:00 2001 From: wangxinhui <wangxinhui@hnkhzn.com> Date: 星期四, 26 六月 2025 17:34:33 +0800 Subject: [PATCH] 代码更新 --- 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderService.cs | 138 +++++++++++++++++++++++++++------------------- 1 files changed, 81 insertions(+), 57 deletions(-) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderService.cs" index 013f1cb..662402c 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_OutboundService/ProOutOrderService.cs" @@ -900,13 +900,17 @@ { return await Task.FromResult(content.Error("鏈壘鍒板簱鍖轰俊鎭�")); } + //鑾峰彇鎵�鏈夊钩搴撳簱瀛� List<Dt_ProStockInfoDetail> proStockInfoDetails = _stockRepository.ProStockInfoRepository.Db.Queryable<Dt_ProStockInfo, Dt_ProStockInfoDetail>((master, detail) => master.Id == detail.ProStockId) .Where((master, detail) => master.WarehouseId == warehouse.WarehouseId && outProInfos.Select(x=>x.ProductCode).Contains(detail.ProductCode)) .Select((master, detail) => detail) .ToList(); - + List<int> stockIds = proStockInfoDetails.Select(x => x.ProStockId).Distinct().ToList(); + //鑾峰彇鎵�鏈夊钩搴撲富琛� + List<Dt_ProStockInfo> proStockInfos = _stockRepository.ProStockInfoRepository.Db.Queryable<Dt_ProStockInfo>().Where(x => stockIds.Contains(x.Id)).Includes(x=>x.proStockInfoDetails).ToList(); proStockInfoDetails = proStockInfoDetails.OrderBy(x => x.DateCode).ThenBy(x => x.CreateDate).ThenBy(x=>x.StockPcsQty).ToList(); + List<Dt_Warehouse> warehouses = await _basicRepository.WarehouseRepository.QueryDataAsync(x => x.WarehouseType == WarehouseTypEnum.鎴愬搧.ToString()); //灏嗗叾鍒嗙粍 outProInfos = outProInfos.GroupBy(x => x.ProductCode).Select(x=>new OutProInfoDTO() @@ -915,6 +919,7 @@ OutQtys=x.Sum(x=>x.OutQtys) }).ToList(); List<Dt_ProStockInfoDetail> UpStockInfoDetails = new List<Dt_ProStockInfoDetail>(); + List<Dt_ProStockInfo> DelStocks = new List<Dt_ProStockInfo>(); foreach (var item in outProInfos) { //鑾峰彇搴撳瓨 @@ -922,6 +927,10 @@ if (outStocks.Count <= 0 || outProInfos==null) { return await Task.FromResult(content.Error($"鏈壘鍒颁骇鍝亄item.ProductCode}搴撳瓨")); + } + if (outStocks.Sum(x=>x.StockPcsQty)< item.OutQtys) + { + return await Task.FromResult(content.Error($"鍙敤骞冲簱鏁伴噺{outStocks.Sum(x => x.StockPcsQty)}涓嶆弧瓒冲嚭搴撴暟閲弡item.OutQtys}")); } foreach (var outStock in outStocks) { @@ -963,6 +972,10 @@ else { outStock.OutSETQty = outStock.OutboundQuantity / Range; + } + if (outStock.OutSETQty==0) + { + return await Task.FromResult(content.Error($"{outStock.BagNo}鍗曞厓鏁伴噺杞崲澶辫触,璇锋鏌�")); } item.OutQtys -= (int)BeyondQtys; UpStockInfoDetails.Add(outStock); @@ -1017,7 +1030,11 @@ outStock.OutboundQuantity = BeyondQtys; float Range = outStock.StockPcsQty / outStock.SETQty; outStock.OutSETQty = outStock.OutboundQuantity / Range; - item.OutQtys -= (int)BeyondQtys; + if (outStock.OutSETQty == 0) + { + return await Task.FromResult(content.Error($"{outStock.BagNo}鍗曞厓鏁伴噺杞崲澶辫触,璇锋鏌�")); + } + item.OutQtys = 0; UpStockInfoDetails.Add(outStock); proStockInfoDetails.Remove(outStock); } @@ -1033,7 +1050,11 @@ outStock.OutboundQuantity = item.OutQtys; float Range = outStock.StockPcsQty / outStock.SETQty; outStock.OutSETQty = outStock.OutboundQuantity / Range; - item.OutQtys -= item.OutQtys; + if (outStock.OutSETQty == 0) + { + return await Task.FromResult(content.Error($"{outStock.BagNo}鍗曞厓鏁伴噺杞崲澶辫触,璇锋鏌�")); + } + item.OutQtys = 0; UpStockInfoDetails.Add(outStock); proStockInfoDetails.Remove(outStock); } @@ -1058,69 +1079,72 @@ return await Task.FromResult(content.Error($"{proOutOrderDetail?.SaleOrder}閿�鍞鍗曟暟閲忛渶鍑簕proOutOrderDetail?.QtyPcs},鍙嚭{proOutOrderDetail?.OverQtyPcs}")); } List<StockOutItemsItem> stockOutItems = new List<StockOutItemsItem>(); - if (proOutOrder.ProOrderStatus == OutOrderStatusEnum.鍑哄簱瀹屾垚.ObjToInt()) + //鑾峰彇鎵�鏈夊凡鎵爜寰呭彂璐х殑搴撳瓨 + List<Dt_ProStockInfoDetail> assOutStocks = _stockRepository.ProStockInfoDetailRepository.Db.Queryable<Dt_ProStockInfoDetail>() + .Where(x => x.OutProNo == ProOutNo).ToList(); + UpStockInfoDetails.AddRange(assOutStocks); + foreach (var item in UpStockInfoDetails) { - //鑾峰彇鎵�鏈夊凡鎵爜寰呭彂璐х殑搴撳瓨 - List<Dt_ProStockInfoDetail> assOutStocks = _stockRepository.ProStockInfoDetailRepository.Db.Queryable<Dt_ProStockInfoDetail>() - .Where(x => x.OutProNo == ProOutNo).ToList(); - UpStockInfoDetails.AddRange(assOutStocks); - foreach (var item in UpStockInfoDetails) + StockOutItemsItem outItemsItem = new StockOutItemsItem() { - StockOutItemsItem outItemsItem = new StockOutItemsItem() - { - PartNum = item.ProductCode, - Rev = item.ProductVersion, - SoNumber = item.OutDetailSaleNo, - BatchNumber = item.ProductCode, - QtyPcs = item.OutboundQuantity, - QtySet = item.OutSETQty - }; - stockOutItems.Add(outItemsItem); - } + PartNum = item.ProductCode, + Rev = item.ProductVersion, + SoNumber = item.OutDetailSaleNo, + BatchNumber = item.ProductCode, + QtyPcs = item.OutboundQuantity, + QtySet = item.OutSETQty + }; + stockOutItems.Add(outItemsItem); } Dt_Warehouse warehouseOut = warehouses.Where(x => x.WarehouseId == proOutOrder.WarehouseId).FirstOrDefault(); - _unitOfWorkManage.BeginTran(); - //澶勭悊搴撳瓨鏁版嵁鍜屼笂浼燛RP - if (proOutOrder.ProOrderStatus == OutOrderStatusEnum.鍑哄簱瀹屾垚.ObjToInt()) + //鑾峰彇鍒犻櫎搴撳瓨 + List<Dt_ProStockInfoDetail> delDetails = UpStockInfoDetails.Where(x => x.AssignDel == 1).ToList(); + List<Dt_ProStockInfoDetail> UpDetails = UpStockInfoDetails.Where(x => x.AssignDel != 1).ToList(); + //鑾峰彇鍒犻櫎鐨勫簱瀛樹富琛� + List<int> delStockIds = delDetails.Select(x => x.ProStockId).Distinct().ToList(); + List<int> delStockDetailIds = delDetails.Select(x => x.Id).ToList(); + foreach (var item in delStockIds) { - //鎴愬搧搴撳瓨璁板綍鍙樺姩寰呭姞鍏� - ERPProOutOrderModel proOutOrderModel = new ERPProOutOrderModel() + Dt_ProStockInfo proStockInfo = proStockInfos.FirstOrDefault(x=>x.Id==item); + Dt_ProStockInfoDetail? proStockInfoDetail= proStockInfo.proStockInfoDetails.FirstOrDefault(x=> !delStockDetailIds.Contains(x.Id)); + if (proStockInfoDetail==null) { - Way = 1, - StockOutCode = _outboundOrderService.CreateCodeByRule(nameof(RuleCodeEnum.ProOutCOdeRule)), - ConfirmedUserNo = App.User.UserName, - AssignUserNo = App.User.UserName, - WarehouseCode = warehouseOut.WarehouseCode, - ShipDate = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"), - DeliverplanCode = proOutOrder.ProOutOrderNo, - Remark = proOutOrder.Remark, - StockOutItems = stockOutItems - }; - //鑾峰彇鍒犻櫎搴撳瓨 - List<Dt_ProStockInfoDetail> delDetails = UpStockInfoDetails.Where(x=>x.AssignDel==1).ToList(); - List<Dt_ProStockInfoDetail> UpDetails = UpStockInfoDetails.Where(x => x.AssignDel != 1).ToList(); - //鏇存柊鏁版嵁 - UpDetails.ForEach(x => - { - x.StockPcsQty -= x.OutboundQuantity; - x.SETQty -= x.OutSETQty; - x.OutDetailId = 0; - x.OutDetailSaleNo = null; - x.OutProNo = null; - }); - _stockRepository.ProStockInfoDetailRepository.DeleteAndMoveIntoHty(delDetails, OperateTypeEnum.鑷姩瀹屾垚); - await _stockRepository.ProStockInfoDetailRepository.UpdateDataAsync(UpDetails); - //鍚屾ERP - string response = _invokeERPService.InvokeProOutApi(proOutOrderModel); - ErpRequestContent erpRequestContent = response.DeserializeObject<ErpRequestContent>(); - if (erpRequestContent.res != 1) - { - throw new Exception("鍚屾ERP澶辫触,閿欒淇℃伅:" + erpRequestContent.Data); + DelStocks.Add(proStockInfo); } } - else + _unitOfWorkManage.BeginTran(); + //澶勭悊搴撳瓨鏁版嵁鍜屼笂浼燛RP + //鎴愬搧搴撳瓨璁板綍鍙樺姩寰呭姞鍏� + ERPProOutOrderModel proOutOrderModel = new ERPProOutOrderModel() { - await _stockRepository.ProStockInfoDetailRepository.UpdateDataAsync(UpStockInfoDetails); + Way = 1, + StockOutCode = _outboundOrderService.CreateCodeByRule(nameof(RuleCodeEnum.ProOutCOdeRule)), + ConfirmedUserNo = App.User.UserName, + AssignUserNo = App.User.UserName, + WarehouseCode = warehouseOut.WarehouseCode, + ShipDate = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"), + DeliverplanCode = proOutOrder.ProOutOrderNo, + Remark = proOutOrder.Remark, + StockOutItems = stockOutItems + }; + //鏇存柊鏁版嵁 + UpDetails.ForEach(x => + { + x.StockPcsQty -= x.OutboundQuantity; + x.SETQty -= x.OutSETQty; + x.OutDetailId = 0; + x.OutDetailSaleNo = null; + x.OutProNo = null; + }); + _stockRepository.ProStockInfoDetailRepository.DeleteAndMoveIntoHty(delDetails, OperateTypeEnum.鑷姩瀹屾垚); + _stockRepository.ProStockInfoRepository.DeleteAndMoveIntoHty(DelStocks, OperateTypeEnum.鑷姩瀹屾垚); + await _stockRepository.ProStockInfoDetailRepository.UpdateDataAsync(UpDetails); + //鍚屾ERP + string response = _invokeERPService.InvokeProOutApi(proOutOrderModel); + ErpRequestContent erpRequestContent = response.DeserializeObject<ErpRequestContent>(); + if (erpRequestContent.res != 1) + { + throw new Exception("鍚屾ERP澶辫触,閿欒淇℃伅:" + erpRequestContent.Data); } await _outboundRepository.ProOutOrderDetailRepository.UpdateDataAsync(proOutOrder.Details); await BaseDal.UpdateDataAsync(proOutOrder); -- Gitblit v1.9.3