* Init Commit * Remove unused code, fix stun visuals bug * Update Content.Shared/Stunnable/SharedStunSystem.cs * Some initial changes * first batch of changes * Commit * One line cleanup * KnockdownStatusEffect ain't worth it. * Fix 2 bugs * Fixes * Remove that actually, * Maybe this? * Meff fix * Meff fix * alert cleanup and API * I expect update loops to be at the top. * Fix LOC * Address review * Address review x 2 * Merg my PR * Fix * Update Content.Shared/Alert/AlertsSystem.cs webedit Co-authored-by: Perry Fraser <perryprog@users.noreply.github.com> * FIX THAT TEST FAIL!!!! * Me when I forget to actually give you alerts * Push * Tests are not failing locally why are they dying on github??? * Fix test fails (real) --------- Co-authored-by: Princess Cheeseballs <66055347+Pronana@users.noreply.github.com> Co-authored-by: ScarKy0 <106310278+ScarKy0@users.noreply.github.com> Co-authored-by: Perry Fraser <perryprog@users.noreply.github.com>
77 lines
2.5 KiB
C#
77 lines
2.5 KiB
C#
using Content.Shared.Chemistry.Reagent;
|
|
using Content.Shared.StatusEffect;
|
|
using Robust.Shared.Prototypes;
|
|
|
|
namespace Content.Shared.EntityEffects.Effects.StatusEffects;
|
|
|
|
/// <summary>
|
|
/// Adds a generic status effect to the entity,
|
|
/// not worrying about things like how to affect the time it lasts for
|
|
/// or component fields or anything. Just adds a component to an entity
|
|
/// for a given time. Easy.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Can be used for things like adding accents or something. I don't know. Go wild.
|
|
/// </remarks>
|
|
[Obsolete("Use ModifyStatusEffect with StatusEffectNewSystem instead")]
|
|
public sealed partial class GenericStatusEffect : EntityEffect
|
|
{
|
|
[DataField(required: true)]
|
|
public string Key = default!;
|
|
|
|
[DataField]
|
|
public string Component = String.Empty;
|
|
|
|
[DataField]
|
|
public float Time = 2.0f;
|
|
|
|
/// <remarks>
|
|
/// true - refresh status effect time, false - accumulate status effect time
|
|
/// </remarks>
|
|
[DataField]
|
|
public bool Refresh = true;
|
|
|
|
/// <summary>
|
|
/// Should this effect add the status effect, remove time from it, or set its cooldown?
|
|
/// </summary>
|
|
[DataField]
|
|
public StatusEffectMetabolismType Type = StatusEffectMetabolismType.Add;
|
|
|
|
public override void Effect(EntityEffectBaseArgs args)
|
|
{
|
|
var statusSys = args.EntityManager.EntitySysManager.GetEntitySystem<StatusEffectsSystem>();
|
|
|
|
var time = Time;
|
|
if (args is EntityEffectReagentArgs reagentArgs)
|
|
time *= reagentArgs.Scale.Float();
|
|
|
|
if (Type == StatusEffectMetabolismType.Add && Component != String.Empty)
|
|
{
|
|
statusSys.TryAddStatusEffect(args.TargetEntity, Key, TimeSpan.FromSeconds(time), Refresh, Component);
|
|
}
|
|
else if (Type == StatusEffectMetabolismType.Remove)
|
|
{
|
|
statusSys.TryRemoveTime(args.TargetEntity, Key, TimeSpan.FromSeconds(time));
|
|
}
|
|
else if (Type == StatusEffectMetabolismType.Set)
|
|
{
|
|
statusSys.TrySetTime(args.TargetEntity, Key, TimeSpan.FromSeconds(time));
|
|
}
|
|
}
|
|
|
|
protected override string? ReagentEffectGuidebookText(IPrototypeManager prototype, IEntitySystemManager entSys) => Loc.GetString(
|
|
"reagent-effect-guidebook-status-effect",
|
|
("chance", Probability),
|
|
("type", Type),
|
|
("time", Time),
|
|
("key", $"reagent-effect-status-effect-{Key}"));
|
|
}
|
|
|
|
public enum StatusEffectMetabolismType
|
|
{
|
|
Update,
|
|
Add,
|
|
Remove,
|
|
Set
|
|
}
|