Some fixes to magboots (#15392)

This commit is contained in:
Menshin
2023-04-22 12:42:36 +02:00
committed by GitHub
parent 035fcaa5b1
commit 8ddef7611b
5 changed files with 25 additions and 61 deletions

View File

@@ -1,27 +1,8 @@
using Content.Shared.Clothing; using Content.Shared.Clothing;
using Robust.Shared.GameStates;
using static Content.Shared.Clothing.MagbootsComponent;
namespace Content.Client.Clothing; namespace Content.Client.Clothing;
public sealed class MagbootsSystem : SharedMagbootsSystem public sealed class MagbootsSystem : SharedMagbootsSystem
{ {
public override void Initialize()
{
base.Initialize();
SubscribeLocalEvent<MagbootsComponent, ComponentHandleState>(OnHandleState);
} }
private void OnHandleState(EntityUid uid, MagbootsComponent component, ref ComponentHandleState args)
{
if (args.Current is not MagbootsComponentState componentState)
return;
if (component.On == componentState.On) return;
component.On = componentState.On;
OnChanged(component);
}
}

View File

@@ -1,19 +1,13 @@
using Content.Server.Atmos.Components; using Content.Server.Atmos.Components;
using Content.Server.Clothing.Components;
using Content.Shared.Alert; using Content.Shared.Alert;
using Content.Shared.Clothing; using Content.Shared.Clothing;
using Content.Shared.Clothing.EntitySystems;
using Content.Shared.Inventory;
using Content.Shared.Inventory.Events; using Content.Shared.Inventory.Events;
using Robust.Shared.Containers;
using Robust.Shared.GameStates;
using static Content.Shared.Clothing.MagbootsComponent;
namespace Content.Server.Clothing; namespace Content.Server.Clothing;
public sealed class MagbootsSystem : SharedMagbootsSystem public sealed class MagbootsSystem : SharedMagbootsSystem
{ {
[Dependency] private readonly AlertsSystem _alertsSystem = default!; [Dependency] private readonly AlertsSystem _alerts = default!;
public override void Initialize() public override void Initialize()
{ {
@@ -21,7 +15,6 @@ public sealed class MagbootsSystem : SharedMagbootsSystem
SubscribeLocalEvent<MagbootsComponent, GotEquippedEvent>(OnGotEquipped); SubscribeLocalEvent<MagbootsComponent, GotEquippedEvent>(OnGotEquipped);
SubscribeLocalEvent<MagbootsComponent, GotUnequippedEvent>(OnGotUnequipped); SubscribeLocalEvent<MagbootsComponent, GotUnequippedEvent>(OnGotUnequipped);
SubscribeLocalEvent<MagbootsComponent, ComponentGetState>(OnGetState);
} }
protected override void UpdateMagbootEffects(EntityUid parent, EntityUid uid, bool state, MagbootsComponent? component) protected override void UpdateMagbootEffects(EntityUid parent, EntityUid uid, bool state, MagbootsComponent? component)
@@ -37,11 +30,11 @@ public sealed class MagbootsSystem : SharedMagbootsSystem
if (state) if (state)
{ {
_alertsSystem.ShowAlert(parent, AlertType.Magboots); _alerts.ShowAlert(parent, AlertType.Magboots);
} }
else else
{ {
_alertsSystem.ClearAlert(parent, AlertType.Magboots); _alerts.ClearAlert(parent, AlertType.Magboots);
} }
} }
@@ -60,9 +53,4 @@ public sealed class MagbootsSystem : SharedMagbootsSystem
UpdateMagbootEffects(args.Equipee, uid, true, component); UpdateMagbootEffects(args.Equipee, uid, true, component);
} }
} }
private void OnGetState(EntityUid uid, MagbootsComponent component, ref ComponentGetState args)
{
args.State = new MagbootsComponentState(component.On);
}
} }

View File

@@ -1,26 +1,15 @@
using Content.Shared.Actions.ActionTypes; using Content.Shared.Actions.ActionTypes;
using Robust.Shared.GameStates; using Robust.Shared.GameStates;
using Robust.Shared.Serialization;
namespace Content.Shared.Clothing; namespace Content.Shared.Clothing;
[RegisterComponent, NetworkedComponent()] [RegisterComponent, NetworkedComponent(), AutoGenerateComponentState]
public sealed class MagbootsComponent : Component [Access(typeof(SharedMagbootsSystem))]
public sealed partial class MagbootsComponent : Component
{ {
[DataField("toggleAction", required: true)] [DataField("toggleAction", required: true)]
public InstantAction ToggleAction = new(); public InstantAction ToggleAction = new();
[ViewVariables] [DataField("on"), AutoNetworkedField]
public bool On; public bool On;
[Serializable, NetSerializable]
public sealed class MagbootsComponentState : ComponentState
{
public bool On { get; }
public MagbootsComponentState(bool @on)
{
On = on;
}
}
} }

View File

@@ -35,29 +35,35 @@ public abstract class SharedMagbootsSystem : EntitySystem
return; return;
args.Handled = true; args.Handled = true;
component.On = !component.On;
ToggleMagboots(uid, component);
}
private void ToggleMagboots(EntityUid uid, MagbootsComponent magboots)
{
magboots.On = !magboots.On;
if (_sharedContainer.TryGetContainingContainer(uid, out var container) && if (_sharedContainer.TryGetContainingContainer(uid, out var container) &&
_inventory.TryGetSlotEntity(container.Owner, "shoes", out var entityUid) && entityUid == component.Owner) _inventory.TryGetSlotEntity(container.Owner, "shoes", out var entityUid) && entityUid == uid)
UpdateMagbootEffects(container.Owner, uid, true, component); UpdateMagbootEffects(container.Owner, uid, true, magboots);
if (TryComp<ItemComponent>(uid, out var item)) if (TryComp<ItemComponent>(uid, out var item))
{ {
_item.SetHeldPrefix(uid, component.On ? "on" : null, item); _item.SetHeldPrefix(uid, magboots.On ? "on" : null, item);
_clothing.SetEquippedPrefix(uid, component.On ? "on" : null); _clothing.SetEquippedPrefix(uid, magboots.On ? "on" : null);
} }
_appearance.SetData(uid, ToggleVisuals.Toggled, component.Owner); _appearance.SetData(uid, ToggleVisuals.Toggled, magboots.On);
OnChanged(component); OnChanged(uid, magboots);
Dirty(component); Dirty(magboots);
} }
protected virtual void UpdateMagbootEffects(EntityUid parent, EntityUid uid, bool state, MagbootsComponent? component) { } protected virtual void UpdateMagbootEffects(EntityUid parent, EntityUid uid, bool state, MagbootsComponent? component) { }
protected void OnChanged(MagbootsComponent component) protected void OnChanged(EntityUid uid, MagbootsComponent component)
{ {
_sharedActions.SetToggled(component.ToggleAction, component.On); _sharedActions.SetToggled(component.ToggleAction, component.On);
_clothingSpeedModifier.SetClothingSpeedModifierEnabled(component.Owner, component.On); _clothingSpeedModifier.SetClothingSpeedModifierEnabled(uid, component.On);
} }
private void AddToggleVerb(EntityUid uid, MagbootsComponent component, GetVerbsEvent<ActivationVerb> args) private void AddToggleVerb(EntityUid uid, MagbootsComponent component, GetVerbsEvent<ActivationVerb> args)
@@ -67,7 +73,7 @@ public abstract class SharedMagbootsSystem : EntitySystem
ActivationVerb verb = new(); ActivationVerb verb = new();
verb.Text = Loc.GetString("toggle-magboots-verb-get-data-text"); verb.Text = Loc.GetString("toggle-magboots-verb-get-data-text");
verb.Act = () => component.On = !component.On; verb.Act = () => ToggleMagboots(uid, component);
// TODO VERB ICON add toggle icon? maybe a computer on/off symbol? // TODO VERB ICON add toggle icon? maybe a computer on/off symbol?
args.Verbs.Add(verb); args.Verbs.Add(verb);
} }

View File

@@ -15,7 +15,7 @@
- type: Magboots - type: Magboots
toggleAction: toggleAction:
icon: { sprite: Clothing/Shoes/Boots/magboots.rsi, state: icon } icon: { sprite: Clothing/Shoes/Boots/magboots.rsi, state: icon }
iconOn: Clothing/Shoes/Boots/magboots.rsi/icon-on.png iconOn: { sprite : Clothing/Shoes/Boots/magboots.rsi, state: icon-on }
name: action-name-magboot-toggle name: action-name-magboot-toggle
description: action-decription-magboot-toggle description: action-decription-magboot-toggle
itemIconStyle: NoItem itemIconStyle: NoItem