using AutoMapper; using Microsoft.IdentityModel.Tokens; using SqlSugar; using System; using System.Collections.Generic; using System.Linq; using System.Reflection.Metadata; using System.Text; using System.Threading.Tasks; using WIDESEA_Core; using WIDESEA_Core.BaseRepository; using WIDESEA_Core.BaseServices; using WIDESEA_Core.Enums; using WIDESEA_Core.Helper; using WIDESEA_Core.Utilities; using WIDESEA_DTO; using WIDESEA_DTO.Inbound; using WIDESEA_IBasicService; using WIDESEA_IInboundRepository; using WIDESEA_IInboundService; using WIDESEA_IStockService; using WIDESEA_ITaskInfoRepository; using WIDESEA_Model.Models; namespace WIDESEA_InboundService { public partial class InboundOrderService : ServiceBase, IInboundOrderService { private readonly IMapper _mapper; private readonly IUnitOfWorkManage _unitOfWorkManage; private readonly ITaskRepository _taskRepository; private IBasicService _basicService; private IStockService _stockService; private IInboundOrderDetailService _inboundOrderDetailService; public IInboundOrderRepository Repository => BaseDal; public InboundOrderService(IInboundOrderRepository BaseDal, IMapper mapper, IUnitOfWorkManage unitOfWorkManage, ITaskRepository taskRepository, IBasicService basicService, IStockService stockService, IInboundOrderDetailService inboundOrderDetailService) : base(BaseDal) { _mapper = mapper; _unitOfWorkManage = unitOfWorkManage; _taskRepository = taskRepository; _basicService = basicService; _stockService = stockService; _inboundOrderDetailService = inboundOrderDetailService; } /// /// 添加单据 /// /// /// public override WebResponseContent AddData(SaveModel saveModel) { InboundOrderAddDTO orderAddDTO = saveModel.MainData.DicToModel(); orderAddDTO.Details = saveModel.DetailData.DicToIEnumerable(); return AddInboundOrder(orderAddDTO); } /// /// 添加单据 /// /// 单据添加DTO /// public WebResponseContent AddInboundOrder(InboundOrderAddDTO orderAddDTO) { WebResponseContent content = new(); try { #region 验证数据 (bool, string, object?) result = CheckInboundOrderAddData(orderAddDTO); if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); #endregion List LocationCodes = orderAddDTO.Details .Where(x => !string.IsNullOrEmpty(x.LocationCode)) .Select(x => x.LocationCode).ToList(); Dt_InboundOrder inboundOrder = _mapper.Map(orderAddDTO); //inboundOrder.OrderNo = DateTime.Now.ToString("yyMMddHHmmss"); inboundOrder.OrderStatus = InboundStatusEnum.未开始.ObjToInt(); Db.Ado.BeginTran(); if (LocationCodes.Any()) { content = _basicService.LocationInfoService.UpdateStatus(LocationCodes, LocationStatusEnum.PalletLock.ObjToInt()); if (!content.Status) throw new Exception(content.Message); } BaseDal.Db.InsertNav(inboundOrder).Include(x => x.Details).ExecuteCommand(); Db.Ado.CommitTran(); content = WebResponseContent.Instance.OK(); } catch (Exception ex) { Db.Ado.RollbackTran(); content = WebResponseContent.Instance.Error(ex.Message); } finally { } return content; } public override WebResponseContent UpdateData(SaveModel saveModel) { WebResponseContent content = new WebResponseContent(); try { if (saveModel.DetailData == null || saveModel.DetailData.Count == 0) throw new Exception($"入库单明细不能为空"); List inboundOrderDetail = saveModel.DetailData.DicToIEnumerable(); //if (inboundOrderDetail.FirstOrDefault(x => x.OrderDetailStatus > 0) != null) throw new Exception($"订单已开始组盘入库"); //var inboundOrderDetails = _inboundOrderDetailService.Db.Queryable().Where(x => saveModel.DelKeys.Contains(x.Id)).ToList(); //if (inboundOrderDetails.Count > 0) //{ // if (inboundOrderDetails.FirstOrDefault(x => x.OrderDetailStatus != OrderDetailStatusEnum.New.ObjToInt()) != null) // throw new Exception($"存在已组盘工单,已先解盘"); //} content = base.UpdateData(saveModel); } catch (Exception ex) { content.Error(ex.Message); } return content; } public override WebResponseContent DeleteData(object[] keys) { WebResponseContent content = new WebResponseContent(); try { //var inboundOrders = BaseDal.QueryData(x => keys.Contains(x.Id)); var inboundOrders = BaseDal.Db.Queryable().Includes(x => x.Details).Where(x => keys.Contains(x.Id)).ToList(); if (inboundOrders.Count < 1) throw new Exception("未找到入库单"); List orderDetails = new List(); foreach (var item in inboundOrders) { if (item.Details.Where(x => x.ReceiptQuantity != x.OverInQuantity).Any()) throw new Exception("存在未入库完成托盘"); orderDetails.AddRange(item.Details); item.Details = null; } BaseDal.DeleteAndMoveIntoHty(inboundOrders, OperateType.人工删除); content.Status = _inboundOrderDetailService.Repository.DeleteAndMoveIntoHty(orderDetails, OperateType.人工删除); } 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); } if (BaseDal.QueryFirst(x => x.OrderNo == inboundOrderAddDTO.orderNo && !string.IsNullOrEmpty(x.OrderNo)) != null) { return (false, "单据已存在", inboundOrderAddDTO); } return (true, "成功", inboundOrderAddDTO); } } }