Reduce Triggers Boilerplate. (#41086)
* Push 1 * cleanup + master merge * launchontrigger * A crumb of cleanup --------- Co-authored-by: Princess Cheeseballs <66055347+Pronana@users.noreply.github.com>
This commit is contained in:
committed by
GitHub
parent
891f5a8f6b
commit
c01ec294d0
@@ -3,52 +3,32 @@ using Content.Shared.Trigger.Components.Effects;
|
||||
|
||||
namespace Content.Shared.Trigger.Systems;
|
||||
|
||||
public sealed class ExplodeOnTriggerSystem : EntitySystem
|
||||
public sealed class ExplodeOnTriggerSystem : XOnTriggerSystem<ExplodeOnTriggerComponent>
|
||||
{
|
||||
[Dependency] private readonly SharedExplosionSystem _explosion = default!;
|
||||
|
||||
public override void Initialize()
|
||||
protected override void OnTrigger(Entity<ExplodeOnTriggerComponent> ent, EntityUid target, ref TriggerEvent args)
|
||||
{
|
||||
base.Initialize();
|
||||
|
||||
SubscribeLocalEvent<ExplodeOnTriggerComponent, TriggerEvent>(OnExplodeTrigger);
|
||||
SubscribeLocalEvent<ExplosionOnTriggerComponent, TriggerEvent>(OnQueueExplosionTrigger);
|
||||
}
|
||||
|
||||
private void OnExplodeTrigger(Entity<ExplodeOnTriggerComponent> ent, ref TriggerEvent args)
|
||||
{
|
||||
if (args.Key != null && !ent.Comp.KeysIn.Contains(args.Key))
|
||||
return;
|
||||
|
||||
var target = ent.Comp.TargetUser ? args.User : ent.Owner;
|
||||
|
||||
if (target == null)
|
||||
return;
|
||||
|
||||
_explosion.TriggerExplosive(target.Value, user: args.User);
|
||||
args.Handled = true;
|
||||
}
|
||||
|
||||
private void OnQueueExplosionTrigger(Entity<ExplosionOnTriggerComponent> ent, ref TriggerEvent args)
|
||||
{
|
||||
var (uid, comp) = ent;
|
||||
if (args.Key != null && !comp.KeysIn.Contains(args.Key))
|
||||
return;
|
||||
|
||||
var target = comp.TargetUser ? args.User : uid;
|
||||
|
||||
if (target == null)
|
||||
return;
|
||||
|
||||
_explosion.QueueExplosion(target.Value,
|
||||
comp.ExplosionType,
|
||||
comp.TotalIntensity,
|
||||
comp.IntensitySlope,
|
||||
comp.MaxTileIntensity,
|
||||
comp.TileBreakScale,
|
||||
comp.MaxTileBreak,
|
||||
comp.CanCreateVacuum,
|
||||
args.User);
|
||||
_explosion.TriggerExplosive(target, user: args.User);
|
||||
args.Handled = true;
|
||||
}
|
||||
}
|
||||
|
||||
public sealed class ExplosionOnTriggerSystem : XOnTriggerSystem<ExplosionOnTriggerComponent>
|
||||
{
|
||||
[Dependency] private readonly SharedExplosionSystem _explosion = default!;
|
||||
|
||||
protected override void OnTrigger(Entity<ExplosionOnTriggerComponent> ent, EntityUid target, ref TriggerEvent args)
|
||||
{
|
||||
_explosion.QueueExplosion(target,
|
||||
ent.Comp.ExplosionType,
|
||||
ent.Comp.TotalIntensity,
|
||||
ent.Comp.IntensitySlope,
|
||||
ent.Comp.MaxTileIntensity,
|
||||
ent.Comp.TileBreakScale,
|
||||
ent.Comp.MaxTileBreak,
|
||||
ent.Comp.CanCreateVacuum,
|
||||
args.User);
|
||||
args.Handled = true;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user