From 701c5766a312caccc887c42376e5115f49a6a3d3 Mon Sep 17 00:00:00 2001 From: 刘磊 <1161824510@qq.com> Date: 星期六, 23 十一月 2024 19:23:26 +0800 Subject: [PATCH] 更新 --- Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/Dt_TaskService.cs | 73 +++++++++++++++++++++++++++++++----- 1 files changed, 63 insertions(+), 10 deletions(-) diff --git a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/Dt_TaskService.cs b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/Dt_TaskService.cs index 93021c6..3efaa61 100644 --- a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/Dt_TaskService.cs +++ b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/Dt_TaskService.cs @@ -533,9 +533,10 @@ //case 4: case 5: task = await CreateInToOutTaskAsync(input, stationManager); break; - + case 7: + task = await CreateEmptyOutTaskAsync(input, stationManager); break; default: - throw new Exception("浣嶇疆绔欏彴绫诲瀷"); + throw new Exception("鏈煡绔欏彴绫诲瀷"); } return task; } @@ -575,7 +576,16 @@ { if (stationManager.stationType != 1 && stationManager.stationType != 6) throw new Exception("閿欒鐨勮皟鍙�"); - DtLocationInfo locationInfo = await RequestLocation(input); + DtLocationInfo locationInfo = null; + if (stationManager.stationType == 1 && stationManager.Roadway.Contains("FR")) + { + locationInfo = await RequestLocation(input, true); + } + else + { + locationInfo = await RequestLocation(input); + } + //DtLocationInfo locationInfo = await RequestLocation(input); if (locationInfo == null) throw new Exception("搴撲綅宸叉弧"); @@ -659,13 +669,13 @@ /// </summary> /// <param name="requestTask">璇锋眰鍙傛暟</param> /// <returns></returns> - private async Task<DtLocationInfo> RequestLocation(RequestTaskDto requestTask) + private async Task<DtLocationInfo> RequestLocation(RequestTaskDto requestTask, bool isCheckRequest = false) { #region 鑾峰彇璐т綅 try { List<DtLocationInfo> locations; - if (requestTask.Roadways.Contains("FR")) + if (isCheckRequest) { locations = await _locationRepository.QueryDataAsync(x => x.LocationStatus == (int)LocationEnum.Free && x.RoadwayNo == requestTask.Roadways && x.EnalbeStatus == 1 && x.LocationType == 2 && x.Remark == "1"); } @@ -687,7 +697,7 @@ return null; } #endregion 鑾峰彇璐т綅 - } + } #endregion // 鑾峰彇宸ヨ壓鐢宠 @@ -706,8 +716,52 @@ }; } - #endregion 璇锋眰浠诲姟鍏ュ簱 + #endregion 璇锋眰绌烘鍑哄簱 + public async Task<Dt_Task> CreateEmptyOutTaskAsync(RequestTaskDto input, Dt_StationManager stationManager) + { + try + { + if (stationManager.stationType != 7) throw new Exception("閿欒鐨勮皟鍙�"); + + var stockinfo = await _stockInfoRepository.Db.Queryable<DtStockInfo>() + .Includes(x => x.LocationInfo) + //.Includes(x=>x.StockInfoDetails) + .Where(x => !x.IsFull && x.LocationInfo.RoadwayNo == stationManager.Roadway) + .OrderBy(x => x.CreateDate) + .FirstAsync(); + + if (stockinfo == null) return null; + + var task = new Dt_Task + { + CurrentAddress = input.Position, + Grade = 1, + Roadway = input.Roadways, + TargetAddress = stationManager.stationLocation, + Dispatchertime = DateTime.Now, + MaterialNo = "", + NextAddress = input.Roadways, + OrderNo = null, + PalletCode = input.PalletCode, + SourceAddress = stockinfo.LocationCode, + TaskState = (int)TaskOutStatusEnum.OutNew, + TaskType = (int)TaskOutboundTypeEnum.OutTray, + TaskNum = await BaseDal.GetTaskNo(), + Creater = "Systeam" + }; + + return task; + } + catch (Exception ex) + { + + throw new Exception(ex.Message); + } + } + + + #region 鐩存帴鍑哄簱浠诲姟瀹屾垚 public async Task<WebResponseContent> CompleteInToOutTaskAsync(Dt_Task task) { WebResponseContent content = new WebResponseContent(); @@ -723,10 +777,9 @@ } catch (Exception ex) { - return content.Error (ex.Message); + return content.Error(ex.Message); } - - return content; } + #endregion } \ No newline at end of file -- Gitblit v1.9.3