From 0c75581f4f388a0d3e221aa04b3ccf0fd10c9cf5 Mon Sep 17 00:00:00 2001 From: 刘磊 <1161824510@qq.com> Date: 星期二, 26 十一月 2024 10:05:15 +0800 Subject: [PATCH] 1 --- Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Dt_TaskService.cs | 79 ++++++++++++++++++++++++++------------- 1 files changed, 52 insertions(+), 27 deletions(-) diff --git a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Dt_TaskService.cs b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Dt_TaskService.cs index a1e0369..980ddb5 100644 --- a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Dt_TaskService.cs +++ b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Dt_TaskService.cs @@ -1,18 +1,9 @@ -锘縰sing log4net.Core; -using Mapster; +锘縰sing Mapster; using Masuit.Tools; -using Masuit.Tools.Models; -using Microsoft.EntityFrameworkCore; -using System.Linq; -using System.Threading.Tasks; using WIDESEA_DTO.MOM; using WIDESEA_DTO.WMS; -using WIDESEA_IStorageBasicRepository; using WIDESEA_IStoragIntegrationServices; -using WIDESEA_Model.Models; using WIDESEA_StorageBasicRepository; -using WIDESEA_StorageTaskRepository; -using WIDESEA_StoragIntegrationServices; using WIDESEAWCS_BasicInfoRepository; namespace WIDESEA_StorageOutTaskServices; @@ -120,7 +111,8 @@ await UpdateLocationAsync(loc); await DeleteStockInfoAsync(stock.Id); await DeleteStockInfoDetailsAsync(stock.StockInfoDetails); - //await DeleteTaskAsync(task.TaskId); + if (task.Roadway.Contains("FR")) //濡傛灉鏄垎瀹� 灏嗕换鍔″垹闄� + await DeleteTaskAsync(task.TaskId); }); return content.OK("浠诲姟瀹屾垚鎴愬姛"); @@ -184,7 +176,7 @@ private (DtLocationInfo, Dt_Task) UpdateStockAndTaskStatus(DtStockInfo stock, Dt_Task task) { - var location = _locationRepository.QueryFirst(x => x.LocationCode == task.SourceAddress); + var location = _locationRepository.QueryFirst(x => x.LocationCode == task.SourceAddress && x.RoadwayNo == task.Roadway); //var details = _stockInfoDetailRepository.QueryData(x => x.StockId == stock.Id); location.LocationStatus = (int)LocationEnum.Free; @@ -315,8 +307,9 @@ // 鏍规嵁鏄惁鏈夌粍鐩樹俊鎭垱寤哄簱瀛樺疄渚嬫ā鍨� DtStockInfo stock = boxing == null ? CreateEmptyPalletStock(task, locationInf) : CreateFullPalletStock(task, locationInf, boxing); + // 鎵ц鏁版嵁搴撲簨鍔� - bool isResult = await ExecuteTransaction(stock, taskHty, locationInf, task.TaskId); + bool isResult = await ExecuteTransaction(stock, taskHty, locationInf, task.TaskId, boxing); if (isResult) { content.OK("鍏ュ簱浠诲姟瀹屾垚鎴愬姛"); @@ -350,13 +343,41 @@ CreateDate = DateTime.Now, Creater = "system", IsFull = false, - AreaCode = area.AreaCode, + AreaCode = area.AreaCode ?? "", LocationId = loation.Id, StockInfoDetails = new List<DtStockInfoDetail>() { new DtStockInfoDetail() { MaterielCode = "绌烘墭鐩�", + Id = 0, + Status = (int)StockStateEmun.宸插叆搴� + } + } + }; + } + + /// <summary> + /// 鍒涘缓鍒嗗鐨勫疄鎵樼洏鐨勫簱瀛樺疄渚嬫ā鍨� + /// </summary> + private DtStockInfo CreateFullPalletStockByFR(Dt_Task task, DtLocationInfo locationInf) + { + var loation = _locationRepository.QueryFirst(x => x.RoadwayNo == task.Roadway && x.LocationCode == task.TargetAddress); + var area = _areaInfoRepository.QueryFirst(x => x.AreaID == loation.AreaId); + return new DtStockInfo() + { + PalletCode = task.PalletCode, + LocationCode = task.TargetAddress, + CreateDate = DateTime.Now, + Creater = "system", + IsFull = false, + AreaCode = area.AreaCode ?? "", + LocationId = loation.Id, + StockInfoDetails = new List<DtStockInfoDetail>() + { + new DtStockInfoDetail() + { + MaterielCode = "瀹炴墭鐩�", Id = 0, Status = (int)StockStateEmun.宸插叆搴� } @@ -405,7 +426,7 @@ stock.LinedProcessFeedbackTime = respone.LinedProcessFeedbackTime; stock.SpecialParameterDuration = respone.SpecialParameterDuration; //2024骞�11鏈�16鏃ワ細鏂板瀛楁璁$畻搴斿嚭搴撴椂闂� - stock.OutboundTime = Convert.ToDateTime(respone.LinedProcessFeedbackTime).AddHours(Convert.ToDouble(respone.SpecialParameterDuration)); + stock.OutboundTime = Convert.ToDateTime(respone.LinedProcessFeedbackTime == null ? DateTime.Now : respone.LinedProcessFeedbackTime).AddHours(Convert.ToDouble(respone.SpecialParameterDuration)); stock.ProductionLine = respone.ProductionLine; stock.ParameterInfos = respone.ParameterInfos.ToJsonString(); stock.StockStatus = 1; @@ -441,9 +462,9 @@ } LogFactory.GetLog("浠诲姟瀹屾垚").InfoFormat(true, "楠岃瘉浠诲姟鏄惁瀛樺湪", JsonConvert.SerializeObject(task)); - if(task.TaskType == (int)TaskOutboundTypeEnum.InToOut) + if (task.TaskType == (int)TaskOutboundTypeEnum.InToOut) { - return await CompleteInToOutTaskAsync(task); + return await CompleteInToOutTaskAsync(task); } // 楠岃瘉搴撳瓨鏄惁瀛樺湪 @@ -544,7 +565,7 @@ // TODO 鍒涘缓浠诲姟閫佽嚦NG鎺掑嚭鍙� var efg = _stationManagerRepository.QueryData(x => x.stationType == 1 && x.stationChildCode == input.Position && x.stationArea == area.AreaCode).ToList(); //List<string> NGStation = input.Position == "1088" ? new List<string>() { "1020" } : new List<string>() { "JZSC01" }; - if(efg.Count <= 0) + if (efg.Count <= 0) { throw new Exception("鏈壘鍒癗G鍏ュ簱绔欏彴閰嶇疆"); } @@ -563,6 +584,7 @@ content = await RequestTrayInTaskAsync(input); return content; } + //Console.WriteLine("qqqqq"); // TODO 鑾峰彇鏈湴鏂欐灞炴�т笌鏁寸洏鐢佃姱灞炴�ц幏鍙栫殑鍊艰繘琛屽姣旓紝濡傛灉涓�鑷村垯缁х画锛屽惁鍒欒繑鍥為敊璇俊鎭� //var productions = await _productionRepository.QueryDataAsync(x => result.TrayBarcodePropertys.Select(x => x.TrayBarcodeProperty).ToList().Contains(x.TrayBarcodeProperty)); @@ -571,7 +593,8 @@ // 璋冪敤CreateBoxingInfo鏂规硶锛屽垱寤虹粍鐩樹俊鎭� - var boxing = await CreateBoxingInfo(result, input.PalletCode); + var boxing = CreateBoxingInfo(result, input.PalletCode); + //Console.WriteLine(boxing.ToJsonString()); if (boxing == null) return content.Error("缁勭洏澶辫触"); // 璋冪敤GetProcessApplyAsync鏂规硶锛岃幏鍙栧伐鑹鸿矾绾� @@ -601,8 +624,8 @@ { throw new Exception("鏈壘鍒癗G鍏ュ簱绔欏彴閰嶇疆"); } - List<string> strings = stationManagers.Select(x=>x.Roadway).ToList(); - // 璋冪敤CreateNewTask鏂规硶锛屽垱寤烘柊浠诲姟 + List<string> strings = stationManagers.Select(x => x.Roadway).ToList(); + //// 璋冪敤CreateNewTask鏂规硶锛屽垱寤烘柊浠诲姟 content = await CreateNewTask(input, strings); if (content.Status) { @@ -702,7 +725,7 @@ } // 鑾峰彇缁勭洏淇℃伅 - private async Task<DtBoxingInfo> CreateBoxingInfo(ResultTrayCellsStatus result, string palletCode) + private DtBoxingInfo CreateBoxingInfo(ResultTrayCellsStatus result, string palletCode) { return new DtBoxingInfo { @@ -1208,12 +1231,14 @@ { // 娣诲姞搴撳瓨 isUpdateStock = await _stockInfoRepository.AddDataNavAsync(stock); - isDeleteBoxing = await _boxingInfoRepository.Db.DeleteNav<DtBoxingInfo>(x => x.Id == boxingInfo.Id) - .Include(x => x.BoxingInfoDetails) - .ExecuteCommandAsync(); + if (boxingInfo != null) + { + isDeleteBoxing = await _boxingInfoRepository.Db.DeleteNav<DtBoxingInfo>(x => x.Id == boxingInfo.Id) + .Include(x => x.BoxingInfoDetails) + .ExecuteCommandAsync(); + } + } - - // 娣诲姞鍘嗗彶浠诲姟 var isTaskHtyAdd = await _task_HtyRepository.AddDataAsync(taskHty) > 0; -- Gitblit v1.9.3