|  |  |  | 
|---|
|  |  |  | using HslCommunication; | 
|---|
|  |  |  | using Mapster; | 
|---|
|  |  |  | using Newtonsoft.Json; | 
|---|
|  |  |  | using System.Text.RegularExpressions; | 
|---|
|  |  |  | using System.Threading.Tasks; | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库,下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库,下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(taskOut); | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 处理新任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | private async Task HandleNewTaskAsync(CommonConveyorLine conveyorLine, ConveyorLineTaskCommand command, string childDeviceCode, int ProtocalDetailValue) | 
|---|
|  |  |  | public async Task HandleNewTaskAsync(CommonConveyorLine conveyorLine, ConveyorLineTaskCommand command, string childDeviceCode, int ProtocalDetailValue) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var stationManager = _stationManagerRepository.QueryFirst(x => x.stationChildCode == childDeviceCode && x.stationPLC == conveyorLine.DeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (_taskRepository.QueryFirst(x => x.PalletCode == taskDTO.PalletCode) != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (_taskRepository.QueryFirst(x => x.PalletCode == command.Barcode) != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var taskExecuting = _taskRepository.QueryFirst(x => x.PalletCode == command.Barcode && (x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting|| x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (taskExecuting != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | taskExecuting.ExceptionMessage = "未接收到线体完成信号系统内部自动完成"; | 
|---|
|  |  |  | _taskService.Delete(taskExecuting); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine($"当前托盘存在任务:【{command.Barcode}】"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, $"当前托盘存在任务{command.Barcode}"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, "当前托盘存在任务"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var content = CreateAndSendTask(taskDTO); | 
|---|
|  |  |  | if (content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var task = _taskService.QueryConveyorLineTask(conveyorLine.DeviceCode, childDeviceCode); | 
|---|
|  |  |  | var task = _taskService.QueryConveyorLineTask(conveyorLine.DeviceCode, childDeviceCode, command.Barcode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | task.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(空托盘),下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(空托盘),下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | 
|---|
|  |  |  | var task = _taskService.QueryBarCodeConveyorLineTask(command.Barcode, childDeviceCode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (task.SourceAddress == "1059-4") | 
|---|
|  |  |  | var value = _sys_ConfigService.GetByConfigKey(CateGoryConst.CONFIG_SYS_InStation, SysConfigKeyConst.JZNGInBoundStation).ConfigValue; | 
|---|
|  |  |  | var valueList = value.Split(',').ToList(); | 
|---|
|  |  |  | if (valueList.Contains(task.SourceAddress)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName.WriteConveyorLineTargetAddress, "1000", childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{task.TaskNum}】,托盘条码:【{task.PalletCode}】已到达【{childDeviceCode}】请求扫码入库(实盘),下一目标地址【{1000}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{task.TaskNum}】,托盘条码:【{task.PalletCode}】已到达【{childDeviceCode}】请求扫码入库(实盘),下一目标地址【{1000}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (task.TargetAddress == "1020-1" || task.TargetAddress == "1049-8") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var next = task.NextAddress; | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | task.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(实盘),下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var taskHty = task.Adapt<Dt_Task_Hty>(); | 
|---|
|  |  |  | _task_HtyRepository.AddData(taskHty); | 
|---|
|  |  |  | _taskService.DeleteData(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | task.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(实盘),下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(实盘),下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|