|  |  |  | 
|---|
|  |  |  | #region << 版 本 注 释 >> | 
|---|
|  |  |  | /*---------------------------------------------------------------- | 
|---|
|  |  |  | * 命名空间:WIDESEAWCS_TaskInfoService | 
|---|
|  |  |  | * 创建者:胡童庆 | 
|---|
|  |  |  | * 创建时间:2024/8/2 16:13:36 | 
|---|
|  |  |  | * 版本:V1.0.0 | 
|---|
|  |  |  | * 描述: | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * ---------------------------------------------------------------- | 
|---|
|  |  |  | * 修改人: | 
|---|
|  |  |  | * 修改时间: | 
|---|
|  |  |  | * 版本:V1.0.1 | 
|---|
|  |  |  | * 修改说明: | 
|---|
|  |  |  | * | 
|---|
|  |  |  | *----------------------------------------------------------------*/ | 
|---|
|  |  |  | #endregion << 版 本 注 释 >> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | using AutoMapper; | 
|---|
|  |  |  | using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; | 
|---|
|  |  |  | using AutoMapper; | 
|---|
|  |  |  | using HslCommunication; | 
|---|
|  |  |  | using Mapster; | 
|---|
|  |  |  | using Newtonsoft.Json; | 
|---|
|  |  |  | using SqlSugar; | 
|---|
|  |  |  | using System; | 
|---|
|  |  |  | using System.Collections.Generic; | 
|---|
|  |  |  | using System.ComponentModel; | 
|---|
|  |  |  | using System.Diagnostics.CodeAnalysis; | 
|---|
|  |  |  | using System.Linq; | 
|---|
|  |  |  | using System.Reflection; | 
|---|
|  |  |  | using System.Text; | 
|---|
|  |  |  | using System.Threading.Tasks; | 
|---|
|  |  |  | using WIDESEAWCS_BasicInfoRepository; | 
|---|
|  |  |  | using WIDESEAWCS_BasicInfoService; | 
|---|
|  |  |  | using WIDESEAWCS_Common; | 
|---|
|  |  |  | using WIDESEAWCS_Common.TaskEnum; | 
|---|
|  |  |  | using WIDESEAWCS_Core; | 
|---|
|  |  |  | using WIDESEAWCS_Core.BaseServices; | 
|---|
|  |  |  | using WIDESEAWCS_Core.Enums; | 
|---|
|  |  |  | using WIDESEAWCS_Core.Helper; | 
|---|
|  |  |  | using WIDESEAWCS_Core.LogHelper; | 
|---|
|  |  |  | using WIDESEAWCS_DTO.TaskInfo; | 
|---|
|  |  |  | using WIDESEAWCS_DTO.WMS; | 
|---|
|  |  |  | using WIDESEAWCS_ISystemServices; | 
|---|
|  |  |  | using WIDESEAWCS_ITaskInfo_HtyRepository; | 
|---|
|  |  |  | using WIDESEAWCS_ITaskInfoRepository; | 
|---|
|  |  |  | using WIDESEAWCS_ITaskInfoService; | 
|---|
|  |  |  | using WIDESEAWCS_Model.Models; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.Models; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.Repository; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.Service; | 
|---|
|  |  |  | using WIDESEAWCS_Common.TaskEnum; | 
|---|
|  |  |  | using WIDESEAWCS_TaskInfoRepository; | 
|---|
|  |  |  | using static Microsoft.EntityFrameworkCore.DbLoggerCategory.Database; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | namespace WIDESEAWCS_TaskInfoService | 
|---|
|  |  |  | { | 
|---|
|  |  |  | public class TaskService : ServiceBase<Dt_Task, ITaskRepository>, ITaskService | 
|---|
|  |  |  | public partial class TaskService : ServiceBase<Dt_Task, ITaskRepository>, ITaskService | 
|---|
|  |  |  | { | 
|---|
|  |  |  | private readonly IRouterService _routerService; | 
|---|
|  |  |  | private readonly ITaskExecuteDetailService _taskExecuteDetailService; | 
|---|
|  |  |  | private readonly ITaskExecuteDetailRepository _taskExecuteDetailRepository; | 
|---|
|  |  |  | private readonly ISys_ConfigService _sys_ConfigService; | 
|---|
|  |  |  | private readonly IMapper _mapper; | 
|---|
|  |  |  | private readonly IDt_StationManagerService _stationManagerService; | 
|---|
|  |  |  | private readonly IDt_StationManagerRepository _stationManagerRepository; | 
|---|
|  |  |  | private readonly IRouterRepository _routerRepository; | 
|---|
|  |  |  | private readonly ITask_HtyRepository _taskHtyRepository; | 
|---|
|  |  |  | private readonly IDt_needBarcodeRepository _taskNeedBarcodeRepository; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Dictionary<string, OrderByType> _taskOrderBy = new() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | {nameof(Dt_Task.Grade),OrderByType.Desc }, | 
|---|
|  |  |  | {nameof(Dt_Task.CreateDate),OrderByType.Asc}, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | { | 
|---|
|  |  |  | {nameof(Dt_Task.Grade), OrderByType.Desc }, | 
|---|
|  |  |  | {nameof(Dt_Task.CreateDate), OrderByType.Asc}, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public Dictionary<string, OrderByType> TaskOrderBy { get { return _taskOrderBy; } set { _taskOrderBy = value; } } | 
|---|
|  |  |  | public Dictionary<string, OrderByType> TaskOrderBy | 
|---|
|  |  |  | { get { return _taskOrderBy; } set { _taskOrderBy = value; } } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public List<int> TaskInboundTypes => typeof(TaskInboundTypeEnum).GetEnumIndexList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public List<int> TaskOutboundTypes => typeof(TaskOutboundTypeEnum).GetEnumIndexList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public TaskService(ITaskRepository BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IMapper mapper) : base(BaseDal) | 
|---|
|  |  |  | public TaskService(ITaskRepository BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IMapper mapper, ISys_ConfigService sys_ConfigService, IDt_StationManagerService stationManagerService, IDt_StationManagerRepository stationManagerRepository, IRouterRepository routerRepository, ITask_HtyRepository htyRepository, IDt_needBarcodeRepository taskNeedBarcodeRepository) : base(BaseDal) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _routerService = routerService; | 
|---|
|  |  |  | _taskExecuteDetailService = taskExecuteDetailService; | 
|---|
|  |  |  | _taskExecuteDetailRepository = taskExecuteDetailRepository; | 
|---|
|  |  |  | _mapper = mapper; | 
|---|
|  |  |  | _sys_ConfigService = sys_ConfigService; | 
|---|
|  |  |  | _stationManagerService = stationManagerService; | 
|---|
|  |  |  | _stationManagerRepository = stationManagerRepository; | 
|---|
|  |  |  | _routerRepository = routerRepository; | 
|---|
|  |  |  | _taskHtyRepository = htyRepository; | 
|---|
|  |  |  | _taskNeedBarcodeRepository = taskNeedBarcodeRepository; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <returns>返回处理结果</returns> | 
|---|
|  |  |  | public WebResponseContent ReceiveWMSTask([NotNull] List<WMSTaskDTO> taskDTOs) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 创建一个WebResponseContent对象用于存储返回结果 | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 创建一个Dt_Task类型的列表用于存储转换后的任务数据 | 
|---|
|  |  |  | List<Dt_Task> tasks = new List<Dt_Task>(); | 
|---|
|  |  |  | // 遍历传入的WMSTaskDTO列表 | 
|---|
|  |  |  | foreach (var item in taskDTOs) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 查询数据库中是否存在相同任务编号或托盘码的任务,如果存在则跳过当前循环 | 
|---|
|  |  |  | if (BaseDal.QueryFirst(x => x.TaskNum == item.TaskNum || x.PalletCode == item.PalletCode) != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 将WMSTaskDTO对象映射为Dt_Task对象 | 
|---|
|  |  |  | Dt_Task task = _mapper.Map<Dt_Task>(item); | 
|---|
|  |  |  | // 设置任务的创建者为"WMS" | 
|---|
|  |  |  | task.Creater = "WMS"; | 
|---|
|  |  |  | // 判断任务类型是否为出库任务 | 
|---|
|  |  |  | if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_Router> routers = _routerService.QueryNextRoutes(item.RoadWay, item.TargetAddress); | 
|---|
|  |  |  | //暂不考虑多路径 | 
|---|
|  |  |  | if (routers.Count > 0) | 
|---|
|  |  |  | // 判断任务目标地址和路径是否满足特定条件 | 
|---|
|  |  |  | if (((task.TargetAddress == "002-021-001" || task.TargetAddress == "001-021-001") && task.Roadway.Contains("JZ")) || task.TaskType == (int)TaskOutboundTypeEnum.OutFireAlarm) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 设置任务状态为出库新建 | 
|---|
|  |  |  | task.TaskState = (int)TaskOutStatusEnum.OutNew; | 
|---|
|  |  |  | // 设置当前地址为源地址 | 
|---|
|  |  |  | task.CurrentAddress = item.SourceAddress; | 
|---|
|  |  |  | task.NextAddress = routers.FirstOrDefault().ChildPosi; | 
|---|
|  |  |  | // 设置下一个地址为目标地址 | 
|---|
|  |  |  | task.NextAddress = item.TargetAddress; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 查询下一个路由 | 
|---|
|  |  |  | List<Dt_Router> routers = _routerService.QueryNextRoutes(item.RoadWay, item.TargetAddress); | 
|---|
|  |  |  | if (routers.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 设置任务状态为出库新建 | 
|---|
|  |  |  | task.TaskState = (int)TaskOutStatusEnum.OutNew; | 
|---|
|  |  |  | // 设置当前地址为源地址 | 
|---|
|  |  |  | task.CurrentAddress = item.SourceAddress; | 
|---|
|  |  |  | // 设置下一个地址为第一个子位置 | 
|---|
|  |  |  | task.NextAddress = routers.FirstOrDefault().ChildPosi; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 查询从源地址到目标地址的路由 | 
|---|
|  |  |  | routers = _routerService.QueryNextRoutes(item.SourceAddress, item.TargetAddress); | 
|---|
|  |  |  | if (routers.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 设置任务状态为出库完成 | 
|---|
|  |  |  | task.TaskState = (int)TaskOutStatusEnum.SC_OutFinish; | 
|---|
|  |  |  | // 设置当前地址为源地址 | 
|---|
|  |  |  | task.CurrentAddress = item.SourceAddress; | 
|---|
|  |  |  | // 设置下一个地址为第一个子位置 | 
|---|
|  |  |  | task.NextAddress = routers.FirstOrDefault().ChildPosi; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 判断任务类型是否为入库任务 | 
|---|
|  |  |  | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_Router> routers = _routerService.QueryNextRoutes(item.SourceAddress, item.TargetAddress); | 
|---|
|  |  |  | //暂不考虑多路径 | 
|---|
|  |  |  | if (routers.Count > 0) | 
|---|
|  |  |  | var value = _sys_ConfigService.GetByConfigKey(CateGoryConst.CONFIG_SYS_InStation, SysConfigKeyConst.JZNGInBoundStation).ConfigValue; | 
|---|
|  |  |  | var valueList = value.Split(',').ToList(); | 
|---|
|  |  |  | // 判断源地址是否不等于"1359-4" | 
|---|
|  |  |  | //if (task.SourceAddress != "1359-4" && task.SourceAddress != "1357-4") | 
|---|
|  |  |  | if (!valueList.Contains(task.SourceAddress)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.TaskState = (int)TaskInStatusEnum.InNew; | 
|---|
|  |  |  | task.CurrentAddress = item.SourceAddress; | 
|---|
|  |  |  | task.NextAddress = routers.FirstOrDefault().ChildPosi; | 
|---|
|  |  |  | // 查询从源地址到目标地址的路由 | 
|---|
|  |  |  | List<Dt_Router> routers = _routerService.QueryNextRoutes(item.SourceAddress, item.TargetAddress); | 
|---|
|  |  |  | if (routers.Count > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 设置任务状态为入库新建 | 
|---|
|  |  |  | task.TaskState = (int)TaskInStatusEnum.InNew; | 
|---|
|  |  |  | // 设置当前地址为源地址 | 
|---|
|  |  |  | task.CurrentAddress = item.SourceAddress; | 
|---|
|  |  |  | // 设置下一个地址为第一个子位置 | 
|---|
|  |  |  | task.NextAddress = routers.FirstOrDefault().ChildPosi; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.CurrentAddress = string.Empty; | 
|---|
|  |  |  | if (task.SourceAddress == "1325-6") | 
|---|
|  |  |  | // 设置当前地址为"001-021-001" | 
|---|
|  |  |  | task.CurrentAddress = "001-021-001"; | 
|---|
|  |  |  | else | 
|---|
|  |  |  | // 设置当前地址为"002-021-001" | 
|---|
|  |  |  | task.CurrentAddress = "002-021-001"; | 
|---|
|  |  |  | // 设置下一个地址为目标地址 | 
|---|
|  |  |  | task.NextAddress = item.TargetAddress; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 将转换后的任务添加到任务列表中 | 
|---|
|  |  |  | tasks.Add(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 将任务列表添加到数据库中 | 
|---|
|  |  |  | BaseDal.AddData(tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 添加任务执行详情 | 
|---|
|  |  |  | _taskExecuteDetailService.AddTaskExecuteDetail(tasks.Select(x => x.TaskNum).ToList(), "接收WMS任务"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 设置返回结果为成功 | 
|---|
|  |  |  | content = WebResponseContent.Instance.OK("成功"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | content = WebResponseContent.Instance.Error($"任务接收错误,错误信息:{ex.Message}"); | 
|---|
|  |  |  | // 捕获异常并设置返回结果为错误信息 | 
|---|
|  |  |  | content = WebResponseContent.Instance.Error($"任务接收错误,错误信息:{ex.Message}返回数据行{ex.StackTrace}"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 返回结果 | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <param name="palletCode">托盘号</param> | 
|---|
|  |  |  | /// <param name="sourceAddress">起始地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public WebResponseContent RequestWMSTask(string palletCode, string sourceAddress) | 
|---|
|  |  |  | public async Task<WebResponseContent> RequestWMSTask(string palletCode, string sourceAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WMSTaskDTO taskDTO = new WMSTaskDTO() | 
|---|
|  |  |  | var hasTask = await BaseDal.QueryFirstAsync(x => x.PalletCode == palletCode); | 
|---|
|  |  |  | if (hasTask != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | TaskNum = Convert.ToInt32(DateTime.Now.ToString("HHmmss")), | 
|---|
|  |  |  | Grade = 1, | 
|---|
|  |  |  | PalletCode = palletCode, | 
|---|
|  |  |  | RoadWay = "SC01", | 
|---|
|  |  |  | SourceAddress = sourceAddress, | 
|---|
|  |  |  | TargetAddress = "SC01", | 
|---|
|  |  |  | TaskState = (int)TaskInStatusEnum.InNew, | 
|---|
|  |  |  | Id = 0, | 
|---|
|  |  |  | TaskType = (int)TaskInboundTypeEnum.Inbound | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | var taskExecuting = BaseDal.QueryFirst(x => x.PalletCode == palletCode && x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | content = ReceiveWMSTask(new List<WMSTaskDTO> { taskDTO }); | 
|---|
|  |  |  | if (taskExecuting != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | taskExecuting.ExceptionMessage = "未接收到线体完成信号系统内部自动完成"; | 
|---|
|  |  |  | Delete(taskExecuting); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine($"当前托盘存在任务:【{palletCode}】"); | 
|---|
|  |  |  | QuartzLogger.WriteLogToFile($"任务异常未完成", $"当前托盘存在任务:【{palletCode}】{Environment.NewLine}"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var wmsIpAddrss = string.Empty; | 
|---|
|  |  |  | var stationManager = _stationManagerRepository.QueryFirst(x => x.stationChildCode == sourceAddress); | 
|---|
|  |  |  | if (stationManager.stationType == 5) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | wmsIpAddrss = GetIpAddress(SysConfigKeyConst.WMSIP_BASE, SysConfigKeyConst.RequestInBoundTaskNG); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | wmsIpAddrss = GetIpAddress(SysConfigKeyConst.WMSIP_BASE, SysConfigKeyConst.RequestTask); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var result = await HttpHelper.PostAsync(wmsIpAddrss, new { Position = sourceAddress, PalletCode = palletCode, stationManager.productLine }.ToJsonString()); | 
|---|
|  |  |  | content = JsonConvert.DeserializeObject<WebResponseContent>(result); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // wms失败返回去NG口任务 | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var task = JsonConvert.DeserializeObject<WMSTaskDTO>(content.Data.ToString()); | 
|---|
|  |  |  | if (task.TaskType == (int)TaskInboundTypeEnum.InNG) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var station = await _stationManagerRepository.QueryFirstAsync(x => x.stationChildCode == task.SourceAddress); | 
|---|
|  |  |  | Dt_Task _Task = _mapper.Map<Dt_Task>(task); | 
|---|
|  |  |  | _Task.TaskState = (int)TaskInStatusEnum.InNew; | 
|---|
|  |  |  | _Task.CurrentAddress = task.SourceAddress; | 
|---|
|  |  |  | _Task.NextAddress = station.stationNGChildCode; | 
|---|
|  |  |  | _Task.TargetAddress = task.TargetAddress; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BaseDal.AddData(_Task); | 
|---|
|  |  |  | _taskExecuteDetailService.AddTaskExecuteDetail(_Task.TaskNum, "接收WMS任务"); | 
|---|
|  |  |  | return content.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return ReceiveWMSTask(new List<WMSTaskDTO> { task }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | content = WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | QuartzLogger.WriteLogToFile($"接收任务异常", $"托盘号:【{palletCode}】请求点位:【{sourceAddress}】异常信息【{ex.Message}】异常行【{ex.StackTrace}】"); | 
|---|
|  |  |  | return WebResponseContent.Instance.Error(ex.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryConveyorLineTask(string deviceNo, string currentAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.InNew || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish) && x.CurrentAddress == currentAddress, TaskOrderBy); | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => ((TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.InNew) || (TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish)) && x.CurrentAddress == currentAddress, TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据设备编号、当前地址查询输送线未执行的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="deviceNo">设备编号</param> | 
|---|
|  |  |  | /// <param name="currentAddress">当前地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryConveyorLineTask(string deviceNo, string currentAddress, string Barcode) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => ((TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.InNew) || (TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish)) && x.CurrentAddress == currentAddress && x.PalletCode == Barcode, TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据设备编号、当前地址查询输送线未执行的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="deviceNo">设备编号</param> | 
|---|
|  |  |  | /// <param name="currentAddress">当前地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryNextConveyorLineTask(string deviceNo, string currentAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => ((TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.InNew) || (TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish)) && x.NextAddress == currentAddress, TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据托盘号、当前地址查询输送线未执行的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="Barcode">托盘号</param> | 
|---|
|  |  |  | /// <param name="currentAddress">当前地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryBarCodeConveyorLineTask(string Barcode, string currentAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => ((TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.InNew) || (TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish)) && x.CurrentAddress == currentAddress && x.PalletCode == Barcode, TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据任务号、下一地址查询输送线执行中的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="taskNum">任务号</param> | 
|---|
|  |  |  | /// <param name="Barcode">下一地址</param> | 
|---|
|  |  |  | /// <param name="currentAddress">下一地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryExecutingCurrentConveyorLineTask(int taskNum, string Barcode, string currentAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.PalletCode == Barcode && x.CurrentAddress == currentAddress && (x.TaskState == (int)TaskInStatusEnum.Line_InExecuting || x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting), TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据任务号、下一地址查询输送线执行中的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="taskNum">任务号</param> | 
|---|
|  |  |  | /// <param name="nextAddress">下一地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryExecutingConveyorLineTask(int taskNum, string nextAddress, string Barcode) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.NextAddress == nextAddress && (x.TaskState == (int)TaskInStatusEnum.Line_InExecuting || x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting), TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据托盘号、下一地址查询输送线执行中的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="taskNum">任务号</param> | 
|---|
|  |  |  | /// <param name="nextAddress">下一地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryExecutingConveyorLineTask(string nextAddress, string Barcode) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.PalletCode == Barcode && (x.NextAddress == nextAddress || x.TargetAddress == nextAddress) && (x.TaskState == (int)TaskInStatusEnum.Line_InExecuting || x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting), TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据任务号、当前地址查询输送线完成的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="taskNum">任务号</param> | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据托盘号、当前地址查询任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="taskNum">任务号</param> | 
|---|
|  |  |  | /// <param name="currentAddress">当前地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryBarcodeTask(string barcode, string currentAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.PalletCode == barcode && x.CurrentAddress == currentAddress, TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据任务号、当前地址查询输送线新建的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="taskNum">任务号</param> | 
|---|
|  |  |  | /// <param name="currentAddress">当前地址</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public Dt_Task QueryCraneConveyorLineTask(int taskNum, string currentAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.CurrentAddress == currentAddress && (x.TaskState == (int)TaskInStatusEnum.InNew || x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据设备编号、任务类型分组(可选)按照优先级以及创建时间排序查询任务池新增的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="deviceNo">设备编号</param> | 
|---|
|  |  |  | 
|---|
|  |  |  | public Dt_Task? QuertStackerCraneTask(string deviceNo, TaskTypeGroup? taskTypeGroup = null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (taskTypeGroup == null) | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && ((TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish) || (TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew)), TaskOrderBy); | 
|---|
|  |  |  | if (taskTypeGroup.Value == TaskTypeGroup.InboundGroup) | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish, TaskOrderBy); | 
|---|
|  |  |  | if (taskTypeGroup.Value == TaskTypeGroup.OutbondGroup) | 
|---|
|  |  |  | 
|---|
|  |  |  | public Dt_Task QueryStackerCraneTask(string deviceNo, string currentAddress = "") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (string.IsNullOrEmpty(currentAddress)) | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && ((TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish) || (TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew)), TaskOrderBy); | 
|---|
|  |  |  | else | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && x.CurrentAddress == currentAddress && (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew), TaskOrderBy); | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && x.CurrentAddress == currentAddress && ((TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish) || (TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew)), TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据设备编号、排除的任务、当前地址按照优先级以及创建时间排序查询任务池出库类型的新增的所有任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="deviceNo">设备编号</param> | 
|---|
|  |  |  | /// <param name="excludedTaskId">排除的任务</param> | 
|---|
|  |  |  | /// <param name="currentAddress">当前地址</param> | 
|---|
|  |  |  | /// <returns>返回任务实体对象,可能为null</returns> | 
|---|
|  |  |  | public List<Dt_Task> QueryAllOutboundTasks(string deviceNo, string currentAddress = "") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (string.IsNullOrEmpty(currentAddress)) | 
|---|
|  |  |  | return BaseDal.QueryData(x => x.Roadway == deviceNo && TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew, TaskOrderBy); | 
|---|
|  |  |  | else | 
|---|
|  |  |  | return BaseDal.QueryData(x => x.Roadway == deviceNo && TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew && x.CurrentAddress == currentAddress, TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 根据设备编号、当前地址按照优先级以及创建时间排序查询任务池出库类型的新增的任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="deviceNo">设备编号</param> | 
|---|
|  |  |  | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | var task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); | 
|---|
|  |  |  | if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <param name="status">任务状态</param> | 
|---|
|  |  |  | public void UpdateTaskStatus(int taskNum, int status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | var task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | if (task == null) return; | 
|---|
|  |  |  | task.TaskState = status; | 
|---|
|  |  |  | task.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | var task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); | 
|---|
|  |  |  | return UpdateTaskStatusToNext(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | int oldState = task.TaskState; | 
|---|
|  |  |  | if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (task.TaskState >= (int)TaskOutStatusEnum.OutFinish) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content = WebResponseContent.Instance.Error($"该任务状态不可跳转到下一步,任务号:【{task.TaskNum}】,任务状态:【{task.TaskState}】"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskOutStatusEnum>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.TaskState = nextStatus; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (task.TaskState == (int)TaskOutStatusEnum.Line_OutFinish) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | task.Modifier = "System"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Task_Hty task_Hty = _mapper.Map<Dt_Task_Hty>(task); | 
|---|
|  |  |  | task_Hty.TaskId = 0; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BaseDal.DeleteData(task); | 
|---|
|  |  |  | _taskHtyRepository.AddData(task_Hty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (task.TaskState == (int)TaskOutStatusEnum.SC_OutFinish) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | content = StackCraneTaskCompleted(task.TaskNum); | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (task.TaskState >= (int)TaskInStatusEnum.InFinish) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content = WebResponseContent.Instance.Error($"该任务状态不可跳转到下一步,任务号:【{task.TaskNum}】,任务状态:【{task.TaskState}】"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskInStatusEnum>(); | 
|---|
|  |  |  | task.TaskState = nextStatus; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (task.TaskState == (int)TaskInStatusEnum.Line_InFinish) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Random random = new Random(); | 
|---|
|  |  |  | #region 入库调用接口获取货位地址 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // TODO: 调用接口获取货位地址 | 
|---|
|  |  |  | // 创建请求对象 | 
|---|
|  |  |  | var taskDto = new RequestTaskDto() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Position = task.NextAddress, | 
|---|
|  |  |  | PalletCode = task.PalletCode, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取WMSip地址 | 
|---|
|  |  |  | var configz = _sys_ConfigService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress); | 
|---|
|  |  |  | var wmsBasez = configz.Where(x => x.ConfigKey == SysConfigKeyConst.WMSIP_BASE).FirstOrDefault()?.ConfigValue; | 
|---|
|  |  |  | var requestLocation = configz.Where(x => x.ConfigKey == SysConfigKeyConst.RequestLocation).FirstOrDefault()?.ConfigValue; | 
|---|
|  |  |  | if (wmsBasez == null || requestLocation == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new InvalidOperationException("WMS IP 未配置"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var wmsIpAddrss = wmsBasez + requestLocation; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送请求并等待响应 | 
|---|
|  |  |  | var abc = HttpHelper.PostAsync(wmsIpAddrss, taskDto.ToJsonString()).Result; | 
|---|
|  |  |  | if (abc == null) | 
|---|
|  |  |  | return content.Error(); | 
|---|
|  |  |  | // 反序列化响应内容 | 
|---|
|  |  |  | content = JsonConvert.DeserializeObject<WebResponseContent>(abc); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QuartzLogger.WriteLogToFile($"Info_获取货位", $"获取货位,任务号:【{task.TaskNum}】,托盘号:【{task.PalletCode}】返回参数【{JsonConvert.SerializeObject(content)}】{Environment.NewLine}{Environment.NewLine}"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 检查状态并返回 | 
|---|
|  |  |  | if (!content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 反序列化任务数据 | 
|---|
|  |  |  | var taskResult = JsonConvert.DeserializeObject<WMSTaskDTO>(content.Data.ToString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.CurrentAddress = task.NextAddress; | 
|---|
|  |  |  | task.NextAddress = $"{random.Next(1, 100).ToString().PadLeft(3, '0')}-{random.Next(1, 100).ToString().PadLeft(3, '0')}-{random.Next(1, 100).ToString().PadLeft(3, '0')}"; | 
|---|
|  |  |  | task.NextAddress = taskResult.TargetAddress; | 
|---|
|  |  |  | task.TargetAddress = task.NextAddress; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #endregion 入库调用接口获取货位地址 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (task.TaskState == (int)TaskInStatusEnum.SC_InFinish) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (App.User.UserId > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | content = StackCraneTaskCompleted(task.TaskNum); | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | task.Modifier = "System"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Task_Hty task_Hty = _mapper.Map<Dt_Task_Hty>(task); | 
|---|
|  |  |  | task_Hty.TaskId = 0; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BaseDal.DeleteData(task); | 
|---|
|  |  |  | _taskHtyRepository.AddData(task_Hty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | 
|---|
|  |  |  | BaseDal.UpdateData(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, App.User.UserId > 0 ? $"人工手动将任务状态从【{oldState}】跳转到【{task.TaskState}】" : $"系统自动流程,任务状态从【{oldState}】转到【{task.TaskState}】"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region 更新任务状态 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取WMSip地址 | 
|---|
|  |  |  | var config = _sys_ConfigService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress); | 
|---|
|  |  |  | var wmsBase = config.FirstOrDefault(x => x.ConfigKey == SysConfigKeyConst.WMSIP_BASE)?.ConfigValue; | 
|---|
|  |  |  | var updateTask = config.FirstOrDefault(x => x.ConfigKey == SysConfigKeyConst.UpdateTask)?.ConfigValue; | 
|---|
|  |  |  | if (wmsBase == null || updateTask == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new InvalidOperationException("WMS IP 未配置"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var wmsIpAddress = wmsBase + updateTask; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var result = HttpHelper.PostAsync(wmsIpAddress, new { TaskNum = task.TaskNum, TaskState = task.TaskState }.ToJsonString()).Result; | 
|---|
|  |  |  | content = JsonConvert.DeserializeObject<WebResponseContent>(result); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #endregion 更新任务状态 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | content = WebResponseContent.Instance.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.CurrentAddress == currentAddress); | 
|---|
|  |  |  | var task = BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.CurrentAddress == currentAddress); | 
|---|
|  |  |  | if (task == null) throw new Exception($"未找到该任务信息,任务号:【{taskNum}】"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | string oldCurrentPos = task.CurrentAddress; | 
|---|
|  |  |  | string oldNextPos = task.NextAddress; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<Dt_Router> routers = _routerService.QueryNextRoutes(task.NextAddress, task.TargetAddress); | 
|---|
|  |  |  | var routers = _routerService.QueryNextRoutes(task.NextAddress, task.TargetAddress); | 
|---|
|  |  |  | if (!routers.Any()) throw new Exception($"未找到设备路由信息"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.CurrentAddress = task.NextAddress; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | task.Modifier = "System"; | 
|---|
|  |  |  | BaseDal.UpdateData(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"系统自动流程,更新当前位置【{oldCurrentPos} ----> {task.CurrentAddress}】和下一位置【{oldNextPos} ----> {task.NextAddress}】"); | 
|---|
|  |  |  | return task; | 
|---|
|  |  |  | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | var task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region WMS同步任务完成 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var keys = new Dictionary<string, object>() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | {"taskNum", taskNum} | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | // 获取WMSip地址 | 
|---|
|  |  |  | var config = _sys_ConfigService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress); | 
|---|
|  |  |  | var wmsBase = config.FirstOrDefault(x => x.ConfigKey == SysConfigKeyConst.WMSIP_BASE)?.ConfigValue; | 
|---|
|  |  |  | var completeTask = config.FirstOrDefault(x => x.ConfigKey == SysConfigKeyConst.CompleteTask)?.ConfigValue; | 
|---|
|  |  |  | if (wmsBase == null || completeTask == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new InvalidOperationException("WMS IP 未配置"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var wmsIpAddress = wmsBase + completeTask; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var result = HttpHelper.GetAsync(wmsIpAddress, keys).Result; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QuartzLogger.WriteLogToFile($"Info_任务完成", $"任务完成,任务号:【{taskNum}】返回参数【{JsonConvert.SerializeObject(result)}】{Environment.NewLine}{Environment.NewLine}"); | 
|---|
|  |  |  | if (result != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | content = JsonConvert.DeserializeObject<WebResponseContent>(result); | 
|---|
|  |  |  | if (!content.Data.IsNullOrEmpty()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (content.Data.ToString() == "NG") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.Remark = "NG"; | 
|---|
|  |  |  | //BaseDal.UpdateData(task); | 
|---|
|  |  |  | //_taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"堆垛机出库完成,MOM返回NG"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | task.ExceptionMessage += "   " + content.Message; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | #endregion WMS同步任务完成 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup && task.TaskState == (int)TaskOutStatusEnum.SC_OutExecuting) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<Dt_Router> routers = _routerService.QueryNextRoutes(task.NextAddress, task.TargetAddress); | 
|---|
|  |  |  | if (!routers.Any()) return WebResponseContent.Instance.Error($"未找到设备路由信息"); | 
|---|
|  |  |  | if (!task.Roadway.Contains("GW") && task.TaskType != (int)TaskOutboundTypeEnum.InToOut) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var routers = _routerService.QueryNextRoutes(task.NextAddress, task.TargetAddress); | 
|---|
|  |  |  | if (!routers.Any()) return WebResponseContent.Instance.Error($"未找到设备路由信息"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskOutStatusEnum>(); | 
|---|
|  |  |  | task.TaskState = nextStatus; | 
|---|
|  |  |  | task.CurrentAddress = task.NextAddress; | 
|---|
|  |  |  | task.NextAddress = routers.FirstOrDefault().ChildPosi; | 
|---|
|  |  |  | task.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | task.Modifier = "System"; | 
|---|
|  |  |  | BaseDal.UpdateData(task); | 
|---|
|  |  |  | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskOutStatusEnum>(); | 
|---|
|  |  |  | task.TaskState = nextStatus; | 
|---|
|  |  |  | task.CurrentAddress = task.NextAddress; | 
|---|
|  |  |  | task.NextAddress = routers.FirstOrDefault().ChildPosi; | 
|---|
|  |  |  | task.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | task.Modifier = "System"; | 
|---|
|  |  |  | BaseDal.UpdateData(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"堆垛机出库完成"); | 
|---|
|  |  |  | //todo 同步到WMS | 
|---|
|  |  |  | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"堆垛机出库完成"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.TaskState = (int)TaskOutStatusEnum.OutFinish; | 
|---|
|  |  |  | //如高温出库后 NG 则将任务标记为NG 并在出库申请后将任务出至NG口 | 
|---|
|  |  |  | if (task.Remark == "NG") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | BaseDal.UpdateData(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | BaseDal.DeleteData(task); | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"高温出库目的地址{task.TargetAddress}"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var taskHty = task.Adapt<Dt_Task_Hty>(); | 
|---|
|  |  |  | _taskHtyRepository.AddData(taskHty); | 
|---|
|  |  |  | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"堆垛机出库完成"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //暂不考虑多个出库口 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup && task.TaskState == (int)TaskInStatusEnum.SC_InExecuting) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //todo | 
|---|
|  |  |  | //todo 同步到WMS | 
|---|
|  |  |  | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskInStatusEnum>(); | 
|---|
|  |  |  | task.TaskState = nextStatus; | 
|---|
|  |  |  | task.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | task.Modifier = "System"; | 
|---|
|  |  |  | BaseDal.UpdateData(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Task_Hty task_Hty = _mapper.Map<Dt_Task_Hty>(task); | 
|---|
|  |  |  | task_Hty.TaskId = 0; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BaseDal.DeleteData(task); | 
|---|
|  |  |  | _taskHtyRepository.AddData(task_Hty); | 
|---|
|  |  |  | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"堆垛机入库完成"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WMSTaskDTO taskDTO = new WMSTaskDTO() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | TaskNum = Convert.ToInt32(DateTime.Now.ToString("HHmmss")), | 
|---|
|  |  |  | Grade = 1, | 
|---|
|  |  |  | PalletCode = task.PalletCode + "S", | 
|---|
|  |  |  | RoadWay = "SC01", | 
|---|
|  |  |  | SourceAddress = task.TargetAddress, | 
|---|
|  |  |  | TargetAddress = "CLOutAreaA", | 
|---|
|  |  |  | TaskState = (int)TaskOutStatusEnum.OutNew, | 
|---|
|  |  |  | Id = 0, | 
|---|
|  |  |  | TaskType = (int)TaskOutboundTypeEnum.Outbound | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | content = ReceiveWMSTask(new List<WMSTaskDTO> { taskDTO }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.RelocationGroup) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OtherGroup) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception($"任务类型错误,未找到该任务类型,任务号:【{taskNum}】,任务类型:【{task.TaskType}】"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | content = WebResponseContent.Instance.OK(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | content = WebResponseContent.Instance.Error($"任务完成异常,任务号:【{taskNum}】"); | 
|---|
|  |  |  | QuartzLogger.WriteLogToFile($"Info_任务完成", $"任务完成异常,任务号:【{taskNum}】异常信息【{ex.Message}】{Environment.NewLine}异常信息【{ex.StackTrace}】{Environment.NewLine}"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | QuartzLogger.WriteLogToFile($"Info_任务完成", $"任务完成,任务号:【{taskNum}】返回参数【{JsonConvert.SerializeObject(content)}】{Environment.NewLine}{Environment.NewLine}"); | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | var task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); | 
|---|
|  |  |  | if (task.TaskState != (int)TaskInStatusEnum.InPending && task.TaskState != (int)TaskOutStatusEnum.OutPending) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content = WebResponseContent.Instance.Error($"该任务状态不可恢复,任务号:【{taskNum}】,任务状态:【{task.TaskState}】"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_TaskExecuteDetail taskExecuteDetail = _taskExecuteDetailRepository.QueryFirst(x => x.TaskId == task.TaskId && x.IsNormal, new Dictionary<string, OrderByType> { { nameof(Dt_TaskExecuteDetail.TaskDetailId), OrderByType.Desc } }); | 
|---|
|  |  |  | var taskExecuteDetail = _taskExecuteDetailRepository.QueryFirst(x => x.TaskId == task.TaskId && x.IsNormal, new Dictionary<string, OrderByType> { { nameof(Dt_TaskExecuteDetail.TaskDetailId), OrderByType.Desc } }); | 
|---|
|  |  |  | if (taskExecuteDetail != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.TaskState = taskExecuteDetail.TaskState; | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.TaskState = (int)TaskInStatusEnum.InNew; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //todo | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.ExceptionMessage = string.Empty; | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <returns>返回处理结果</returns> | 
|---|
|  |  |  | public WebResponseContent RollbackTaskStatusToLast(int taskNum) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = new(); | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | var task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); | 
|---|
|  |  |  | if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int oldState = task.TaskState; | 
|---|
|  |  |  | Dt_TaskExecuteDetail taskExecuteDetail = _taskExecuteDetailRepository.QueryFirst(x => x.TaskId == task.TaskId && x.TaskState < task.TaskState && x.TaskState > 0, new Dictionary<string, OrderByType> { { nameof(Dt_TaskExecuteDetail.TaskDetailId), OrderByType.Desc } }); | 
|---|
|  |  |  | var taskExecuteDetail = _taskExecuteDetailRepository.QueryFirst(x => x.TaskId == task.TaskId && x.TaskState < task.TaskState && x.TaskState > 0, new Dictionary<string, OrderByType> { { nameof(Dt_TaskExecuteDetail.TaskDetailId), OrderByType.Desc } }); | 
|---|
|  |  |  | if (taskExecuteDetail != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.TaskState = taskExecuteDetail.TaskState; | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public Dt_Task QueryRelocationTask(string deviceNo) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && x.TaskType == (int)TaskRelocationTypeEnum.Relocation && x.TaskState == (int)TaskStatus.Created); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | public Dt_Task QueryOutFireAlarmTask(string deviceNo) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.Roadway == deviceNo && x.TaskType == (int)TaskOutboundTypeEnum.OutFireAlarm && x.TaskState == (int)TaskOutStatusEnum.OutNew); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public Dt_Task QueryExecutingTaskByBarcode(string barcode, string nextAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return BaseDal.QueryFirst(x => x.PalletCode == barcode && x.NextAddress == nextAddress && (x.TaskState == (int)TaskInStatusEnum.Line_InExecuting || x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting), TaskOrderBy); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private string GetIpAddress(string baseIp, string name) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var configz = _sys_ConfigService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress); | 
|---|
|  |  |  | var wcsBasez = configz.Where(x => x.ConfigKey == baseIp).FirstOrDefault()?.ConfigValue; | 
|---|
|  |  |  | var address = configz.Where(x => x.ConfigKey == name).FirstOrDefault()?.ConfigValue; | 
|---|
|  |  |  | if (wcsBasez == null || address == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new InvalidOperationException("WMS IP 未配置"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return wcsBasez + address; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | public WebResponseContent Delete(Dt_Task task) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var taskHty = task.Adapt<Dt_Task_Hty>(); | 
|---|
|  |  |  | taskHty.Creater = App.User.UserName != null ? App.User.UserName : "System"; | 
|---|
|  |  |  | _taskHtyRepository.AddData(taskHty); | 
|---|
|  |  |  | return base.DeleteData(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | #region 重写方法 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public override WebResponseContent DeleteData(object[] key) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | foreach (var item in key) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var task = BaseDal.QueryFirst(x => x.TaskId == Convert.ToInt32(item)); | 
|---|
|  |  |  | var taskHty = task.Adapt<Dt_Task_Hty>(); | 
|---|
|  |  |  | taskHty.Creater = App.User.UserName != null ? App.User.UserName : "System"; | 
|---|
|  |  |  | _taskHtyRepository.AddData(taskHty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return base.DeleteData(key); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #endregion 重写方法 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|