Some fixes to magboots (#15392)
This commit is contained in:
@@ -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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user