* adjust min blindness back to 0 when PermanentBlindnessComponent is removed * mapinit changes * remove OnRemove, move changes to OnShutdown * goodbye event * dependency removal * final adjustment --------- Co-authored-by: lunarcomets <luanrcomets2@gmail,com>
58 lines
2.1 KiB
C#
58 lines
2.1 KiB
C#
using Content.Shared.Examine;
|
|
using Content.Shared.Eye.Blinding.Components;
|
|
using Content.Shared.Eye.Blinding.Systems;
|
|
using Content.Shared.IdentityManagement;
|
|
using Robust.Shared.Network;
|
|
|
|
namespace Content.Shared.Traits.Assorted;
|
|
|
|
/// <summary>
|
|
/// This handles permanent blindness, both the examine and the actual effect.
|
|
/// </summary>
|
|
public sealed class PermanentBlindnessSystem : EntitySystem
|
|
{
|
|
[Dependency] private readonly INetManager _net = default!;
|
|
[Dependency] private readonly BlindableSystem _blinding = default!;
|
|
|
|
/// <inheritdoc/>
|
|
public override void Initialize()
|
|
{
|
|
SubscribeLocalEvent<PermanentBlindnessComponent, MapInitEvent>(OnMapInit);
|
|
SubscribeLocalEvent<PermanentBlindnessComponent, ComponentShutdown>(OnShutdown);
|
|
SubscribeLocalEvent<PermanentBlindnessComponent, ExaminedEvent>(OnExamined);
|
|
}
|
|
|
|
private void OnExamined(Entity<PermanentBlindnessComponent> blindness, ref ExaminedEvent args)
|
|
{
|
|
if (args.IsInDetailsRange && !_net.IsClient && blindness.Comp.Blindness == 0)
|
|
{
|
|
args.PushMarkup(Loc.GetString("permanent-blindness-trait-examined", ("target", Identity.Entity(blindness, EntityManager))));
|
|
}
|
|
}
|
|
|
|
private void OnShutdown(Entity<PermanentBlindnessComponent> blindness, ref ComponentShutdown args)
|
|
{
|
|
if (!TryComp<BlindableComponent>(blindness.Owner, out var blindable))
|
|
return;
|
|
|
|
if (blindable.MinDamage != 0)
|
|
{
|
|
_blinding.SetMinDamage((blindness.Owner, blindable), 0);
|
|
}
|
|
}
|
|
|
|
private void OnMapInit(Entity<PermanentBlindnessComponent> blindness, ref MapInitEvent args)
|
|
{
|
|
if(!TryComp<BlindableComponent>(blindness.Owner, out var blindable))
|
|
return;
|
|
|
|
if (blindness.Comp.Blindness != 0)
|
|
_blinding.SetMinDamage((blindness.Owner, blindable), blindness.Comp.Blindness);
|
|
else
|
|
{
|
|
var maxMagnitudeInt = (int) BlurryVisionComponent.MaxMagnitude;
|
|
_blinding.SetMinDamage((blindness.Owner, blindable), maxMagnitudeInt);
|
|
}
|
|
}
|
|
}
|