ninja stun change (#20503)

* tagless fields

* add damage and paralyze instead of electrocuting

* add disable bool to RevealNinja

* raise MeleeAttackEvent on the user after swinging

* uncloak ninja after attacking

* revert RevealNinja bool

* revert meleeattack event

* revert uncloak

* validate shock prototype

* damagespecifier no validation

* ;

* :trollface:

---------

Co-authored-by: deltanedas <@deltanedas:kde.org>
This commit is contained in:
deltanedas
2023-11-06 04:08:33 +00:00
committed by GitHub
parent 525d8e3e94
commit 38904904d0
3 changed files with 29 additions and 18 deletions

View File

@@ -1,12 +1,15 @@
using Content.Server.Ninja.Events; using Content.Server.Ninja.Events;
using Content.Server.Power.EntitySystems; using Content.Server.Power.EntitySystems;
using Content.Shared.Electrocution; using Content.Shared.Damage;
using Content.Shared.Damage.Prototypes;
using Content.Shared.Interaction; using Content.Shared.Interaction;
using Content.Shared.Ninja.Components; using Content.Shared.Ninja.Components;
using Content.Shared.Ninja.Systems; using Content.Shared.Ninja.Systems;
using Content.Shared.Popups; using Content.Shared.Popups;
using Content.Shared.Stunnable;
using Content.Shared.Whitelist; using Content.Shared.Whitelist;
using Robust.Shared.Audio; using Robust.Shared.Audio;
using Robust.Shared.Prototypes;
using Robust.Shared.Timing; using Robust.Shared.Timing;
namespace Content.Server.Ninja.Systems; namespace Content.Server.Ninja.Systems;
@@ -17,11 +20,13 @@ namespace Content.Server.Ninja.Systems;
public sealed class StunProviderSystem : SharedStunProviderSystem public sealed class StunProviderSystem : SharedStunProviderSystem
{ {
[Dependency] private readonly BatterySystem _battery = default!; [Dependency] private readonly BatterySystem _battery = default!;
[Dependency] private readonly DamageableSystem _damageable = default!;
[Dependency] private readonly IGameTiming _timing = default!; [Dependency] private readonly IGameTiming _timing = default!;
[Dependency] private readonly IPrototypeManager _proto = default!;
[Dependency] private readonly SharedAudioSystem _audio = default!; [Dependency] private readonly SharedAudioSystem _audio = default!;
[Dependency] private readonly SharedElectrocutionSystem _electrocution = default!;
[Dependency] private readonly SharedNinjaGlovesSystem _gloves = default!; [Dependency] private readonly SharedNinjaGlovesSystem _gloves = default!;
[Dependency] private readonly SharedPopupSystem _popup = default!; [Dependency] private readonly SharedPopupSystem _popup = default!;
[Dependency] private readonly SharedStunSystem _stun = default!;
public override void Initialize() public override void Initialize()
{ {
@@ -55,8 +60,9 @@ public sealed class StunProviderSystem : SharedStunProviderSystem
_audio.PlayPvs(comp.Sound, target); _audio.PlayPvs(comp.Sound, target);
// not holding hands with target so insuls don't matter _damageable.TryChangeDamage(target, comp.StunDamage, false, true, null, origin: uid);
_electrocution.TryDoElectrocution(target, uid, comp.StunDamage, comp.StunTime, false, ignoreInsulation: true); _stun.TryParalyze(target, comp.StunTime, refresh: false);
// short cooldown to prevent instant stunlocking // short cooldown to prevent instant stunlocking
comp.NextStun = _timing.CurTime + comp.Cooldown; comp.NextStun = _timing.CurTime + comp.Cooldown;

View File

@@ -1,3 +1,4 @@
using Content.Shared.Damage;
using Content.Shared.Ninja.Systems; using Content.Shared.Ninja.Systems;
using Content.Shared.Whitelist; using Content.Shared.Whitelist;
using Robust.Shared.Audio; using Robust.Shared.Audio;
@@ -17,49 +18,55 @@ public sealed partial class StunProviderComponent : Component
/// The powercell entity to take power from. /// The powercell entity to take power from.
/// Determines whether stunning is possible. /// Determines whether stunning is possible.
/// </summary> /// </summary>
[DataField("batteryUid"), ViewVariables(VVAccess.ReadWrite), AutoNetworkedField] [DataField, ViewVariables(VVAccess.ReadWrite), AutoNetworkedField]
public EntityUid? BatteryUid; public EntityUid? BatteryUid;
/// <summary> /// <summary>
/// Sound played when stunning someone. /// Sound played when stunning someone.
/// </summary> /// </summary>
[DataField("sound"), ViewVariables(VVAccess.ReadWrite)] [DataField, ViewVariables(VVAccess.ReadWrite)]
public SoundSpecifier Sound = new SoundCollectionSpecifier("sparks"); public SoundSpecifier Sound = new SoundCollectionSpecifier("sparks");
/// <summary> /// <summary>
/// Joules required in the battery to stun someone. Defaults to 10 uses on a small battery. /// Joules required in the battery to stun someone. Defaults to 10 uses on a small battery.
/// </summary> /// </summary>
[DataField("stunCharge"), ViewVariables(VVAccess.ReadWrite)] [DataField, ViewVariables(VVAccess.ReadWrite)]
public float StunCharge = 36.0f; public float StunCharge = 36f;
/// <summary> /// <summary>
/// Shock damage dealt when stunning someone /// Damage dealt when stunning someone
/// </summary> /// </summary>
[DataField("stunDamage"), ViewVariables(VVAccess.ReadWrite)] [DataField, ViewVariables(VVAccess.ReadWrite)]
public int StunDamage = 5; public DamageSpecifier StunDamage = new()
{
DamageDict = new()
{
{ "Shock", 5 }
}
};
/// <summary> /// <summary>
/// Time that someone is stunned for, stacks if done multiple times. /// Time that someone is stunned for, stacks if done multiple times.
/// </summary> /// </summary>
[DataField("stunTime"), ViewVariables(VVAccess.ReadWrite)] [DataField, ViewVariables(VVAccess.ReadWrite)]
public TimeSpan StunTime = TimeSpan.FromSeconds(5); public TimeSpan StunTime = TimeSpan.FromSeconds(5);
/// <summary> /// <summary>
/// How long stunning is disabled after stunning something. /// How long stunning is disabled after stunning something.
/// </summary> /// </summary>
[DataField("cooldown"), ViewVariables(VVAccess.ReadWrite)] [DataField, ViewVariables(VVAccess.ReadWrite)]
public TimeSpan Cooldown = TimeSpan.FromSeconds(2); public TimeSpan Cooldown = TimeSpan.FromSeconds(2);
/// <summary> /// <summary>
/// Locale string to popup when there is no power /// Locale string to popup when there is no power
/// </summary> /// </summary>
[DataField("noPowerPopup", required: true), ViewVariables(VVAccess.ReadWrite)] [DataField(required: true), ViewVariables(VVAccess.ReadWrite)]
public string NoPowerPopup = string.Empty; public string NoPowerPopup = string.Empty;
/// <summary> /// <summary>
/// Whitelist for what counts as a mob. /// Whitelist for what counts as a mob.
/// </summary> /// </summary>
[DataField("whitelist")] [DataField]
public EntityWhitelist Whitelist = new() public EntityWhitelist Whitelist = new()
{ {
Components = new[] {"Stamina"} Components = new[] {"Stamina"}
@@ -69,6 +76,6 @@ public sealed partial class StunProviderComponent : Component
/// When someone can next be stunned. /// When someone can next be stunned.
/// Essentially a UseDelay unique to this component. /// Essentially a UseDelay unique to this component.
/// </summary> /// </summary>
[DataField("nextStun", customTypeSerializer: typeof(TimeOffsetSerializer)), ViewVariables(VVAccess.ReadWrite)] [DataField(customTypeSerializer: typeof(TimeOffsetSerializer)), ViewVariables(VVAccess.ReadWrite)]
public TimeSpan NextStun = TimeSpan.Zero; public TimeSpan NextStun = TimeSpan.Zero;
} }

View File

@@ -213,8 +213,6 @@
stripTimeReduction: 1 stripTimeReduction: 1
stealthy: true stealthy: true
- type: NinjaGloves - type: NinjaGloves
# not actually electrified, just used to make stun ability work
- type: Electrified
- type: entity - type: entity
parent: ClothingHandsGlovesColorBlack parent: ClothingHandsGlovesColorBlack