* Rejig Actions * fix merge errors * lambda-b-gon * fix PAI, add innate actions * Revert "fix PAI, add innate actions" This reverts commit 4b501ac083e979e31ebd98d7b98077e0dbdd344b. * Just fix by making nullable. if only require: true actually did something somehow. * Make AddActions() ensure an actions component and misc comments * misc cleanup * Limit range even when not checking for obstructions * remove old guardian code * rename function and make EntityUid nullable * fix magboot bug * fix action search menu * make targeting toggle all equivalent actions * fix combat popups (enabling <-> disabling) * fix networking * Allow action locking * prevent telepathy
92 lines
3.1 KiB
C#
92 lines
3.1 KiB
C#
using Content.Server.Alert;
|
|
using Content.Server.Atmos.Components;
|
|
using Content.Server.Clothing.Components;
|
|
using Content.Shared.Actions;
|
|
using Content.Shared.Alert;
|
|
using Content.Shared.Clothing;
|
|
using Content.Shared.Inventory.Events;
|
|
using Content.Shared.Movement.EntitySystems;
|
|
using Content.Shared.Slippery;
|
|
using Content.Shared.Verbs;
|
|
|
|
namespace Content.Server.Clothing
|
|
{
|
|
public sealed class MagbootsSystem : SharedMagbootsSystem
|
|
{
|
|
[Dependency] private readonly AlertsSystem _alertsSystem = default!;
|
|
|
|
public override void Initialize()
|
|
{
|
|
base.Initialize();
|
|
|
|
SubscribeLocalEvent<MagbootsComponent, GetVerbsEvent<ActivationVerb>>(AddToggleVerb);
|
|
SubscribeLocalEvent<MagbootsComponent, SlipAttemptEvent>(OnSlipAttempt);
|
|
SubscribeLocalEvent<MagbootsComponent, RefreshMovementSpeedModifiersEvent>(OnRefreshMovespeed);
|
|
SubscribeLocalEvent<MagbootsComponent, GotEquippedEvent>(OnGotEquipped);
|
|
SubscribeLocalEvent<MagbootsComponent, GotUnequippedEvent>(OnGotUnequipped);
|
|
}
|
|
|
|
public void UpdateMagbootEffects(EntityUid parent, EntityUid uid, bool state, MagbootsComponent? component)
|
|
{
|
|
if (!Resolve(uid, ref component))
|
|
return;
|
|
state = state && component.On;
|
|
|
|
if (TryComp(parent, out MovedByPressureComponent? movedByPressure))
|
|
{
|
|
movedByPressure.Enabled = state;
|
|
}
|
|
|
|
if (state)
|
|
{
|
|
_alertsSystem.ShowAlert(parent, AlertType.Magboots);
|
|
}
|
|
else
|
|
{
|
|
_alertsSystem.ClearAlert(parent, AlertType.Magboots);
|
|
}
|
|
}
|
|
|
|
private void OnGotUnequipped(EntityUid uid, MagbootsComponent component, GotUnequippedEvent args)
|
|
{
|
|
if (args.Slot == "shoes")
|
|
{
|
|
UpdateMagbootEffects(args.Equipee, uid, false, component);
|
|
}
|
|
}
|
|
|
|
private void OnGotEquipped(EntityUid uid, MagbootsComponent component, GotEquippedEvent args)
|
|
{
|
|
if (args.Slot == "shoes")
|
|
{
|
|
UpdateMagbootEffects(args.Equipee, uid, true, component);
|
|
}
|
|
}
|
|
|
|
private void OnRefreshMovespeed(EntityUid uid, MagbootsComponent component, RefreshMovementSpeedModifiersEvent args)
|
|
{
|
|
args.ModifySpeed(component.WalkSpeedModifier, component.SprintSpeedModifier);
|
|
}
|
|
|
|
private void AddToggleVerb(EntityUid uid, MagbootsComponent component, GetVerbsEvent<ActivationVerb> args)
|
|
{
|
|
if (!args.CanAccess || !args.CanInteract)
|
|
return;
|
|
|
|
ActivationVerb verb = new();
|
|
verb.Text = Loc.GetString("toggle-magboots-verb-get-data-text");
|
|
verb.Act = () => component.On = !component.On;
|
|
// TODO VERB ICON add toggle icon? maybe a computer on/off symbol?
|
|
args.Verbs.Add(verb);
|
|
}
|
|
|
|
private void OnSlipAttempt(EntityUid uid, MagbootsComponent component, SlipAttemptEvent args)
|
|
{
|
|
if (component.On)
|
|
{
|
|
args.Cancel();
|
|
}
|
|
}
|
|
}
|
|
}
|