#region << 版 本 注 释 >>
|
/*----------------------------------------------------------------
|
* 命名空间:WIDESEAWCS_TaskInfoService
|
* 创建者:胡童庆
|
* 创建时间:2024/8/2 16:13:36
|
* 版本:V1.0.0
|
* 描述:
|
*
|
* ----------------------------------------------------------------
|
* 修改人:
|
* 修改时间:
|
* 版本:V1.0.1
|
* 修改说明:
|
*
|
*----------------------------------------------------------------*/
|
#endregion << 版 本 注 释 >>
|
|
using AutoMapper;
|
using Magicodes.ExporterAndImporter.Core;
|
using Microsoft.AspNetCore.Mvc.RazorPages;
|
using NetTaste;
|
using Newtonsoft.Json;
|
using OfficeOpenXml.FormulaParsing.Excel.Functions.DateTime;
|
using OfficeOpenXml.FormulaParsing.Excel.Functions.Math;
|
using OfficeOpenXml.FormulaParsing.Excel.Functions.Text;
|
using SqlSugar;
|
using System;
|
using System.Collections.Generic;
|
using System.ComponentModel;
|
using System.Diagnostics;
|
using System.Diagnostics.CodeAnalysis;
|
using System.Linq;
|
using System.Linq.Expressions;
|
using System.Reflection;
|
using System.Reflection.Metadata;
|
using System.Security.Policy;
|
using System.Text;
|
using System.Threading.Tasks;
|
using System.Xml.Linq;
|
using WIDESEA_Comm.Http;
|
using WIDESEA_Common.Log;
|
using WIDESEAWCS_Common.TaskEnum;
|
using WIDESEAWCS_Core;
|
using WIDESEAWCS_Core.BaseServices;
|
using WIDESEAWCS_Core.Enums;
|
using WIDESEAWCS_Core.Utilities;
|
using WIDESEAWCS_DTO.Enum;
|
using WIDESEAWCS_DTO.TaskInfo;
|
using WIDESEAWCS_IBasicInfoRepository;
|
using WIDESEAWCS_IBasicInfoService;
|
using WIDESEAWCS_ITaskInfoRepository;
|
using WIDESEAWCS_ITaskInfoService;
|
using WIDESEAWCS_Model.Models;
|
using WIDESEAWCS_QuartzJob;
|
using WIDESEAWCS_QuartzJob.Models;
|
using WIDESEAWCS_QuartzJob.Service;
|
using WIDESEAWCS_TaskInfoRepository;
|
using static Microsoft.IO.RecyclableMemoryStreamManager;
|
|
namespace WIDESEAWCS_TaskInfoService
|
{
|
public class TaskService : ServiceBase<Dt_Task, ITaskRepository>, ITaskService
|
{
|
private readonly IRouterService _routerService;
|
private readonly ITaskExecuteDetailService _taskExecuteDetailService;
|
private readonly ITaskExecuteDetailRepository _taskExecuteDetailRepository;
|
private readonly ITask_HtyService _taskHtyService;
|
private readonly ITask_HtyRepository _taskHtyRepository;
|
private readonly IMapper _mapper;
|
private readonly IDt_StationManagerRepository _stationManagerRepository;
|
|
|
private Dictionary<string, OrderByType> _taskOrderBy = new()
|
{
|
{nameof(Dt_Task.Grade),OrderByType.Desc },
|
{nameof(Dt_Task.CreateDate),OrderByType.Asc},
|
};
|
|
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 List<int> TaskRelocationboundTypes => typeof(TaskRelocationTypeEnum).GetEnumIndexList();
|
|
public TaskService(ITaskRepository BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IMapper mapper, ITask_HtyService taskHtyService, IDt_StationManagerRepository stationManagerRepository, ITask_HtyRepository taskHtyRepository) : base(BaseDal)
|
{
|
_routerService = routerService;
|
_taskExecuteDetailService = taskExecuteDetailService;
|
_taskExecuteDetailRepository = taskExecuteDetailRepository;
|
_taskHtyService = taskHtyService;
|
_mapper = mapper;
|
_stationManagerRepository = stationManagerRepository;
|
_taskHtyRepository = taskHtyRepository;
|
}
|
|
/// <summary>
|
/// 接收WMS任务信息
|
/// </summary>
|
/// <param name="taskDTOs">WMS任务对象集合</param>
|
/// <returns>返回处理结果</returns>
|
public WebResponseContent ReceiveWMSTask([NotNull] List<WMSTaskDTO> taskDTOs)
|
{
|
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.TaskId || x.PalletCode == item.TPbarcode) != null)
|
{
|
continue;
|
}
|
// 将WMSTaskDTO对象映射为Dt_Task对象
|
Dt_Task task = _mapper.Map<Dt_Task>(item);
|
// 设置任务的创建者为"WMS"
|
task.Creater = "WMS";
|
task.Grade = 1; // 设置默认优先级为1
|
// 判断任务类型是否为出库任务
|
if (item.TaskType == "2")
|
{
|
task.TaskType = (int)TaskOutboundTypeEnum.Outbound;
|
List<Dt_Router> routers = _routerService.QueryNextRoutes(item.WhCode, item.EndPoint);
|
if (routers.Count > 0)
|
{
|
// 设置任务状态为出库新建
|
task.TaskState = (int)TaskOutStatusEnum.OutNew;
|
// 设置当前地址为源地址
|
task.CurrentAddress = item.BeginPoint;
|
// 设置下一个地址为第一个子位置
|
task.NextAddress = routers.FirstOrDefault().ChildPosi;
|
}
|
else
|
{
|
// 查询从源地址到目标地址的路由
|
routers = _routerService.QueryNextRoutes(item.BeginPoint, item.EndPoint);
|
if (routers.Count > 0)
|
{
|
// 设置任务状态为出库完成
|
task.TaskState = (int)TaskOutStatusEnum.SC_OutFinish;
|
// 设置当前地址为源地址
|
task.CurrentAddress = item.BeginPoint;
|
// 设置下一个地址为第一个子位置
|
task.NextAddress = routers.FirstOrDefault().ChildPosi;
|
}
|
}
|
}// 判断任务类型是否为入库任务
|
else if (item.TaskType == "1")
|
{
|
task.TaskType = (int)TaskInboundTypeEnum.Inbound;
|
// 查询从源地址到目标地址的路由
|
List<Dt_Router> routers = _routerService.QueryNextRoutes(item.BeginPoint, item.EndPoint);
|
if (routers.Count > 0)
|
{
|
// 设置任务状态为入库新建
|
task.TaskState = (int)TaskInStatusEnum.InNew;
|
// 设置当前地址为源地址
|
task.CurrentAddress = item.BeginPoint;
|
// 设置下一个地址为第一个子位置
|
task.NextAddress = routers.FirstOrDefault().ChildPosi;
|
}
|
}
|
else if (item.TaskType == "3")
|
{
|
task.TaskType = (int)TaskRelocationTypeEnum.Relocation;
|
// 设置任务状态为新建
|
task.TaskState = (int)TaskRelocationStatusEnum.RelocationNew;
|
task.Grade = 3; // 设置默认优先级为1
|
}
|
else
|
{
|
return content.Error($"任务类型错误,未找到该任务类型,任务号:【{item.TaskId}】,任务类型:【{item.TaskType}】");
|
}
|
}
|
BaseDal.AddData(tasks);
|
_taskExecuteDetailService.AddTaskExecuteDetail(tasks.Select(x => x.TaskId).ToList(), "接收WMS任务");
|
content = WebResponseContent.Instance.OK("成功");
|
}
|
catch (Exception ex)
|
{
|
content = WebResponseContent.Instance.Error($"生成任务失败,错误信息:{ex.Message}");
|
}
|
finally
|
{
|
WriteLog.GetLog("生成任务").Write(JsonConvert.SerializeObject(content), "生成任务");
|
}
|
return content;
|
}
|
|
public WebResponseContent GetTask(WMSTaskDTO taskDTO)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskDTO.TaskId || x.Roadway == taskDTO.WhCode);
|
Dt_Task_Hty taskHty = _taskHtyRepository.QueryFirst(x => x.TaskNum == taskDTO.TaskId || x.Roadway == taskDTO.WhCode);
|
if (task != null)
|
{
|
return content.OK(data: new WMSTaskDTO()
|
{
|
TaskId = task.TaskNum,
|
TPbarcode = task.PalletCode,
|
WhCode = task.Roadway,
|
BeginPoint = task.SourceAddress,
|
EndPoint = task.TargetAddress,
|
Results = GetTaskState(task.TaskState)
|
});
|
}
|
else if (taskHty != null)
|
{
|
return content.OK(data: new WMSTaskDTO()
|
{
|
TaskId = taskHty.TaskNum,
|
TPbarcode = taskHty.PalletCode,
|
WhCode = taskHty.Roadway,
|
BeginPoint = taskHty.SourceAddress,
|
EndPoint = taskHty.TargetAddress,
|
Results = GetTaskState(taskHty.TaskState)
|
});
|
}
|
else
|
{
|
return content.Error($"未找到该任务信息,任务号:【{taskDTO.TaskId}】");
|
}
|
}
|
catch (Exception ex)
|
{
|
return content.Error(ex.Message);
|
}
|
}
|
|
public Dictionary<int, string> TaskStateMapping = new Dictionary<int, string>
|
{
|
// 新建状态
|
{ (int)TaskInStatusEnum.InNew, "4" },
|
{ (int)TaskOutStatusEnum.OutNew, "4" },
|
{ (int)TaskRelocationStatusEnum.RelocationNew, "4" },
|
|
// 执行中状态
|
{ (int)TaskInStatusEnum.Line_InExecuting, "5" },
|
{ (int)TaskInStatusEnum.SC_InExecuting, "5" },
|
{ (int)TaskOutStatusEnum.Line_OutExecuting, "5" },
|
{ (int)TaskOutStatusEnum.SC_OutExecuting, "5" },
|
{ (int)TaskRelocationStatusEnum.Relocation_Executing, "5" },
|
|
// 手动完成状态
|
{ (int)TaskInStatusEnum.InHandFinish, "2" },
|
{ (int)TaskOutStatusEnum.OutHandFinish, "2" },
|
{ (int)TaskRelocationStatusEnum.RelocationHandFinish, "2" },
|
|
// 已完成状态
|
{ (int)TaskInStatusEnum.InFinish, "1" },
|
{ (int)TaskOutStatusEnum.OutFinish, "1" },
|
{ (int)TaskRelocationStatusEnum.RelocationFinish, "1" },
|
|
// 已取消状态
|
{ (int)TaskInStatusEnum.InCancel, "3" },
|
{ (int)TaskOutStatusEnum.OutCancel, "3" },
|
{ (int)TaskRelocationStatusEnum.RelocationCancel, "3" },
|
|
// 异常/挂起状态
|
{ (int)TaskInStatusEnum.InException, "6" },
|
{ (int)TaskInStatusEnum.InPending, "6" },
|
{ (int)TaskOutStatusEnum.OutPending, "6" },
|
{ (int)TaskOutStatusEnum.OutException, "6" },
|
{ (int)TaskRelocationStatusEnum.RelocationPending, "6" },
|
{ (int)TaskRelocationStatusEnum.RelocationException, "6" }
|
};
|
|
public string GetTaskState(int state)
|
{
|
try
|
{
|
return TaskStateMapping.TryGetValue(state, out var result)
|
? result
|
: "0";
|
}
|
catch (Exception ex)
|
{
|
return $"获取任务状态失败,错误信息:{ex.Message}";
|
}
|
}
|
|
|
/// <summary>
|
/// 根据设备编号、当前地址查询输送线未执行的任务
|
/// </summary>
|
/// <param name="deviceNo">设备编号</param>
|
/// <param name="currentAddress">当前地址</param>
|
/// <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);
|
}
|
|
/// <summary>
|
/// 根据设备编号、当前地址查询RGV未执行的任务
|
/// </summary>
|
/// <param name="deviceNo">设备编号</param>
|
/// <param name="currentAddress">当前地址</param>
|
/// <returns></returns>
|
public Dt_Task QueryRGVTask(string deviceNo, string currentAddress)
|
{
|
return BaseDal.QueryFirst(x => (TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish || TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish) && x.CurrentAddress == currentAddress, TaskOrderBy);
|
}
|
|
/// <summary>
|
/// 查找移库作业
|
/// </summary>
|
/// <param name="deviceNo"></param>
|
/// <returns></returns>
|
public Dt_Task QueryRelocationTask(string deviceNo)
|
{
|
return BaseDal.QueryFirst(x => x.Roadway == deviceNo && x.TaskType == (int)TaskRelocationTypeEnum.Relocation && x.TaskState == (int)TaskRelocationStatusEnum.RelocationNew);
|
}
|
|
/// <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="taskNum">任务号</param>
|
/// <param name="nextAddress">下一地址</param>
|
/// <returns></returns>
|
public Dt_Task QueryExecutingConveyorLineTask(int taskNum, string nextAddress)
|
{
|
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="currentAddress">当前地址</param>
|
/// <returns></returns>
|
public Dt_Task QueryCompletedConveyorLineTask(int taskNum, string currentAddress)
|
{
|
return BaseDal.QueryFirst(x => x.TaskNum == taskNum && x.CurrentAddress == currentAddress && (x.TaskState == (int)TaskInStatusEnum.Line_InFinish || x.TaskState == (int)TaskOutStatusEnum.Line_OutFinish), TaskOrderBy);
|
}
|
|
/// <summary>
|
/// 根据设备编号、任务类型分组(可选)按照优先级以及创建时间排序查询任务池新增的任务
|
/// </summary>
|
/// <param name="deviceNo">设备编号</param>
|
/// <param name="taskTypeGroup">任务类型分组(可选)</param>
|
/// <returns></returns>
|
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);
|
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)
|
return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew, TaskOrderBy);
|
return null;
|
}
|
|
/// <summary>
|
/// 根据设备编号、当前地址按照优先级以及创建时间排序查询任务池新增的任务
|
/// </summary>
|
/// <param name="deviceNo">设备编号</param>
|
/// <param name="currentAddress">当前地址</param>
|
/// <returns>返回任务实体对象,可能为null</returns>
|
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);
|
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.TaskState == (int)AGVTaskStatusEnum.AGVNew && x.Roadway == deviceNo, TaskOrderBy);
|
}
|
|
/// <summary>
|
/// 根据设备编号、当前地址按照优先级以及创建时间排序查询任务池入库类型的新增的任务
|
/// </summary>
|
/// <param name="deviceNo">设备编号</param>
|
/// <param name="currentAddress">当前地址</param>
|
/// <returns>返回任务实体对象,可能为null</returns>
|
public Dt_Task QueryStackerCraneInTask(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, TaskOrderBy);
|
else
|
return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish && x.CurrentAddress == currentAddress, TaskOrderBy);
|
}
|
|
/// <summary>
|
/// 根据设备编号、当前地址按照优先级以及创建时间排序查询任务池出库类型的新增的任务
|
/// </summary>
|
/// <param name="deviceNo">设备编号</param>
|
/// <param name="currentAddress">当前地址</param>
|
/// <returns>返回任务实体对象,可能为null</returns>
|
public Dt_Task QueryStackerCraneOutTask(string deviceNo, string currentAddress = "")
|
{
|
if (string.IsNullOrEmpty(currentAddress))
|
return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew, TaskOrderBy);
|
else
|
return BaseDal.QueryFirst(x => x.Roadway == deviceNo && TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew && x.CurrentAddress == currentAddress, TaskOrderBy);
|
}
|
|
/// <summary>
|
/// 根据设备编号、当前地址按照优先级以及创建时间排序查询任务池出库类型的新增的任务
|
/// </summary>
|
/// <param name="deviceNo">设备编号</param>
|
/// <param name="currentAddress">当前地址</param>
|
/// <returns>返回任务实体对象集合,可能为null</returns>
|
public List<Dt_Task> QueryStackerCraneOutTasks(string deviceNo, List<string> outStationCodes)
|
{
|
return BaseDal.QueryData(x => x.Roadway == deviceNo && TaskOutboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskOutStatusEnum.OutNew && outStationCodes.Contains(x.CurrentAddress), TaskOrderBy);
|
}
|
|
/// <summary>
|
/// 根据出库货位查询是否有当前浅货位任务
|
/// </summary>
|
/// <param name="deviceNo">设备编号</param>
|
/// <param name="currentAddress">当前地址</param>
|
/// <returns>返回任务实体对象集合,可能为null</returns>
|
public List<Dt_Task> QueryStationIsOccupiedOutTasks(string deviceNo, string SourceAddress)
|
{
|
return BaseDal.QueryData(x => x.Roadway == deviceNo && SourceAddress.Contains(x.SourceAddress), TaskOrderBy);
|
}
|
|
/// <summary>
|
/// 更新任务异常信息显示
|
/// </summary>
|
/// <param name="taskNum">任务号</param>
|
/// <param name="message">异常信息</param>
|
public WebResponseContent UpdateTaskExceptionMessage(int taskNum, string message)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum);
|
if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】");
|
if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup)
|
{
|
task.TaskState = (int)TaskOutStatusEnum.OutPending;
|
}
|
else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup)
|
{
|
task.TaskState = (int)TaskInStatusEnum.InPending;
|
}
|
task.ExceptionMessage = message;
|
task.ModifyDate = DateTime.Now;
|
BaseDal.UpdateData(task);
|
|
_taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, task.ExceptionMessage);
|
|
content = WebResponseContent.Instance.OK();
|
}
|
catch (Exception ex)
|
{
|
content = WebResponseContent.Instance.Error(ex.Message);
|
}
|
return content;
|
}
|
|
/// <summary>
|
/// 更新任务状态信息,并同步至WMS
|
/// </summary>
|
/// <param name="taskNum">任务号</param>
|
/// <param name="status">任务状态</param>
|
public void UpdateTaskStatus(int taskNum, int status)
|
{
|
Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum);
|
if (task == null) return;
|
task.TaskState = status;
|
task.ModifyDate = DateTime.Now;
|
BaseDal.UpdateData(task);
|
}
|
|
/// <summary>
|
/// 将任务状态修改为下一个状态
|
/// </summary>
|
/// <param name="taskNum">任务号</param>
|
public WebResponseContent UpdateTaskStatusToNext(int taskNum)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum);
|
if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】");
|
return UpdateTaskStatusToNext(task);
|
}
|
catch (Exception ex)
|
{
|
content = WebResponseContent.Instance.Error(ex.Message);
|
}
|
return content;
|
}
|
|
/// <summary>
|
/// 将任务状态修改为下一个状态
|
/// </summary>
|
/// <param name="task">任务实体对象</param>
|
/// <returns></returns>
|
public WebResponseContent UpdateTaskStatusToNext([NotNull] Dt_Task task)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
int oldState = task.TaskState;
|
if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup)
|
{
|
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)
|
{
|
int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskInStatusEnum>();
|
task.TaskState = nextStatus;
|
|
if (task.TaskState == (int)TaskInStatusEnum.Line_InFinish)
|
{
|
#region 入库调用接口获取货位地址
|
|
// 检查状态并返回
|
if (!content.Status)
|
return content;
|
|
// 反序列化任务数据
|
var taskResult = JsonConvert.DeserializeObject<WMSTaskDTO>(content.Data.ToString());
|
|
task.CurrentAddress = task.NextAddress;
|
task.NextAddress = taskResult.EndPoint;
|
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
|
{
|
throw new Exception($"任务类型错误,未找到该任务类型,任务号:【{task.TaskNum}】,任务类型:【{task.TaskType}】");
|
}
|
|
if (task.TaskState <= 0)
|
{
|
return content = WebResponseContent.Instance.Error($"该任务状态不可跳转到下一步,任务号:【{task.TaskNum}】,任务状态:【{task.TaskState}】");
|
}
|
|
task.ModifyDate = DateTime.Now;
|
task.Modifier = "System";
|
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();
|
}
|
catch (Exception ex)
|
{
|
content = WebResponseContent.Instance.Error(ex.Message);
|
}
|
return content;
|
}
|
|
/// <summary>
|
/// 根据任务号、当前地址更新任务位置信息
|
/// </summary>
|
/// <param name="taskNum">任务号</param>
|
/// <param name="currentAddress">当前地址</param>
|
/// <returns></returns>
|
public Dt_Task? UpdatePosition(int taskNum, string currentAddress)
|
{
|
try
|
{
|
Dt_Task 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);
|
if (!routers.Any()) throw new Exception($"未找到设备路由信息");
|
|
task.CurrentAddress = task.NextAddress;
|
task.NextAddress = routers.FirstOrDefault().ChildPosi;
|
|
task.ModifyDate = DateTime.Now;
|
task.Modifier = "System";
|
BaseDal.UpdateData(task);
|
|
_taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"系统自动流程,更新当前位置【{oldCurrentPos} ----> {task.CurrentAddress}】和下一位置【{oldNextPos} ----> {task.NextAddress}】");
|
return task;
|
}
|
catch (Exception ex)
|
{
|
}
|
return null;
|
}
|
|
|
public WebResponseContent StackCraneTaskCompleted(int taskNum)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum);
|
if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】");
|
|
if ( task.TaskState == (int)AGVTaskStatusEnum.AGV_Executing)
|
{
|
task.TaskState = (int)AGVTaskStatusEnum.AGVFinish;
|
task.ModifyDate = DateTime.Now;
|
BaseDal.DeleteData(task);
|
//_taskHtyService.AddTaskHty(task, (int)OperateTypeEnum.自动完成);
|
|
Dt_Task_Hty taskHty = _mapper.Map<Dt_Task_Hty>(task);
|
taskHty.OperateType = (int)OperateTypeEnum.自动完成;
|
_taskHtyRepository.AddData(taskHty);
|
|
_taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"AGV搬运完成完成");
|
}
|
else
|
{
|
throw new Exception($"任务类型错误,未找到该任务类型,任务号:【{taskNum}】,任务类型:【{task.TaskType}】");
|
}
|
content = WebResponseContent.Instance.OK();
|
}
|
catch (Exception ex)
|
{
|
content = WebResponseContent.Instance.Error($"任务完成异常,任务号:【{taskNum}】");
|
}
|
return content;
|
}
|
|
public WebResponseContent TaskCancel(WMSTaskDTO taskDTO)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
List<Dt_Task> tasks = BaseDal.QueryData(x => (x.TaskState == (int)TaskInStatusEnum.InNew || x.TaskState == (int)TaskOutStatusEnum.OutNew || x.TaskState == (int)TaskRelocationStatusEnum.RelocationNew) && x.TaskNum == taskDTO.TaskId && x.PalletCode == taskDTO.TPbarcode && x.Roadway == taskDTO.WhCode);
|
if (tasks.Count == 0) return content.Error("没有需要取消的任务");
|
foreach (Dt_Task task in tasks)
|
{
|
task.TaskState = task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup ? (int)TaskOutStatusEnum.OutCancel : task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup ? (int)TaskInStatusEnum.InCancel : (int)TaskRelocationStatusEnum.RelocationCancel;
|
task.ModifyDate = taskDTO.TaskTime;
|
task.Modifier = taskDTO.OperatorId;
|
BaseDal.DeleteData(task);
|
|
Dt_Task_Hty taskHty = _mapper.Map<Dt_Task_Hty>(task);
|
//_taskHtyService.AddTaskHty(task, (int)OperateTypeEnum.WMS取消);
|
taskHty.OperateType = (int)OperateTypeEnum.WMS取消;
|
_taskHtyRepository.AddData(taskHty);
|
_taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, "人工取消任务");
|
}
|
content = WebResponseContent.Instance.OK("取消任务成功");
|
}
|
catch (Exception ex)
|
{
|
content = WebResponseContent.Instance.Error(ex.Message);
|
}
|
return content;
|
}
|
|
/// <summary>
|
/// 恢复挂起任务
|
/// </summary>
|
/// <param name="taskNum">任务号</param>
|
/// <returns>返回处理结果</returns>
|
public WebResponseContent TaskStatusRecovery(int taskNum)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
Dt_Task 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 } });
|
if (taskExecuteDetail != null)
|
{
|
task.TaskState = taskExecuteDetail.TaskState;
|
}
|
else
|
{
|
if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup)
|
{
|
task.TaskState = (int)TaskOutStatusEnum.OutNew;
|
}
|
else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup)
|
{
|
task.TaskState = (int)TaskInStatusEnum.InNew;
|
}
|
//todo
|
}
|
|
task.ExceptionMessage = string.Empty;
|
|
BaseDal.UpdateData(task);
|
|
_taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"人工恢复挂起任务,恢复挂起时任务状态【{task.TaskState}】");
|
|
content = WebResponseContent.Instance.OK();
|
}
|
catch (Exception ex)
|
{
|
content = WebResponseContent.Instance.Error(ex.Message);
|
}
|
return content;
|
}
|
|
/// <summary>
|
/// 回滚任务状态
|
/// </summary>
|
/// <param name="taskNum">任务号</param>
|
/// <returns>返回处理结果</returns>
|
public WebResponseContent RollbackTaskStatusToLast(int taskNum)
|
{
|
WebResponseContent content = new();
|
try
|
{
|
Dt_Task 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 } });
|
if (taskExecuteDetail != null)
|
{
|
task.TaskState = taskExecuteDetail.TaskState;
|
task.CurrentAddress = taskExecuteDetail.CurrentAddress;
|
task.NextAddress = taskExecuteDetail.NextAddress;
|
}
|
else
|
{
|
return content = WebResponseContent.Instance.Error($"未找到任务明细信息,该任务状态不可回滚到上一步,任务号:【{taskNum}】,任务状态:【{task.TaskState}】");
|
}
|
|
task.ExceptionMessage = string.Empty;
|
|
BaseDal.UpdateData(task);
|
|
_taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"人工将任务状态从【{oldState}】回滚到【{task.TaskState}】");
|
|
content = WebResponseContent.Instance.OK();
|
}
|
catch (Exception ex)
|
{
|
content = WebResponseContent.Instance.Error(ex.Message);
|
}
|
return content;
|
}
|
|
|
/// <summary>
|
/// 删除数据
|
/// </summary>
|
/// <param name="keys">主键数组</param>
|
/// <returns></returns>
|
public virtual WebResponseContent DeleteData(object[] keys)
|
{
|
try
|
{
|
List<Dt_Task> tasks = BaseDal.QureyDataByIds(keys);
|
foreach (Dt_Task task in tasks)
|
{
|
//_taskHtyService.AddTaskHty(task, (int)OperateTypeEnum.人工删除);
|
|
Dt_Task_Hty taskHty = _mapper.Map<Dt_Task_Hty>(task);
|
taskHty.OperateType = (int)OperateTypeEnum.人工删除;
|
_taskHtyRepository.AddData(taskHty);
|
}
|
|
|
if (typeof(Dt_Task).GetNavigatePro() == null)
|
return BaseDal.DeleteDataByIds(keys) ? WebResponseContent.Instance.OK() : WebResponseContent.Instance.Error();
|
else
|
{
|
if (keys != null)
|
{
|
Type detailType = typeof(Dt_Task).GetDetailType();
|
string name = typeof(Dt_Task).GetMainIdByDetail();
|
List<object> dynamicDelKeys = new List<object>();
|
|
for (int i = 0; i < keys.Length; i++)
|
{
|
dynamicDelKeys.Add(keys[i]);
|
}
|
((SqlSugarClient)BaseDal.Db).BeginTran();
|
|
if (dynamicDelKeys.Count > 0)
|
BaseDal.Db.Deleteable<object>().AS(detailType.Name).Where($"{name} in (@id)", new { id = dynamicDelKeys.ToArray() }).ExecuteCommandHasChange();
|
|
BaseDal.DeleteDataByIds(keys);
|
|
((SqlSugarClient)BaseDal.Db).CommitTran();
|
|
return WebResponseContent.Instance.OK();
|
}
|
else
|
{
|
return WebResponseContent.Instance.Error("参数错误");
|
}
|
}
|
}
|
catch (Exception ex)
|
{
|
((SqlSugarClient)BaseDal.Db).RollbackTran();
|
return WebResponseContent.Instance.Error(ex.Message);
|
}
|
}
|
}
|
}
|