diff --git a/Content.Server/Explosion/EntitySystems/TriggerSystem.OnUse.cs b/Content.Server/Explosion/EntitySystems/TriggerSystem.OnUse.cs index 5337460b2993..d8a98027f55e 100644 --- a/Content.Server/Explosion/EntitySystems/TriggerSystem.OnUse.cs +++ b/Content.Server/Explosion/EntitySystems/TriggerSystem.OnUse.cs @@ -16,26 +16,12 @@ public sealed partial class TriggerSystem private void InitializeOnUse() { SubscribeLocalEvent(OnTimerUse); - SubscribeLocalEvent(OnUseSelf); SubscribeLocalEvent(OnExamined); SubscribeLocalEvent>(OnGetAltVerbs); SubscribeLocalEvent(OnStuck); SubscribeLocalEvent(OnRandomTimerTriggerMapInit); } - private void OnUseSelf(EntityUid uid, OnUseTimerTriggerComponent comp, UserActivateInWorldEvent args) - { - // Allow grenades to activate themselves (if they're posessed or ghost role) - - if (args.Handled) - return; - - if (args.Target != uid) - return; - - StartTimer((uid, comp), uid); - } - private void OnStuck(EntityUid uid, OnUseTimerTriggerComponent component, ref EntityStuckEvent args) { if (!component.StartOnStick) diff --git a/Content.Server/NPC/HTN/PrimitiveTasks/Operators/Interactions/StartTimerOperator.cs b/Content.Server/NPC/HTN/PrimitiveTasks/Operators/Interactions/StartTimerOperator.cs new file mode 100644 index 000000000000..fe72e16e3e5e --- /dev/null +++ b/Content.Server/NPC/HTN/PrimitiveTasks/Operators/Interactions/StartTimerOperator.cs @@ -0,0 +1,35 @@ +using System.Threading; +using System.Threading.Tasks; +using Content.Server.Explosion.EntitySystems; +using Content.Shared.Explosion.Components; + +namespace Content.Server.NPC.HTN.PrimitiveTasks.Operators.Interactions; + +public sealed partial class StartTimerOperator : HTNOperator +{ + [Dependency] private readonly IEntityManager _entManager = default!; + + [DataField("idleKey")] + public string IdleKey = "IdleTime"; + + public override async Task<(bool Valid, Dictionary? Effects)> Plan(NPCBlackboard blackboard, CancellationToken cancelToken) + { + return new(true, new Dictionary() + { + { IdleKey, 1f } + }); + } + + public override HTNOperatorStatus Update(NPCBlackboard blackboard, float frameTime) + { + var owner = blackboard.GetValue(NPCBlackboard.Owner); + var trigger = _entManager.System(); + if (!_entManager.TryGetComponent(owner, out var timer)) + return HTNOperatorStatus.Failed; + + trigger.StartTimer((owner, timer), owner); + blackboard.SetValue(IdleKey, timer.Delay); + + return HTNOperatorStatus.Finished; + } +} diff --git a/Resources/Prototypes/NPCs/Animated/grenades.yml b/Resources/Prototypes/NPCs/Animated/grenades.yml index dc1bbb1c2ad4..39de114a7756 100644 --- a/Resources/Prototypes/NPCs/Animated/grenades.yml +++ b/Resources/Prototypes/NPCs/Animated/grenades.yml @@ -37,7 +37,7 @@ - !type:TargetInRangePrecondition targetKey: Target rangeKey: MeleeRange - operator: !type:InteractionActivateSelfOperator + operator: !type:StartTimerOperator - tasks: - !type:HTNCompoundTask task: IdleCompound \ No newline at end of file