Trigger Refactor (#39034)
This commit is contained in:
44
Content.Shared/Trigger/Systems/TriggerSystem.Signal.cs
Normal file
44
Content.Shared/Trigger/Systems/TriggerSystem.Signal.cs
Normal file
@@ -0,0 +1,44 @@
|
||||
using Content.Shared.Trigger.Components.Triggers;
|
||||
using Content.Shared.Trigger.Components.Effects;
|
||||
using Content.Shared.DeviceLinking.Events;
|
||||
|
||||
namespace Content.Shared.Trigger.Systems;
|
||||
|
||||
public sealed partial class TriggerSystem
|
||||
{
|
||||
private void InitializeSignal()
|
||||
{
|
||||
SubscribeLocalEvent<SignalOnTriggerComponent, ComponentInit>(SignalOnTriggerInit);
|
||||
SubscribeLocalEvent<TriggerOnSignalComponent, ComponentInit>(TriggerOnSignalInit);
|
||||
|
||||
SubscribeLocalEvent<SignalOnTriggerComponent, TriggerEvent>(HandleSignalOnTrigger);
|
||||
SubscribeLocalEvent<TriggerOnSignalComponent, SignalReceivedEvent>(OnSignalReceived);
|
||||
}
|
||||
|
||||
private void SignalOnTriggerInit(Entity<SignalOnTriggerComponent> ent, ref ComponentInit args)
|
||||
{
|
||||
_deviceLink.EnsureSourcePorts(ent.Owner, ent.Comp.Port);
|
||||
}
|
||||
|
||||
private void TriggerOnSignalInit(Entity<TriggerOnSignalComponent> ent, ref ComponentInit args)
|
||||
{
|
||||
_deviceLink.EnsureSinkPorts(ent.Owner, ent.Comp.Port);
|
||||
}
|
||||
|
||||
private void HandleSignalOnTrigger(Entity<SignalOnTriggerComponent> ent, ref TriggerEvent args)
|
||||
{
|
||||
if (args.Key != null && !ent.Comp.KeysIn.Contains(args.Key))
|
||||
return;
|
||||
|
||||
_deviceLink.InvokePort(ent.Owner, ent.Comp.Port);
|
||||
args.Handled = true;
|
||||
}
|
||||
|
||||
private void OnSignalReceived(Entity<TriggerOnSignalComponent> ent, ref SignalReceivedEvent args)
|
||||
{
|
||||
if (args.Port != ent.Comp.Port)
|
||||
return;
|
||||
|
||||
Trigger(ent.Owner, args.Trigger, ent.Comp.KeyOut);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user