using AutoMapper; using MailKit.Search; using SqlSugar; using System; using System.Collections.Generic; using System.Data; using System.Globalization; using System.Linq; using System.Reflection.Metadata; using System.Text; using System.Threading.Tasks; using WIDESEA_BasicRepository; using WIDESEA_Common; using WIDESEA_Common.OrderEnum; using WIDESEA_Core; using WIDESEA_Core.BaseRepository; using WIDESEA_Core.BaseServices; using WIDESEA_Core.CodeConfigEnum; using WIDESEA_Core.Enums; using WIDESEA_Core.Helper; using WIDESEA_Core.Utilities; using WIDESEA_DTO; using WIDESEA_DTO.Basic; using WIDESEA_DTO.Inbound; using WIDESEA_DTO.Outbound; using WIDESEA_IBasicRepository; using WIDESEA_IBasicService; using WIDESEA_IInboundRepository; using WIDESEA_IInboundService; using WIDESEA_InboundRepository; using WIDESEA_IStockRepository; using WIDESEA_IStockService; using WIDESEA_ITaskInfoRepository; using WIDESEA_Model.Models; using static WIDESEA_Common.HouseInventoryIn; namespace WIDESEA_InboundService { public partial class InboundOrderService : ServiceBase, IInboundOrderService { private readonly IMapper _mapper; private readonly IUnitOfWorkManage _unitOfWorkManage; private readonly ITaskRepository _taskRepository; private readonly IInboundRepository _inboundRepository; private readonly IBasicRepository _basicRepository; private IBasicService _basicService; private IStockService _stockService; private IInboundOrderDetailService _inboundOrderDetailService; private IInboundOrder_HtyService _inboundOrderHtyService; private IInboundOrderDetail_HtyService _inboundOrderDetail_HtyService; private IWarehouseService _warehouseService; private readonly IStockRepository _stockRepository; private IPalletTypeInfoRepository _palletTypeInfoRepository; public IInboundOrderRepository Repository => BaseDal; public InboundOrderService(IInboundOrderRepository BaseDal, IMapper mapper, IBasicService basicService, IBasicRepository basicRepository, IInboundRepository inboundRepository, IUnitOfWorkManage unitOfWorkManage, ITaskRepository taskRepository, IStockService stockService, IInboundOrderDetailService inboundOrderDetailService, IInboundOrder_HtyService inboundOrderHtyService, IInboundOrderDetail_HtyService inboundOrderDetail_HtyService, IWarehouseService warehouseService, IStockRepository stockRepository,IPalletTypeInfoRepository palletTypeInfoRepository) : base(BaseDal) { _mapper = mapper; _unitOfWorkManage = unitOfWorkManage; _taskRepository = taskRepository; _stockService = stockService; _inboundRepository = inboundRepository; _basicRepository = basicRepository; _inboundOrderDetailService = inboundOrderDetailService; _inboundOrderHtyService = inboundOrderHtyService; _inboundOrderDetail_HtyService = inboundOrderDetail_HtyService; _basicService = basicService; _warehouseService = warehouseService; _stockRepository = stockRepository; _palletTypeInfoRepository = palletTypeInfoRepository; } /// /// 组盘 /// /// /// public WebResponseContent MaterielGroup(SaveModel saveModel) { WebResponseContent content = new WebResponseContent(); try { var orderNo = saveModel.MainData["orderNo"].ToString(); var palletCode = saveModel.MainData["palletCode"].ToString(); var warehouseId = saveModel.MainData["warehouseId"].ObjToInt(); var Initiallife = saveModel.MainData["initiallife"].ObjToInt(); var serNums = saveModel.DelKeys.Select(x => x.ToString()).ToList(); Dt_Warehouse warehouse = _warehouseService.Repository.QueryFirst(x => x.WarehouseId == warehouseId); if (warehouse == null) { return WebResponseContent.Instance.Error($"未找到该仓库信息"); } Dt_InboundOrder inboundOrder = BaseDal.Db.Queryable().Where(x => x.OrderNo == orderNo && x.WarehouseId == warehouse.WarehouseId).Includes(x => x.Details).First(); if (inboundOrder == null) { return WebResponseContent.Instance.Error($"未找到入库单信息"); } if (inboundOrder.Details == null || inboundOrder.Details.Count <= 0) { return WebResponseContent.Instance.Error($"未找到入库单明细信息"); } List models = CodeAnalysisHelper.CodeAnalysis(AnalysisCodeEnum.MatSerNumAnalysis, serNums); //验证判断时间格式 WebResponseContent IsValidContent = IsValidMCDates(models); if (!IsValidContent.Status) { return content.Error(IsValidContent.Message); } string materielCode = models.FirstOrDefault()?.MaterielCode ?? ""; Dt_MaterielInfo materielInfo = _basicRepository.MaterielInfoRepository.QueryFirst(x => x.MaterielCode == materielCode); if (materielInfo == null) { return WebResponseContent.Instance.Error($"未找到该物料的信息"); } List inboundOrderDetails = inboundOrder.Details.Where(x => x.MaterielCode == materielCode && x.BatchNo == (models.FirstOrDefault()?.LotNo ?? "")).ToList(); if (inboundOrderDetails == null || inboundOrderDetails.Count <= 0) { return WebResponseContent.Instance.Error($"未在入库单明细中找到该物料信息"); } var inboundOrderDet = inboundOrderDetails.FirstOrDefault(); //Dt_StockInfo? stockInfo = _stockService.StockInfoService.GetStockByPalletCode(palletCode); decimal beforeQuantity = 0; Dt_StockInfo stockInfo = _stockRepository.StockInfoRepository.Db.Queryable().Where(x => x.PalletCode == palletCode).Includes(x => x.Details).First(); if (stockInfo == null) { stockInfo = new Dt_StockInfo() { BatchNo = inboundOrderDet.BatchNo, PalletCode = palletCode, PalletType =1,//GetPalletType(warehouse, palletCode) IsFull = true, StockStatus = (int)StockStatusEmun.组盘暂存, Creater = "WMS", CreateDate = DateTime.Now, MaterialType = (int)InventoryMaterialType.成品, Materialweight = 0, Wlstatus = (int)InventoryMaterialStatus.合格, Mgeneratetime = DateTime.Now, WarehouseId = warehouse.WarehouseId, Details = new List() }; } else { if (stockInfo.StockStatus != StockStatusEmun.组盘暂存.ObjToInt()) { return WebResponseContent.Instance.Error($"托盘号重复"); } beforeQuantity = stockInfo.Details.Sum(x => x.StockQuantity); } if (warehouse.WarehouseCode == WarehouseEnum.SC01_BC.ToString()) { stockInfo.Remark = Initiallife.ToString(); string batchNo = models.FirstOrDefault()?.LotNo ?? ""; //Dt_StockInfoDetail existDetail = _stockRepository.StockInfoDetailRepository.QueryFirst(x => x.BatchNo == batchNo); //if (existDetail != null) //{ // return WebResponseContent.Instance.Error($"{batchNo}测试架已存在"); //} if (models.Count >= 2) { return WebResponseContent.Instance.Error($"组盘明细不唯一"); } if (palletCode.Substring(0, 1) == "6") { stockInfo.PalletType = PalletTypeEnum.MediumPallet.ObjToInt(); } else { stockInfo.PalletType = PalletTypeEnum.LargestPallet.ObjToInt(); } } else if (warehouse.WarehouseCode == WarehouseEnum.SC01_BC.ToString()) { if (models.Count >= 2) { return WebResponseContent.Instance.Error($"组盘明细不唯一"); } } List stockInfoDetails = new List(); foreach (var model in models) { Dt_InboundOrderDetail? notGroupDetail = inboundOrderDetails.Where(x => x.OrderDetailStatus <= OrderDetailStatusEnum.Inbounding.ObjToInt() && x.MaterielCode == model.MaterielCode && x.BatchNo == model.LotNo && x.OrderQuantity > x.ReceiptQuantity).FirstOrDefault(); if (notGroupDetail == null) { return WebResponseContent.Instance.Error($"该物料在该入库单中已全部组盘完成"); } Dt_StockInfoDetail stockInfoDetail = new Dt_StockInfoDetail() { MaterielCode = inboundOrderDet.MaterielCode, MaterielName = inboundOrderDet.MaterielName, OrderNo = inboundOrder.OrderNo, BatchNo = inboundOrderDet.BatchNo, LinId = inboundOrderDet.LinId, StockQuantity = model.Quantity, Status = (int)StockStatusEmun.组盘暂存, Creater = "WMS", CreateDate = DateTime.Now, Id = inboundOrderDet.LinId.ObjToInt(), }; if (stockInfo.Id > 0) { stockInfoDetail.StockId = stockInfo.Id; } stockInfo.Details.Add(stockInfoDetail); stockInfoDetails.Add(stockInfoDetail); decimal decimalReceiptQuantity = Convert.ToDecimal(notGroupDetail.ReceiptQuantity); decimal decimalModelQuantity = Convert.ToDecimal(model.Quantity); decimal decimalOrderQuantity = Convert.ToDecimal(notGroupDetail.OrderQuantity); decimalReceiptQuantity += decimalModelQuantity; // 检查是否超出订单数量 if (decimalReceiptQuantity > decimalOrderQuantity) { return WebResponseContent.Instance.Error($"组盘数量溢出{decimalReceiptQuantity - decimalOrderQuantity}"); } // 转回float类型存储,但比较和计算都使用decimal完成 notGroupDetail.ReceiptQuantity = Convert.ToDecimal(decimalReceiptQuantity); if (notGroupDetail.OrderDetailStatus == OrderDetailStatusEnum.New.ObjToInt()) { notGroupDetail.OrderDetailStatus = OrderDetailStatusEnum.GroupAndInbound.ObjToInt(); } } decimal totalQuantity = stockInfo.Details.Sum(x => x.StockQuantity); inboundOrder.OrderStatus = InOrderStatusEnum.入库中.ObjToInt(); _unitOfWorkManage.BeginTran(); if (stockInfo.Id == 0) { _stockRepository.StockInfoRepository.Db.InsertNav(stockInfo).Include(x => x.Details).ExecuteCommand(); } else { _stockRepository.StockInfoRepository.Db.UpdateNav(stockInfo).Include(x => x.Details, new UpdateNavOptions() { OneToManyInsertOrUpdate = true }).ExecuteCommand(); } _inboundRepository.InboundOrderDetailRepository.UpdateData(inboundOrderDetails); _inboundRepository.InboundOrderRepository.UpdateData(inboundOrder); _unitOfWorkManage.CommitTran(); content.OK(); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } finally { } return content; } public int GetPalletType(Dt_Warehouse warehouse, string palletCode) { if (warehouse.WarehouseCode == WarehouseEnum.SC01_BC.ObjToString()) { Dt_PalletTypeInfo palletTypeInfo = _palletTypeInfoRepository.QueryFirst(x => x.CodeStartStr == palletCode.Substring(0, 1)); if (palletTypeInfo == null) { throw new Exception($"托盘号错误"); } return palletTypeInfo.PalletType; } //else if (warehouse.WarehouseCode == WarehouseEnum.HA152.ObjToString()) //{ // Dt_PalletTypeInfo palletTypeInfo = _palletTypeInfoRepository.QueryFirst(x => x.CodeStartStr == palletCode.Substring(0, 2)); // if (palletTypeInfo == null) // { // throw new Exception($"托盘号错误"); // } // return palletTypeInfo.PalletType; //} //else if (warehouse.WarehouseCode == WarehouseEnum.HA57.ObjToString()) //{ // Dt_PalletTypeInfo palletTypeInfo = _palletTypeInfoRepository.QueryFirst(x => x.CodeStartStr == palletCode.Substring(0, 3)); // if (palletTypeInfo == null) // { // throw new Exception($"托盘号错误"); // } // return palletTypeInfo.PalletType; //} //else if (warehouse.WarehouseCode == WarehouseEnum.HA58.ObjToString()) //{ // Dt_PalletTypeInfo palletTypeInfo = _palletTypeInfoRepository.QueryFirst(x => x.CodeStartStr == palletCode.Substring(0, 2)); // if (palletTypeInfo == null) // { // throw new Exception($"托盘号错误"); // } // return palletTypeInfo.PalletType; //} return -1; } /// /// 判断正确时间格式 /// public WebResponseContent IsValidMCDates(List analysisModels) { string[] effDates = analysisModels.Select(x => x.EffectiveDate).Distinct().ToArray(); string[] ProDates = analysisModels.Select(x => x.ProductionDate).Distinct().ToArray(); foreach (string effDate in effDates) { string format = "yyyy-MM-dd"; // 目标格式 DateTime parsedDate; // 解析并验证格式 bool isValid = DateTime.TryParseExact( effDate, format, CultureInfo.InvariantCulture, DateTimeStyles.None, out parsedDate ); if (!isValid) { return WebResponseContent.Instance.Error("格式无效或日期不合法"); } } foreach (string ProDate in ProDates) { string format = "yyyy-MM-dd"; // 目标格式 DateTime parsedDate; // 解析并验证格式 bool isValid = DateTime.TryParseExact( ProDate, format, CultureInfo.InvariantCulture, DateTimeStyles.None, out parsedDate ); if (!isValid) { return WebResponseContent.Instance.Error("格式无效或日期不合法"); } } return WebResponseContent.Instance.OK(); } /// /// 入库单据下发 /// /// /// public WebResponseContent AddInboundOrders(HouseInbound model) { WebResponseContent content = new WebResponseContent(); try { foreach (var item in model.DetailList) { //获取物料信息 Dt_MaterielInfo materielInfo = _basicRepository.MaterielInfoRepository.QueryFirst(x => x.MaterielCode == item.MaterielCode); if (materielInfo == null) { return content.Error($"物料{item.MaterielCode}不存在!"); } Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x => x.WarehouseCode == model.InWarehouse); if (warehouse == null) { return content.Error($"未找到仓库信息"); } Dt_InboundOrder inboundOrderOld = BaseDal.Db.Queryable().Where(x => x.UpperOrderNo == model.AsnNo).Includes(x => x.Details).First(); if (inboundOrderOld != null) { if (inboundOrderOld.OrderStatus != OrderDetailStatusEnum.New.ObjToInt()) { return content.Error($"{model.AsnNo}单据已开始!"); } Dt_InboundOrderDetail? inboundOrderDetailOld = inboundOrderOld.Details?.FirstOrDefault(x => x.LinId == item.LinId && x.MaterielCode == item.MaterielCode); if (inboundOrderDetailOld != null) { inboundOrderDetailOld.OrderQuantity += item.OrderQuantity; _inboundRepository.InboundOrderDetailRepository.UpdateData(inboundOrderDetailOld); } else { Dt_InboundOrderDetail orderDetail = new Dt_InboundOrderDetail() { OrderId = inboundOrderOld.Id, MaterielCode = item.MaterielCode, BatchNo = "", OrderQuantity = item.OrderQuantity, ReceiptQuantity = 0, OverInQuantity = 0, OrderDetailStatus = OrderDetailStatusEnum.New.ObjToInt(), LinId = item.LinId, MaterielName = materielInfo.MaterielName, MaterieSpec = materielInfo.MaterieSpec }; _inboundRepository.InboundOrderDetailRepository.AddData(orderDetail); } } else { Dt_InboundOrderDetail orderDetail = new Dt_InboundOrderDetail() { MaterielCode = item.MaterielCode, BatchNo = item.BatchNo, OrderQuantity = item.OrderQuantity, ReceiptQuantity = 0, OverInQuantity = 0, OrderDetailStatus = OrderDetailStatusEnum.New.ObjToInt(), LinId = item.LinId, LPNNo = item.LPN_No, MaterielName = item.MaterielName, MaterieSpec = item.MaterieSpec, Creater = "上游WMS" }; Dt_InboundOrder inboundOrder = new Dt_InboundOrder() { OrderNo = model.AsnNo, UpperOrderNo = model.AsnNo, WarehouseId = warehouse.WarehouseId, //SupplierId = "", OrderStatus = InboundStatusEnum.未开始.ObjToInt(), CreateType = CreateType.UpperSystemPush.ObjToInt(), Remark = "", TransactionCode = model.TransactionCode, InoutType = model.OrderType, OrderType = model.InoutType.ObjToInt(), Creater = "上游WMS", Details = new List { orderDetail } }; //switch (model.OrderType)//单据类型 //{ // case 1: // inboundOrder.OrderType = InOrderTypeEnum.Allocat.ObjToInt(); // break; // case 3: // inboundOrder.OrderType = InOrderTypeEnum.CustomerRecovery.ObjToInt(); // break; // case 6: // inboundOrder.OrderType = InOrderTypeEnum.SaleReturn.ObjToInt(); // break; // default: // break; //}; Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); } } content = WebResponseContent.Instance.OK(); //InboundOrderAddDTO orderAddDTO1 = new InboundOrderAddDTO(); //orderAddDTO1.OrderNo = orderAddDTO.AsnNo; //orderAddDTO1.UpperOrderNo = orderAddDTO.AsnNo; //orderAddDTO1.OutWareHouse = orderAddDTO.InWarehouse; //orderAddDTO1.TransactionCode = orderAddDTO.TransactionCode; //orderAddDTO1.InoutType = orderAddDTO.OrderType; //orderAddDTO1.OrderType = orderAddDTO.InoutType.ObjToInt(); //orderAddDTO1.Details = orderAddDTO.DetailList.DicToIEnumerable(); //#region 验证数据 //(bool, string, object?) result = CheckInboundOrderAddData(orderAddDTO1); //if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); //#endregion //Dt_InboundOrder inboundOrder = _mapper.Map(orderAddDTO1); //inboundOrder.OrderStatus = InboundStatusEnum.未开始.ObjToInt(); //inboundOrder.Creater = "WMS"; //inboundOrder.CreateDate = DateTime.Now; //bool a = BaseDal.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } finally { } return content; } /// /// 盘点入库 /// /// public WebResponseContent InventoryIn(string name) { WebResponseContent content = new(); try { //Dt_StockInfoDetail stockInfoDetail = _stockService.StockInfoDetailService.Repository.QueryFirst(x => x.OrderNo == name); ////Dt_OutboundOrderDetail outboundOrderDetail= //HouseInventoryIn houseInventoryIn1 = new HouseInventoryIn(); //houseInventoryIn1.No = name; //InventoryIn inventoryIn = new InventoryIn(); //inventoryIn.LinId = stockInfoDetail.LinId; ////inventoryIn.LPN_No =stockInfoDetail. //inventoryIn.MaterielCode = stockInfoDetail.MaterielCode; //inventoryIn.OrderQuantity = stockInfoDetail.StockQuantity; //inventoryIn.BatchNo = stockInfoDetail.BatchNo; //inventoryIn.FinishQty = stockInfoDetail.FinishQty; //inventoryIn.WarehouseCode = // inventoryIn.StorageAreaCode = // inventoryIn.StorageLocationCode = // #region 验证数据 //(bool, string, object ?) result = CheckInboundOrderAddData(orderAddDTO1); // if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); // #endregion // Dt_OutboundOrder inboundOrder = _mapper.Map(orderAddDTO1); // inboundOrder.OrderStatus = InboundStatusEnum.未开始.ObjToInt(); // inboundOrder.OrderType = OutOrderTypeEnum.OutInventory.ObjToInt(); // inboundOrder.Creater = "WMS"; // inboundOrder.CreateDate = DateTime.Now; // bool a = BaseDal.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); content = WebResponseContent.Instance.OK(); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } finally { } return content; } /// /// 入库单据取消 /// /// /// public WebResponseContent CancelIn(HouseCancelIn houseCancelIn) { WebResponseContent content = new(); try { InboundOrderAddDTO orderAddDTO1 = new InboundOrderAddDTO(); orderAddDTO1.OrderNo = houseCancelIn.AsnNo; orderAddDTO1.Details = houseCancelIn.DetailList.DicToIEnumerable(); Dt_InboundOrder oldOutboundOrder = BaseDal.Db.Queryable().Where(x => x.UpperOrderNo == orderAddDTO1.OrderNo).Includes(x => x.Details).First(); Dt_InboundOrderDetail dt_InboundOrderDetail = BaseDal.Db.Queryable().Where(x => x.OrderId == oldOutboundOrder.Id).First(); if (oldOutboundOrder.OrderStatus != InboundStatusEnum.未开始.ObjToInt()) { return WebResponseContent.Instance.Error("该入库单任务已开始执行,不可取消"); } oldOutboundOrder.OrderStatus = InboundStatusEnum.取消.ObjToInt(); BaseDal.UpdateData(oldOutboundOrder); Dt_InboundOrder_Hty inboundOrder_Hty = new Dt_InboundOrder_Hty { OrderStatus = oldOutboundOrder.OrderStatus, CreateType = oldOutboundOrder.CreateType, //SourceId = oldOutboundOrder.SourceId, UpperOrderNo = oldOutboundOrder.UpperOrderNo, //OrderNo = oldOutboundOrder.OrderNo, //OutWareHouse = oldOutboundOrder.OutWareHouse, TransactionCode = oldOutboundOrder.TransactionCode, InoutType = oldOutboundOrder.InoutType, OrderType = oldOutboundOrder.OrderType, Creater = "WMS", CreateDate = DateTime.Now, }; _inboundOrderHtyService.AddData(inboundOrder_Hty); foreach (var item in oldOutboundOrder.Details) { Dt_InboundOrderDetail_Hty dt_InboundOrderDetail_Hty = new Dt_InboundOrderDetail_Hty { OrderId = dt_InboundOrderDetail.OrderId, MaterielCode = dt_InboundOrderDetail.MaterielCode, MaterielName = dt_InboundOrderDetail.MaterielName, BatchNo = dt_InboundOrderDetail.BatchNo, OrderQuantity = dt_InboundOrderDetail.OrderQuantity, ReceiptQuantity = dt_InboundOrderDetail.ReceiptQuantity, OverInQuantity = dt_InboundOrderDetail.OverInQuantity, OrderDetailStatus = dt_InboundOrderDetail.OrderDetailStatus, Creater = "WMS", CreateDate = DateTime.Now, }; _inboundOrderDetail_HtyService.AddData(dt_InboundOrderDetail_Hty); _inboundOrderDetailService.DeleteData(item); } BaseDal.DeleteData(oldOutboundOrder); content = WebResponseContent.Instance.OK(); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } finally { } return content; } public WebResponseContent GetInboundOrders(SaveModel saveModel) { WebResponseContent content = new WebResponseContent(); try { int pageNo = saveModel.MainData["pageNo"].ObjToInt(); string? orderNo = saveModel.MainData["orderNo"].ToString(); int warehouseId = saveModel.MainData["warehouseId"].ObjToInt(); List dt_ReceiveOrders = new List(); if (string.IsNullOrEmpty(orderNo)) { dt_ReceiveOrders = Db.Queryable().Where(x => x.OrderStatus < InboundStatusEnum.入库完成.ObjToInt() && x.WarehouseId == warehouseId).Includes(x => x.Details).OrderByDescending(x => x.CreateDate).ToPageList(pageNo, 10); } else { dt_ReceiveOrders = Db.Queryable().Where(x => (x.OrderNo.Contains(orderNo)) && x.OrderStatus < InboundStatusEnum.入库完成.ObjToInt() && x.WarehouseId == warehouseId).Includes(x => x.Details).OrderByDescending(x => x.CreateDate).ToPageList(pageNo, 10); } content.OK(data: dt_ReceiveOrders); } catch (Exception ex) { content.Error(ex.Message); } return content; } /// /// 验证单据添加DTO对象 /// /// 单据添加DTO /// //private (bool, string, object?) CheckInboundOrderAddData(InboundOrderAddDTO inboundOrderAddDTO) //{ // (bool, string, object?) result1 = ModelValidate.ValidateModelData(inboundOrderAddDTO); // if (!result1.Item1) return result1; // (bool, string, object?) result2 = ModelValidate.ValidateModelData(inboundOrderAddDTO.Details); // if (!result2.Item1) return result2; // IEnumerable inOrderTypes = Enum.GetValues().Cast(); // if (!inOrderTypes.Contains(inboundOrderAddDTO.OrderType)) // { // return (false, "未找到该单据类型", inboundOrderAddDTO); // } // List materielCodes = inboundOrderAddDTO.Details.Select(x => x.MaterielCode).ToList(); // if (!_basicService.MaterielInfoService.ExsitMateriels(materielCodes)) // { // return (false, "有物料信息未录入,请录入物料信息", inboundOrderAddDTO); // } // Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x => x.WarehouseCode == inboundOrderAddDTO.OutWareHouse); // if (warehouse == null) // { // return (false, "未找到仓库信息", inboundOrderAddDTO); // } // if (BaseDal.QueryFirst(x => x.OrderName == inboundOrderAddDTO.orderName && !string.IsNullOrEmpty(x.OrderName)) != null) // { // return (false, "单据已存在", inboundOrderAddDTO); // } // return (true, "成功", inboundOrderAddDTO); //} } }