|  |  |  | 
|---|
|  |  |  | using Masuit.Tools; | 
|---|
|  |  |  | using WIDESEA_Common; | 
|---|
|  |  |  | using Mapster; | 
|---|
|  |  |  | using Masuit.Tools; | 
|---|
|  |  |  | using SixLabors.Fonts.Tables.AdvancedTypographic; | 
|---|
|  |  |  | using SqlSugar; | 
|---|
|  |  |  | using WIDESEA_Common.CustomModels; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //using WIDESEA_Common.CustomModels; | 
|---|
|  |  |  | using WIDESEA_Core.Const; | 
|---|
|  |  |  | using WIDESEA_DTO; | 
|---|
|  |  |  | using WIDESEA_DTO.MOM; | 
|---|
|  |  |  | using WIDESEA_DTO.WMS; | 
|---|
|  |  |  | using WIDESEA_Model.Models; | 
|---|
|  |  |  | using WIDESEAWCS_Model.Models; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.Models; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!result.Success) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<string> strings = new List<string>() { "2036","2038","2084","2086"}; | 
|---|
|  |  |  | if (input.Position.Contains(strings)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Console.WriteLine($"{result.MOMMessage}"); | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var taskNG = new Dt_Task | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CurrentAddress = input.Position, | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.InToOut, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | Creater = "System", | 
|---|
|  |  |  | ProductionLine = result.ProductionLine, | 
|---|
|  |  |  | ProcessCode = result.ProcessCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | return taskNG; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (result.SerialNos.Count <= 0) | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.InToOut, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam" | 
|---|
|  |  |  | Creater = "System" | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | return taskNG; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 处理异常电芯情况 | 
|---|
|  |  |  | var serialNosError = result.SerialNos.Where(x => x.SerialNoStatus != 1 && x.SerialNoStatus != 4).ToList(); | 
|---|
|  |  |  | if (serialNosError.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (stationManager.stationType != 3) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var taskNG = new Dt_Task | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CurrentAddress = input.Position, | 
|---|
|  |  |  | Grade = 1, | 
|---|
|  |  |  | Roadway = input.Roadways, | 
|---|
|  |  |  | TargetAddress = stationManager.stationNGLocation, | 
|---|
|  |  |  | Dispatchertime = DateTime.Now, | 
|---|
|  |  |  | MaterialNo = "", | 
|---|
|  |  |  | NextAddress = stationManager.stationNGChildCode, | 
|---|
|  |  |  | OrderNo = null, | 
|---|
|  |  |  | PalletCode = input.PalletCode, | 
|---|
|  |  |  | SourceAddress = stationManager.stationLocation, | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.InToOut, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | ProductionLine = result.ProductionLine, | 
|---|
|  |  |  | ProcessCode = result.ProcessCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | return taskNG; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Console.WriteLine($"站台{stationManager.stationChildCode}MOM返回电芯异常:{result.MOMMessage}"); | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //var serialNosError = result.SerialNos.Where(x => x.SerialNoStatus != 1 && x.SerialNoStatus != 4).ToList(); | 
|---|
|  |  |  | //if (serialNosError.Count > 0) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    if (stationManager.stationType != 3) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        var taskNG = new Dt_Task | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            CurrentAddress = input.Position, | 
|---|
|  |  |  | //            Grade = 1, | 
|---|
|  |  |  | //            Roadway = input.Roadways, | 
|---|
|  |  |  | //            TargetAddress = stationManager.stationNGLocation, | 
|---|
|  |  |  | //            Dispatchertime = DateTime.Now, | 
|---|
|  |  |  | //            MaterialNo = "", | 
|---|
|  |  |  | //            NextAddress = stationManager.stationNGChildCode, | 
|---|
|  |  |  | //            OrderNo = null, | 
|---|
|  |  |  | //            PalletCode = input.PalletCode, | 
|---|
|  |  |  | //            SourceAddress = stationManager.stationLocation, | 
|---|
|  |  |  | //            TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | //            TaskType = (int)TaskOutboundTypeEnum.InToOut, | 
|---|
|  |  |  | //            TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | //            Creater = "System", | 
|---|
|  |  |  | //            ProductionLine = result.ProductionLine, | 
|---|
|  |  |  | //            ProcessCode = result.ProcessCode, | 
|---|
|  |  |  | //        }; | 
|---|
|  |  |  | //        return taskNG; | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    else | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        Console.WriteLine($"站台{stationManager.stationChildCode}MOM返回电芯异常:{result.MOMMessage}"); | 
|---|
|  |  |  | //        return null; | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //else | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    throw new Exception($"站台{stationManager.stationChildCode}MOM返回电芯异常:{result.MOMMessage}"); | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.InToOut, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | Creater = "System", | 
|---|
|  |  |  | ProductionLine = result.ProductionLine, | 
|---|
|  |  |  | ProcessCode = result.ProcessCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.InToOut, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | Creater = "System", | 
|---|
|  |  |  | ProductionLine = result.ProductionLine, | 
|---|
|  |  |  | ProcessCode = result.ProcessCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | TaskType = stationManager.stationType == 1 ? (int)TaskInboundTypeEnum.Inbound : (int)TaskInboundTypeEnum.InTray, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | Creater = "System", | 
|---|
|  |  |  | ProductionLine = result.ProductionLine, | 
|---|
|  |  |  | ProcessCode = result.ProcessCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | locations = await _locationRepository.QueryDataAsync(x => x.LocationStatus == (int)LocationEnum.Distribute && x.RoadwayNo == requestTask.Roadways && x.EnalbeStatus == 1 && x.LocationType == 1); | 
|---|
|  |  |  | if (locations.IsNullOrEmpty()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | locations = await _locationRepository.QueryDataAsync(x => x.LocationStatus == (int)LocationEnum.Free && x.RoadwayNo == requestTask.Roadways && x.EnalbeStatus == 1 && x.LocationType == 1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (locations == null) | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (stationManager.stationType != 7) throw new Exception("错误的调取"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 从缓存中获取库存信息 | 
|---|
|  |  |  | //IDictionary<string, DtStockInfo>? stockInfos = _simpleCacheService.HashGetAll<DtStockInfo>(WIDESEA_Cache.CacheConst.Cache_DtStockInfo); | 
|---|
|  |  |  | //List<DtStockInfo> stockInfoList = stockInfos.Values.ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //var stockinfo1 = stockInfoList.OrderBy(x => x.CreateDate) | 
|---|
|  |  |  | //    .ToList(); | 
|---|
|  |  |  | //var stockinfo = stockinfo1.Where(x => x.LocationInfo != null && !x.IsFull && x.LocationInfo.RoadwayNo == stationManager.Roadway) | 
|---|
|  |  |  | //    .FirstOrDefault(); | 
|---|
|  |  |  | 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) | 
|---|
|  |  |  | .OrderBy(x=>x.CreateDate) | 
|---|
|  |  |  | .FirstAsync(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (stockinfo == null) return null; | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskState = (int)TaskOutStatusEnum.OutNew, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.OutTray, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | Creater = "System", | 
|---|
|  |  |  | ProductionLine = stockinfo.ProductionLine, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //_simpleCacheService.HashDel<DtStockInfo>(WIDESEA_Cache.CacheConst.Cache_DtStockInfo, new string[] { task.PalletCode }); | 
|---|
|  |  |  | return task; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region 直接出库任务完成 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public async Task<WebResponseContent> CompleteInToOutTaskAsync(Dt_Task task) | 
|---|
|  |  |  | public async Task<WebResponseContent> CompleteInToOutTaskAsync(Dt_Task task,DtStockInfo stock) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //添加历史 | 
|---|
|  |  |  | var taskHty = CreateHistoricalTask(task); | 
|---|
|  |  |  | // 添加历史任务 | 
|---|
|  |  |  | var isTaskHtyAdd = await _task_HtyRepository.AddDataAsync(taskHty) > 0; | 
|---|
|  |  |  | //删除任务 | 
|---|
|  |  |  | BaseDal.DeleteData(task); | 
|---|
|  |  |  | DtStockInfo_Hty stockInfo_Hty = null; | 
|---|
|  |  |  | if (stock != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo_Hty = stock.Adapt<DtStockInfo_Hty>(); | 
|---|
|  |  |  | stockInfo_Hty.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var taskHty = task.Adapt<Dt_Task_Hty>(); | 
|---|
|  |  |  | taskHty.FinishTime = DateTime.Now; | 
|---|
|  |  |  | taskHty.OperateType = App.User.UserName != null ? (int)OperateTypeEnum.人工完成 : (int)OperateTypeEnum.自动完成; | 
|---|
|  |  |  | taskHty.Creater = App.User.UserName != null ? App.User.UserName : "System"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var location = _locationRepository.QueryFirst(x => x.LocationCode == task.SourceAddress && x.RoadwayNo == task.Roadway); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(location != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | int lastStatus = location.LocationStatus; | 
|---|
|  |  |  | location.LocationStatus = (int)LocationEnum.Free; | 
|---|
|  |  |  | _locationStatusChangeRecordRepository.AddLocationStatusChangeRecord(location, lastStatus, (int)StatusChangeTypeEnum.AutomaticDelivery, task.TaskNum); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.TaskState = (int)TaskOutStatusEnum.OutFinish; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 事务处理 | 
|---|
|  |  |  | await _unitOfWorkManage.UseTranAsync(async () => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (stockInfo_Hty != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | await DeleteStockInfoAsync(stock.Id); | 
|---|
|  |  |  | await DeleteStockInfoDetailsAsync(stock.StockInfoDetails); | 
|---|
|  |  |  | await AddStockInfoHtyAsync(stockInfo_Hty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (location != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | await UpdateLocationAsync(location); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | await DeleteTaskAsync(task.TaskId); | 
|---|
|  |  |  | await AddTaskHtyAsync(taskHty); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return content.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | TaskType = (int)TaskInboundTypeEnum.InTray, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | Creater = "System", | 
|---|
|  |  |  | ProductionLine = result.ProductionLine, | 
|---|
|  |  |  | ProcessCode = result.ProcessCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.Line_InFinish, | 
|---|
|  |  |  | TaskType = (int)TaskInboundTypeEnum.Inbound, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | Creater = "System", | 
|---|
|  |  |  | ProductionLine = result.ProductionLine, | 
|---|
|  |  |  | ProcessCode = result.ProcessCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Thread.Sleep(10000); | 
|---|
|  |  |  | Thread.Sleep(TimeSpan.FromMinutes(10)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var area = await _areaInfoRepository.QueryFirstAsync(x => x.AreaCode == "GWSC1"); | 
|---|
|  |  |  | var devices = SqlSugarHelper.DbWCS.Queryable<Dt_DeviceInfo>() | 
|---|
|  |  |  | .Where(x => x.DeviceStatus == "1") | 
|---|
|  |  |  | .Where(x => x.DeviceCode.Contains("GWSC")) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  | var deviceCode = devices.Select(x => x.DeviceCode).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var stockInfo = await _stockInfoRepository.Db.Queryable<DtStockInfo>() | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) // 预加载LocationInfo | 
|---|
|  |  |  | .Includes(x => x.StockInfoDetails) // 预加载StockInfoDetails | 
|---|
|  |  |  | .Where(x => x.AreaCode == area.AreaCode && x.OutboundTime < DateTime.Now && x.IsFull == true) // 过滤条件 | 
|---|
|  |  |  | .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && x.LocationInfo.AreaId == area.AreaID) // 过滤条件 | 
|---|
|  |  |  | .WhereIF(!deviceCode.IsNullOrEmpty(), x => deviceCode.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | .OrderBy(x => x.OutboundTime) // 排序 | 
|---|
|  |  |  | .ToListAsync(); // 获取第一个元素 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region 常温补空托盘至分容 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private static readonly Dictionary<string, (int Count, DateTime LastRequestTime)> requestTrackerToCW = new(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public async Task<WebResponseContent> GetFROutTrayToCW(RequestTaskDto taskDTO) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //string requestKey = JsonConvert.SerializeObject(taskDTO); | 
|---|
|  |  |  | //// 检查请求次数和时间限制 | 
|---|
|  |  |  | //if (requestTrackerToCW.TryGetValue(requestKey, out var requestInfo)) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    if (requestInfo.Count > 5 && DateTime.Now < requestInfo.LastRequestTime.AddMinutes(2)) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        // 如果请求次数超过限制且未超过10分钟,抛出异常 | 
|---|
|  |  |  | //        throw new InvalidOperationException("请求次数已达到限制,请稍后再试。"); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //// 更新请求跟踪信息 | 
|---|
|  |  |  | //if (requestTrackerToCW.ContainsKey(requestKey)) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    requestTrackerToCW[requestKey] = (requestInfo.Count + 1, DateTime.Now); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //else | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    requestTrackerToCW[requestKey] = (1, DateTime.Now); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var station = _stationManagerRepository.QueryFirst(x => x.stationChildCode == taskDTO.Position && x.stationStatus == "1"); | 
|---|
|  |  |  | var locations = _locationRepository.QueryData(x => x.RoadwayNo == station.Roadway && x.LocationStatus == (int)LocationEnum.Free && x.LocationType == 1); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | _locationStatusChangeRecordRepository.AddLocationStatusChangeRecord(location, lastStatus, (int)StatusChangeTypeEnum.AutomaticDelivery, task.TaskNum); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 返回成功响应 | 
|---|
|  |  |  | //requestTrackerToCW.Remove(requestKey); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return content.OK(data: wmsTask); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteColorLine(station.Roadway, ConsoleColor.Magenta); | 
|---|
|  |  |  | var stackers = station.Roadway.Split(',').ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var devices = SqlSugarHelper.DbWCS.Queryable<Dt_DeviceInfo>() | 
|---|
|  |  |  | var deviceCode = SqlSugarHelper.DbWCS.Queryable<Dt_DeviceInfo>() | 
|---|
|  |  |  | .Where(x => x.DeviceStatus == "1") | 
|---|
|  |  |  | .Where(x => stackers.Contains(x.DeviceCode)) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  | .ToList().Select(x => x.DeviceCode).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var deviceCode = devices.Select(x => x.DeviceCode).ToList(); | 
|---|
|  |  |  | // 从缓存中获取库存信息 | 
|---|
|  |  |  | //IDictionary<string, DtStockInfo>? stockInfos = _simpleCacheService.HashGetAll<DtStockInfo>(WIDESEA_Cache.CacheConst.Cache_DtStockInfo); | 
|---|
|  |  |  | //List<DtStockInfo> stockInfoList = stockInfos.Values.ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //var result1 = stockInfoList.Where(x => x.ProductionLine == productLine) | 
|---|
|  |  |  | //    .Where(x => x.AreaCode == areaCode && x.IsFull == false) | 
|---|
|  |  |  | //    .WhereIF(!deviceCode.IsNullOrEmpty(), x => x.LocationInfo != null && deviceCode.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | //    .OrderBy(x => x.CreateDate) // 排序 | 
|---|
|  |  |  | //    .ToList(); // 转换为列表 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //var result = result1.Where(x => x.StockInfoDetails != null && x.StockInfoDetails.Any(y => y.MaterielCode == "空托盘")) | 
|---|
|  |  |  | //    .Where(x => x.LocationInfo != null && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && x.LocationInfo.AreaId == area.AreaID && x.LocationInfo.EnalbeStatus == (int)EnableEnum.Enable) // 过滤条件 | 
|---|
|  |  |  | //    .FirstOrDefault(); // 获取第一个元素 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //if (result != null) | 
|---|
|  |  |  | //    _simpleCacheService.HashDel<DtStockInfo>(WIDESEA_Cache.CacheConst.Cache_DtStockInfo, new string[] { result.PalletCode }); | 
|---|
|  |  |  | //else | 
|---|
|  |  |  | //    ConsoleHelper.WriteColorLine($"常温{productLine}空托盘库存不足", ConsoleColor.Red); | 
|---|
|  |  |  | var result = await _stockInfoRepository.Db.Queryable<DtStockInfo>() | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) // 预加载LocationInfo | 
|---|
|  |  |  | .Includes(x => x.StockInfoDetails) // 预加载StockInfoDetails | 
|---|
|  |  |  | .Where(x => x.ProductionLine == productLine) | 
|---|
|  |  |  | .Where(x => x.AreaCode == areaCode && x.IsFull == false) | 
|---|
|  |  |  | .Where(x => x.StockInfoDetails.Any(y => y.MaterielCode == "空托盘")) | 
|---|
|  |  |  | .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && x.LocationInfo.AreaId == area.AreaID && x.LocationInfo.EnalbeStatus == (int)EnableEnum.Enable) // 过滤条件 | 
|---|
|  |  |  | .WhereIF(!deviceCode.IsNullOrEmpty(), x => deviceCode.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | .OrderBy(x => x.CreateDate) // 排序 | 
|---|
|  |  |  | .FirstAsync(); // 转换为列表 | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) | 
|---|
|  |  |  | .Includes(x => x.StockInfoDetails) | 
|---|
|  |  |  | .Where(x => x.AreaCode == areaCode && x.IsFull == false && x.ProductionLine == productLine) | 
|---|
|  |  |  | .WhereIF(!deviceCode.IsNullOrEmpty(), x => deviceCode.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && x.LocationInfo.AreaId == area.AreaID && x.LocationInfo.EnalbeStatus == (int)EnableEnum.Enable) // 过滤条件 | 
|---|
|  |  |  | .Where(x => x.StockInfoDetails.Any(y => y.MaterielCode == "空托盘")) | 
|---|
|  |  |  | .OrderBy(x => x.CreateDate) // 排序 | 
|---|
|  |  |  | .FirstAsync(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //var firstOrDefault = result[0]; // 查找第一个匹配的元素 | 
|---|
|  |  |  | //return firstOrDefault; | 
|---|
|  |  |  | if (result.IsNullOrEmpty()) | 
|---|
|  |  |  | ConsoleHelper.WriteColorLine($"常温{productLine}空托盘库存不足", ConsoleColor.Red); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return result; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region  常温3出库至包装 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 用于追踪每个请求的调用次数和最后请求时间。 | 
|---|
|  |  |  | private static readonly Dictionary<string, (int Count, DateTime LastRequestTime)> requestTracker = new(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 常温3出库至包装 | 
|---|
|  |  |  | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_StationManager station = _stationManagerRepository.QueryFirst(x => x.stationChildCode == json.Position && x.stationType == 12 && x.stationArea == "Call"); | 
|---|
|  |  |  | if (station == null) { throw new Exception($"未找到包装站台信息,请检查传入参数{json.Position}"); } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var stockInfo = _stockInfoRepository.Db.Queryable<DtStockInfo>() | 
|---|
|  |  |  | .Where(x => x.ProductionLine == station.productLine) | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) // 预加载LocationInfo | 
|---|
|  |  |  | .Where(x => x.AreaCode == "CWSC3" && x.IsFull == true) // 过滤条件 | 
|---|
|  |  |  | .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock) // 过滤条件 | 
|---|
|  |  |  | .OrderBy(x => x.OutboundTime) // 排序 | 
|---|
|  |  |  | .First(); // 获取第一个元素 | 
|---|
|  |  |  | EqptRunDto basic = new EqptRunDto() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | EquipmentModel = "0", | 
|---|
|  |  |  | Password ="", | 
|---|
|  |  |  | EmployeeNo = "82412152", | 
|---|
|  |  |  | SessionId = Guid.NewGuid().ToString(), | 
|---|
|  |  |  | RequestTime = TimeZoneInfo.ConvertTimeToUtc(DateTime.Now).ToString("yyyy-MM-ddTHH:mm:ss.fffZ"), | 
|---|
|  |  |  | Software = "包装上料", | 
|---|
|  |  |  | EquipmentCode = station.stationEquipMOM, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | var result = _agingInOrOutInputService.Change(basic).Result; | 
|---|
|  |  |  | var respone = JsonConvert.DeserializeObject<EqptRunDTO>(result.Data.ToString()); | 
|---|
|  |  |  | if(!result.Status || !respone.Success) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception($"{station.productLine}获取MOM换型数据异常,异常信息{respone.MOMMessage}"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //DtStockInfo stockInfo = _stockInfoRepository.QueryFirst(X => X.IsFull && X.AreaCode == "CWSC3" && X.ProductionLine == station.productLine); | 
|---|
|  |  |  | if (stockInfo == null) throw new Exception("库内无满足条件的库存可出库"); | 
|---|
|  |  |  | var deviceCode = SqlSugarHelper.DbWCS.Queryable<Dt_DeviceInfo>() | 
|---|
|  |  |  | .Where(x => x.DeviceStatus == "1") | 
|---|
|  |  |  | .Where(x => x.DeviceCode.Contains("CWSC")) // 过滤条件 | 
|---|
|  |  |  | .ToList().Select(x => x.DeviceCode).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //var outBoundMateriel = _dt_ChangeoversRepository.QueryData(x => x.Status == "1").ToList(); | 
|---|
|  |  |  | //List<string>? materielCodes = outBoundMateriel.Count != 0 | 
|---|
|  |  |  | //    ? outBoundMateriel.Where(x => x.ProductionLine == station.productLine && x.ProcessCode == "CWSC3") | 
|---|
|  |  |  | //                      .Select(x => x.MaterielCode) | 
|---|
|  |  |  | //                      .ToList() | 
|---|
|  |  |  | //    : null; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region Redis缓存查询代码 | 
|---|
|  |  |  | //// 从缓存中获取库存信息 | 
|---|
|  |  |  | //IDictionary<string, DtStockInfo>? stockInfos = _simpleCacheService.HashGetAll<DtStockInfo>(WIDESEA_Cache.CacheConst.Cache_DtStockInfo); | 
|---|
|  |  |  | //List<DtStockInfo> stockInfoList = stockInfos.Values.ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //// 修改后的查询代码 | 
|---|
|  |  |  | //var stockInfo1 = stockInfoList | 
|---|
|  |  |  | //    .Where(x => x.ProductionLine == station.productLine) | 
|---|
|  |  |  | //    .Where(x => x.AreaCode == "CWSC3" && x.IsFull == true) | 
|---|
|  |  |  | //    .OrderBy(x => x.OutboundTime) | 
|---|
|  |  |  | //    .ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //var stockInfo = stockInfo1 | 
|---|
|  |  |  | //    // 增加对 LocationInfo 的空值检查 | 
|---|
|  |  |  | //    .Where(x => x.LocationInfo != null && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock) | 
|---|
|  |  |  | //    // 增加对 LocationInfo 的空值检查 | 
|---|
|  |  |  | //    .WhereIF(!deviceCode.IsNullOrEmpty(), x => x.LocationInfo != null && deviceCode.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | //    .WhereIF(!materielCodes.IsNullOrEmpty(), x => x.StockInfoDetails != null && x.StockInfoDetails.Any(y => materielCodes.Contains(y.MaterielCode))) | 
|---|
|  |  |  | //    .FirstOrDefault(); | 
|---|
|  |  |  | // 修改后的查询代码 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //var stockInfo = await _stockInfoRepository.Db.Queryable<DtStockInfo>() | 
|---|
|  |  |  | //                    .Includes(x => x.LocationInfo) | 
|---|
|  |  |  | //                    .Includes(x => x.StockInfoDetails) | 
|---|
|  |  |  | //                    .Where(x => x.ProductionLine == station.productLine) | 
|---|
|  |  |  | //                    .Where(x => x.AreaCode == "CWSC3" && x.IsFull == true) | 
|---|
|  |  |  | //                    // 增加对 LocationInfo 的空值检查 | 
|---|
|  |  |  | //                    .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock) | 
|---|
|  |  |  | //                    // 增加对 LocationInfo 的空值检查 | 
|---|
|  |  |  | //                    .WhereIF(!deviceCode.IsNullOrEmpty(), x => deviceCode.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | //                    .WhereIF(!materielCodes.IsNullOrEmpty(), x => x.StockInfoDetails.Any(y => materielCodes.Contains(y.MaterielCode))) | 
|---|
|  |  |  | //                    .OrderBy(x => x.OutboundTime) | 
|---|
|  |  |  | //                    .FirstAsync(); | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  |  | 
|---|
|  |  |  | DtStockInfo stockInfo = null; | 
|---|
|  |  |  | var stockInfoList = await _stockInfoRepository.Db.Queryable<DtStockInfo>() | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) | 
|---|
|  |  |  | .Where(x => x.ProductionLine == station.productLine | 
|---|
|  |  |  | && x.AreaCode == "CWSC3" | 
|---|
|  |  |  | && x.IsFull == true | 
|---|
|  |  |  | && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock) | 
|---|
|  |  |  | .WhereIF(!deviceCode.IsNullOrEmpty(), x => deviceCode.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | .OrderBy(x => x.OutboundTime) | 
|---|
|  |  |  | .ToListAsync(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | foreach (var stock in stockInfoList) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var hasMatchingDetail = await _stockInfoRepository.Db.Queryable<DtStockInfoDetail>() | 
|---|
|  |  |  | .Where(d => d.StockId == stock.Id && respone.PreProductNo.Contains(d.MaterielCode)) | 
|---|
|  |  |  | .AnyAsync(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (hasMatchingDetail) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | stockInfo = stock; | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (stockInfo == null) throw new Exception($"CWSC3库内【{station.productLine}】,【物料编码{respone.PreProductNo}】无满足条件的库存可出库"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | DtLocationInfo locationInfo = _locationRepository.QueryFirst(x => x.AreaId == 5 && x.LocationCode == stockInfo.LocationCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | SourceAddress = stockInfo.LocationCode, | 
|---|
|  |  |  | TaskState = (int)TaskOutStatusEnum.OutNew, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.Outbound, | 
|---|
|  |  |  | TaskNum = await BaseDal.GetTaskNo(), | 
|---|
|  |  |  | Creater = "Systeam", | 
|---|
|  |  |  | TaskNum = BaseDal.GetTaskNo().Result, | 
|---|
|  |  |  | Creater = "System", | 
|---|
|  |  |  | ProductionLine = stockInfo.ProductionLine, | 
|---|
|  |  |  | ProcessCode = stockInfo.ProcessCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WMSTaskDTO taskDTO = CreateTaskDTO(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int lastStatus = locationInfo.LocationStatus; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BaseDal.AddData(task); | 
|---|
|  |  |  | stockInfo.LocationInfo.LocationStatus = (int)LocationEnum.InStockDisable; | 
|---|
|  |  |  | _locationRepository.UpdateData(stockInfo.LocationInfo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //_simpleCacheService.HashDel<DtStockInfo>(WIDESEA_Cache.CacheConst.Cache_DtStockInfo, new string[] { taskDTO.PalletCode }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _locationStatusChangeRecordRepository.AddLocationStatusChangeRecord(stockInfo.LocationInfo, lastStatus, (int)StatusChangeTypeEnum.AutomaticDelivery, task.TaskNum); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Console.WriteLine($"CW3至包装出库异常:{ex.ToString()}"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | LogFactory.GetLog($"包装请求出库任务").Info(true, $"【异常】:【{ex.Message}】{Environment.NewLine}【{ex.StackTrace}】{Environment.NewLine}{Environment.NewLine}"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return content.Error($"失败:{ex.Message}"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region 火警出库 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public WebResponseContent EmergencyTask(object obj) | 
|---|
|  |  |  | public WebResponseContent EmergencyTask(Object obj) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | var emergencyTask = new DTSEmergencyTask(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Console.WriteLine($"火警参数:{obj.ToString()}"); | 
|---|
|  |  |  | emergencyTask = JsonConvert.DeserializeObject<DTSEmergencyTask>(obj.ToString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (emergencyTask == null) throw new Exception("火警参数为空"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | DtLocationInfo locationInfo = _locationRepository.QueryFirst(x => x.Row == emergencyTask.row && x.Column == emergencyTask.column && x.Layer == emergencyTask.layer && x.AreaId == emergencyTask.zone); | 
|---|
|  |  |  | if (locationInfo == null) | 
|---|
|  |  |  | string[] strings = emergencyTask.LocationCode.Split("-"); | 
|---|
|  |  |  | string Roadway = strings[0]; | 
|---|
|  |  |  | //switch (Roadways[0]) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    case "J": | 
|---|
|  |  |  | //        Roadway = "JZSC" + Roadways[1]; | 
|---|
|  |  |  | //        break; | 
|---|
|  |  |  | //    case "G": | 
|---|
|  |  |  | //        Roadway = "GWSC" + Roadways[1]; | 
|---|
|  |  |  | //        break; | 
|---|
|  |  |  | //    case "C": | 
|---|
|  |  |  | //        Roadway = "CWSC" + Roadways[1]; | 
|---|
|  |  |  | //        break; | 
|---|
|  |  |  | //    default: throw new Exception("未识别库位编码"); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | int Row = Convert.ToInt16(strings[1]); | 
|---|
|  |  |  | int Column= Convert.ToInt16(strings[2]); | 
|---|
|  |  |  | int Layer= Convert.ToInt16(strings[3]); | 
|---|
|  |  |  | if (!strings[0].Contains("SC")) throw new Exception("未知库区"); | 
|---|
|  |  |  | for (int i = 0; i < 2; i++) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("未知库位"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //查找消防站台 | 
|---|
|  |  |  | var station = _stationManagerRepository.QueryFirst(t => t.Roadway == locationInfo.RoadwayNo | 
|---|
|  |  |  | && t.stationType == (int)StationManager.FireStation | 
|---|
|  |  |  | /*&& t. == "Enable"*/); | 
|---|
|  |  |  | if (station == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("消防站台未配置!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //查找库存信息 | 
|---|
|  |  |  | var stockInfo = _stockInfoRepository.QueryFirst(x => x.LocationCode == locationInfo.LocationCode && x.LocationInfo.RoadwayNo == locationInfo.RoadwayNo); | 
|---|
|  |  |  | //托盘码 | 
|---|
|  |  |  | string barcode = string.Empty; | 
|---|
|  |  |  | if (stockInfo != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | barcode = stockInfo.PalletCode; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //无库存信息,生成随机托盘码 | 
|---|
|  |  |  | barcode = "M" + DateTime.Now.ToString("MMddHHmmss") + "-" + new Random().Next(100, 1000); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Task fireTask = BaseDal.QueryFirst(x => x.TaskType == 500 && x.SourceAddress == locationInfo.LocationCode && x.Roadway == station.Roadway); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (fireTask != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("已添加火警出库任务"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int taskNum = BaseDal.GetTaskNo().Result; | 
|---|
|  |  |  | Dt_Task task = new Dt_Task | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CreateDate = DateTime.Now, | 
|---|
|  |  |  | Creater = "DTS", | 
|---|
|  |  |  | CurrentAddress = locationInfo.LocationCode, | 
|---|
|  |  |  | Grade = 1, | 
|---|
|  |  |  | Dispatchertime = DateTime.Now, | 
|---|
|  |  |  | PalletCode = barcode, | 
|---|
|  |  |  | Roadway = station.Roadway, | 
|---|
|  |  |  | SourceAddress = locationInfo.LocationCode, | 
|---|
|  |  |  | TaskState = (int)TaskOutStatusEnum.OutNew, | 
|---|
|  |  |  | TaskType = 500, | 
|---|
|  |  |  | TargetAddress = station.stationLocation, | 
|---|
|  |  |  | NextAddress = station.stationChildCode, | 
|---|
|  |  |  | TaskNum = taskNum, //_taskRepository.GetTaskNo().Result, | 
|---|
|  |  |  | TaskId = 0, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 尝试添加新任务 | 
|---|
|  |  |  | WMSTaskDTO taskDTO = new WMSTaskDTO() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | TaskNum = task.TaskNum.Value, | 
|---|
|  |  |  | Grade = 1, | 
|---|
|  |  |  | PalletCode = task.PalletCode, | 
|---|
|  |  |  | RoadWay = task.Roadway, | 
|---|
|  |  |  | SourceAddress = task.SourceAddress, | 
|---|
|  |  |  | TargetAddress = task.TargetAddress, | 
|---|
|  |  |  | TaskState = task.TaskState.Value, | 
|---|
|  |  |  | Id = 0, | 
|---|
|  |  |  | TaskType = 500, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var configs = _configService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress); | 
|---|
|  |  |  | var ipAddress = configs.FirstOrDefault(x => x.ConfigKey == SysConfigConst.WCSIPAddress)?.ConfigValue; | 
|---|
|  |  |  | var ReceiveByWMSTask = configs.FirstOrDefault(x => x.ConfigKey == SysConfigConst.ReceiveByWMSTask)?.ConfigValue; | 
|---|
|  |  |  | if (ReceiveByWMSTask == null || ipAddress == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("WMS IP 未配置"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var wmsIpAddrss = ipAddress + ReceiveByWMSTask; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var respon = HttpHelper.Post(wmsIpAddrss, JsonConvert.SerializeObject(taskDTO)); | 
|---|
|  |  |  | if (respon != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent respone = JsonConvert.DeserializeObject<WebResponseContent>(respon.ToString()); | 
|---|
|  |  |  | if (respone.Status) | 
|---|
|  |  |  | DtLocationInfo locationInfo = _locationRepository.QueryFirst(x => x.Row == Row && x.Column == Column && x.Layer == (i == 0 ? Layer - 1 : Layer) && x.RoadwayNo == Roadway); | 
|---|
|  |  |  | if (locationInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var taskId = BaseDal.AddData(task); | 
|---|
|  |  |  | throw new Exception("未知库位"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //查找消防站台 | 
|---|
|  |  |  | var station = _stationManagerRepository.QueryFirst(t => t.Roadway == locationInfo.RoadwayNo && t.stationType == (int)StationManager.FireStation); | 
|---|
|  |  |  | if (station == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("消防站台未配置!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //查找库存信息 | 
|---|
|  |  |  | var stockInfo = _stockInfoRepository.QueryFirst(x => x.LocationCode == locationInfo.LocationCode && x.LocationInfo.RoadwayNo == locationInfo.RoadwayNo); | 
|---|
|  |  |  | //托盘码 | 
|---|
|  |  |  | string barcode = string.Empty; | 
|---|
|  |  |  | if (stockInfo != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | barcode = stockInfo.PalletCode; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("WCS处理失败:" + respone.Message); | 
|---|
|  |  |  | //无库存信息,生成随机托盘码 | 
|---|
|  |  |  | barcode = "M" + DateTime.Now.ToString("MMddHHmmss") + "-" + new Random().Next(100, 1000); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("请求处理失败"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Task fireTask = BaseDal.QueryFirst(x => x.TaskType == (int)TaskOutboundTypeEnum.OutFireAlarm && x.SourceAddress == locationInfo.LocationCode && x.Roadway == station.Roadway); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (fireTask != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("已添加火警出库任务"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int taskNum = BaseDal.GetTaskNo().Result; | 
|---|
|  |  |  | Dt_Task task = new Dt_Task | 
|---|
|  |  |  | { | 
|---|
|  |  |  | CreateDate = DateTime.Now, | 
|---|
|  |  |  | Creater = "DTS", | 
|---|
|  |  |  | CurrentAddress = locationInfo.LocationCode, | 
|---|
|  |  |  | Grade = i == 0 ? 5 : 3, | 
|---|
|  |  |  | Dispatchertime = DateTime.Now, | 
|---|
|  |  |  | PalletCode = barcode, | 
|---|
|  |  |  | Roadway = station.Roadway, | 
|---|
|  |  |  | SourceAddress = locationInfo.LocationCode, | 
|---|
|  |  |  | TaskState = (int)TaskOutStatusEnum.OutNew, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.OutFireAlarm, | 
|---|
|  |  |  | TargetAddress = station.stationLocation, | 
|---|
|  |  |  | NextAddress = station.stationLocation, | 
|---|
|  |  |  | TaskNum = taskNum, //_taskRepository.GetTaskNo().Result, | 
|---|
|  |  |  | TaskId = 0, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 尝试添加新任务 | 
|---|
|  |  |  | WMSTaskDTO taskDTO = new WMSTaskDTO() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | TaskNum = task.TaskNum.Value, | 
|---|
|  |  |  | Grade = 1, | 
|---|
|  |  |  | PalletCode = task.PalletCode, | 
|---|
|  |  |  | RoadWay = task.Roadway, | 
|---|
|  |  |  | SourceAddress = task.SourceAddress, | 
|---|
|  |  |  | TargetAddress = task.TargetAddress, | 
|---|
|  |  |  | TaskState = task.TaskState.Value, | 
|---|
|  |  |  | Id = 0, | 
|---|
|  |  |  | TaskType = task.TaskType, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<WMSTaskDTO> taskDTOs = new List<WMSTaskDTO>(); | 
|---|
|  |  |  | taskDTOs.Add(taskDTO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var configs = _configService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress); | 
|---|
|  |  |  | var ipAddress = configs.FirstOrDefault(x => x.ConfigKey == SysConfigConst.WCSIPAddress)?.ConfigValue; | 
|---|
|  |  |  | var ReceiveByWMSTask = configs.FirstOrDefault(x => x.ConfigKey == SysConfigConst.ReceiveWMSTask)?.ConfigValue; | 
|---|
|  |  |  | if (ReceiveByWMSTask == null || ipAddress == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("WMS IP 未配置"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var wmsIpAddrss = ipAddress + ReceiveByWMSTask; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var respon = HttpHelper.Post(wmsIpAddrss, JsonConvert.SerializeObject(taskDTOs)); | 
|---|
|  |  |  | if (respon != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent respone = JsonConvert.DeserializeObject<WebResponseContent>(respon.ToString()); | 
|---|
|  |  |  | if (respone.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var taskId = BaseDal.AddData(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("WCS处理失败:" + respone.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("请求处理失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LogFactory.GetLog("DTS火警出库").Info(true, $"\r\r--------------------------------------"); | 
|---|
|  |  |  | LogFactory.GetLog("DTS火警出库").Info(true, obj.ToJsonString()); | 
|---|
|  |  |  | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region 分容空框入库改为直接出库 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public async Task<WebResponseContent> SetEmptyOutbyInToOutAsync(RequestTaskDto request) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | var task = await BaseDal.QueryFirstAsync(x => x.PalletCode == request.PalletCode && x.CurrentAddress == request.Position); | 
|---|
|  |  |  | var task = await BaseDal.QueryFirstAsync(x => x.PalletCode == request.PalletCode); | 
|---|
|  |  |  | if (!task.IsNullOrEmpty()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var fromStation = await _stationManagerRepository.QueryFirstAsync(x => x.stationChildCode == request.Position); | 
|---|
|  |  |  | var toStation = await _stationManagerRepository.QueryFirstAsync(x => x.stationType == 7 && x.productLine == fromStation.productLine && x.stationArea == fromStation.stationArea); | 
|---|
|  |  |  | if (!toStation.IsNullOrEmpty()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var location = await _locationRepository.QueryFirstAsync(x => x.LocationCode == task.TargetAddress && x.AreaId == int.Parse(fromStation.stationArea)); | 
|---|
|  |  |  | task.TargetAddress = toStation.stationLocation; | 
|---|
|  |  |  | task.NextAddress = toStation.stationChildCode; | 
|---|
|  |  |  | task.Grade = 3; | 
|---|
|  |  |  | task.TaskType = (int)TaskOutboundTypeEnum.InToOut; | 
|---|
|  |  |  | task.TaskState = (int)TaskOutStatusEnum.OutNew; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var location = await _locationRepository.QueryFirstAsync(x => x.LocationCode == task.TargetAddress); | 
|---|
|  |  |  | location.LocationStatus = (int)LocationEnum.Free; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | await _locationRepository.UpdateDataAsync(location); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region 分容空框出库改为直接出库 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 分容空框出库改为直接出库 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="request"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public async Task<WebResponseContent> SetEmptyOutbyInToOutOneAsync(RequestTaskDto request) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | var task = await BaseDal.QueryFirstAsync(x => x.PalletCode == request.PalletCode); | 
|---|
|  |  |  | if (!task.IsNullOrEmpty()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var toStation = await _stationManagerRepository.QueryFirstAsync(x => x.stationChildCode == request.Position); | 
|---|
|  |  |  | var fromStation = await _stationManagerRepository.QueryFirstAsync(x => x.stationType == 6 && x.productLine == toStation.productLine && x.stationArea == toStation.stationArea); | 
|---|
|  |  |  | if (!fromStation.IsNullOrEmpty()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //var location = await _locationRepository.QueryFirstAsync(x => x.LocationCode == task.TargetAddress && x.AreaId == int.Parse(fromStation.stationArea)); | 
|---|
|  |  |  | task.SourceAddress = toStation.stationLocation; | 
|---|
|  |  |  | task.CurrentAddress = toStation.stationChildCode; | 
|---|
|  |  |  | task.Grade = 3; | 
|---|
|  |  |  | task.TaskType = (int)TaskOutboundTypeEnum.InToOut; | 
|---|
|  |  |  | task.TaskState = (int)TaskOutStatusEnum.OutNew; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //location.LocationStatus = (int)LocationEnum.Free; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //await _locationRepository.UpdateDataAsync(location); | 
|---|
|  |  |  | await BaseDal.UpdateDataAsync(task); | 
|---|
|  |  |  | return content.OK("成功"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine("分容空框出库改为直接出库:未找到对应站台"); | 
|---|
|  |  |  | content.Error("未找到对应站台"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine("分容空框出库改为直接出库:未找到任务"); | 
|---|
|  |  |  | content.Error("未找到任务"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 获取任务类型描述方法 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="taskType"></param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | private string GetTaskTypeDesc(int taskType) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return taskType switch | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (int)TaskInboundTypeEnum.Inbound => TaskInboundTypeEnum.Inbound.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskInboundTypeEnum.InTray => TaskInboundTypeEnum.InTray.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskInboundTypeEnum.InNG => TaskInboundTypeEnum.InNG.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskInboundTypeEnum.InQuality => TaskInboundTypeEnum.InQuality.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutboundTypeEnum.OutTray => TaskOutboundTypeEnum.OutTray.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutboundTypeEnum.Outbound => TaskOutboundTypeEnum.Outbound.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutboundTypeEnum.OutNG => TaskOutboundTypeEnum.OutNG.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutboundTypeEnum.InToOut=> TaskOutboundTypeEnum.InToOut.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region 大屏接口 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 获取任务信息 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public WebResponseContent GetTaskInfo() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var task = BaseDal.QueryData(x => true).ToList(); | 
|---|
|  |  |  | var newTask = task.Select(x => new | 
|---|
|  |  |  | { | 
|---|
|  |  |  | x.PalletCode, | 
|---|
|  |  |  | x.Roadway, | 
|---|
|  |  |  | x.SourceAddress, | 
|---|
|  |  |  | x.TargetAddress, | 
|---|
|  |  |  | x.ProductionLine, | 
|---|
|  |  |  | TaskType = new List<string> { GetTaskTypeDesc(x.TaskType) }[0], // 每个任务独立生成 TaskType | 
|---|
|  |  |  | TaskState = new List<string> { GetTaskStateDesc(x.TaskState) }[0] // 每个任务独立生成 TaskState | 
|---|
|  |  |  | }).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return content.OK(data: newTask); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 定义获取任务状态描述方法 | 
|---|
|  |  |  | private string GetTaskStateDesc(int? taskState) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return taskState switch | 
|---|
|  |  |  | { | 
|---|
|  |  |  | (int)TaskInStatusEnum.InNew => TaskInStatusEnum.InNew.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskInStatusEnum.Line_InExecuting => TaskInStatusEnum.Line_InExecuting.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskInStatusEnum.Line_InFinish => TaskInStatusEnum.Line_InFinish.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskInStatusEnum.SC_InExecuting => TaskInStatusEnum.SC_InExecuting.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskInStatusEnum.SC_InFinish => TaskInStatusEnum.SC_InFinish.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutStatusEnum.OutNew => TaskOutStatusEnum.OutNew.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutStatusEnum.SC_OutExecuting => TaskOutStatusEnum.SC_OutExecuting.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutStatusEnum.SC_OutFinish => TaskOutStatusEnum.SC_OutFinish.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutStatusEnum.Line_OutExecuting => TaskOutStatusEnum.Line_OutExecuting.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | (int)TaskOutStatusEnum.Line_OutFinish => TaskOutStatusEnum.Line_OutFinish.GetIntegralRuleTypeEnumDesc(), | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 获取库存信息 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public WebResponseContent GetStockInfo() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var now = DateTime.Now; | 
|---|
|  |  |  | var startOfDay = new DateTime(now.Year, now.Month, now.Day); | 
|---|
|  |  |  | var endOfDay = startOfDay.AddDays(1); | 
|---|
|  |  |  | var result = _stockInfoRepository.Db.Queryable<DtStockInfo>().ToList(); | 
|---|
|  |  |  | return content.OK(data: result); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 获取货位状态 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public WebResponseContent GetStockQuantity() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var location = _locationRepository.Db.Queryable<DtLocationInfo>().ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return content.OK(data: location); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | public WebResponseContent Getproductionvolume() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var now = DateTime.Now; | 
|---|
|  |  |  | var startOfDay = new DateTime(now.Year, now.Month, now.Day); | 
|---|
|  |  |  | var endOfDay1 = startOfDay.AddDays(-7); | 
|---|
|  |  |  | var taskHty = _task_HtyRepository.Db.Queryable<Dt_Task_Hty>().Where(it => it.CreateDate > endOfDay1).ToList(); | 
|---|
|  |  |  | return content.OK(data: taskHty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public WebResponseContent Getoutput() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var now = DateTime.Now; | 
|---|
|  |  |  | var firstDayOfYear = new DateTime(now.Year, 1, 1); | 
|---|
|  |  |  | var taskHty = _task_HtyRepository.Db.Queryable<Dt_Task_Hty>().Where(it => it.CreateDate > firstDayOfYear && it.TaskType == 100).ToList(); | 
|---|
|  |  |  | return content.OK(data: taskHty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  | public WebResponseContent GetTimeout() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var now = DateTime.Now; | 
|---|
|  |  |  | // 使用Subtract方法 | 
|---|
|  |  |  | var threeHoursAgo = now.Subtract(TimeSpan.FromHours(3)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<DtStockInfo> dtStocks = _stockInfoRepository.Db.Queryable<DtStockInfo>() | 
|---|
|  |  |  | .Where(x => x.OutboundTime < threeHoursAgo).ToList(); | 
|---|
|  |  |  | return content.OK1(total1:dtStocks.Count, data: dtStocks); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | public WebResponseContent Getproductionstatistics() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var now = DateTime.Now; | 
|---|
|  |  |  | var thirtyDaysAgo = now.AddDays(-30); | 
|---|
|  |  |  | var roadwayMappings = new Dictionary<string, string> { | 
|---|
|  |  |  | { "JZ", "静置库" }, | 
|---|
|  |  |  | { "CH", "陈化库" }, | 
|---|
|  |  |  | { "FR", "分容库" }, | 
|---|
|  |  |  | { "GW", "高温库" }, | 
|---|
|  |  |  | { "CW", "常温库" } | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | var roadwayKeys = roadwayMappings.Keys.ToArray(); | 
|---|
|  |  |  | var taskTypes = new[] { 100, 104, 200, 204 }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var taskHty = _task_HtyRepository.Db.Queryable<Dt_Task_Hty>() | 
|---|
|  |  |  | .Where(it => | 
|---|
|  |  |  | it.CreateDate >= thirtyDaysAgo && | 
|---|
|  |  |  | it.CreateDate <= now && | 
|---|
|  |  |  | taskTypes.Contains(it.TaskType) && | 
|---|
|  |  |  | roadwayKeys.Any(rk => it.Roadway.Contains(rk))) | 
|---|
|  |  |  | .ToList() | 
|---|
|  |  |  | .Select(t => new { | 
|---|
|  |  |  | OriginalRoadway = t.Roadway, | 
|---|
|  |  |  | RoadwayKey = roadwayKeys.FirstOrDefault(rk => t.Roadway.Contains(rk)), | 
|---|
|  |  |  | TaskType = t.TaskType, | 
|---|
|  |  |  | CreateDate = t.CreateDate | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .Where(t => t.RoadwayKey != null) | 
|---|
|  |  |  | .GroupBy(t => new { | 
|---|
|  |  |  | RoadwayKey = t.RoadwayKey, | 
|---|
|  |  |  | Date = t.CreateDate.Date, | 
|---|
|  |  |  | Hour = t.CreateDate.Hour | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .OrderByDescending(group => group.Key.Date) | 
|---|
|  |  |  | .ThenByDescending(group => group.Key.Hour) | 
|---|
|  |  |  | .Select(group => new TaskHourData | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Hour = $"{group.Key.Date:yyyy/M/d} {(group.Key.Hour == 23 ? "23:00-24:00" : $"{group.Key.Hour}:00-{group.Key.Hour + 1}:00")}", | 
|---|
|  |  |  | Roadway = roadwayMappings[group.Key.RoadwayKey], | 
|---|
|  |  |  | TaskType100Count = group.Count(t => t.TaskType == 100), | 
|---|
|  |  |  | TaskType104Count = group.Count(t => t.TaskType == 104), | 
|---|
|  |  |  | TaskType200Count = group.Count(t => t.TaskType == 200), | 
|---|
|  |  |  | TaskType204Count = group.Count(t => t.TaskType == 204) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 按日期和库位分组,找出每天的最后一个小时 | 
|---|
|  |  |  | var dailyLastHours = taskHty | 
|---|
|  |  |  | .GroupBy(item => new { | 
|---|
|  |  |  | Date = DateTime.Parse(item.Hour.Split(' ')[0]), | 
|---|
|  |  |  | item.Roadway | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .Select(group => new { | 
|---|
|  |  |  | Date = group.Key.Date, | 
|---|
|  |  |  | Roadway = group.Key.Roadway, | 
|---|
|  |  |  | LastHour = group.Max(item => int.Parse(item.Hour.Split(' ')[1].Split(':')[0])) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 生成汇总数据(调整Hour格式为"日期+日汇总") | 
|---|
|  |  |  | var summaryItems = dailyLastHours | 
|---|
|  |  |  | .Select(dailyLastHour => { | 
|---|
|  |  |  | // 找到该日期该库位的所有小时数据 | 
|---|
|  |  |  | var dailyItems = taskHty | 
|---|
|  |  |  | .Where(item => | 
|---|
|  |  |  | DateTime.Parse(item.Hour.Split(' ')[0]) == dailyLastHour.Date && | 
|---|
|  |  |  | item.Roadway == dailyLastHour.Roadway) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return new TaskHourData | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Hour = $"{dailyLastHour.Date:yyyy/M/d}日汇总", // 修改Hour格式 | 
|---|
|  |  |  | Roadway = dailyLastHour.Roadway, | 
|---|
|  |  |  | TaskType100Count = dailyItems.Sum(item => item.TaskType100Count), | 
|---|
|  |  |  | TaskType104Count = dailyItems.Sum(item => item.TaskType104Count), | 
|---|
|  |  |  | TaskType200Count = dailyItems.Sum(item => item.TaskType200Count), | 
|---|
|  |  |  | TaskType204Count = dailyItems.Sum(item => item.TaskType204Count), | 
|---|
|  |  |  | IsSummary = true | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 将汇总数据添加到结果中 | 
|---|
|  |  |  | taskHty = taskHty.Concat(summaryItems).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 调整排序逻辑:先按日期降序,再按是否汇总(汇总在前),最后按小时降序 | 
|---|
|  |  |  | taskHty = taskHty | 
|---|
|  |  |  | .OrderByDescending(item => { | 
|---|
|  |  |  | var datePart = item.Hour.Contains("日汇总") | 
|---|
|  |  |  | ? item.Hour.Split("日汇总")[0] | 
|---|
|  |  |  | : item.Hour.Split(' ')[0]; | 
|---|
|  |  |  | return DateTime.Parse(datePart); | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .ThenByDescending(item => item.IsSummary) // 汇总数据排在前面 | 
|---|
|  |  |  | .ThenByDescending(item => { | 
|---|
|  |  |  | if (!item.IsSummary && item.Hour.Contains(' ')) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return int.Parse(item.Hour.Split(' ')[1].Split(':')[0]); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return 0; | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .ToList(); | 
|---|
|  |  |  | return content.OK1(total1: taskHty.Count, data: taskHty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | public WebResponseContent GetLocationStatus() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<DtLocationInfo> LocationList = _locationRepository.Db.Queryable<DtLocationInfo>().Where(x => x.LocationStatus != 2 && x.LocationStatus != 0).ToList(); | 
|---|
|  |  |  | return content.OK1(total1: LocationList.Count, data: LocationList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | internal class TaskHourData | 
|---|
|  |  |  | { | 
|---|
|  |  |  | public string Hour { get; set; } | 
|---|
|  |  |  | public string Roadway { get; set; } | 
|---|
|  |  |  | public int TaskType100Count { get; set; } | 
|---|
|  |  |  | public int TaskType104Count { get; set; } | 
|---|
|  |  |  | public int TaskType200Count { get; set; } | 
|---|
|  |  |  | public int TaskType204Count { get; set; } | 
|---|
|  |  |  | public bool IsSummary { get; set; } = false; | 
|---|
|  |  |  | } | 
|---|