| | |
| | | if (stockInfo != null) |
| | | { |
| | | Dt_LocationInfo locationInfo = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == stockInfo.LocationCode); |
| | | if (locationInfo == null) |
| | | { |
| | | throw new Exception("未找到出库库位"); |
| | | } |
| | | Dt_Task dt_Task = BaseDal.QueryFirst(x => x.SourceAddress == locationInfo.LocationCode || x.TargetAddress == locationInfo.LocationCode); |
| | | if (dt_Task != null) |
| | | { |
| | |
| | | Dt_StockInfoDetail stockInfoDetail = _stockService.StockInfoDetailService.Repository.QueryFirst(x => x.StockId == stockInfo.Id); |
| | | if (roadwayInfo != null) |
| | | { |
| | | Dt_Task task = new() |
| | | if (roadwayInfo.RoadwayNo.Contains("CP")) |
| | | { |
| | | PalletType = stockInfo.PalletType, |
| | | OrderNo = stockInfoDetail.OrderNo, |
| | | CurrentAddress = locationInfo.LocationCode, |
| | | Grade = 0, |
| | | Creater = "WMS", |
| | | PalletCode = stockInfo.PalletCode, |
| | | NextAddress = roadwayInfo.OutSCStationCode, |
| | | Roadway = locationInfo.RoadwayNo, |
| | | SourceAddress = locationInfo.LocationCode, |
| | | TargetAddress = "", |
| | | TaskStatus = OutTaskStatusEnum.OutNew.ObjToInt(), |
| | | TaskType = taskType.ObjToInt(), |
| | | Depth = locationInfo.Depth, |
| | | WarehouseId = stockInfo.WarehouseId, |
| | | TaskNum = BaseDal.GetTaskNum(nameof(SequenceEnum.SeqTaskNum)) |
| | | }; |
| | | if (taskType != TaskTypeEnum.OutEmpty) |
| | | { |
| | | task.MaterielCode = stockInfo.Details?.Where(x => x.StockId == stockInfo.Id).FirstOrDefault()?.MaterielCode; |
| | | task.Quantity = (float)stockInfo.Details?.Where(x => x.StockId == stockInfo.Id).Sum(x => x.StockQuantity); |
| | | Dt_Task task = new() |
| | | { |
| | | PalletType = stockInfo.PalletType, |
| | | OrderNo = stockInfoDetail.OrderNo, |
| | | CurrentAddress = locationInfo.LocationCode, |
| | | Grade = 0, |
| | | Creater = "WMS", |
| | | PalletCode = stockInfo.PalletCode, |
| | | NextAddress = roadwayInfo.OutSCStationCode, |
| | | Roadway = locationInfo.RoadwayNo, |
| | | SourceAddress = locationInfo.LocationCode, |
| | | TargetAddress = "", |
| | | TaskStatus = OutTaskStatusEnum.OutNew.ObjToInt(), |
| | | TaskType = taskType.ObjToInt(), |
| | | Depth = locationInfo.Depth, |
| | | WarehouseId = stockInfo.WarehouseId, |
| | | TaskNum = BaseDal.GetTaskNum(nameof(SequenceEnum.SeqTaskNum)), |
| | | MaterielCode = stockInfoDetail.MaterielCode, |
| | | Quantity = (float)stockInfoDetail.StockQuantity |
| | | }; |
| | | tasks.Add(task); |
| | | } |
| | | tasks.Add(task); |
| | | else |
| | | { |
| | | Dt_Task task = new() |
| | | { |
| | | PalletType = stockInfo.PalletType, |
| | | OrderNo = stockInfoDetail.OrderNo, |
| | | CurrentAddress = locationInfo.LocationCode, |
| | | Grade = 0, |
| | | Creater = "WMS", |
| | | PalletCode = stockInfo.PalletCode, |
| | | NextAddress = roadwayInfo.OutSCStationCode, |
| | | Roadway = locationInfo.RoadwayNo, |
| | | SourceAddress = locationInfo.LocationCode, |
| | | TargetAddress = "", |
| | | TaskStatus = OutTaskStatusEnum.OutNew.ObjToInt(), |
| | | TaskType = taskType.ObjToInt(), |
| | | Depth = locationInfo.Depth, |
| | | WarehouseId = stockInfo.WarehouseId, |
| | | TaskNum = BaseDal.GetTaskNum(nameof(SequenceEnum.SeqTaskNum)) |
| | | }; |
| | | if (taskType != TaskTypeEnum.OutEmpty) |
| | | { |
| | | task.MaterielCode = stockInfo.Details?.Where(x => x.StockId == stockInfo.Id).FirstOrDefault()?.MaterielCode; |
| | | task.Quantity = (float)stockInfo.Details?.Where(x => x.StockId == stockInfo.Id).Sum(x => x.StockQuantity); |
| | | } |
| | | tasks.Add(task); |
| | | } |
| | | |
| | | } |
| | | } |
| | | |
| | |
| | | (int)OrderTypeEnum.反拣出库单 => TaskTypeEnum.ReverseOut, |
| | | _ => new TaskTypeEnum() |
| | | }; |
| | | tasks = GetTasks(result.Item1,typeEnum); |
| | | tasks = GetTasks(result.Item1, typeEnum); |
| | | tasks.ForEach(x => |
| | | { |
| | | x.OrderNo = outboundOrder.OrderNo; |
| | |
| | | { |
| | | return WebResponseContent.Instance.Error($"未找到该仓库信息"); |
| | | } |
| | | Dt_OutboundOrder oldOuboundOrder = BaseDal.Db.Queryable<Dt_OutboundOrder>().Where(x => x.UpperOrderNo == orderAddDTO.No).Includes(x => x.Details).First(); |
| | | Dt_Production production = new Dt_Production(); |
| | | if (oldOuboundOrder != null) |
| | | if (warehouse.WarehouseCode.Contains("CP")) |
| | | { |
| | | if (oldOuboundOrder.OutWareHouse != warehouse.WarehouseCode) |
| | | Dt_NewOutboundOrder newOutboundOrder = BaseDal.Db.Queryable<Dt_NewOutboundOrder>().Where(x => x.UpperOrderNo == orderAddDTO.No).Includes(x => x.Details).First(); |
| | | Dt_Production production1 = new Dt_Production(); |
| | | if (newOutboundOrder != null) |
| | | { |
| | | return WebResponseContent.Instance.Error($"仓库不一致"); |
| | | if (newOutboundOrder.OutWareHouse != warehouse.WarehouseCode) |
| | | { |
| | | return WebResponseContent.Instance.Error($"仓库不一致"); |
| | | } |
| | | else |
| | | { |
| | | OutboundOrderAddDTO orderAddDTO1 = new OutboundOrderAddDTO(); |
| | | orderAddDTO1.Details = orderAddDTO.DetailList.DicToIEnumerable<OutboundOrderDetailAddDTO>(); |
| | | var details = orderAddDTO1.Details.FirstOrDefault(); |
| | | Dt_NewOutboundOrderDetail outboundOrderDetail = new Dt_NewOutboundOrderDetail() |
| | | { |
| | | LPNNo = details.LPNNo, |
| | | BatchNo = details.BatchNo, |
| | | MaterielCode = details.MaterielCode, |
| | | MaterielName = details.MaterielName, |
| | | MaterieSpec = details.MaterieSpec, |
| | | OrderDetailStatus = OrderDetailStatusEnum.New.ObjToInt(), |
| | | OrderQuantity = details.OrderQuantity, |
| | | LinId = details.LinId, |
| | | OrderId = newOutboundOrder.Id, |
| | | Creater = "WMS", |
| | | CreateDate = DateTime.Now, |
| | | Remark = details.Remark, |
| | | SupplierBatch = details.SupplierBatch, |
| | | OrinalLocation = details.OrinalLocation, |
| | | }; |
| | | _newOutboundOrderDetailRepository.AddData(outboundOrderDetail); |
| | | foreach (var item in orderAddDTO1.Details) |
| | | { |
| | | if (string.IsNullOrWhiteSpace(item.Remark)) |
| | | { |
| | | continue; |
| | | } |
| | | string[] remarkEntries = item.Remark.Split( |
| | | new[] { ';' }, |
| | | StringSplitOptions.RemoveEmptyEntries |
| | | ); |
| | | |
| | | foreach (var entry in remarkEntries) |
| | | { |
| | | string[] keyValuePairs = entry.Split( |
| | | new[] { ',' }, |
| | | StringSplitOptions.RemoveEmptyEntries |
| | | ); |
| | | |
| | | foreach (var kvp in keyValuePairs) |
| | | { |
| | | int colonIndex = kvp.IndexOf(':'); |
| | | if (colonIndex <= 0 || colonIndex >= kvp.Length - 1) |
| | | { |
| | | continue; |
| | | } |
| | | |
| | | string key = kvp.Substring(0, colonIndex).Trim(); |
| | | string value = kvp.Substring(colonIndex + 1).Trim(); |
| | | |
| | | switch (key) |
| | | { |
| | | case "制造单号": |
| | | production1.ProductionNo = value; |
| | | break; |
| | | case "制造部件": |
| | | production1.ManufacturingCo = value; |
| | | break; |
| | | case "出库数量": |
| | | if (decimal.TryParse(value, out decimal outQuantity)) |
| | | { |
| | | production1.OutQuantity = outQuantity; |
| | | } |
| | | else |
| | | { |
| | | Console.WriteLine($"出库数量格式错误:{value}(应为数值,如14.0000)"); |
| | | } |
| | | break; |
| | | default: |
| | | Console.WriteLine($"未知键名:{key}(对应值:{value},跳过该键值对)"); |
| | | break; |
| | | } |
| | | |
| | | } |
| | | production1.Creater = "WMS"; |
| | | production1.OrderId = outboundOrderDetail.Id; |
| | | _productionRepository.AddData(production1); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | else |
| | | { |
| | | OutboundOrderAddDTO orderAddDTO1 = new OutboundOrderAddDTO(); |
| | | orderAddDTO1.OrderNo = orderAddDTO.No; |
| | | orderAddDTO1.UpperOrderNo = orderAddDTO.No; |
| | | orderAddDTO1.OutWareHouse = orderAddDTO.OutWareHouse; |
| | | orderAddDTO1.TransactionCode = orderAddDTO.TransactionCode ?? "工单发料"; |
| | | orderAddDTO1.InoutType = orderAddDTO.OrderType ?? InoutTypeEnum.WorkFeed.ToString(); |
| | | orderAddDTO1.OrderType = orderAddDTO.InoutType; |
| | | orderAddDTO1.System = orderAddDTO.System; |
| | | IEnumerable<int> inOrderTypes = Enum.GetValues<OrderTypeEmun>().Cast<int>(); |
| | | orderAddDTO1.Details = orderAddDTO.DetailList.DicToIEnumerable<OutboundOrderDetailAddDTO>(); |
| | | var details = orderAddDTO1.Details.FirstOrDefault(); |
| | | Dt_OutboundOrderDetail outboundOrderDetail = new Dt_OutboundOrderDetail() |
| | | #region 验证数据 |
| | | (bool, string, object?) result = CheckOutboundOrderAddData(orderAddDTO1); |
| | | if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); |
| | | #endregion |
| | | Dt_NewOutboundOrder inboundOrder = _mapper.Map<Dt_NewOutboundOrder>(orderAddDTO1); |
| | | inboundOrder.OrderStatus = InboundStatusEnum.未开始.ObjToInt(); |
| | | inboundOrder.Creater = "WMS"; |
| | | inboundOrder.CreateDate = DateTime.Now; |
| | | inboundOrder.CreateType = CreateType.UpperSystemPush.ObjToInt(); |
| | | _unitOfWorkManage.BeginTran(); |
| | | bool a = BaseDal.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); |
| | | |
| | | foreach (var item in orderAddDTO1.Details) |
| | | { |
| | | LPNNo = details.LPNNo, |
| | | BatchNo = details.BatchNo, |
| | | MaterielCode = details.MaterielCode, |
| | | MaterielName = details.MaterielName, |
| | | MaterieSpec = details.MaterieSpec, |
| | | OrderDetailStatus = OrderDetailStatusEnum.New.ObjToInt(), |
| | | OrderQuantity = details.OrderQuantity, |
| | | LinId = details.LinId, |
| | | OrderId = oldOuboundOrder.Id, |
| | | Creater = "WMS", |
| | | CreateDate = DateTime.Now, |
| | | Remark = details.Remark, |
| | | SupplierBatch = details.SupplierBatch |
| | | }; |
| | | _outboundOrderDetailRepository.AddData(outboundOrderDetail); |
| | | if (string.IsNullOrWhiteSpace(item.Remark)) |
| | | { |
| | | continue; |
| | | } |
| | | string[] remarkEntries = item.Remark.Split( |
| | | new[] { ';' }, |
| | | StringSplitOptions.RemoveEmptyEntries |
| | | ); |
| | | |
| | | foreach (var entry in remarkEntries) |
| | | { |
| | | string[] keyValuePairs = entry.Split( |
| | | new[] { ',' }, |
| | | StringSplitOptions.RemoveEmptyEntries |
| | | ); |
| | | |
| | | foreach (var kvp in keyValuePairs) |
| | | { |
| | | int colonIndex = kvp.IndexOf(':'); |
| | | if (colonIndex <= 0 || colonIndex >= kvp.Length - 1) |
| | | { |
| | | continue; |
| | | } |
| | | |
| | | string key = kvp.Substring(0, colonIndex).Trim(); |
| | | string value = kvp.Substring(colonIndex + 1).Trim(); |
| | | |
| | | switch (key) |
| | | { |
| | | case "制造单号": |
| | | production1.ProductionNo = value; |
| | | break; |
| | | case "制造部件": |
| | | production1.ManufacturingCo = value; |
| | | break; |
| | | case "出库数量": |
| | | if (decimal.TryParse(value, out decimal outQuantity)) |
| | | { |
| | | production1.OutQuantity = outQuantity; |
| | | } |
| | | else |
| | | { |
| | | Console.WriteLine($"出库数量格式错误:{value}(应为数值,如14.0000)"); |
| | | } |
| | | break; |
| | | default: |
| | | Console.WriteLine($"未知键名:{key}(对应值:{value},跳过该键值对)"); |
| | | break; |
| | | } |
| | | |
| | | } |
| | | production1.Creater = "WMS"; |
| | | production1.OrderId = inboundOrder.Details.FirstOrDefault().Id; |
| | | _productionRepository.AddData(production1); |
| | | } |
| | | } |
| | | _unitOfWorkManage.CommitTran(); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | Dt_OutboundOrder oldOuboundOrder = BaseDal.Db.Queryable<Dt_OutboundOrder>().Where(x => x.UpperOrderNo == orderAddDTO.No).Includes(x => x.Details).First(); |
| | | Dt_Production production = new Dt_Production(); |
| | | if (oldOuboundOrder != null) |
| | | { |
| | | if (oldOuboundOrder.OutWareHouse != warehouse.WarehouseCode) |
| | | { |
| | | return WebResponseContent.Instance.Error($"仓库不一致"); |
| | | } |
| | | else |
| | | { |
| | | OutboundOrderAddDTO orderAddDTO1 = new OutboundOrderAddDTO(); |
| | | orderAddDTO1.Details = orderAddDTO.DetailList.DicToIEnumerable<OutboundOrderDetailAddDTO>(); |
| | | var details = orderAddDTO1.Details.FirstOrDefault(); |
| | | Dt_OutboundOrderDetail outboundOrderDetail = new Dt_OutboundOrderDetail() |
| | | { |
| | | LPNNo = details.LPNNo, |
| | | BatchNo = details.BatchNo, |
| | | MaterielCode = details.MaterielCode, |
| | | MaterielName = details.MaterielName, |
| | | MaterieSpec = details.MaterieSpec, |
| | | OrderDetailStatus = OrderDetailStatusEnum.New.ObjToInt(), |
| | | OrderQuantity = details.OrderQuantity, |
| | | LinId = details.LinId, |
| | | OrderId = oldOuboundOrder.Id, |
| | | Creater = "WMS", |
| | | CreateDate = DateTime.Now, |
| | | Remark = details.Remark, |
| | | SupplierBatch = details.SupplierBatch |
| | | }; |
| | | _outboundOrderDetailRepository.AddData(outboundOrderDetail); |
| | | foreach (var item in orderAddDTO1.Details) |
| | | { |
| | | if (string.IsNullOrWhiteSpace(item.Remark)) |
| | | { |
| | | continue; |
| | | } |
| | | string[] remarkEntries = item.Remark.Split( |
| | | new[] { ';' }, |
| | | StringSplitOptions.RemoveEmptyEntries |
| | | ); |
| | | |
| | | foreach (var entry in remarkEntries) |
| | | { |
| | | string[] keyValuePairs = entry.Split( |
| | | new[] { ',' }, |
| | | StringSplitOptions.RemoveEmptyEntries |
| | | ); |
| | | |
| | | foreach (var kvp in keyValuePairs) |
| | | { |
| | | int colonIndex = kvp.IndexOf(':'); |
| | | if (colonIndex <= 0 || colonIndex >= kvp.Length - 1) |
| | | { |
| | | continue; |
| | | } |
| | | |
| | | string key = kvp.Substring(0, colonIndex).Trim(); |
| | | string value = kvp.Substring(colonIndex + 1).Trim(); |
| | | |
| | | switch (key) |
| | | { |
| | | case "制造单号": |
| | | production.ProductionNo = value; |
| | | break; |
| | | case "制造部件": |
| | | production.ManufacturingCo = value; |
| | | break; |
| | | case "出库数量": |
| | | if (decimal.TryParse(value, out decimal outQuantity)) |
| | | { |
| | | production.OutQuantity = outQuantity; |
| | | } |
| | | else |
| | | { |
| | | Console.WriteLine($"出库数量格式错误:{value}(应为数值,如14.0000)"); |
| | | } |
| | | break; |
| | | default: |
| | | Console.WriteLine($"未知键名:{key}(对应值:{value},跳过该键值对)"); |
| | | break; |
| | | } |
| | | |
| | | } |
| | | production.Creater = "WMS"; |
| | | production.OrderId = outboundOrderDetail.Id; |
| | | _productionRepository.AddData(production); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | else |
| | | { |
| | | OutboundOrderAddDTO orderAddDTO1 = new OutboundOrderAddDTO(); |
| | | orderAddDTO1.OrderNo = orderAddDTO.No; |
| | | orderAddDTO1.UpperOrderNo = orderAddDTO.No; |
| | | orderAddDTO1.OutWareHouse = orderAddDTO.OutWareHouse; |
| | | orderAddDTO1.TransactionCode = orderAddDTO.TransactionCode ?? "工单发料"; |
| | | orderAddDTO1.InoutType = orderAddDTO.OrderType ?? InoutTypeEnum.WorkFeed.ToString(); |
| | | orderAddDTO1.OrderType = orderAddDTO.InoutType; |
| | | orderAddDTO1.System = orderAddDTO.System; |
| | | IEnumerable<int> inOrderTypes = Enum.GetValues<OrderTypeEmun>().Cast<int>(); |
| | | orderAddDTO1.Details = orderAddDTO.DetailList.DicToIEnumerable<OutboundOrderDetailAddDTO>(); |
| | | #region 验证数据 |
| | | (bool, string, object?) result = CheckOutboundOrderAddData(orderAddDTO1); |
| | | if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); |
| | | #endregion |
| | | Dt_OutboundOrder inboundOrder = _mapper.Map<Dt_OutboundOrder>(orderAddDTO1); |
| | | inboundOrder.OrderStatus = InboundStatusEnum.未开始.ObjToInt(); |
| | | inboundOrder.Creater = "WMS"; |
| | | inboundOrder.CreateDate = DateTime.Now; |
| | | inboundOrder.CreateType = CreateType.UpperSystemPush.ObjToInt(); |
| | | _unitOfWorkManage.BeginTran(); |
| | | bool a = BaseDal.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); |
| | | |
| | | foreach (var item in orderAddDTO1.Details) |
| | | { |
| | | if (string.IsNullOrWhiteSpace(item.Remark)) |
| | |
| | | |
| | | } |
| | | production.Creater = "WMS"; |
| | | production.OrderId = outboundOrderDetail.Id; |
| | | production.OrderId = inboundOrder.Details.FirstOrDefault().Id; |
| | | _productionRepository.AddData(production); |
| | | } |
| | | } |
| | | _unitOfWorkManage.CommitTran(); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | OutboundOrderAddDTO orderAddDTO1 = new OutboundOrderAddDTO(); |
| | | orderAddDTO1.OrderNo = orderAddDTO.No; |
| | | orderAddDTO1.UpperOrderNo = orderAddDTO.No; |
| | | orderAddDTO1.OutWareHouse = orderAddDTO.OutWareHouse; |
| | | orderAddDTO1.TransactionCode = orderAddDTO.TransactionCode?? "工单发料"; |
| | | orderAddDTO1.InoutType = orderAddDTO.OrderType ?? InoutTypeEnum.WorkFeed.ToString(); |
| | | orderAddDTO1.OrderType = orderAddDTO.InoutType; |
| | | orderAddDTO1.System = orderAddDTO.System; |
| | | IEnumerable<int> inOrderTypes = Enum.GetValues<OrderTypeEmun>().Cast<int>(); |
| | | orderAddDTO1.Details = orderAddDTO.DetailList.DicToIEnumerable<OutboundOrderDetailAddDTO>(); |
| | | #region 验证数据 |
| | | (bool, string, object?) result = CheckOutboundOrderAddData(orderAddDTO1); |
| | | if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); |
| | | #endregion |
| | | Dt_OutboundOrder inboundOrder = _mapper.Map<Dt_OutboundOrder>(orderAddDTO1); |
| | | inboundOrder.OrderStatus = InboundStatusEnum.未开始.ObjToInt(); |
| | | inboundOrder.Creater = "WMS"; |
| | | inboundOrder.CreateDate = DateTime.Now; |
| | | inboundOrder.CreateType = CreateType.UpperSystemPush.ObjToInt(); |
| | | _unitOfWorkManage.BeginTran(); |
| | | bool a = BaseDal.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); |
| | | |
| | | foreach (var item in orderAddDTO1.Details) |
| | | { |
| | | if (string.IsNullOrWhiteSpace(item.Remark)) |
| | | { |
| | | continue; |
| | | } |
| | | string[] remarkEntries = item.Remark.Split( |
| | | new[] { ';' }, |
| | | StringSplitOptions.RemoveEmptyEntries |
| | | ); |
| | | |
| | | foreach (var entry in remarkEntries) |
| | | { |
| | | string[] keyValuePairs = entry.Split( |
| | | new[] { ',' }, |
| | | StringSplitOptions.RemoveEmptyEntries |
| | | ); |
| | | |
| | | foreach (var kvp in keyValuePairs) |
| | | { |
| | | int colonIndex = kvp.IndexOf(':'); |
| | | if (colonIndex <= 0 || colonIndex >= kvp.Length - 1) |
| | | { |
| | | continue; |
| | | } |
| | | |
| | | string key = kvp.Substring(0, colonIndex).Trim(); |
| | | string value = kvp.Substring(colonIndex + 1).Trim(); |
| | | |
| | | switch (key) |
| | | { |
| | | case "制造单号": |
| | | production.ProductionNo = value; |
| | | break; |
| | | case "制造部件": |
| | | production.ManufacturingCo = value; |
| | | break; |
| | | case "出库数量": |
| | | if (decimal.TryParse(value, out decimal outQuantity)) |
| | | { |
| | | production.OutQuantity = outQuantity; |
| | | } |
| | | else |
| | | { |
| | | Console.WriteLine($"出库数量格式错误:{value}(应为数值,如14.0000)"); |
| | | } |
| | | break; |
| | | default: |
| | | Console.WriteLine($"未知键名:{key}(对应值:{value},跳过该键值对)"); |
| | | break; |
| | | } |
| | | |
| | | } |
| | | production.Creater = "WMS"; |
| | | production.OrderId = inboundOrder.Details.FirstOrDefault().Id; |
| | | _productionRepository.AddData(production); |
| | | } |
| | | } |
| | | _unitOfWorkManage.CommitTran(); |
| | | } |
| | | |
| | | |
| | | content = WebResponseContent.Instance.OK(); |
| | |
| | | inboundOrder.OrderType = OutOrderTypeEnum.OutInventory.ObjToInt(); |
| | | inboundOrder.Creater = "WMS"; |
| | | inboundOrder.CreateDate = DateTime.Now; |
| | | |
| | | Dt_OutboundOrder oldOutboundOrder = BaseDal.Db.Queryable<Dt_OutboundOrder>().Where(x => x.OrderNo == orderAddDTO1.OrderNo).Includes(x => x.Details).First(); |
| | | Dt_OutboundOrderDetail outboundOrderDetail = _outboundService.OutboundOrderDetailService.Repository.QueryFirst(x => x.OrderId == oldOutboundOrder.Id); |
| | | List<StockSelectViewDTO> stockSelectViews = new List<StockSelectViewDTO>(); |
| | | StockSelectViewDTO stockSelectViewDTO = new() |
| | | foreach (var item in inboundOrder.Details) |
| | | { |
| | | OrderNo = orderAddDTO1.OrderNo, |
| | | MaterielCode = outboundOrderDetail.MaterielCode, |
| | | MaterielName = outboundOrderDetail.MaterielName, |
| | | UseableQuantity = outboundOrderDetail.OrderQuantity, |
| | | BatchNo = outboundOrderDetail.BatchNo, |
| | | LinId = outboundOrderDetail.LinId, |
| | | }; |
| | | |
| | | StockSelectViewDTO stockSelectViewDTO = new() |
| | | { |
| | | OrderNo = orderAddDTO1.OrderNo, |
| | | MaterielCode = item.MaterielCode, |
| | | MaterielName = item.MaterielName, |
| | | UseableQuantity = item.OrderQuantity, |
| | | BatchNo = item.BatchNo, |
| | | LinId = item.LinId, |
| | | }; |
| | | stockSelectViews.Add(stockSelectViewDTO); |
| | | } |
| | | _unitOfWorkManage.BeginTran(); |
| | | bool a = BaseDal.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); |
| | | stockSelectViews.Add(stockSelectViewDTO); |
| | | GenerateOutboundTasks(oldOutboundOrder.Id, stockSelectViews); |
| | | |
| | | GenerateOutboundTasks(inboundOrder.Id, stockSelectViews); |
| | | _unitOfWorkManage.CommitTran(); |
| | | content = WebResponseContent.Instance.OK(); |
| | | } |
| | |
| | | } |
| | | _unitOfWorkManage.CommitTran(); |
| | | //将任务推送到WCS |
| | | PushTasksToWCS(tasks); |
| | | |
| | | if (tasks.FirstOrDefault().Roadway.Contains("SC01_BC")) |
| | | { |
| | | PushTasksToWCS(tasks); |
| | | } |
| | | else |
| | | { |
| | | PushTasksWCS(tasks); |
| | | } |
| | | return WebResponseContent.Instance.OK(); |
| | | } |
| | | catch (Exception ex) |
| | |
| | | { |
| | | return content.Error($"未找到{item.PalletCode}库存明细数据"); |
| | | } |
| | | if (item.System.Contains("SMOM")) |
| | | { |
| | | return content.Error($"SMOM系统库存数据不可手动盘点,托盘号{item.PalletCode}"); |
| | | } |
| | | Dt_LocationInfo? locationInfo = locationInfos.FirstOrDefault(x => x.LocationCode == item.LocationCode); |
| | | if (locationInfo != null && (locationInfo.EnableStatus == EnableStatusEnum.OnlyOut.ObjToInt() || locationInfo.EnableStatus == EnableStatusEnum.Normal.ObjToInt()) && locationInfo.LocationStatus == LocationStatusEnum.InStock.ObjToInt() && item.StockStatus == StockStatusEmun.入库完成.ObjToInt()) |
| | | { |