| | |
| | | using System.Text; |
| | | using System.Threading.Tasks; |
| | | using SqlSugar; |
| | | using SqlSugar.Extensions; |
| | | using WIDESEA_Common.StockEnum; |
| | | using WIDESEA_Core; |
| | | using WIDESEA_DTO.CalcOut; |
| | |
| | | { |
| | | public partial class OutboundService |
| | | { |
| | | public WebResponseContent GetOrderInfo(string orderNo) |
| | | { |
| | | try |
| | | { |
| | | Dt_OutboundOrder outboundOrder = _outboundRepository.Db.Queryable<Dt_OutboundOrder>().First(x => x.OrderNo == orderNo); |
| | | return WebResponseContent.Instance.OK(data: outboundOrder); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | return WebResponseContent.Instance.Error(ex.Message); |
| | | } |
| | | } |
| | | |
| | | //public WebResponseContent QueryPickingTasks(string palletCode, string orderNo) |
| | | //{ |
| | | // try |
| | | // { |
| | | // Dt_StockInfo stockInfo = _stockInfoRepository.Db.Queryable<Dt_StockInfo>().Where(x => x.PalletCode == palletCode).Includes(x => x.Details).First(); |
| | | |
| | | // var outboundOrder = _outboundRepository.QueryFirst(x => x.OrderNo == orderNo); |
| | | |
| | | // bool isMatMixed = false; |
| | | // if (stockInfo != null) |
| | | // { |
| | | // isMatMixed = stockInfo.Details.GroupBy(x => new |
| | | // { |
| | | // x.MaterielCode, |
| | | // x.MaterielName, |
| | | // x.BatchNo, |
| | | // x.SupplyCode, |
| | | // x.WarehouseCode |
| | | // }).Count() > 1; |
| | | // } |
| | | |
| | | |
| | | // List<Dt_OutStockLockInfo> outStockLockInfos = _outboundLockInfoRepository.QueryData(x => x.PalletCode == palletCode && x.OrderNo == orderNo); |
| | | // return WebResponseContent.Instance.OK(data: new { outStockLockInfos, stockInfo, isMatMixed }); |
| | | // } |
| | | // catch (Exception ex) |
| | | // { |
| | | // return WebResponseContent.Instance.Error(ex.Message); |
| | | // } |
| | | //} |
| | | |
| | | public WebResponseContent QueryPickingTasks(string palletCode, string orderNo) |
| | | { |
| | | try |
| | | { |
| | | List<Dt_OutStockLockInfo> outStockLockInfos = _outboundLockInfoService.Repository.QueryData(x => x.PalletCode == palletCode && x.OrderNo == orderNo); |
| | | return WebResponseContent.Instance.OK(data: outStockLockInfos); |
| | | Dt_StockInfo stockInfo = _stockInfoRepository.Db.Queryable<Dt_StockInfo>() |
| | | .Where(x => x.PalletCode == palletCode) |
| | | .Includes(x => x.Details) |
| | | .First(); |
| | | |
| | | List<Dt_OutStockLockInfo> outStockLockInfos = _outboundLockInfoRepository |
| | | .QueryData(x => x.PalletCode == palletCode && x.OrderNo == orderNo); |
| | | |
| | | bool isMatMixed = false; |
| | | bool orderOver = false; |
| | | decimal sumQty = 0; |
| | | if (stockInfo != null && stockInfo.Details != null && stockInfo.Details.Any()) |
| | | { |
| | | if (outStockLockInfos.FirstOrDefault() != null) |
| | | { |
| | | bool includeBatchNo = !string.IsNullOrEmpty(outStockLockInfos.FirstOrDefault().BatchNo); |
| | | bool includeSupplyCode = !string.IsNullOrEmpty(outStockLockInfos.FirstOrDefault().SupplyCode); |
| | | var orderId = outStockLockInfos.FirstOrDefault().OrderDetailIds.Split(","); |
| | | foreach (var item in orderId) |
| | | { |
| | | Dt_OutboundOrderDetail outboundOrderDetail = _outboundRepository.Db.Queryable<Dt_OutboundOrderDetail>().Where(x=>x.Id == item.ObjToInt()).First(); |
| | | if(outboundOrderDetail == null) |
| | | { |
| | | return WebResponseContent.Instance.Error("该æççåºåºæç»æªæ¾å°"); |
| | | } |
| | | sumQty += (outboundOrderDetail.OrderQuantity - outboundOrderDetail.OverOutQuantity - outboundOrderDetail.MoveQty); |
| | | } |
| | | if(sumQty < outStockLockInfos.FirstOrDefault().AssignQuantity) |
| | | { |
| | | orderOver = true; |
| | | } |
| | | if (includeBatchNo && includeSupplyCode) |
| | | { |
| | | isMatMixed = stockInfo.Details.GroupBy(x => new |
| | | { |
| | | x.MaterielCode, |
| | | x.MaterielName, |
| | | x.BatchNo, |
| | | x.SupplyCode, |
| | | x.WarehouseCode |
| | | }).Count() > 1; |
| | | } |
| | | else if (includeBatchNo && !includeSupplyCode) |
| | | { |
| | | isMatMixed = stockInfo.Details.GroupBy(x => new |
| | | { |
| | | x.MaterielCode, |
| | | x.MaterielName, |
| | | x.BatchNo, |
| | | x.WarehouseCode |
| | | }).Count() > 1; |
| | | } |
| | | else if (!includeBatchNo && includeSupplyCode) |
| | | { |
| | | isMatMixed = stockInfo.Details.GroupBy(x => new |
| | | { |
| | | x.MaterielCode, |
| | | x.MaterielName, |
| | | x.SupplyCode, |
| | | x.WarehouseCode |
| | | }).Count() > 1; |
| | | } |
| | | else |
| | | { |
| | | isMatMixed = stockInfo.Details.GroupBy(x => new |
| | | { |
| | | x.MaterielCode, |
| | | x.MaterielName, |
| | | x.WarehouseCode |
| | | }).Count() > 1; |
| | | } |
| | | } |
| | | else |
| | | { |
| | | isMatMixed = stockInfo.Details.GroupBy(x => new |
| | | { |
| | | x.MaterielCode, |
| | | x.MaterielName, |
| | | x.WarehouseCode |
| | | }).Count() > 1; |
| | | |
| | | Dt_OutStockLockInfo outStockLockInfo = _outboundLockInfoRepository.QueryFirst(x=>x.PalletCode == palletCode); |
| | | |
| | | if (outStockLockInfo != null) |
| | | { |
| | | return WebResponseContent.Instance.Error($"该æçå¨è¯¥åæ®ä¸æ æ£éè®°å½ï¼è¯·åå¾{outStockLockInfo.OrderNo}åæ®ä¸è¿è¡æ£è´§æä½"); |
| | | } |
| | | } |
| | | } |
| | | |
| | | return WebResponseContent.Instance.OK(data: new { outStockLockInfos, stockInfo, isMatMixed, orderOver }); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | |
| | | try |
| | | { |
| | | // æå»ºæ¥è¯¢æ¡ä»¶ |
| | | var query = _stockChangeService.Repository.Db |
| | | var query = _stockChangeRepository.Db |
| | | .Queryable<Dt_StockQuantityChangeRecord>() |
| | | .LeftJoin<Dt_OutboundOrder>((r, o) => r.OrderNo == o.OrderNo) |
| | | .Where((r, o) => r.ChangeType == (int)StockChangeTypeEnum.Outbound) |