|  |  |  | 
|---|
|  |  |  | using System.Linq; | 
|---|
|  |  |  | using System.Text; | 
|---|
|  |  |  | using System.Threading.Tasks; | 
|---|
|  |  |  | using WIDESEA_Common.StockEnum; | 
|---|
|  |  |  | using WIDESEA_Common.WareHouseEnum; | 
|---|
|  |  |  | using WIDESEA_Core; | 
|---|
|  |  |  | using WIDESEA_Core.BaseServices; | 
|---|
|  |  |  | using WIDESEA_Core.Enums; | 
|---|
|  |  |  | using WIDESEA_Core.Helper; | 
|---|
|  |  |  | using WIDESEA_IBasicRepository; | 
|---|
|  |  |  | using WIDESEA_IStockRepository; | 
|---|
|  |  |  | using WIDESEA_IStockService; | 
|---|
|  |  |  | 
|---|
|  |  |  | //æ ¹æ®å
å
å·è¿è¡åºåæ£é¤ | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //è·ååºå | 
|---|
|  |  |  | List<string> BagNos = proStockInfoDetails.Select(x => x.BagNo).Distinct().ToList(); | 
|---|
|  |  |  | List<Dt_ProStockInfo> proStockInfos = _stockRepository.ProStockInfoRepository.Db.Queryable<Dt_ProStockInfo>() | 
|---|
|  |  |  | .Where(x => x.StockStatus == StockStatusEmun.åºåºå®æ.ObjToInt()) | 
|---|
|  |  |  | .Includes(x => x.proStockInfoDetails) | 
|---|
|  |  |  | .Where(x => x.proStockInfoDetails.Any(v => BagNos.Contains(v.BagNo))).Distinct().ToList(); | 
|---|
|  |  |  | List<Dt_ProStockInfoDetail> delProStockDetails=new List<Dt_ProStockInfoDetail>(); | 
|---|
|  |  |  | //foreach (var item in collection) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    Dt_ProStockInfoDetail delProStockDetal= | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | List<Dt_ProStockInfoDetail> upProStockDetails = new List<Dt_ProStockInfoDetail>(); | 
|---|
|  |  |  | List<Dt_ProStockInfo> delProStockInfos = new List<Dt_ProStockInfo>(); | 
|---|
|  |  |  | foreach (var item in proStockInfoDetails) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_ProStockInfo? proStockInfo = proStockInfos.Where(x => x.proStockInfoDetails.Any(v => v.BagNo == item?.BagNo)).FirstOrDefault(); | 
|---|
|  |  |  | Dt_ProStockInfoDetail? proStockInfoDetail = proStockInfo?.proStockInfoDetails.Where(x => x.BagNo == item?.BagNo).FirstOrDefault(); | 
|---|
|  |  |  | if (proStockInfo==null || proStockInfoDetail == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error($"æªæ¾å°{item?.BagNo}åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //夿æç»æ¯å¦å
¨é¨æ«åº | 
|---|
|  |  |  | if (proStockInfoDetail.StockPcsQty==item.StockPcsQty) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | delProStockDetails.Add(proStockInfoDetail); | 
|---|
|  |  |  | proStockInfo.proStockInfoDetails.Remove(proStockInfoDetail); | 
|---|
|  |  |  | item.OutDetailId = proStockInfoDetail.OutDetailId; | 
|---|
|  |  |  | item.OutDetailSaleNo = proStockInfoDetail.OutDetailSaleNo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | proStockInfoDetail.StockPcsQty -= item.StockPcsQty; | 
|---|
|  |  |  | proStockInfoDetail.SETQty -= item.SETQty; | 
|---|
|  |  |  | proStockInfoDetail.OutboundQuantity = 0; | 
|---|
|  |  |  | item.OutDetailId = 0; | 
|---|
|  |  |  | item.OutDetailSaleNo = ""; | 
|---|
|  |  |  | upProStockDetails.Add(proStockInfoDetail); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (proStockInfo.proStockInfoDetails.Count==0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | delProStockInfos.Add(proStockInfo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (delProStockInfos.Count>0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | BaseDal.DeleteAndMoveIntoHty(delProStockInfos, OperateTypeEnum.èªå¨å é¤); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (delProStockDetails.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _stockRepository.ProStockInfoDetailRepository.DeleteAndMoveIntoHty(delProStockDetails, OperateTypeEnum.èªå¨å é¤); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (upProStockDetails.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _stockRepository.ProStockInfoDetailRepository.UpdateData(upProStockDetails); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | content.OK("æå", proStockInfoDetails); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //æ¥æ¾å¯ç¨åºå | 
|---|
|  |  |  | public List<Dt_ProStockInfo> GetUseableStocks(int warehoseId,Dt_ProOutOrderDetail proOutOrderDetail) | 
|---|
|  |  |  | public List<Dt_ProStockInfo> GetUseableStocks(int warehoseId,Dt_ProOutOrderDetail proOutOrderDetail, bool isFineWorks = false) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<string> locationCodes = _basicRepository.LocationInfoRepository.GetCanOutLocationCodes(warehoseId); | 
|---|
|  |  |  | return BaseDal.GetProStocks(proOutOrderDetail,locationCodes); | 
|---|
|  |  |  | return BaseDal.GetProStocks(proOutOrderDetail,locationCodes, isFineWorks); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// MESæåºå¯ç¨åºå | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public List<Dt_ProStockInfo> GetUseableStocks(Dt_MesRworkOutboundOrder mesRworkOutboundOrder) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //è½¬æ¢æ æåä»ä»åºä¿¡æ¯è·åå°¾æ°å±æ§çè´§ä½ | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x=>x.WarehouseId== mesRworkOutboundOrder.WarehouseId); | 
|---|
|  |  |  | List<string> locationCodes = _basicRepository.LocationInfoRepository.GetCanOutLocationCodes(warehouse.WarehouseId); | 
|---|
|  |  |  | return BaseDal.GetProStocks(mesRworkOutboundOrder, locationCodes); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //æ¥æ¾å¯ç¨æ¥åºåºå | 
|---|
|  |  |  | public List<Dt_ProStockInfo> GetUseableStocks(int warehoseId, Dt_ErpProScrapSheetDetail erpProScrapSheetDetail) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<string> locationCodes = _basicRepository.LocationInfoRepository.GetCanOutLocationCodes(warehoseId); | 
|---|
|  |  |  | return BaseDal.GetProStocks(erpProScrapSheetDetail, locationCodes); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// è·ååºåºåºå | 
|---|
|  |  |  | 
|---|
|  |  |  | public List<Dt_ProStockInfo> GetOutboundStocks(List<Dt_ProStockInfo> stockInfos, Dt_ProOutOrderDetail outOrderDetail, float needQuantity, out float residueQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_ProStockInfo> assignOutStocks =new List<Dt_ProStockInfo>(); | 
|---|
|  |  |  | float stockTotalQuantity = stockInfos.Select(x => x.proStockInfoDetails.Sum(v => v.StockPcsQty - v.OutboundQuantity)).Sum(x => x); | 
|---|
|  |  |  | bool isCanLot = string.IsNullOrEmpty(outOrderDetail.PLot); | 
|---|
|  |  |  | float stockTotalQuantity = stockInfos.Select(x => x.proStockInfoDetails.Where(x => x.ProductCode == outOrderDetail.PCode && x.ProductVersion.StartsWith(outOrderDetail.PVer.Substring(0, 1)) | 
|---|
|  |  |  | && (isCanLot ? isCanLot : x.ProductCode == outOrderDetail.PLot)) | 
|---|
|  |  |  | .Sum(v => v.StockPcsQty - v.OutboundQuantity)).Sum(x => x); | 
|---|
|  |  |  | //stockInfos = stockInfos.OrderBy(x => x.Id).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (stockTotalQuantity >= needQuantity)//åºåå¤ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | int index = 0; | 
|---|
|  |  |  | while (needQuantity > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_ProStockInfo stockInfo = stockInfos[index]; | 
|---|
|  |  |  | float useableStockQuantity = stockInfo.proStockInfoDetails | 
|---|
|  |  |  | .Where(x => x.ProductCode == outOrderDetail.PCode && x.ProductVersion.StartsWith(outOrderDetail.PVer.Substring(0,1)) | 
|---|
|  |  |  | && (isCanLot ? isCanLot : x.ProductCode == outOrderDetail.PLot)) | 
|---|
|  |  |  | .Sum(x => x.StockPcsQty - x.OutboundQuantity); | 
|---|
|  |  |  | if (useableStockQuantity < needQuantity && useableStockQuantity >0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo.proStockInfoDetails.Where(x => x.ProductCode == outOrderDetail.PCode && x.ProductVersion.StartsWith(outOrderDetail.PVer.Substring(0, 1)) | 
|---|
|  |  |  | && (isCanLot ? isCanLot : x.ProductCode == outOrderDetail.PLot)).ToList().ForEach(x => x.OutboundQuantity = x.StockPcsQty); | 
|---|
|  |  |  | needQuantity -= useableStockQuantity; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo.proStockInfoDetails.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //满足æ¡ä»¶è¿è¡åé
 | 
|---|
|  |  |  | if ((x.StockPcsQty > x.OutboundQuantity) | 
|---|
|  |  |  | && x.ProductCode == outOrderDetail.PCode && x.ProductVersion.StartsWith(outOrderDetail.PVer.Substring(0, 1)) | 
|---|
|  |  |  | && (isCanLot ? isCanLot : x.ProductCode == outOrderDetail.PLot)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (x.StockPcsQty - x.OutboundQuantity >= needQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OutboundQuantity += needQuantity; | 
|---|
|  |  |  | needQuantity = 0; | 
|---|
|  |  |  | x.OutDetailSaleNo = outOrderDetail.SaleOrder; | 
|---|
|  |  |  | x.OutDetailId = outOrderDetail.Id; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | needQuantity -= (x.StockPcsQty - x.OutboundQuantity); | 
|---|
|  |  |  | x.OutboundQuantity = x.StockPcsQty; | 
|---|
|  |  |  | x.OutDetailSaleNo = outOrderDetail.SaleOrder; | 
|---|
|  |  |  | x.OutDetailId = outOrderDetail.Id; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | assignOutStocks.Add(stockInfo); | 
|---|
|  |  |  | index++; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | residueQuantity = needQuantity; | 
|---|
|  |  |  | return assignOutStocks; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// è·åæ¥åºåºå | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | public List<Dt_ProStockInfo> GetOutboundStocks(List<Dt_ProStockInfo> stockInfos, Dt_ErpProScrapSheetDetail outOrderDetail, float needQuantity, out float residueQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_ProStockInfo> assignOutStocks = new List<Dt_ProStockInfo>(); | 
|---|
|  |  |  | float stockTotalQuantity = stockInfos.Select(x => x.proStockInfoDetails.Where(x => | 
|---|
|  |  |  | x.ProductCode == outOrderDetail.ScrapProCode | 
|---|
|  |  |  | && x.ProductVersion == outOrderDetail.ScrapProVersion | 
|---|
|  |  |  | && x.LotNumber == outOrderDetail.ScrapProLotNo).Sum(v => v.StockPcsQty - v.OutboundQuantity)).Sum(x => x); | 
|---|
|  |  |  | //stockInfos = stockInfos.OrderBy(x => x.Id).ToList(); | 
|---|
|  |  |  | if (stockTotalQuantity >= needQuantity)//åºåå¤ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_ProStockInfo stockInfo = stockInfos[index]; | 
|---|
|  |  |  | float useableStockQuantity = stockInfo.proStockInfoDetails | 
|---|
|  |  |  | .Where(x => x.SaleOrder == outOrderDetail.SaleOrder && x.ProductCode==outOrderDetail.PCode && x.ProductVersion==outOrderDetail.PVer) | 
|---|
|  |  |  | .Where(x => | 
|---|
|  |  |  | x.ProductCode == outOrderDetail.ScrapProCode | 
|---|
|  |  |  | && x.ProductVersion==outOrderDetail.ScrapProVersion | 
|---|
|  |  |  | && x.LotNumber == outOrderDetail.ScrapProLotNo) | 
|---|
|  |  |  | .Sum(x => x.StockPcsQty - x.OutboundQuantity); | 
|---|
|  |  |  | if (useableStockQuantity < needQuantity && useableStockQuantity > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo.proStockInfoDetails.Where(x => | 
|---|
|  |  |  | x.ProductCode == outOrderDetail.ScrapProCode | 
|---|
|  |  |  | && x.ProductVersion == outOrderDetail.ScrapProVersion | 
|---|
|  |  |  | && x.LotNumber == outOrderDetail.ScrapProLotNo).ToList().ForEach(x => x.OutboundQuantity = x.StockPcsQty); | 
|---|
|  |  |  | needQuantity -= useableStockQuantity; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo.proStockInfoDetails.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //满足æ¡ä»¶è¿è¡åé
 | 
|---|
|  |  |  | if ((x.StockPcsQty > x.OutboundQuantity) | 
|---|
|  |  |  | && x.ProductCode == outOrderDetail.ScrapProCode | 
|---|
|  |  |  | && x.ProductVersion == outOrderDetail.ScrapProVersion | 
|---|
|  |  |  | && x.LotNumber == outOrderDetail.ScrapProLotNo) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (x.StockPcsQty - x.OutboundQuantity >= needQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OutboundQuantity += needQuantity; | 
|---|
|  |  |  | needQuantity = 0; | 
|---|
|  |  |  | x.OutDetailId = outOrderDetail.Id; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | needQuantity -= (x.StockPcsQty - x.OutboundQuantity); | 
|---|
|  |  |  | x.OutboundQuantity = x.StockPcsQty; | 
|---|
|  |  |  | x.OutDetailId = outOrderDetail.Id; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | assignOutStocks.Add(stockInfo); | 
|---|
|  |  |  | index++; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | residueQuantity = needQuantity; | 
|---|
|  |  |  | return assignOutStocks; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// è·åMESæåºåºå | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | public List<Dt_ProStockInfo> GetOutboundStocks(List<Dt_ProStockInfo> stockInfos, Dt_MesRworkOutboundOrder mesRworkOutboundOrder, float needQuantity, out float residueQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_ProStockInfo> assignOutStocks = new List<Dt_ProStockInfo>(); | 
|---|
|  |  |  | bool isCanDate = string.IsNullOrEmpty(mesRworkOutboundOrder.DateCode); | 
|---|
|  |  |  | float stockTotalQuantity = stockInfos.Select(x => x.proStockInfoDetails.Where(x => x.ProductCode == mesRworkOutboundOrder.ProductCode | 
|---|
|  |  |  | && x.ProductVersion == mesRworkOutboundOrder.ProductVersion | 
|---|
|  |  |  | && (isCanDate ? isCanDate : x.DateCode == mesRworkOutboundOrder.DateCode)) | 
|---|
|  |  |  | .Sum(v => v.StockPcsQty - v.OutboundQuantity)).Sum(x => x); | 
|---|
|  |  |  | //stockInfos = stockInfos.OrderBy(x => x.Id).ToList(); | 
|---|
|  |  |  | if (stockTotalQuantity >= needQuantity)//åºåå¤ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | int index = 0; | 
|---|
|  |  |  | while (needQuantity > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_ProStockInfo stockInfo = stockInfos[index]; | 
|---|
|  |  |  | float useableStockQuantity = stockInfo.proStockInfoDetails | 
|---|
|  |  |  | .Where(x => x.ProductCode == mesRworkOutboundOrder.ProductCode | 
|---|
|  |  |  | && x.ProductVersion == mesRworkOutboundOrder.ProductVersion | 
|---|
|  |  |  | && (isCanDate? isCanDate: x.DateCode == mesRworkOutboundOrder.DateCode)) | 
|---|
|  |  |  | .Sum(x => x.StockPcsQty - x.OutboundQuantity); | 
|---|
|  |  |  | if (useableStockQuantity < needQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo.proStockInfoDetails.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if ((x.StockPcsQty > x.OutboundQuantity) && x.SaleOrder == outOrderDetail.SaleOrder && x.ProductCode == outOrderDetail.PCode && x.ProductVersion == outOrderDetail.PVer) | 
|---|
|  |  |  | if ((x.StockPcsQty > x.OutboundQuantity) | 
|---|
|  |  |  | && x.ProductCode == mesRworkOutboundOrder.ProductCode | 
|---|
|  |  |  | && x.ProductVersion == mesRworkOutboundOrder.ProductVersion | 
|---|
|  |  |  | && (isCanDate ? isCanDate : x.DateCode == mesRworkOutboundOrder.DateCode)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (x.StockPcsQty - x.OutboundQuantity >= needQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | index++; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | for (int i = 0; i < stockInfos.Count; i++) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_ProStockInfo stockInfo = stockInfos[i]; | 
|---|
|  |  |  | float useableStockQuantity = stockInfo.proStockInfoDetails | 
|---|
|  |  |  | .Where(x => x.SaleOrder == outOrderDetail.SaleOrder && x.ProductCode == outOrderDetail.PCode && x.ProductVersion == outOrderDetail.PVer) | 
|---|
|  |  |  | .Sum(x => x.StockPcsQty - x.OutboundQuantity); | 
|---|
|  |  |  | if (useableStockQuantity < needQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo.proStockInfoDetails.ForEach(x => x.OutboundQuantity = x.StockPcsQty); | 
|---|
|  |  |  | needQuantity -= useableStockQuantity; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo.proStockInfoDetails.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (x.StockPcsQty > x.OutboundQuantity && x.SaleOrder == outOrderDetail.SaleOrder && x.ProductCode == outOrderDetail.PCode && x.ProductVersion == outOrderDetail.PVer) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (x.StockPcsQty - x.OutboundQuantity >= needQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OutboundQuantity += needQuantity; | 
|---|
|  |  |  | needQuantity = 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | needQuantity -= (x.StockPcsQty - x.OutboundQuantity); | 
|---|
|  |  |  | x.OutboundQuantity = x.StockPcsQty; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | assignOutStocks.Add(stockInfo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | residueQuantity = needQuantity; | 
|---|
|  |  |  | return assignOutStocks; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ////å¤çåºåºåºå | 
|---|
|  |  |  | //public (List<Dt_ProStockInfoDetail>?, List<Dt_ProStockInfoDetail>?) HandleOutProStock(Dt_ProStockInfo proStockInfo) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    List<Dt_ProStockInfoDetail>? deleteStockDetails = null; | 
|---|
|  |  |  | //    List<Dt_ProStockInfoDetail>? updateStockDetails = null; | 
|---|
|  |  |  | //    foreach (var item in proStockInfo.proStockInfoDetails) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        if (item.StockPcsQty==item.OutboundQuantity) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            item.ProOutDetailStatus = StockStatusEmun.åºåºå®æ.ObjToInt(); | 
|---|
|  |  |  | //            deleteStockDetails.Add(item); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        else if(item.StockPcsQty> item.OutboundQuantity && item.OutboundQuantity>0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            item.StockPcsQty-=item.OutboundQuantity; | 
|---|
|  |  |  | //            updateStockDetails.Add(item); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    return (deleteStockDetails, updateStockDetails); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | public WebResponseContent GetProCodeByWarehouse(int warehouseId) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //è·åææåºååå· | 
|---|
|  |  |  | List<Dt_ProStockInfoDetail> proStockInfoDetails = _stockRepository.ProStockInfoRepository.Db.Queryable<Dt_ProStockInfo, Dt_ProStockInfoDetail>((master, detail) => master.Id == detail.ProStockId) | 
|---|
|  |  |  | .Where((master, detail) => master.WarehouseId == warehouseId) | 
|---|
|  |  |  | .Select((master, detail) => detail) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  | //è¿æ»¤éå¤ | 
|---|
|  |  |  | List<string> proCode = proStockInfoDetails.Select(x => x.ProductCode).Distinct().ToList(); | 
|---|
|  |  |  | return WebResponseContent.Instance.OK("æå",data: proCode); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public WebResponseContent GetProVersionByCode(string scrapProCode, int warehouseId) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //è·åæå®äº§ååºåçæ¬ | 
|---|
|  |  |  | List<Dt_ProStockInfoDetail> proStockInfoDetails = _stockRepository.ProStockInfoRepository.Db.Queryable<Dt_ProStockInfo, Dt_ProStockInfoDetail>((master, detail) => master.Id == detail.ProStockId) | 
|---|
|  |  |  | .Where((master, detail) => master.WarehouseId == warehouseId && detail.ProductCode== scrapProCode) | 
|---|
|  |  |  | .Select((master, detail) => detail) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  | //è¿æ»¤éå¤ | 
|---|
|  |  |  | List<string> productVersion = proStockInfoDetails.Select(x => x.ProductVersion).Distinct().ToList(); | 
|---|
|  |  |  | return WebResponseContent.Instance.OK("æå",data: productVersion); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public WebResponseContent GetProLotNoByCode(string scrapProCode, int warehouseId) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //è·åæå®äº§ååºåæ¹æ¬¡ | 
|---|
|  |  |  | List<Dt_ProStockInfoDetail> proStockInfoDetails = _stockRepository.ProStockInfoRepository.Db.Queryable<Dt_ProStockInfo, Dt_ProStockInfoDetail>((master, detail) => master.Id == detail.ProStockId) | 
|---|
|  |  |  | .Where((master, detail) => master.WarehouseId == warehouseId && detail.ProductCode == scrapProCode) | 
|---|
|  |  |  | .Select((master, detail) => detail) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  | //è¿æ»¤éå¤ | 
|---|
|  |  |  | List<string> lotNumber = proStockInfoDetails.Select(x => x.LotNumber).Distinct().ToList(); | 
|---|
|  |  |  | return WebResponseContent.Instance.OK("æå", data: lotNumber); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|