#region << 版 本 注 释 >> /*---------------------------------------------------------------- * 创建者:Hupe * 创建时间:2021/10/14 20:04:50 * 版本:V1.0.0 * 描述: * * ---------------------------------------------------------------- * 修改人: * 时间: * 修改说明: * * 版本:V1.0.1 *----------------------------------------------------------------*/ #endregion << 版 本 注 释 >> using ARI.EAP.HOST.Common; using ARI.EAP.HOST.MQ; using ARI.EAP.HOST.MQ.body; using ARI.EAP.HOST.SRD; using Glorysoft.SECS.EQP; using Glorysoft.SECS.EQP.Common; using Glorysoft.SECS.EQP.Utilities; using Glorysoft.SECSwell; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace ARI.EAP.HOST.Handlers.EventHandlers { public class Material_HoldHandler : IEventHandler { public void Execute(SECSTransaction trans, EVENT even) { try { MQMessage mQMessage = new MQMessage(); mQMessage.header.messageName = "MaterialHold"; MaterialHoldBody materialHoldBody = new MaterialHoldBody(); materialHoldBody.spoolingFlag = EquipmentStatus.SpoolingFlag.ToString(); int index = 1; foreach (var key in even.validVariables) { string name = Configurations.conf.sRDConfiguration.tryGetSVOrDV(key); switch (name) { case ("SubstrateID"): { materialHoldBody.substrateId = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Clock"): { materialHoldBody.eventTimestamp = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("MaterialStatus"): { materialHoldBody.materialStatus = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("StateFlag"): { materialHoldBody.stateFlag = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("LocationID"): { materialHoldBody.locationId = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Target A"): { materialHoldBody.target_A = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Target B"): { materialHoldBody.target_B = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Target C"): { materialHoldBody.target_C = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Target D"): { materialHoldBody.target_D = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Reroute A"): { materialHoldBody.reroutet_A = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Reroute B"): { materialHoldBody.reroutet_B = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Reroute C"): { materialHoldBody.reroutet_C = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; case ("Reroute D"): { materialHoldBody.reroutet_D = trans.Primary.Root.Item(3).Item(2).Item(index).Value.ToString(); } break; } trans.Primary.Root.Item(3).Item(2).Item(index).Name = name; index++; } Global.MF.addlog(trans, LoggerService.Receive, even.name, 0); LoggerService.SECSLogger.Info(trans.Primary); Global.MF.addlog(trans, LoggerService.Send, even.name, 1); LoggerService.SECSLogger.Info(trans.Secondary); mQMessage.body = materialHoldBody; Task.Run(() => MainForm.mq.EAPRequest(mQMessage)); } catch (Exception e) { LoggerService.SECSLogger.Error(e); } } } }