|  |  |  | 
|---|
|  |  |  | using System.Diagnostics.Metrics; | 
|---|
|  |  |  | using System.Reflection.Metadata; | 
|---|
|  |  |  | using WIDESEA_DTO.Task; | 
|---|
|  |  |  | using WIDESEA_DTO.Stock; | 
|---|
|  |  |  | using SqlSugar; | 
|---|
|  |  |  | using OfficeOpenXml.FormulaParsing.Excel.Functions.RefAndLookup; | 
|---|
|  |  |  | using OfficeOpenXml.FormulaParsing.Excel.Functions.Math; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | namespace WIDESEA_TaskInfoService | 
|---|
|  |  |  | { | 
|---|
|  |  |  | public partial class TaskService | 
|---|
|  |  |  | { | 
|---|
|  |  |  | static object lock_out = new object(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | static object solderMask_out = new object(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// æµè¯æ¶åºä» | 
|---|
|  |  |  | 
|---|
|  |  |  | PalletType = stockInfo.PalletType, | 
|---|
|  |  |  | WarehouseId = stockInfo.WarehouseId, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | string MaterielCode = stockInfo.Details.Where(x => x.StockId == stockInfo.Id).FirstOrDefault()?.MaterielCode; | 
|---|
|  |  |  | float Quantity = (float)stockInfo.Details.Where(x => x.StockId == stockInfo.Id).Sum(x => x.StockQuantity); | 
|---|
|  |  |  | if (MaterielCode != null && Quantity != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | taskOut.MaterielCode = MaterielCode; | 
|---|
|  |  |  | taskOut.Quantity = Quantity; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | stockInfo.StockStatus = (int)StockStatusEmun.åºåºéå®; | 
|---|
|  |  |  | LocationStatusEnum locationStatus = (LocationStatusEnum)locationInfo.LocationStatus; | 
|---|
|  |  |  | locationInfo.LocationStatus = (int)LocationStatusEnum.Lock; | 
|---|
|  |  |  | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | //å°ä»»å¡æ¨éå°WCS | 
|---|
|  |  |  | PushTasksToWCS(new List<Dt_Task>() { taskOut }, "AGV_CSJ"); | 
|---|
|  |  |  | responseContent.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | responseContent.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return responseContent; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | public MesResponseContent SolderMaskOutNotice(SolderMaskOutNotice model) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | lock (solderMask_out) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | MesResponseContent responseContent = new MesResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x => x.WarehouseCode == WarehouseEnum.HA154.ToString()); | 
|---|
|  |  |  | //è·ååºåè®°å½ | 
|---|
|  |  |  | List<Dt_StockInfo> stockInfos = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Where(x => | 
|---|
|  |  |  | x.WarehouseId == warehouse.WarehouseId && | 
|---|
|  |  |  | x.StockStatus == (int)StockStatusEmun.å
¥åºå®æ).Includes(x => x.Details).ToList(); | 
|---|
|  |  |  | Dt_StockInfo? stockInfo = stockInfos.FirstOrDefault(x => x.Details.Any(x => x.BatchNo == model.LotNo)); | 
|---|
|  |  |  | if (stockInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return responseContent.Error($"é²çåº:æ {model.LotNo}å¯ç¨åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_Task exsit2 = Repository.QueryFirst(x => x.PalletCode == stockInfo.PalletCode); | 
|---|
|  |  |  | if (exsit2 != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return responseContent.Error($"é²çä»»å¡{stockInfo.PalletCode}å·²åå¨"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_LocationInfo locationInfo = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == stockInfo.LocationCode && | 
|---|
|  |  |  | x.WarehouseId == stockInfo.WarehouseId && | 
|---|
|  |  |  | x.LocationStatus == (int)LocationStatusEnum.InStock && | 
|---|
|  |  |  | (x.EnableStatus == (int)EnableStatusEnum.Normal || x.EnableStatus == (int)EnableStatusEnum.OnlyOut)); | 
|---|
|  |  |  | if (locationInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return responseContent.Error($"é²çè´§ä½:{stockInfo.LocationCode}åºåºæ¡ä»¶ä¸æ»¡è¶³"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //çæé²çåºåºä»»å¡ éå®åºå æ´æ¹è´§ä½ç¶æ | 
|---|
|  |  |  | Dt_Task taskOut = new() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CurrentAddress = stockInfo.LocationCode, | 
|---|
|  |  |  | Grade = 0, | 
|---|
|  |  |  | PalletCode = stockInfo.PalletCode, | 
|---|
|  |  |  | NextAddress = "", | 
|---|
|  |  |  | Roadway = locationInfo.RoadwayNo, | 
|---|
|  |  |  | SourceAddress = stockInfo.LocationCode, | 
|---|
|  |  |  | TargetAddress = model.TargetAddressCode, | 
|---|
|  |  |  | TaskStatus = (int)TaskStatusEnum.New, | 
|---|
|  |  |  | TaskType = stockInfo.PalletType<2 ? (int)TaskTypeEnum.MaskOutNoticeSmall : (int)TaskTypeEnum.MaskOutNoticeLarge, | 
|---|
|  |  |  | TaskNum = BaseDal.GetTaskNum(nameof(SequenceEnum.SeqTaskNum)), | 
|---|
|  |  |  | PalletType = stockInfo.PalletType, | 
|---|
|  |  |  | WarehouseId = stockInfo.WarehouseId, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | string MaterielCode = stockInfo.Details.Where(x => x.StockId == stockInfo.Id).FirstOrDefault()?.MaterielCode; | 
|---|
|  |  |  | float Quantity = (float)stockInfo.Details.Where(x => x.StockId == stockInfo.Id).Sum(x => x.StockQuantity); | 
|---|
|  |  |  | if (MaterielCode != null && Quantity != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | taskOut.MaterielCode = MaterielCode; | 
|---|
|  |  |  | taskOut.Quantity = Quantity; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | stockInfo.StockStatus = (int)StockStatusEmun.åºåºéå®; | 
|---|
|  |  |  | LocationStatusEnum locationStatus = (LocationStatusEnum)locationInfo.LocationStatus; | 
|---|
|  |  |  | locationInfo.LocationStatus = (int)LocationStatusEnum.Lock; | 
|---|
|  |  |  | //夿æ¯å¦æåºåºåä¿¡æ¯ | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  | //æ´æ°åºåç¶æ | 
|---|
|  |  |  | _stockRepository.StockInfoRepository.UpdateData(stockInfo); | 
|---|
|  |  |  | //æ´æ°è´§ä½ç¶æ | 
|---|
|  |  |  | _basicService.LocationInfoService.UpdateLocationStatus(locationInfo, stockInfo.PalletType, LocationStatusEnum.Lock, stockInfo.WarehouseId); | 
|---|
|  |  |  | //æ°å»ºä»»å¡ | 
|---|
|  |  |  | BaseDal.AddData(taskOut); | 
|---|
|  |  |  | //å å
¥è´§ä½åå¨è®°å½ | 
|---|
|  |  |  | _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, locationStatus, LocationStatusEnum.Lock, LocationChangeType.OutboundAssignLocation, stockInfo.Details.FirstOrDefault()?.OrderNo ?? "", taskOut.TaskNum); | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | //å°ä»»å¡æ¨éå°WCS | 
|---|
|  |  |  | PushTasksToWCS(new List<Dt_Task>() { taskOut }, "AGV_ZH"); | 
|---|
|  |  |  | responseContent.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | responseContent.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return responseContent; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public MesResponseContent SolderMaskOut(SolderMaskOut model) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | lock (solderMask_out) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | MesResponseContent responseContent = new MesResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x => x.WarehouseCode == WarehouseEnum.HA154.ToString()); | 
|---|
|  |  |  | //è·ååºåè®°å½ | 
|---|
|  |  |  | List<Dt_StockInfo> stockInfos = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Where(x => | 
|---|
|  |  |  | x.WarehouseId == warehouse.WarehouseId && | 
|---|
|  |  |  | x.StockStatus == (int)StockStatusEmun.å
¥åºå®æ).Includes(x => x.Details).ToList(); | 
|---|
|  |  |  | Dt_StockInfo? stockInfo = stockInfos.FirstOrDefault(x => x.Details.Any(x => x.BatchNo == model.LotNo)); | 
|---|
|  |  |  | if (stockInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return responseContent.Error($"é²çåº:æ {model.LotNo}å¯ç¨åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_Task exsit2 = Repository.QueryFirst(x => x.PalletCode == stockInfo.PalletCode); | 
|---|
|  |  |  | if (exsit2 != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return responseContent.Error($"é²çä»»å¡{stockInfo.PalletCode}å·²åå¨"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_LocationInfo locationInfo = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == stockInfo.LocationCode && | 
|---|
|  |  |  | x.WarehouseId == stockInfo.WarehouseId && | 
|---|
|  |  |  | x.LocationStatus == (int)LocationStatusEnum.InStock && | 
|---|
|  |  |  | (x.EnableStatus == (int)EnableStatusEnum.Normal || x.EnableStatus == (int)EnableStatusEnum.OnlyOut)); | 
|---|
|  |  |  | if (locationInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return responseContent.Error($"é²çè´§ä½:{stockInfo.LocationCode}åºåºæ¡ä»¶ä¸æ»¡è¶³"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //çæé²çåºåºä»»å¡ éå®åºå æ´æ¹è´§ä½ç¶æ | 
|---|
|  |  |  | Dt_Task taskOut = new() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CurrentAddress = stockInfo.LocationCode, | 
|---|
|  |  |  | Grade = 0, | 
|---|
|  |  |  | PalletCode = stockInfo.PalletCode, | 
|---|
|  |  |  | NextAddress = "", | 
|---|
|  |  |  | Roadway = locationInfo.RoadwayNo, | 
|---|
|  |  |  | SourceAddress = stockInfo.LocationCode, | 
|---|
|  |  |  | TargetAddress = model.TargetAddressCode, | 
|---|
|  |  |  | TaskStatus = (int)TaskStatusEnum.New, | 
|---|
|  |  |  | TaskType = stockInfo.PalletType < 2 ? (int)TaskTypeEnum.MaskOutSmall : (int)TaskTypeEnum.MaskOutLarge, | 
|---|
|  |  |  | TaskNum = BaseDal.GetTaskNum(nameof(SequenceEnum.SeqTaskNum)), | 
|---|
|  |  |  | PalletType = stockInfo.PalletType, | 
|---|
|  |  |  | WarehouseId = stockInfo.WarehouseId, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | string MaterielCode = stockInfo.Details.Where(x => x.StockId == stockInfo.Id).FirstOrDefault()?.MaterielCode; | 
|---|
|  |  |  | float Quantity = (float)stockInfo.Details.Where(x => x.StockId == stockInfo.Id).Sum(x => x.StockQuantity); | 
|---|
|  |  |  | if (MaterielCode != null && Quantity != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | taskOut.MaterielCode = MaterielCode; | 
|---|
|  |  |  | taskOut.Quantity = Quantity; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | stockInfo.StockStatus = (int)StockStatusEmun.åºåºéå®; | 
|---|
|  |  |  | LocationStatusEnum locationStatus = (LocationStatusEnum)locationInfo.LocationStatus; | 
|---|
|  |  |  | locationInfo.LocationStatus = (int)LocationStatusEnum.Lock; | 
|---|
|  |  |  | //夿æ¯å¦æåºåºåä¿¡æ¯ | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  | //æ´æ°åºåç¶æ | 
|---|
|  |  |  | _stockRepository.StockInfoRepository.UpdateData(stockInfo); | 
|---|
|  |  |  | //æ´æ°è´§ä½ç¶æ | 
|---|
|  |  |  | _basicService.LocationInfoService.UpdateLocationStatus(locationInfo, stockInfo.PalletType, LocationStatusEnum.Lock, stockInfo.WarehouseId); | 
|---|
|  |  |  | //æ°å»ºä»»å¡ | 
|---|
|  |  |  | BaseDal.AddData(taskOut); | 
|---|
|  |  |  | //å å
¥è´§ä½åå¨è®°å½ | 
|---|
|  |  |  | _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, locationStatus, LocationStatusEnum.Lock, LocationChangeType.OutboundAssignLocation, stockInfo.Details.FirstOrDefault()?.OrderNo ?? "", taskOut.TaskNum); | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | //å°ä»»å¡æ¨éå°WCS | 
|---|
|  |  |  | PushTasksToWCS(new List<Dt_Task>() { taskOut }, "AGV_ZH"); | 
|---|
|  |  |  | responseContent.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | 
|---|
|  |  |  | PalletType = stockInfo.PalletType, | 
|---|
|  |  |  | WarehouseId = stockInfo.WarehouseId, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | string MaterielCode = stockInfo.Details.Where(x => x.StockId == stockInfo.Id).FirstOrDefault()?.MaterielCode; | 
|---|
|  |  |  | float Quantity = (float)stockInfo.Details.Where(x => x.StockId == stockInfo.Id).Sum(x => x.StockQuantity); | 
|---|
|  |  |  | if (MaterielCode != null && Quantity != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | taskIn.MaterielCode = MaterielCode; | 
|---|
|  |  |  | taskIn.Quantity = Quantity; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //æ´æ¹åºåç¶æ | 
|---|
|  |  |  | stockInfo.StockStatus = StockStatusEmun.éåº.ObjToInt(); | 
|---|
|  |  |  | BaseDal.AddData(taskIn); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | 
|---|
|  |  |  | List<Dt_OutStockLockInfo>? outStockLockInfos = null; | 
|---|
|  |  |  | List<Dt_LocationInfo>? locationInfos = null; | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //åé
åºå | 
|---|
|  |  |  | (List<Dt_StockInfo>, Dt_MesOutboundOrder, List<Dt_OutStockLockInfo>, List<Dt_LocationInfo>) result = _outboundService.MesOutboundOrderService.AssignStockOutbound(mesOutboundOrder); | 
|---|
|  |  |  | if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //åå»ºä»»å¡ | 
|---|
|  |  |  | tasks = GetTasks(result.Item1, TaskTypeEnum.MesOutbound); | 
|---|
|  |  |  | result.Item2.OrderStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | result.Item3.ForEach(x => | 
|---|
|  |  |  | 
|---|
|  |  |  | tasks.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.TargetAddress = model.Line; | 
|---|
|  |  |  | x.OrderNo = mesOutboundOrder.TaskNo; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x => x.WarehouseId == palletTypeInfo.WarehouseId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //夿æ¯å¦æçåºåæ¯å¦å·²åå¨ | 
|---|
|  |  |  | Dt_StockInfo stockInfoOld = _stockRepository.StockInfoRepository.QueryFirst(x => x.PalletCode == model.CarrierCode); | 
|---|
|  |  |  | if (stockInfoOld != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error($"æçå·åºå{model.CarrierCode}å·²åå¨"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_StockInfo_Hty stockInfo_Hty = _stockRepository.StockInfo_HtyRepository.QueryData(x => x.PalletCode == model.CarrierCode).OrderByDescending(x => x.SourceId).First(); | 
|---|
|  |  |  | Dt_StockInfoDetail_Hty stockInfoDetail_Hty = _stockRepository.StockInfoDetail_HtyRepository.QueryFirst(x => x.StockId == stockInfo_Hty.SourceId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_StockInfoDetail stockInfoDetail = new Dt_StockInfoDetail() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | MaterielSpec = stockInfoDetail_Hty.MaterielSpec, | 
|---|
|  |  |  | BatchNo = stockInfoDetail_Hty?.BatchNo ?? "", | 
|---|
|  |  |  | EffectiveDate = model.ExpirationDate, | 
|---|
|  |  |  | MaterielCode = model.MaterialCode, | 
|---|
|  |  |  | InboundOrderRowNo = stockInfoDetail_Hty?.InboundOrderRowNo ?? 0, | 
|---|
|  |  |  | MaterielName = model.MaterialCode, | 
|---|
|  |  |  | MaterielName = stockInfoDetail_Hty.MaterielName, | 
|---|
|  |  |  | ProductionDate = model.ProductionDate, | 
|---|
|  |  |  | OrderNo = stockInfoDetail_Hty?.OrderNo ?? "", | 
|---|
|  |  |  | OutboundQuantity = 0, | 
|---|
|  |  |  | 
|---|
|  |  |  | MesResponseContent modelCount = new MesResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicService.WarehouseService.Repository.QueryFirst(x => x.WarehouseCode == WarehouseEnum.HA58.ToString()); | 
|---|
|  |  |  | if (warehouse == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("ä»åºä¿¡æ¯æªé
ç½®"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MesPPOutboundOrder mesPPOutboundOrder = BaseDal.Db.Queryable<Dt_MesPPOutboundOrder>().Where(x => x.TaskNo == model.TaskNo).Includes(x => x.Details).First(); | 
|---|
|  |  |  | if (mesPPOutboundOrder != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("å·²å卿¤ä»»å¡åå·"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<Dt_MesPPOutboundOrderDetail> mesPPOutboundOrderDetail = new List<Dt_MesPPOutboundOrderDetail>(); | 
|---|
|  |  |  | foreach (var item in model.Carriers) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x => x.WarehouseCode == item.Warehouse); | 
|---|
|  |  |  | if (warehouse == null) | 
|---|
|  |  |  | //mesPPOutboundOrderDetail.Add(_mapper.Map<Dt_MesPPOutboundOrderDetail>(item)); | 
|---|
|  |  |  | Dt_MesPPOutboundOrderDetail dt_MesPPOutboundOrderDetail = new Dt_MesPPOutboundOrderDetail | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("ä»åºä¿¡æ¯æªé
ç½®"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_StockInfo stockInfo = _stockRepository.StockInfoRepository.QueryFirst(x => x.PalletCode == item.CarrierCode || x.WarehouseId == warehouse.WarehouseId); | 
|---|
|  |  |  | if (stockInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("æªæ¾å°æ¤è½½å
·ç¼å·åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MesPPOutboundOrder mesPPOutboundOrder = BaseDal.Db.Queryable<Dt_MesPPOutboundOrder>().Where(x => x.TaskNo == model.TaskNo).Includes(x => x.Details).First(); | 
|---|
|  |  |  | if (mesPPOutboundOrder != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("å·²å卿¤ä»»å¡åå·"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MesPPOutboundOrderDetail mesPPOutboundOrderDetail = new Dt_MesPPOutboundOrderDetail() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Warehouse = item.Warehouse, | 
|---|
|  |  |  | CarrierCode = item.CarrierCode, | 
|---|
|  |  |  | Warehouse = item.Warehouse, | 
|---|
|  |  |  | OrderDetailStatus = OrderDetailStatusEnum.New.ObjToInt() | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_MesPPOutboundOrder mesOutboundOrder = new Dt_MesPPOutboundOrder() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CreateType = OrderCreateTypeEnum.UpperSystemPush.ObjToInt(), | 
|---|
|  |  |  | MaterialCode = model.MaterialCode, | 
|---|
|  |  |  | MaterialName = model.MaterialName, | 
|---|
|  |  |  | OrderQuantity = model.RequiredQuantity, | 
|---|
|  |  |  | TaskNo = model.TaskNo, | 
|---|
|  |  |  | Unit = model.Unit,//PPéè¦è½¬æ¢æç±³(鿱平æ¹(PNLæ°*é¢ç§¯)/宽度) | 
|---|
|  |  |  | Width = model.Width, | 
|---|
|  |  |  | TargetAddressCode = model.TargetAddressCode, | 
|---|
|  |  |  | OrderType = TaskTypeEnum.MesHandPickOutbound.ObjToInt(), | 
|---|
|  |  |  | OrderStatus = OutOrderStatusEnum.æªå¼å§.ObjToInt(), | 
|---|
|  |  |  | WarehouseId = warehouse.WarehouseId, | 
|---|
|  |  |  | Details = new List<Dt_MesPPOutboundOrderDetail> { mesPPOutboundOrderDetail } | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | //Db.InsertNav(mesOutboundOrder).Include(x=>x.Details).ExecuteCommand(); | 
|---|
|  |  |  | List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<Dt_StockInfo>? stockInfos = null; | 
|---|
|  |  |  | List<Dt_OutStockLockInfo>? outStockLockInfos = null; | 
|---|
|  |  |  | List<Dt_LocationInfo>? locationInfos = null; | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (List<Dt_StockInfo>, Dt_MesPPOutboundOrder, List<Dt_OutStockLockInfo>, List<Dt_LocationInfo>) result = _outboundService.MesPPOutboundOrderService.AssignStockOutbound(mesOutboundOrder); | 
|---|
|  |  |  | if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | tasks = GetTasks(result.Item1, TaskTypeEnum.MesOutbound); | 
|---|
|  |  |  | result.Item2.OrderStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | result.Item3.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.Status = OutLockStockStatusEnum.åºåºä¸.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | stockInfos = result.Item1; | 
|---|
|  |  |  | mesOutboundOrder = result.Item2; | 
|---|
|  |  |  | outStockLockInfos = result.Item3; | 
|---|
|  |  |  | locationInfos = result.Item4; | 
|---|
|  |  |  | mesPPOutboundOrderDetail.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("æ åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tasks.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.TargetAddress = model.TargetAddressCode; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int id = BaseDal.AddData(tasks); | 
|---|
|  |  |  | outStockLockInfos.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OrderNo = mesOutboundOrder.TaskNo; | 
|---|
|  |  |  | x.OrderDetailId = id; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | //_outboundService.MesPPOutboundOrderService.Repository.AddData(mesOutboundOrder); | 
|---|
|  |  |  | Db.InsertNav(mesOutboundOrder).Include(x => x.Details).ExecuteCommand(); | 
|---|
|  |  |  | if (stockInfos != null && stockInfos.Count > 0 && outStockLockInfos != null && outStockLockInfos.Count > 0 && locationInfos != null && locationInfos.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = _outboundService.MesOutboundOrderService.LockOutboundStockDataUpdate(stockInfos, outStockLockInfos, locationInfos, tasks: tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return MesResponseContent.Instance.Error(content.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | PushTasksToWCS(tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | mesPPOutboundOrderDetail.Add(dt_MesPPOutboundOrderDetail); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MesPPOutboundOrder mesOutboundOrder = new Dt_MesPPOutboundOrder() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CreateType = OrderCreateTypeEnum.UpperSystemPush.ObjToInt(), | 
|---|
|  |  |  | MaterialCode = model.MaterialCode, | 
|---|
|  |  |  | MaterialName = model.MaterialName, | 
|---|
|  |  |  | OrderQuantity = model.RequiredQuantity, | 
|---|
|  |  |  | TaskNo = model.TaskNo, | 
|---|
|  |  |  | Unit = model.Unit,//PPéè¦è½¬æ¢æç±³(鿱平æ¹(PNLæ°*é¢ç§¯)/宽度) | 
|---|
|  |  |  | Width = model.Width, | 
|---|
|  |  |  | TargetAddressCode = model.TargetAddressCode, | 
|---|
|  |  |  | OrderStatus = OutOrderStatusEnum.æªå¼å§.ObjToInt(), | 
|---|
|  |  |  | OrderType = OutOrderTypeEnum.Issue.ObjToInt(), | 
|---|
|  |  |  | WarehouseId = warehouse.WarehouseId, | 
|---|
|  |  |  | Details = mesPPOutboundOrderDetail | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | #region | 
|---|
|  |  |  | //Db.InsertNav(mesOutboundOrder).Include(x=>x.Details).ExecuteCommand(); | 
|---|
|  |  |  | //    List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    List<Dt_StockInfo>? stockInfos = null; | 
|---|
|  |  |  | //    List<Dt_OutStockLockInfo>? outStockLockInfos = null; | 
|---|
|  |  |  | //    List<Dt_LocationInfo>? locationInfos = null; | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //(List<Dt_StockInfo>, Dt_MesPPOutboundOrder, List<Dt_OutStockLockInfo>, List<Dt_LocationInfo>) result = _outboundService.MesPPOutboundOrderService.AssignStockOutbound(mesOutboundOrder); | 
|---|
|  |  |  | //        if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            tasks = GetTasks(result.Item1, TaskTypeEnum.MesOutbound); | 
|---|
|  |  |  | //            result.Item2.OrderStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | //            result.Item3.ForEach(x => | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                x.Status = OutLockStockStatusEnum.åºåºä¸.ObjToInt(); | 
|---|
|  |  |  | //            }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            stockInfos = result.Item1; | 
|---|
|  |  |  | //            mesOutboundOrder = result.Item2; | 
|---|
|  |  |  | //            outStockLockInfos = result.Item3; | 
|---|
|  |  |  | //            locationInfos = result.Item4; | 
|---|
|  |  |  | //            mesPPOutboundOrderDetail.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        else | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            throw new Exception("æ åºå"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    tasks.ForEach(x => | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        x.TargetAddress = model.TargetAddressCode; | 
|---|
|  |  |  | //    }); | 
|---|
|  |  |  | //    _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    int id = BaseDal.AddData(tasks); | 
|---|
|  |  |  | //    outStockLockInfos.ForEach(x => | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        x.OrderNo = mesOutboundOrder.TaskNo; | 
|---|
|  |  |  | //        x.OrderDetailId = id; | 
|---|
|  |  |  | //    }); | 
|---|
|  |  |  | //    //_outboundService.MesPPOutboundOrderService.Repository.AddData(mesOutboundOrder); | 
|---|
|  |  |  | //    Db.InsertNav(mesOutboundOrder).Include(x => x.Details).ExecuteCommand(); | 
|---|
|  |  |  | //    if (stockInfos != null && stockInfos.Count > 0 && outStockLockInfos != null && outStockLockInfos.Count > 0 && locationInfos != null && locationInfos.Count > 0) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        WebResponseContent content = _outboundService.MesOutboundOrderService.LockOutboundStockDataUpdate(stockInfos, outStockLockInfos, locationInfos, tasks: tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        if (!content.Status) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | //            return MesResponseContent.Instance.Error(content.Message); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | //    PushTasksToWCS(tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  | Db.InsertNav(mesOutboundOrder).Include(x => x.Details).ExecuteCommand(); | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | return MesResponseContent.Instance.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return MesResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicService.WarehouseService.Repository.QueryFirst(x => x.WarehouseCode == WarehouseEnum.HA58.ToString()); | 
|---|
|  |  |  | if (warehouse == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("ä»åºåºç¡ä¿¡æ¯æªé
ç½®"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MesPPCutOutboundOrder mesPPCutOutboundOrder = BaseDal.Db.Queryable<Dt_MesPPCutOutboundOrder>().Where(x => x.TaskNo == model.TaskNo).Includes(x => x.Details).First(); | 
|---|
|  |  |  | if (mesPPCutOutboundOrder != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("å·²å卿¤ä»»å¡åå·"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<Dt_MesPPCutOutboundOrderDetail> mesPPCutOutboundOrderDetail = new List<Dt_MesPPCutOutboundOrderDetail>(); | 
|---|
|  |  |  | foreach (var item in model.MaterialDetails) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicService.WarehouseService.Repository.QueryFirst(x => x.WarehouseCode == WarehouseEnum.HA58.ToString()); | 
|---|
|  |  |  | if (warehouse == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("ä»åºåºç¡ä¿¡æ¯æªé
ç½®"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MaterielInfo materielInfo = _basicRepository.MaterielInfoRepository.QueryFirst(x => x.MaterielCode == item.MaterialCode); | 
|---|
|  |  |  | if (materielInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error($"æªæ¾å°è¯¥ç©æä¿¡æ¯"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MesPPCutOutboundOrder mesPPCutOutboundOrder = BaseDal.Db.Queryable<Dt_MesPPCutOutboundOrder>().Where(x => x.TaskNo == model.TaskNo).Includes(x => x.Details).First(); | 
|---|
|  |  |  | if (mesPPCutOutboundOrder != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error("å·²å卿¤ä»»å¡åå·"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MesPPCutOutboundOrderDetail mesPPCutOutboundOrderDetail = new Dt_MesPPCutOutboundOrderDetail() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | MaterielCode = item.MaterialCode, | 
|---|
|  |  |  | MaterielName = item.MaterialName, | 
|---|
|  |  |  | OrderQuantity = item.RequiredQuantity, | 
|---|
|  |  |  | Unit = item.Unit, | 
|---|
|  |  |  | LayerCode = item.LayerCode, | 
|---|
|  |  |  | Sequence = item.Sequence, | 
|---|
|  |  |  | TargetAddressCode = item.TargetAddressCode, | 
|---|
|  |  |  | Width = item.Width, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | Dt_MesPPCutOutboundOrder mesPPOutboundOrder = new Dt_MesPPCutOutboundOrder() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CreateType = OrderCreateTypeEnum.UpperSystemPush.ObjToInt(), | 
|---|
|  |  |  | TaskNo = model.TaskNo, | 
|---|
|  |  |  | OrderType = TaskTypeEnum.MesOutbound.ObjToInt(), | 
|---|
|  |  |  | OrderStatus = OutOrderStatusEnum.æªå¼å§.ObjToInt(), | 
|---|
|  |  |  | WarehouseId = warehouse.WarehouseId, | 
|---|
|  |  |  | Details = new List<Dt_MesPPCutOutboundOrderDetail> { mesPPCutOutboundOrderDetail } | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<Dt_StockInfo>? stockInfos = null; | 
|---|
|  |  |  | List<Dt_OutStockLockInfo>? outStockLockInfos = null; | 
|---|
|  |  |  | List<Dt_LocationInfo>? locationInfos = null; | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (List<Dt_StockInfo>, Dt_MesPPCutOutboundOrderDetail, List<Dt_OutStockLockInfo>, List<Dt_LocationInfo>) result = _outboundService.MesPPOutboundOrderService.AssignStockOutbound(mesPPOutboundOrder, mesPPCutOutboundOrderDetail); | 
|---|
|  |  |  | if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | tasks = GetTasks(result.Item1, TaskTypeEnum.MesOutbound); | 
|---|
|  |  |  | result.Item2.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | result.Item3.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.Status = OutLockStockStatusEnum.åºåºä¸.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | stockInfos = result.Item1; | 
|---|
|  |  |  | mesPPCutOutboundOrderDetail = result.Item2; | 
|---|
|  |  |  | outStockLockInfos = result.Item3; | 
|---|
|  |  |  | locationInfos = result.Item4; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("æ åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tasks.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.TargetAddress = mesPPCutOutboundOrderDetail.TargetAddressCode; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int id = BaseDal.AddData(tasks); | 
|---|
|  |  |  | outStockLockInfos.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OrderNo = mesPPOutboundOrder.TaskNo; | 
|---|
|  |  |  | x.OrderDetailId = id; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | //_outboundService.MesPPOutboundOrderService.Repository.AddData(mesOutboundOrder); | 
|---|
|  |  |  | Db.InsertNav(mesPPOutboundOrder).Include(x => x.Details).ExecuteCommand(); | 
|---|
|  |  |  | if (stockInfos != null && stockInfos.Count > 0 && outStockLockInfos != null && outStockLockInfos.Count > 0 && locationInfos != null && locationInfos.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = _outboundService.MesOutboundOrderService.LockOutboundStockDataUpdate(stockInfos, outStockLockInfos, locationInfos, tasks: tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return MesResponseContent.Instance.Error(content.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | PushTasksToWCS(tasks, "AGV_PP"); | 
|---|
|  |  |  | mesPPCutOutboundOrderDetail.Add(_mapper.Map<Dt_MesPPCutOutboundOrderDetail>(item)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_MesPPCutOutboundOrder mesPPOutboundOrder = new Dt_MesPPCutOutboundOrder() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CreateType = OrderCreateTypeEnum.UpperSystemPush.ObjToInt(), | 
|---|
|  |  |  | TaskNo = model.TaskNo, | 
|---|
|  |  |  | OrderType = OutOrderTypeEnum.Issue.ObjToInt(), | 
|---|
|  |  |  | OrderStatus = OutOrderStatusEnum.æªå¼å§.ObjToInt(), | 
|---|
|  |  |  | WarehouseId = warehouse.WarehouseId, | 
|---|
|  |  |  | Details = mesPPCutOutboundOrderDetail, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  | Db.InsertNav(mesPPOutboundOrder).Include(x => x.Details).ExecuteCommand(); | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | #region | 
|---|
|  |  |  | //List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //List<Dt_StockInfo>? stockInfos = null; | 
|---|
|  |  |  | //List<Dt_OutStockLockInfo>? outStockLockInfos = null; | 
|---|
|  |  |  | //List<Dt_LocationInfo>? locationInfos = null; | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //(List<Dt_StockInfo>, Dt_MesPPCutOutboundOrderDetail, List<Dt_OutStockLockInfo>, List<Dt_LocationInfo>) result = _outboundService.MesPPOutboundOrderService.AssignStockOutbound(mesPPOutboundOrder, mesPPCutOutboundOrderDetail); | 
|---|
|  |  |  | //    if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        tasks = GetTasks(result.Item1, TaskTypeEnum.MesOutbound); | 
|---|
|  |  |  | //        result.Item2.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | //        result.Item3.ForEach(x => | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            x.Status = OutLockStockStatusEnum.åºåºä¸.ObjToInt(); | 
|---|
|  |  |  | //        }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        stockInfos = result.Item1; | 
|---|
|  |  |  | //        mesPPCutOutboundOrderDetail = result.Item2; | 
|---|
|  |  |  | //        outStockLockInfos = result.Item3; | 
|---|
|  |  |  | //        locationInfos = result.Item4; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    else | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        throw new Exception("æ åºå"); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //tasks.ForEach(x => | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    x.TargetAddress = mesPPCutOutboundOrderDetail.TargetAddressCode; | 
|---|
|  |  |  | //}); | 
|---|
|  |  |  | //_unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //int id = BaseDal.AddData(tasks); | 
|---|
|  |  |  | //outStockLockInfos.ForEach(x => | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    x.OrderNo = mesPPOutboundOrder.TaskNo; | 
|---|
|  |  |  | //    x.OrderDetailId = id; | 
|---|
|  |  |  | //}); | 
|---|
|  |  |  | ////_outboundService.MesPPOutboundOrderService.Repository.AddData(mesOutboundOrder); | 
|---|
|  |  |  | //Db.InsertNav(mesPPOutboundOrder).Include(x => x.Details).ExecuteCommand(); | 
|---|
|  |  |  | //if (stockInfos != null && stockInfos.Count > 0 && outStockLockInfos != null && outStockLockInfos.Count > 0 && locationInfos != null && locationInfos.Count > 0) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    WebResponseContent content = _outboundService.MesOutboundOrderService.LockOutboundStockDataUpdate(stockInfos, outStockLockInfos, locationInfos, tasks: tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    if (!content.Status) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | //        return MesResponseContent.Instance.Error(content.Message); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //_unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | //PushTasksToWCS(tasks, "AGV_PP"); | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  | return MesResponseContent.Instance.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return MesResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //䏿¬¡åªåä¸å·ç©æå
¥åºæç» | 
|---|
|  |  |  | foreach (var item in model.MaterialLotInfo) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //è·åç©æä¿¡æ¯ | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskType = TaskTypeEnum.Inbound.ObjToInt(), | 
|---|
|  |  |  | TaskStatus = TaskStatusEnum.New.ObjToInt(), | 
|---|
|  |  |  | WarehouseId = stockInfo.WarehouseId, | 
|---|
|  |  |  | PalletType = stockInfo.PalletType | 
|---|
|  |  |  | PalletType = stockInfo.PalletType, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | string MaterielCode = stockInfo.Details.Where(x => x.StockId == stockInfo.Id).FirstOrDefault()?.MaterielCode; | 
|---|
|  |  |  | float Quantity = (float)stockInfo.Details.Where(x => x.StockId == stockInfo.Id).Sum(x => x.StockQuantity); | 
|---|
|  |  |  | if (MaterielCode != null && Quantity != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | newTask.MaterielCode = MaterielCode; | 
|---|
|  |  |  | newTask.Quantity = Quantity; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LocationStatusEnum lastStatus = (LocationStatusEnum)locationInfo.LocationStatus; | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  | _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, lastStatus, LocationStatusEnum.Lock, LocationChangeType.InboundAssignLocation); | 
|---|
|  |  |  | 
|---|
|  |  |  | MesResponseContent content = new MesResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //é夿æ¥è¯¢ç«åº,å¹³åº | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x => x.WarehouseCode == WarehouseEnum.HA58.ToString()); | 
|---|
|  |  |  | List<Dt_StockInfo> stockInfos = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Where(x => | 
|---|
|  |  |  | x.WarehouseId == warehouse.WarehouseId && | 
|---|
|  |  |  | 
|---|
|  |  |  | var stock = stockInfo.Details.FirstOrDefault(); | 
|---|
|  |  |  | if (stock != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | content.BSucc = true; | 
|---|
|  |  |  | content.StrCode = "0000"; | 
|---|
|  |  |  | content.StrMsg = "æ§è¡æå"; | 
|---|
|  |  |  | content.MaterialCode = stock.MaterielCode; | 
|---|
|  |  |  | content.Quantity = stock.StockQuantity; | 
|---|
|  |  |  | content.Unit = stock.Unit; | 
|---|
|  |  |  | content.Warehouse = warehouse.WarehouseCode; | 
|---|
|  |  |  | content.WarehouseName = warehouse.WarehouseName; | 
|---|
|  |  |  | content.CutedWidth = stock.CutedWidth; | 
|---|
|  |  |  | content.CarrierCode = stockInfo.PalletCode; | 
|---|
|  |  |  | content.MaterialLot = stock.BatchNo; | 
|---|
|  |  |  | content.Content = new | 
|---|
|  |  |  | { | 
|---|
|  |  |  | MaterialCode = stock.MaterielCode, | 
|---|
|  |  |  | Quantity = stock.StockQuantity, | 
|---|
|  |  |  | Unit = stock.Unit, | 
|---|
|  |  |  | Warehouse = warehouse.WarehouseCode, | 
|---|
|  |  |  | WarehouseName = warehouse.WarehouseName, | 
|---|
|  |  |  | CutedWidth = stock.CutedWidth, | 
|---|
|  |  |  | CarrierCode = stockInfo.PalletCode, | 
|---|
|  |  |  | MaterialLot = stock.BatchNo, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | return content.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// MESæåå
¥åºåæ¥æ¶ | 
|---|
|  |  |  | /// çæPP大å·åºåºä»»å¡ | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="keys">åºåºåæç»ä¸»é®</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public MesResponseContent BagInfoSync(MesBagInfoModel bagInfoModel) | 
|---|
|  |  |  | public WebResponseContent MESPPGenerateOutboundTasks(int[] keys) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | MesResponseContent content = new MesResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x=>x.WarehouseCode==bagInfoModel.WarehouseCode); | 
|---|
|  |  |  | if (warehouse==null) | 
|---|
|  |  |  | List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  | List<StockSelectViewDTO> stockSelectViews = new List<StockSelectViewDTO>(); | 
|---|
|  |  |  | List<Dt_StockInfo> stockInfos = new List<Dt_StockInfo>(); | 
|---|
|  |  |  | List<Dt_MesPPOutboundOrderDetail> outboundOrderDetails = new List<Dt_MesPPOutboundOrderDetail>(); | 
|---|
|  |  |  | List<Dt_OutStockLockInfo> outStockLockInfos = new List<Dt_OutStockLockInfo>(); | 
|---|
|  |  |  | List<Dt_LocationInfo> locationInfos = new List<Dt_LocationInfo>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | (List<Dt_Task>, List<Dt_StockInfo>?, List<Dt_MesPPOutboundOrderDetail>?, List<Dt_OutStockLockInfo>?, List<Dt_LocationInfo>?, Dt_MesPPOutboundOrder mesPPOutboundOrder) result = MESPPOutboundTaskDataHandle(keys); | 
|---|
|  |  |  | if (result.Item2 != null && result.Item2.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error("æªæ¾å°ä»åºä¿¡æ¯"); | 
|---|
|  |  |  | stockInfos.AddRange(result.Item2); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<Dt_MesProInOrderDetail> mesProInOrderDetails = new List<Dt_MesProInOrderDetail>(); | 
|---|
|  |  |  | foreach (var item in bagInfoModel.BagDetails) | 
|---|
|  |  |  | if (result.Item3 != null && result.Item3.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | mesProInOrderDetails.Add(_mapper.Map<Dt_MesProInOrderDetail>(item)); | 
|---|
|  |  |  | outboundOrderDetails.AddRange(result.Item3); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | mesProInOrderDetails.ForEach(x => | 
|---|
|  |  |  | if (result.Item4 != null && result.Item4.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OverInQuantity = 0; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | Dt_MesProInOrder mesProInOrder = new Dt_MesProInOrder() | 
|---|
|  |  |  | outStockLockInfos.AddRange(result.Item4); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (result.Item5 != null && result.Item5.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WarehouseId = warehouse.WarehouseId, | 
|---|
|  |  |  | BatchNo = bagInfoModel.BatchNo, | 
|---|
|  |  |  | MesProStatus = InOrderStatusEnum.æªå¼å§.ObjToInt(), | 
|---|
|  |  |  | UnPackStock=bagInfoModel.UnPackStock, | 
|---|
|  |  |  | Details= mesProInOrderDetails | 
|---|
|  |  |  | locationInfos.AddRange(result.Item5); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | tasks.AddRange(result.Item1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (result.mesPPOutboundOrder != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WebResponseContent content = MESPPGenerateOutboundTaskDataUpdate(tasks, stockInfos, outboundOrderDetails, outStockLockInfos, locationInfos, result.mesPPOutboundOrder); | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// PP大å·åºåºä»»å¡æ°æ®å¤ç | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="orderDetailId"></param> | 
|---|
|  |  |  | /// <param name="stockSelectViews"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | /// <exception cref="Exception"></exception> | 
|---|
|  |  |  | public (List<Dt_Task>, List<Dt_StockInfo>?, List<Dt_MesPPOutboundOrderDetail>?, List<Dt_OutStockLockInfo>?, List<Dt_LocationInfo>?, Dt_MesPPOutboundOrder mesPPOutboundOrder) MESPPOutboundTaskDataHandle(int[] keys) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  | List<Dt_MesPPOutboundOrderDetail> outboundOrderDetails = BaseDal.Db.Queryable<Dt_MesPPOutboundOrderDetail>().Where(x => keys.Contains(x.Id)).ToList(); | 
|---|
|  |  |  | if (outboundOrderDetails == null || outboundOrderDetails.Count == 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("æªæ¾å°åºåºåæç»ä¿¡æ¯"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (outboundOrderDetails.FirstOrDefault(x => x.OrderDetailStatus > OrderDetailStatusEnum.New.ObjToInt() && x.OrderDetailStatus != OrderDetailStatusEnum.AssignOverPartial.ObjToInt()) != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("æéåºåºåæç»åå¨åºåºä¸æå·²å®æ"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<Dt_StockInfo>? stockInfos = null; | 
|---|
|  |  |  | List<Dt_MesPPOutboundOrderDetail>? orderDetails = null; | 
|---|
|  |  |  | List<Dt_OutStockLockInfo>? outStockLockInfos = null; | 
|---|
|  |  |  | List<Dt_LocationInfo>? locationInfos = null; | 
|---|
|  |  |  | Dt_MesPPOutboundOrder? mesPPOutboundOrders = null; | 
|---|
|  |  |  | if (outboundOrderDetails.FirstOrDefault().OrderDetailStatus == OrderDetailStatusEnum.New.ObjToInt()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (List<Dt_StockInfo>, List<Dt_MesPPOutboundOrderDetail>, List<Dt_OutStockLockInfo>, List<Dt_LocationInfo>, Dt_MesPPOutboundOrder mesPPOutboundOrder) result = _outboundService.MesPPOutboundOrderDetailService.AssignStockOutbound(outboundOrderDetails); | 
|---|
|  |  |  | if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_MesPPOutboundOrder outboundOrder = _outboundService.MesPPOutboundOrderService.Repository.QueryFirst(x => x.Id == outboundOrderDetails.FirstOrDefault().OrderId); | 
|---|
|  |  |  | TaskTypeEnum typeEnum = outboundOrder.OrderType switch | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (int)OutOrderTypeEnum.Issue => TaskTypeEnum.Outbound, | 
|---|
|  |  |  | (int)OutOrderTypeEnum.Allocate => TaskTypeEnum.OutAllocate, | 
|---|
|  |  |  | (int)OutOrderTypeEnum.Quality => TaskTypeEnum.OutQuality, | 
|---|
|  |  |  | _ => new TaskTypeEnum() | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | tasks = GetTasks(result.Item1, typeEnum); | 
|---|
|  |  |  | result.Item2.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | result.Item3.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.Status = OutLockStockStatusEnum.åºåºä¸.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | stockInfos = result.Item1; | 
|---|
|  |  |  | orderDetails = result.Item2; | 
|---|
|  |  |  | outStockLockInfos = result.Item3; | 
|---|
|  |  |  | locationInfos = result.Item4; | 
|---|
|  |  |  | mesPPOutboundOrders = result.mesPPOutboundOrder; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("æ åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //else | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    List<Dt_OutStockLockInfo> stockLockInfos = _outboundService.OutboundStockLockInfoService.GetByOrderDetailId(outboundOrderDetails.oi, OutLockStockStatusEnum.å·²åé
); | 
|---|
|  |  |  | //    if (stockLockInfos != null && stockLockInfos.Count > 0) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        List<Dt_StockInfo> stocks = _stockService.StockInfoService.Repository.GetStockInfosByPalletCodes(stockLockInfos.Select(x => x.PalletCode).Distinct().ToList()); | 
|---|
|  |  |  | //        tasks = GetTasks(stocks); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return (tasks, stockInfos, orderDetails, outStockLockInfos, locationInfos, mesPPOutboundOrders); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// PPå¹³åºç´æ¥åºåº | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="orderDetailId"></param> | 
|---|
|  |  |  | /// <param name="stockSelectViews"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public WebResponseContent PPGeneratePKOutboundTask(int orderDetailId, List<PPStockSelectViewDTO> stockSelectViews) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (List<Dt_Task>, List<Dt_StockInfo>?, List<Dt_MesPPCutOutboundOrderDetail>?, List<Dt_OutStockLockInfo>?, List<Dt_LocationInfo>?) result = PPOutboundTaskDataHandle(orderDetailId, stockSelectViews); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WebResponseContent content = PPGenerateOutboundTaskDataUpdate(result.Item1, result.Item2, result.Item3, result.Item4, result.Item5); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// PPç«åºå°å·ç´æ¥åºåº | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="orderDetailId"></param> | 
|---|
|  |  |  | /// <param name="stockSelectViews"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public WebResponseContent PPCutOutGenerateOutboundTasks(int orderDetailId, List<PPStockSelectViewDTO> stockSelectViews) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (List<Dt_Task>, List<Dt_StockInfo>?, List<Dt_MesPPCutOutboundOrderDetail>?, List<Dt_OutStockLockInfo>?, List<Dt_LocationInfo>?) result = PPOutboundTaskDataHandle(orderDetailId, stockSelectViews); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WebResponseContent content = PPGenerateOutboundTaskDataUpdate(result.Item1, result.Item2, result.Item3, result.Item4, result.Item5); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// åºåºä»»å¡æ°æ®å¤ç | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="orderDetailId"></param> | 
|---|
|  |  |  | /// <param name="stockSelectViews"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | /// <exception cref="Exception"></exception> | 
|---|
|  |  |  | public (List<Dt_Task>, List<Dt_StockInfo>?, List<Dt_MesPPCutOutboundOrderDetail>?, List<Dt_OutStockLockInfo>?, List<Dt_LocationInfo>?) PPOutboundTaskDataHandle(int orderDetailId, List<PPStockSelectViewDTO> stockSelectViews) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  | Dt_MesPPCutOutboundOrderDetail outboundOrderDetail = _outboundService.MesPPCutOutboundOrderDetailService.Repository.QueryFirst(x => x.Id == orderDetailId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (outboundOrderDetail == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("æªæ¾å°åºåºåæç»ä¿¡æ¯"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (stockSelectViews.Sum(x => x.UseableQuantity) > outboundOrderDetail.OrderQuantity - outboundOrderDetail.LockQuantity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("éæ©æ°éè¶
åºåæ®æ°é"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<Dt_StockInfo>? stockInfos = null; | 
|---|
|  |  |  | Dt_MesPPCutOutboundOrderDetail? orderDetail = null; | 
|---|
|  |  |  | List<Dt_OutStockLockInfo>? outStockLockInfos = null; | 
|---|
|  |  |  | List<Dt_LocationInfo>? locationInfos = null; | 
|---|
|  |  |  | if (outboundOrderDetail.OrderDetailStatus == OrderDetailStatusEnum.New.ObjToInt()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (List<Dt_StockInfo>, Dt_MesPPCutOutboundOrderDetail, List<Dt_OutStockLockInfo>, List<Dt_LocationInfo>) result = _outboundService.MesPPCutOutboundOrderDetailService.AssignStockOutbound(outboundOrderDetail, stockSelectViews); | 
|---|
|  |  |  | if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_MesPPCutOutboundOrder outboundOrder = _outboundService.MesPPCutOutboundOrderService.Repository.QueryFirst(x => x.Id == outboundOrderDetail.OrderId); | 
|---|
|  |  |  | TaskTypeEnum typeEnum = outboundOrder.OrderType switch | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (int)OutOrderTypeEnum.Issue => TaskTypeEnum.Outbound, | 
|---|
|  |  |  | (int)OutOrderTypeEnum.Allocate => TaskTypeEnum.OutAllocate, | 
|---|
|  |  |  | (int)OutOrderTypeEnum.Quality => TaskTypeEnum.OutQuality, | 
|---|
|  |  |  | _ => new TaskTypeEnum() | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | tasks = GetTasks(result.Item1, TaskTypeEnum.Outbound); | 
|---|
|  |  |  | result.Item2.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | result.Item3.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.Status = OutLockStockStatusEnum.åºåºä¸.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | stockInfos = result.Item1; | 
|---|
|  |  |  | orderDetail = result.Item2; | 
|---|
|  |  |  | outStockLockInfos = result.Item3; | 
|---|
|  |  |  | locationInfos = result.Item4; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("æ åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_OutStockLockInfo> stockLockInfos = _outboundService.OutboundStockLockInfoService.GetByOrderDetailId(outboundOrderDetail.OrderId, OutLockStockStatusEnum.å·²åé
); | 
|---|
|  |  |  | if (stockLockInfos != null && stockLockInfos.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_StockInfo> stocks = _stockService.StockInfoService.Repository.GetStockInfosByPalletCodes(stockLockInfos.Select(x => x.PalletCode).Distinct().ToList()); | 
|---|
|  |  |  | tasks = GetTasks(stocks, TaskTypeEnum.Outbound); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return (tasks, stockInfos, orderDetail == null ? null : new List<Dt_MesPPCutOutboundOrderDetail> { orderDetail }, outStockLockInfos, locationInfos); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public WebResponseContent PPGenerateOutboundTaskDataUpdate(List<Dt_Task> tasks, List<Dt_StockInfo>? stockInfos = null, List<Dt_MesPPCutOutboundOrderDetail>? outboundOrderDetails = null, List<Dt_OutStockLockInfo>? outStockLockInfos = null, List<Dt_LocationInfo>? locationInfos = null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BaseDal.AddData(tasks); | 
|---|
|  |  |  | if (stockInfos != null && stockInfos.Count > 0 && outboundOrderDetails != null && outboundOrderDetails.Count > 0 && outStockLockInfos != null && outStockLockInfos.Count > 0 && locationInfos != null && locationInfos.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfos.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.StockStatus = StockStatusEmun.åºåºéå®.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | WebResponseContent content = _outboundService.MesPPCutOutboundOrderDetailService.LockOutboundStockDataUpdate(stockInfos, outboundOrderDetails, outStockLockInfos, locationInfos, tasks: tasks); | 
|---|
|  |  |  | if (!content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (outboundOrderDetails != null && outboundOrderDetails.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | outboundOrderDetails.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _outboundService.MesPPCutOutboundOrderDetailService.Repository.UpdateData(outboundOrderDetails); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | PushTasksToWCS(tasks); | 
|---|
|  |  |  | return WebResponseContent.Instance.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | #region | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// çæPPå°å·åºåºä»»å¡ | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="keys">åºåºåæç»ä¸»é®</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | //public WebResponseContent PPCutOutGenerateOutboundTasks(int[] keys) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    try | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  | //        List<StockSelectViewDTO> stockSelectViews = new List<StockSelectViewDTO>(); | 
|---|
|  |  |  | //        List<Dt_StockInfo> stockInfos = new List<Dt_StockInfo>(); | 
|---|
|  |  |  | //        List<Dt_MesPPCutOutboundOrderDetail> outboundOrderDetails = new List<Dt_MesPPCutOutboundOrderDetail>(); | 
|---|
|  |  |  | //        List<Dt_OutStockLockInfo> outStockLockInfos = new List<Dt_OutStockLockInfo>(); | 
|---|
|  |  |  | //        List<Dt_LocationInfo> locationInfos = new List<Dt_LocationInfo>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        (List<Dt_Task>, List<Dt_StockInfo>?, List<Dt_MesPPCutOutboundOrderDetail>?, List<Dt_OutStockLockInfo>?, List<Dt_LocationInfo>?) result = PPCutOutboundTaskDataHandle(keys); | 
|---|
|  |  |  | //        if (result.Item2 != null && result.Item2.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            stockInfos.AddRange(result.Item2); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        if (result.Item3 != null && result.Item3.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            outboundOrderDetails.AddRange(result.Item3); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        if (result.Item4 != null && result.Item4.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            outStockLockInfos.AddRange(result.Item4); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        if (result.Item5 != null && result.Item5.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            locationInfos.AddRange(result.Item5); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            tasks.AddRange(result.Item1); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        WebResponseContent content = PPCutOutGenerateOutboundTaskDataUpdate(tasks, stockInfos, outboundOrderDetails, outStockLockInfos, locationInfos); | 
|---|
|  |  |  | //        return content; | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    catch (Exception ex) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | //        return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ///// <summary> | 
|---|
|  |  |  | ///// PPå°å·åºåºä»»å¡æ°æ®å¤ç | 
|---|
|  |  |  | ///// </summary> | 
|---|
|  |  |  | ///// <param name="orderDetailId"></param> | 
|---|
|  |  |  | ///// <param name="stockSelectViews"></param> | 
|---|
|  |  |  | ///// <returns></returns> | 
|---|
|  |  |  | ///// <exception cref="Exception"></exception> | 
|---|
|  |  |  | //public (List<Dt_Task>, List<Dt_StockInfo>?, List<Dt_MesPPCutOutboundOrderDetail>?, List<Dt_OutStockLockInfo>?, List<Dt_LocationInfo>?) PPCutOutboundTaskDataHandle(int[] keys) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  | //    List<Dt_MesPPCutOutboundOrderDetail> outboundOrderDetails = BaseDal.Db.Queryable<Dt_MesPPCutOutboundOrderDetail>().Where(x => keys.Contains(x.Id)).ToList(); | 
|---|
|  |  |  | //    if (outboundOrderDetails == null || outboundOrderDetails.Count == 0) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        throw new Exception("æªæ¾å°åºåºåæç»ä¿¡æ¯"); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    if (outboundOrderDetails.FirstOrDefault(x => x.OrderDetailStatus > OrderDetailStatusEnum.New.ObjToInt() && x.OrderDetailStatus != OrderDetailStatusEnum.AssignOverPartial.ObjToInt()) != null) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        throw new Exception("æéåºåºåæç»åå¨åºåºä¸æå·²å®æ"); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    List<Dt_StockInfo>? stockInfos = null; | 
|---|
|  |  |  | //    List<Dt_MesPPCutOutboundOrderDetail>? orderDetails = null; | 
|---|
|  |  |  | //    List<Dt_OutStockLockInfo>? outStockLockInfos = null; | 
|---|
|  |  |  | //    List<Dt_LocationInfo>? locationInfos = null; | 
|---|
|  |  |  | //    if (outboundOrderDetails.FirstOrDefault().OrderDetailStatus == OrderDetailStatusEnum.New.ObjToInt()) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        (List<Dt_StockInfo>, List<Dt_MesPPCutOutboundOrderDetail>, List<Dt_OutStockLockInfo>, List<Dt_LocationInfo>) result = _outboundService.MesPPCutOutboundOrderDetailService.AssignStockOutbound(outboundOrderDetails); | 
|---|
|  |  |  | //        if (result.Item1 != null && result.Item1.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            Dt_MesPPCutOutboundOrder outboundOrder = _outboundService.MesPPCutOutboundOrderService.Repository.QueryFirst(x => x.Id == outboundOrderDetails.FirstOrDefault().OrderId); | 
|---|
|  |  |  | //            //TaskTypeEnum typeEnum = outboundOrder.OrderType switch | 
|---|
|  |  |  | //            //{ | 
|---|
|  |  |  | //            //    (int)OutOrderTypeEnum.Issue => TaskTypeEnum.Outbound, | 
|---|
|  |  |  | //            //    (int)OutOrderTypeEnum.Allocate => TaskTypeEnum.OutAllocate, | 
|---|
|  |  |  | //            //    (int)OutOrderTypeEnum.Quality => TaskTypeEnum.OutQuality, | 
|---|
|  |  |  | //            //    _ => new TaskTypeEnum() | 
|---|
|  |  |  | //            //}; | 
|---|
|  |  |  | //            tasks = GetTasks(result.Item1, TaskTypeEnum.MesOutbound); | 
|---|
|  |  |  | //            result.Item2.ForEach(x => | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                x.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | //            }); | 
|---|
|  |  |  | //            result.Item3.ForEach(x => | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                x.Status = OutLockStockStatusEnum.åºåºä¸.ObjToInt(); | 
|---|
|  |  |  | //            }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            stockInfos = result.Item1; | 
|---|
|  |  |  | //            orderDetails = result.Item2; | 
|---|
|  |  |  | //            outStockLockInfos = result.Item3; | 
|---|
|  |  |  | //            locationInfos = result.Item4; | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        else | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            throw new Exception("æ åºå"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    //else | 
|---|
|  |  |  | //    //{ | 
|---|
|  |  |  | //    //    List<Dt_OutStockLockInfo> stockLockInfos = _outboundService.OutboundStockLockInfoService.GetByOrderDetailId(outboundOrderDetails.OrderId, OutLockStockStatusEnum.å·²åé
); | 
|---|
|  |  |  | //    //    if (stockLockInfos != null && stockLockInfos.Count > 0) | 
|---|
|  |  |  | //    //    { | 
|---|
|  |  |  | //    //        List<Dt_StockInfo> stocks = _stockService.StockInfoService.Repository.GetStockInfosByPalletCodes(stockLockInfos.Select(x => x.PalletCode).Distinct().ToList()); | 
|---|
|  |  |  | //    //        tasks = GetTasks(stocks); | 
|---|
|  |  |  | //    //    } | 
|---|
|  |  |  | //    //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    return (tasks, stockInfos, orderDetails, outStockLockInfos, locationInfos); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ///// <summary> | 
|---|
|  |  |  | ///// çæPPå°å·åºåºä»»å¡åæ°æ®æ´æ°å°æ°æ®åº | 
|---|
|  |  |  | ///// </summary> | 
|---|
|  |  |  | ///// <param name="tasks"></param> | 
|---|
|  |  |  | ///// <param name="stockInfos"></param> | 
|---|
|  |  |  | ///// <param name="outboundOrderDetails"></param> | 
|---|
|  |  |  | ///// <param name="outStockLockInfos"></param> | 
|---|
|  |  |  | ///// <param name="locationInfos"></param> | 
|---|
|  |  |  | ///// <returns></returns> | 
|---|
|  |  |  | //public WebResponseContent PPCutOutGenerateOutboundTaskDataUpdate(List<Dt_Task> tasks, List<Dt_StockInfo>? stockInfos = null, List<Dt_MesPPCutOutboundOrderDetail>? outboundOrderDetails = null, List<Dt_OutStockLockInfo>? outStockLockInfos = null, List<Dt_LocationInfo>? locationInfos = null) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    try | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        BaseDal.AddData(tasks); | 
|---|
|  |  |  | //        if (stockInfos != null && stockInfos.Count > 0 && outboundOrderDetails != null && outboundOrderDetails.Count > 0 && outStockLockInfos != null && outStockLockInfos.Count > 0 && locationInfos != null && locationInfos.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            stockInfos.ForEach(x => | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                x.StockStatus = StockStatusEmun.åºåºéå®.ObjToInt(); | 
|---|
|  |  |  | //            }); | 
|---|
|  |  |  | //            WebResponseContent content = _outboundService.MesPPCutOutboundOrderDetailService.LockOutboundStockDataUpdate(stockInfos, outboundOrderDetails, outStockLockInfos, locationInfos, tasks: tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            if (!content.Status) | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | //                return content; | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        else if (outboundOrderDetails != null && outboundOrderDetails.Count > 0) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            outboundOrderDetails.ForEach(x => | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                x.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | //            }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            _outboundService.MesPPCutOutboundOrderDetailService.Repository.UpdateData(outboundOrderDetails); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | //        PushTasksToWCS(tasks,"AGV_PP"); | 
|---|
|  |  |  | //        return WebResponseContent.Instance.OK(); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    catch (Exception ex) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | //        return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// çæPP大å·åºåºä»»å¡åæ°æ®æ´æ°å°æ°æ®åº | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="tasks"></param> | 
|---|
|  |  |  | /// <param name="stockInfos"></param> | 
|---|
|  |  |  | /// <param name="outboundOrderDetails"></param> | 
|---|
|  |  |  | /// <param name="outStockLockInfos"></param> | 
|---|
|  |  |  | /// <param name="locationInfos"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public WebResponseContent MESPPGenerateOutboundTaskDataUpdate(List<Dt_Task> tasks, List<Dt_StockInfo>? stockInfos = null, List<Dt_MesPPOutboundOrderDetail>? outboundOrderDetails = null, List<Dt_OutStockLockInfo>? outStockLockInfos = null, List<Dt_LocationInfo>? locationInfos = null, Dt_MesPPOutboundOrder? mesPPOutboundOrder = null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.BeginTran(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BaseDal.AddData(tasks); | 
|---|
|  |  |  | if (stockInfos != null && stockInfos.Count > 0 && outboundOrderDetails != null && outboundOrderDetails.Count > 0 && outStockLockInfos != null && outStockLockInfos.Count > 0 && locationInfos != null && locationInfos.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfos.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.StockStatus = StockStatusEmun.åºåºéå®.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | WebResponseContent content = _outboundService.MesPPOutboundOrderDetailService.LockOutboundStockDataUpdate(mesPPOutboundOrder, stockInfos, outboundOrderDetails, outStockLockInfos, locationInfos, tasks: tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (outboundOrderDetails != null && outboundOrderDetails.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | outboundOrderDetails.ForEach(x => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.OrderDetailStatus = OrderDetailStatusEnum.Outbound.ObjToInt(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _outboundService.MesPPOutboundOrderDetailService.Repository.UpdateData(outboundOrderDetails); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | _unitOfWorkManage.CommitTran(); | 
|---|
|  |  |  | PushTasksToWCS(tasks); | 
|---|
|  |  |  | return WebResponseContent.Instance.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _unitOfWorkManage.RollbackTran(); | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// è·åMESé»çæ¹æ¬¡ä¿¡æ¯ | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="model"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public WebResponseContent GetZHMesMaterialLot(string materialLot) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_ApiInfo apiInfo = _apiInfoRepository.QueryFirst(x => x.ApiCode == APIEnum.WMS_MES_GetProductByLot.ToString()); | 
|---|
|  |  |  | object obj = new { LotNo = materialLot }; | 
|---|
|  |  |  | MESRoot<object> root = new MESRoot<object>() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | From = "WMS", | 
|---|
|  |  |  | DateTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"), | 
|---|
|  |  |  | Content = obj | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | Db.InsertNav(mesProInOrder).Include(x=>x.Details).ExecuteCommand(); | 
|---|
|  |  |  | return content.OK("æ¥æ¶æå"); | 
|---|
|  |  |  | JsonSerializerSettings settings = new JsonSerializerSettings | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ContractResolver = new CamelCasePropertyNamesContractResolver() | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | string request = JsonConvert.SerializeObject(root, settings); | 
|---|
|  |  |  | string response = HttpMesHelper.Post(apiInfo.ApiAddress, request); | 
|---|
|  |  |  | MesResponseContent mesResponseContent = response.DeserializeObject<MesResponseContent>(); | 
|---|
|  |  |  | //è°ç¨æ¥å£ | 
|---|
|  |  |  | if (mesResponseContent.BSucc == true) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | content.OK(mesResponseContent.StrMsg, mesResponseContent.Content); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | content.Error(mesResponseContent.StrMsg); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// æåè¿å·¥æåº | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="model"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public MesResponseContent RworkTask(RworkTaskModel model) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x => x.WarehouseCode == WarehouseEnum.HA72.ToString()); | 
|---|
|  |  |  | //è·ååºåè®°å½ | 
|---|
|  |  |  | List<Dt_StockInfo> stockInfos = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Where(x => | 
|---|
|  |  |  | x.WarehouseId == warehouse.WarehouseId && | 
|---|
|  |  |  | x.StockStatus == (int)StockStatusEmun.å
¥åºå®æ).Includes(x => x.Details).ToList(); | 
|---|
|  |  |  | Dt_StockInfo? stockInfo = stockInfos.FirstOrDefault(x => x.Details.Any(x => x.BatchNo == model.ProductVersion)); | 
|---|
|  |  |  | if (stockInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return MesResponseContent.Instance.Error($"å°¾æ°ä»:{model.ProductVersion}æ å¯ç¨åºå"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Dt_Task exsit2 = Repository.QueryFirst(x => x.PalletCode == stockInfo.PalletCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | throw; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return MesResponseContent.Instance.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|