-
Notifications
You must be signed in to change notification settings - Fork 220
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'lavaland' of https://github.com/Erisfiregamer1/Einstein…
…-Engines into lavaland
- Loading branch information
Showing
1,379 changed files
with
633,730 additions
and
140,982 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
16 changes: 16 additions & 0 deletions
16
Content.Client/Chemistry/EntitySystems/FillableOneTimeInjectorSystem.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
using Content.Client.Chemistry.UI; | ||
using Content.Client.Items; | ||
using Content.Shared.Chemistry.Components; | ||
using Content.Shared.Chemistry.EntitySystems; | ||
using Robust.Shared.GameStates; | ||
|
||
namespace Content.Client.Chemistry.EntitySystems; | ||
|
||
public sealed class FillableOneTimeInjectorSystem : SharedFillableOneTimeInjectorSystem | ||
{ | ||
public override void Initialize() | ||
{ | ||
base.Initialize(); | ||
Subs.ItemStatus<FillableOneTimeInjectorComponent>(ent => new FillableOneTimeInjectorStatusControl(ent, SolutionContainers)); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
84 changes: 84 additions & 0 deletions
84
Content.Client/Chemistry/UI/FillableOneTimeInjectorStatusControl.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
using Content.Client.Message; | ||
using Content.Client.Stylesheets; | ||
using Content.Shared.Chemistry.Components; | ||
using Content.Shared.Chemistry.EntitySystems; | ||
using Content.Shared.FixedPoint; | ||
using Robust.Client.UserInterface; | ||
using Robust.Client.UserInterface.Controls; | ||
using Robust.Shared.Timing; | ||
|
||
namespace Content.Client.Chemistry.UI; | ||
|
||
public sealed class FillableOneTimeInjectorStatusControl : Control | ||
{ | ||
private readonly Entity<FillableOneTimeInjectorComponent> _parent; | ||
private readonly SharedSolutionContainerSystem _solutionContainers; | ||
private readonly RichTextLabel _label; | ||
|
||
private FixedPoint2 PrevVolume; | ||
private FixedPoint2 PrevMaxVolume; | ||
private FixedPoint2 PrevTransferAmount; | ||
private FillableOneTimeInjectorToggleMode PrevToggleStateIndex; | ||
|
||
public FillableOneTimeInjectorStatusControl(Entity<FillableOneTimeInjectorComponent> parent, SharedSolutionContainerSystem solutionContainers) | ||
{ | ||
_parent = parent; | ||
_solutionContainers = solutionContainers; | ||
_label = new RichTextLabel { StyleClasses = { StyleNano.StyleClassItemStatus } }; | ||
AddChild(_label); | ||
} | ||
|
||
protected override void FrameUpdate(FrameEventArgs args) | ||
{ | ||
base.FrameUpdate(args); | ||
|
||
if (!_solutionContainers.TryGetSolution(_parent.Owner, _parent.Comp.SolutionName, out _, out var solution)) | ||
return; | ||
|
||
// only updates the UI if any of the details are different than they previously were | ||
if (PrevVolume == solution.Volume | ||
&& PrevMaxVolume == solution.MaxVolume | ||
&& PrevTransferAmount == _parent.Comp.TransferAmount) | ||
return; | ||
|
||
PrevVolume = solution.Volume; | ||
PrevMaxVolume = solution.MaxVolume; | ||
PrevTransferAmount = _parent.Comp.TransferAmount; | ||
var modeStringLocalized = ""; | ||
|
||
// only updates the UI if any of the details are different than they previously were | ||
if(PrevToggleStateIndex == _parent.Comp.ToggleState) | ||
return; | ||
|
||
PrevToggleStateIndex = _parent.Comp.ToggleState; | ||
|
||
// Update current volume and injector state | ||
modeStringLocalized = Loc.GetString( | ||
_parent.Comp.ToggleState switch | ||
{ | ||
FillableOneTimeInjectorToggleMode.Draw => "injector-draw-text", | ||
FillableOneTimeInjectorToggleMode.Inject => "injector-inject-text", | ||
FillableOneTimeInjectorToggleMode.Spent => "injector-spent-text", | ||
_ => "injector-invalid-injector-toggle-mode" | ||
}); | ||
|
||
if (_parent.Comp.ToggleState != FillableOneTimeInjectorToggleMode.Draw) | ||
{ | ||
_label.SetMarkup( | ||
Loc.GetString( | ||
"onetime-injector-simple-volume-label", | ||
("currentVolume", solution.Volume), | ||
("modeString", modeStringLocalized))); | ||
} | ||
else | ||
{ | ||
_label.SetMarkup( | ||
Loc.GetString( | ||
"injector-volume-label", | ||
("currentVolume", solution.Volume), | ||
("totalVolume", solution.MaxVolume), | ||
("modeString", modeStringLocalized), | ||
("transferVolume", _parent.Comp.TransferAmount))); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
37 changes: 37 additions & 0 deletions
37
Content.Client/DeltaV/AACTablet/UI/AACBoundUserInterface.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
using Content.Shared.DeltaV.AACTablet; | ||
using Content.Shared.DeltaV.QuickPhrase; | ||
using Robust.Shared.Prototypes; | ||
|
||
namespace Content.Client.DeltaV.AACTablet.UI; | ||
|
||
public sealed class AACBoundUserInterface : BoundUserInterface | ||
{ | ||
[ViewVariables] | ||
private AACWindow? _window; | ||
|
||
public AACBoundUserInterface(EntityUid owner, Enum uiKey) : base(owner, uiKey) | ||
{ | ||
} | ||
|
||
protected override void Open() | ||
{ | ||
base.Open(); | ||
_window?.Close(); | ||
_window = new AACWindow(); | ||
_window.OpenCentered(); | ||
|
||
_window.PhraseButtonPressed += OnPhraseButtonPressed; | ||
_window.OnClose += Close; | ||
} | ||
|
||
private void OnPhraseButtonPressed(ProtoId<QuickPhrasePrototype> phraseId) | ||
{ | ||
SendMessage(new AACTabletSendPhraseMessage(phraseId)); | ||
} | ||
|
||
protected override void Dispose(bool disposing) | ||
{ | ||
base.Dispose(disposing); | ||
_window?.Orphan(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
<controls:FancyWindow xmlns="https://spacestation14.io" | ||
xmlns:controls="clr-namespace:Content.Client.UserInterface.Controls" | ||
Title="AAC Tablet" | ||
Resizable="False" | ||
SetSize="540 300" | ||
MinSize="540 300"> | ||
<ScrollContainer HScrollEnabled="False" Name="WindowBody"> | ||
</ScrollContainer> | ||
</controls:FancyWindow> |
Oops, something went wrong.