From b40f6e7f21c5708c72cdce913631da623bef5d49 Mon Sep 17 00:00:00 2001 From: hutongqing <hutongqing@hnkhzn.com> Date: 星期一, 23 十二月 2024 21:05:01 +0800 Subject: [PATCH] 1 --- 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_StockService/StockInfoService.cs | 101 +++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 98 insertions(+), 3 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 37f7521..13e2579 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" @@ -1,4 +1,5 @@ 锘縰sing AutoMapper; +using MailKit.Search; using OfficeOpenXml.FormulaParsing.Excel.Functions.RefAndLookup; using SqlSugar; using System; @@ -12,6 +13,7 @@ using WIDESEA_Core.Helper; using WIDESEA_DTO.Stock; using WIDESEA_IBasicRepository; +using WIDESEA_IOutboundRepository; using WIDESEA_IRecordRepository; using WIDESEA_IRecordService; using WIDESEA_IStockRepository; @@ -24,15 +26,108 @@ { private readonly IMapper _mapper; private readonly IBasicRepository _basicRepository; + private readonly IOutboundRepository _outboundRepository; public IStockInfoRepository Repository => BaseDal; - public StockInfoService(IStockInfoRepository BaseDal, IMapper mapper, IBasicRepository basicRepository) : base(BaseDal) + public StockInfoService(IStockInfoRepository BaseDal, IMapper mapper, IBasicRepository basicRepository, IOutboundRepository outboundRepository) : base(BaseDal) { _mapper = mapper; _basicRepository = basicRepository; + _outboundRepository = outboundRepository; } + public List<StockSelectViewDTO> GetStockSelectViews(int orderId, string materielCode) + { + try + { + Dt_OutboundOrder outboundOrder = _outboundRepository.OutboundOrderRepository.QueryFirst(x => x.Id == orderId); + if (outboundOrder == null) + { + throw new Exception($"鏈壘鍒板嚭搴撳崟淇℃伅"); + } + + List<string> locationCodes = _basicRepository.LocationInfoRepository.GetCanOutLocationCodes(outboundOrder.WarehouseId); + + return BaseDal.QueryTabs<Dt_StockInfo, Dt_StockInfoDetail, StockSelectViewDTO>((a, b) => a.Id == b.StockId, (a, b) => new StockSelectViewDTO + { + LocationCode = a.LocationCode, + MaterielCode = b.MaterielCode, + MaterielName = b.MaterielName, + PalletCode = a.PalletCode, + UseableQuantity = b.StockQuantity - b.OutboundQuantity + }, a => locationCodes.Contains(a.LocationCode), b => b.StockQuantity > b.OutboundQuantity && b.MaterielCode == materielCode, x => true).GroupBy(x => x.PalletCode).Select(x => new StockSelectViewDTO + { + LocationCode = x.FirstOrDefault()?.LocationCode ?? "", + MaterielCode = x.FirstOrDefault()?.MaterielCode ?? "", + MaterielName = x.FirstOrDefault()?.MaterielName ?? "", + PalletCode = x.Key, + UseableQuantity = x.Sum(x => x.UseableQuantity) + }).ToList(); + } + catch (Exception ex) + { + return null; + } + + } + public StockOutboundOrderDTO GetStockOutboundOrder(SaveModel saveModel) + { + 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) + { + throw new Exception($"鏈壘鍒板簱瀛樹俊鎭�"); + } + Dt_StockInfoDetail stockInfoDetail = stockInfo.Details.FirstOrDefault(); + if (stockInfoDetail == null) + { + throw new Exception($"鏈壘鍒板簱瀛樿鎯�"); + } + BaseDal.QueryTabs<Dt_OutboundOrder, Dt_OutboundOrderDetail, StockOutboundOrderDTO>((a, b) => a.Id == b.OrderId, (a, b) => new StockOutboundOrderDTO + { + OrderNo = a.OrderNo, + 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 + { + 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, + }).ToList(); + return new StockOutboundOrderDTO(); + } + catch (Exception ex) + { + return null; + } + } + + /// <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>(); @@ -110,11 +205,11 @@ return outStocks; } - public List<Dt_StockInfo> GetUseableStocks(string materielCode, int warehoseId) + public List<Dt_StockInfo> GetUseableStocks(string materielCode, string batchNo, int warehoseId) { List<string> locationCodes = _basicRepository.LocationInfoRepository.GetCanOutLocationCodes(warehoseId); - return BaseDal.GetStockInfos(materielCode, locationCodes); + return BaseDal.GetStockInfos(materielCode, batchNo, locationCodes); } } } -- Gitblit v1.9.3