Add ItemStatus for mopping (#13745)
* Add ItemStatus for mopping Big QOL feature * a
This commit is contained in:
20
Content.Client/Fluids/MoppingSystem.cs
Normal file
20
Content.Client/Fluids/MoppingSystem.cs
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
using Content.Client.Fluids.UI;
|
||||||
|
using Content.Client.Items;
|
||||||
|
using Content.Shared.Fluids;
|
||||||
|
using Robust.Client.UserInterface;
|
||||||
|
|
||||||
|
namespace Content.Client.Fluids;
|
||||||
|
|
||||||
|
public sealed class MoppingSystem : SharedMoppingSystem
|
||||||
|
{
|
||||||
|
public override void Initialize()
|
||||||
|
{
|
||||||
|
base.Initialize();
|
||||||
|
Subs.ItemStatus<AbsorbentComponent>(GetAbsorbent);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Control GetAbsorbent(EntityUid arg)
|
||||||
|
{
|
||||||
|
return new AbsorbentItemStatus(arg, EntityManager);
|
||||||
|
}
|
||||||
|
}
|
||||||
13
Content.Client/Fluids/UI/AbsorbentItemStatus.xaml
Normal file
13
Content.Client/Fluids/UI/AbsorbentItemStatus.xaml
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
<Control xmlns="https://spacestation14.io">
|
||||||
|
<BoxContainer Orientation="Horizontal">
|
||||||
|
<ProgressBar
|
||||||
|
HorizontalExpand="True"
|
||||||
|
Name="PercentBar"
|
||||||
|
MinSize="20 20"
|
||||||
|
VerticalAlignment="Center"
|
||||||
|
Margin="2 8 4 2"
|
||||||
|
MaxValue="1.0"
|
||||||
|
MinValue="0.0">
|
||||||
|
</ProgressBar>
|
||||||
|
</BoxContainer>
|
||||||
|
</Control>
|
||||||
31
Content.Client/Fluids/UI/AbsorbentItemStatus.xaml.cs
Normal file
31
Content.Client/Fluids/UI/AbsorbentItemStatus.xaml.cs
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
using Content.Shared.Fluids;
|
||||||
|
using Robust.Client.AutoGenerated;
|
||||||
|
using Robust.Client.UserInterface;
|
||||||
|
using Robust.Client.UserInterface.XAML;
|
||||||
|
using Robust.Shared.Timing;
|
||||||
|
|
||||||
|
namespace Content.Client.Fluids.UI
|
||||||
|
{
|
||||||
|
[GenerateTypedNameReferences]
|
||||||
|
public sealed partial class AbsorbentItemStatus : Control
|
||||||
|
{
|
||||||
|
private readonly IEntityManager _entManager;
|
||||||
|
private readonly EntityUid _uid;
|
||||||
|
|
||||||
|
public AbsorbentItemStatus(EntityUid uid, IEntityManager entManager)
|
||||||
|
{
|
||||||
|
RobustXamlLoader.Load(this);
|
||||||
|
_uid = uid;
|
||||||
|
_entManager = entManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void FrameUpdate(FrameEventArgs args)
|
||||||
|
{
|
||||||
|
base.FrameUpdate(args);
|
||||||
|
if (!_entManager.TryGetComponent<AbsorbentComponent>(_uid, out var absorbent))
|
||||||
|
return;
|
||||||
|
|
||||||
|
PercentBar.Value = absorbent.Progress;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,3 +1,4 @@
|
|||||||
|
using System.Linq;
|
||||||
using Content.Server.Chemistry.Components.SolutionManager;
|
using Content.Server.Chemistry.Components.SolutionManager;
|
||||||
using Content.Server.Chemistry.EntitySystems;
|
using Content.Server.Chemistry.EntitySystems;
|
||||||
using Content.Server.DoAfter;
|
using Content.Server.DoAfter;
|
||||||
@@ -5,6 +6,7 @@ using Content.Server.Fluids.Components;
|
|||||||
using Content.Server.Popups;
|
using Content.Server.Popups;
|
||||||
using Content.Shared.Chemistry.Components;
|
using Content.Shared.Chemistry.Components;
|
||||||
using Content.Shared.FixedPoint;
|
using Content.Shared.FixedPoint;
|
||||||
|
using Content.Shared.Fluids;
|
||||||
using Content.Shared.Interaction;
|
using Content.Shared.Interaction;
|
||||||
using Content.Shared.Tag;
|
using Content.Shared.Tag;
|
||||||
using JetBrains.Annotations;
|
using JetBrains.Annotations;
|
||||||
@@ -15,7 +17,7 @@ using Robust.Shared.Map;
|
|||||||
namespace Content.Server.Fluids.EntitySystems;
|
namespace Content.Server.Fluids.EntitySystems;
|
||||||
|
|
||||||
[UsedImplicitly]
|
[UsedImplicitly]
|
||||||
public sealed class MoppingSystem : EntitySystem
|
public sealed class MoppingSystem : SharedMoppingSystem
|
||||||
{
|
{
|
||||||
[Dependency] private readonly DoAfterSystem _doAfterSystem = default!;
|
[Dependency] private readonly DoAfterSystem _doAfterSystem = default!;
|
||||||
[Dependency] private readonly SpillableSystem _spillableSystem = default!;
|
[Dependency] private readonly SpillableSystem _spillableSystem = default!;
|
||||||
@@ -30,11 +32,37 @@ public sealed class MoppingSystem : EntitySystem
|
|||||||
public override void Initialize()
|
public override void Initialize()
|
||||||
{
|
{
|
||||||
base.Initialize();
|
base.Initialize();
|
||||||
|
SubscribeLocalEvent<AbsorbentComponent, ComponentInit>(OnAbsorbentInit);
|
||||||
SubscribeLocalEvent<AbsorbentComponent, AfterInteractEvent>(OnAfterInteract);
|
SubscribeLocalEvent<AbsorbentComponent, AfterInteractEvent>(OnAfterInteract);
|
||||||
|
SubscribeLocalEvent<AbsorbentComponent, SolutionChangedEvent>(OnAbsorbentSolutionChange);
|
||||||
SubscribeLocalEvent<TransferCancelledEvent>(OnTransferCancelled);
|
SubscribeLocalEvent<TransferCancelledEvent>(OnTransferCancelled);
|
||||||
SubscribeLocalEvent<TransferCompleteEvent>(OnTransferComplete);
|
SubscribeLocalEvent<TransferCompleteEvent>(OnTransferComplete);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void OnAbsorbentInit(EntityUid uid, AbsorbentComponent component, ComponentInit args)
|
||||||
|
{
|
||||||
|
// TODO: I know dirty on init but no prediction moment.
|
||||||
|
UpdateAbsorbent(uid, component);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnAbsorbentSolutionChange(EntityUid uid, AbsorbentComponent component, SolutionChangedEvent args)
|
||||||
|
{
|
||||||
|
UpdateAbsorbent(uid, component);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void UpdateAbsorbent(EntityUid uid, AbsorbentComponent component)
|
||||||
|
{
|
||||||
|
if (!_solutionSystem.TryGetSolution(uid, AbsorbentComponent.SolutionName, out var solution))
|
||||||
|
return;
|
||||||
|
|
||||||
|
var oldProgress = component.Progress;
|
||||||
|
|
||||||
|
component.Progress = (float) (solution.Volume / solution.MaxVolume);
|
||||||
|
if (component.Progress.Equals(oldProgress))
|
||||||
|
return;
|
||||||
|
Dirty(component);
|
||||||
|
}
|
||||||
|
|
||||||
private void OnAfterInteract(EntityUid uid, AbsorbentComponent component, AfterInteractEvent args)
|
private void OnAfterInteract(EntityUid uid, AbsorbentComponent component, AfterInteractEvent args)
|
||||||
{
|
{
|
||||||
if (!args.CanReach || args.Handled)
|
if (!args.CanReach || args.Handled)
|
||||||
|
|||||||
@@ -1,15 +1,18 @@
|
|||||||
using Content.Server.Fluids.EntitySystems;
|
|
||||||
using Content.Shared.FixedPoint;
|
using Content.Shared.FixedPoint;
|
||||||
using Robust.Shared.Audio;
|
using Robust.Shared.Audio;
|
||||||
|
using Robust.Shared.GameStates;
|
||||||
|
|
||||||
namespace Content.Server.Fluids.Components;
|
namespace Content.Shared.Fluids;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// For entities that can clean up puddles
|
/// For entities that can clean up puddles
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[RegisterComponent, Access(typeof(MoppingSystem))]
|
[RegisterComponent, NetworkedComponent]
|
||||||
public sealed class AbsorbentComponent : Component
|
public sealed class AbsorbentComponent : Component
|
||||||
{
|
{
|
||||||
|
// TODO: Predicted solutions my beloved.
|
||||||
|
public float Progress;
|
||||||
|
|
||||||
public const string SolutionName = "absorbed";
|
public const string SolutionName = "absorbed";
|
||||||
|
|
||||||
[DataField("pickupAmount")]
|
[DataField("pickupAmount")]
|
||||||
39
Content.Shared/Fluids/SharedMoppingSystem.cs
Normal file
39
Content.Shared/Fluids/SharedMoppingSystem.cs
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
using Robust.Shared.GameStates;
|
||||||
|
using Robust.Shared.Serialization;
|
||||||
|
|
||||||
|
namespace Content.Shared.Fluids;
|
||||||
|
|
||||||
|
public abstract class SharedMoppingSystem : EntitySystem
|
||||||
|
{
|
||||||
|
public override void Initialize()
|
||||||
|
{
|
||||||
|
base.Initialize();
|
||||||
|
SubscribeLocalEvent<AbsorbentComponent, ComponentGetState>(OnAbsorbentGetState);
|
||||||
|
SubscribeLocalEvent<AbsorbentComponent, ComponentHandleState>(OnAbsorbentHandleState);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnAbsorbentHandleState(EntityUid uid, AbsorbentComponent component, ref ComponentHandleState args)
|
||||||
|
{
|
||||||
|
if (args.Current is not AbsorbentComponentState state)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (component.Progress.Equals(state.Progress))
|
||||||
|
return;
|
||||||
|
|
||||||
|
component.Progress = state.Progress;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnAbsorbentGetState(EntityUid uid, AbsorbentComponent component, ref ComponentGetState args)
|
||||||
|
{
|
||||||
|
args.State = new AbsorbentComponentState()
|
||||||
|
{
|
||||||
|
Progress = component.Progress,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
[Serializable, NetSerializable]
|
||||||
|
protected sealed class AbsorbentComponentState : ComponentState
|
||||||
|
{
|
||||||
|
public float Progress;
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user