From aeaa71fbd60e8f824ce56f82ad91c9480fd75af7 Mon Sep 17 00:00:00 2001 From: dengjunjie <dengjunjie@hnkhzn.com> Date: 星期一, 13 一月 2025 21:00:53 +0800 Subject: [PATCH] 优化拣选入库任务 --- 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_StockService/StockInfoService.cs | 82 +++++++++++++++++++++++++---------------- 1 files changed, 50 insertions(+), 32 deletions(-) diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/StockInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/StockInfoService.cs" index de66c45..0e31f7b 100644 --- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/StockInfoService.cs" +++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_StockService/StockInfoService.cs" @@ -37,6 +37,12 @@ _outboundRepository = outboundRepository; } + /// <summary> + /// 鏌ヨ璁㈠崟绔嬪簱搴撳瓨瑙嗗浘 + /// </summary> + /// <param name="orderId"></param> + /// <param name="materielCode"></param> + /// <returns></returns> public List<StockSelectViewDTO> GetStockSelectViews(int orderId, string materielCode) { try @@ -71,54 +77,66 @@ } } - public StockOutboundOrderDTO GetStockOutboundOrder(SaveModel saveModel) + /// <summary> + /// 鏌ヨ璁㈠崟骞冲簱搴撳瓨瑙嗗浘 + /// </summary> + /// <param name="orderId"></param> + /// <param name="materielCode"></param> + /// <returns></returns> + public List<StockSelectViewDTO> GetPKStockSelectViews(int orderId, string materielCode) { try { - var palletCode = saveModel.MainData["barcode"].ToString(); - Dt_StockInfo stockInfo = BaseDal.Db.Queryable<Dt_StockInfo>().Where(x => x.PalletCode == palletCode).Includes(x => x.Details).First(); - if (stockInfo == null) + Dt_OutboundOrder outboundOrder = _outboundRepository.OutboundOrderRepository.QueryFirst(x => x.Id == orderId); + if (outboundOrder == null) { - throw new Exception($"鏈壘鍒板簱瀛樹俊鎭�"); + throw new Exception($"鏈壘鍒板嚭搴撳崟淇℃伅"); } - Dt_StockInfoDetail stockInfoDetail = stockInfo.Details.FirstOrDefault(); - if (stockInfoDetail == null) + return BaseDal.QueryTabs<Dt_StockInfo, Dt_StockInfoDetail, StockSelectViewDTO>((a, b) => a.Id == b.StockId && a.WarehouseId == outboundOrder.WarehouseId, (a, b) => new StockSelectViewDTO { - throw new Exception($"鏈壘鍒板簱瀛樿鎯�"); - } - BaseDal.QueryTabs<Dt_OutboundOrder, Dt_OutboundOrderDetail, StockOutboundOrderDTO>((a, b) => a.Id == b.OrderId, (a, b) => new StockOutboundOrderDTO - { - OrderNo = a.OrderNo, + LocationCode = a.LocationCode, MaterielCode = b.MaterielCode, MaterielName = b.MaterielName, - PalletCode = stockInfo.PalletCode, - BatchNo = b.BatchNo, - OrderQuantity = b.OrderQuantity, - OverOutQuantity = b.OverOutQuantity, - OutboundQuantity = stockInfoDetail.OutboundQuantity, - SerialNumber = stockInfoDetail.SerialNumber, - StockQuantity = stockInfoDetail.StockQuantity, - - }, a => true, b => b.BatchNo == stockInfoDetail.BatchNo && b.MaterielCode == stockInfoDetail.MaterielCode, x => true).Select(x => new StockOutboundOrderDTO + PalletCode = a.PalletCode, + UseableQuantity = b.StockQuantity - b.OutboundQuantity + }, a => a.LocationCode == "骞冲簱浣�", b => b.StockQuantity > b.OutboundQuantity && b.MaterielCode == materielCode, x => true).GroupBy(x => x.PalletCode).Select(x => new StockSelectViewDTO { - OrderNo = x.OrderNo, - MaterielCode = x.MaterielCode, - MaterielName = x.MaterielName, - PalletCode = x.PalletCode, - BatchNo = x.BatchNo, - OrderQuantity = x.OrderQuantity, - OverOutQuantity = x.OverOutQuantity, - OutboundQuantity = x.OutboundQuantity, - SerialNumber = x.SerialNumber, - StockQuantity = x.StockQuantity, + LocationCode = x.FirstOrDefault()?.LocationCode ?? "", + MaterielCode = x.FirstOrDefault()?.MaterielCode ?? "", + MaterielName = x.FirstOrDefault()?.MaterielName ?? "", + PalletCode = x.Key, + UseableQuantity = x.Sum(x => x.UseableQuantity) }).ToList(); - return new StockOutboundOrderDTO(); } catch (Exception ex) { return null; } } + + public WebResponseContent StockQueryData(SaveModel saveModel) + { + try + { + var barcode = saveModel.MainData["barcode"].ToString(); + var warehouseId = saveModel.MainData["warehouseId"].ObjToInt(); + Dt_StockInfo stockInfo = BaseDal.Db.Queryable<Dt_StockInfo>().Where(x => x.PalletCode == barcode && x.WarehouseId == warehouseId).Includes(x => x.Details).First(); + if (stockInfo == null) throw new Exception("鏈壘鍒版墭鐩樹俊鎭�"); + return WebResponseContent.Instance.OK(data: stockInfo); + } + catch (Exception ex) + { + return WebResponseContent.Instance.Error(ex.Message); + } + } + /// <summary> + /// + /// </summary> + /// <param name="stockInfos"></param> + /// <param name="materielCode"></param> + /// <param name="needQuantity"></param> + /// <param name="residueQuantity"></param> + /// <returns></returns> public List<Dt_StockInfo> GetOutboundStocks(List<Dt_StockInfo> stockInfos, string materielCode, float needQuantity, out float residueQuantity) { List<Dt_StockInfo> outStocks = new List<Dt_StockInfo>(); -- Gitblit v1.9.3