uichange Communications Console (#14236)
This commit is contained in:
@@ -28,6 +28,7 @@ namespace Content.Client.Communications.UI
|
|||||||
|
|
||||||
public CommunicationsConsoleBoundUserInterface(ClientUserInterfaceComponent owner, Enum uiKey) : base(owner, uiKey)
|
public CommunicationsConsoleBoundUserInterface(ClientUserInterfaceComponent owner, Enum uiKey) : base(owner, uiKey)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void Open()
|
protected override void Open()
|
||||||
|
|||||||
@@ -0,0 +1,16 @@
|
|||||||
|
<controls:FancyWindow xmlns="https://spacestation14.io"
|
||||||
|
xmlns:controls="clr-namespace:Content.Client.UserInterface.Controls"
|
||||||
|
Title="{Loc 'comms-console-menu-title'}"
|
||||||
|
MinSize="350 225">
|
||||||
|
<BoxContainer Orientation="Vertical" HorizontalExpand="True" VerticalExpand="True" Margin="5">
|
||||||
|
<LineEdit Name="MessageInput" PlaceHolder="{Loc 'comms-console-menu-announcement-placeholder'}" HorizontalExpand="True" Margin="0 0 0 5" />
|
||||||
|
<Button Name="AnnounceButton" Text="{Loc 'comms-console-menu-announcement-button'}" StyleClasses="OpenLeft" Access="Public" />
|
||||||
|
|
||||||
|
<OptionButton Name="AlertLevelButton" StyleClasses="OpenRight" Access="Public" />
|
||||||
|
|
||||||
|
<Control MinSize="10 10" />
|
||||||
|
|
||||||
|
<RichTextLabel Name="CountdownLabel" VerticalExpand="True" />
|
||||||
|
<Button Name="EmergencyShuttleButton" Text="Placeholder Text" Access="Public" />
|
||||||
|
</BoxContainer>
|
||||||
|
</controls:FancyWindow>
|
||||||
@@ -1,7 +1,10 @@
|
|||||||
using System.Threading;
|
using Content.Client.UserInterface.Controls;
|
||||||
|
using System.Threading;
|
||||||
|
using Robust.Client.AutoGenerated;
|
||||||
using Robust.Client.UserInterface;
|
using Robust.Client.UserInterface;
|
||||||
using Robust.Client.UserInterface.Controls;
|
using Robust.Client.UserInterface.Controls;
|
||||||
using Robust.Client.UserInterface.CustomControls;
|
using Robust.Client.UserInterface.CustomControls;
|
||||||
|
using Robust.Client.UserInterface.XAML;
|
||||||
using Robust.Shared.IoC;
|
using Robust.Shared.IoC;
|
||||||
using Robust.Shared.Localization;
|
using Robust.Shared.Localization;
|
||||||
using Robust.Shared.Maths;
|
using Robust.Shared.Maths;
|
||||||
@@ -10,36 +13,22 @@ using Timer = Robust.Shared.Timing.Timer;
|
|||||||
|
|
||||||
namespace Content.Client.Communications.UI
|
namespace Content.Client.Communications.UI
|
||||||
{
|
{
|
||||||
public sealed class CommunicationsConsoleMenu : DefaultWindow
|
[GenerateTypedNameReferences]
|
||||||
|
public sealed partial class CommunicationsConsoleMenu : FancyWindow
|
||||||
{
|
{
|
||||||
private CommunicationsConsoleBoundUserInterface Owner { get; set; }
|
private CommunicationsConsoleBoundUserInterface Owner { get; set; }
|
||||||
private readonly CancellationTokenSource _timerCancelTokenSource = new();
|
private readonly CancellationTokenSource _timerCancelTokenSource = new();
|
||||||
private LineEdit _messageInput { get; set; }
|
|
||||||
public readonly Button AnnounceButton;
|
|
||||||
public readonly Button EmergencyShuttleButton;
|
|
||||||
private readonly RichTextLabel _countdownLabel;
|
|
||||||
public readonly OptionButton AlertLevelButton;
|
|
||||||
|
|
||||||
public CommunicationsConsoleMenu(CommunicationsConsoleBoundUserInterface owner)
|
public CommunicationsConsoleMenu(CommunicationsConsoleBoundUserInterface owner)
|
||||||
{
|
{
|
||||||
SetSize = MinSize = (600, 400);
|
|
||||||
IoCManager.InjectDependencies(this);
|
IoCManager.InjectDependencies(this);
|
||||||
|
RobustXamlLoader.Load(this);
|
||||||
|
|
||||||
Title = Loc.GetString("comms-console-menu-title");
|
|
||||||
Owner = owner;
|
Owner = owner;
|
||||||
|
|
||||||
_messageInput = new LineEdit
|
AnnounceButton.OnPressed += (_) => Owner.AnnounceButtonPressed(MessageInput.Text.Trim());
|
||||||
{
|
|
||||||
PlaceHolder = Loc.GetString("comms-console-menu-announcement-placeholder"),
|
|
||||||
HorizontalExpand = true,
|
|
||||||
SizeFlagsStretchRatio = 1
|
|
||||||
};
|
|
||||||
AnnounceButton = new Button();
|
|
||||||
AnnounceButton.Text = Loc.GetString("comms-console-menu-announcement-button");
|
|
||||||
AnnounceButton.OnPressed += (_) => Owner.AnnounceButtonPressed(_messageInput.Text.Trim());
|
|
||||||
AnnounceButton.Disabled = !owner.CanAnnounce;
|
AnnounceButton.Disabled = !owner.CanAnnounce;
|
||||||
|
|
||||||
AlertLevelButton = new OptionButton();
|
|
||||||
AlertLevelButton.OnItemSelected += args =>
|
AlertLevelButton.OnItemSelected += args =>
|
||||||
{
|
{
|
||||||
var metadata = AlertLevelButton.GetItemMetadata(args.Id);
|
var metadata = AlertLevelButton.GetItemMetadata(args.Id);
|
||||||
@@ -50,37 +39,9 @@ namespace Content.Client.Communications.UI
|
|||||||
};
|
};
|
||||||
AlertLevelButton.Disabled = !owner.AlertLevelSelectable;
|
AlertLevelButton.Disabled = !owner.AlertLevelSelectable;
|
||||||
|
|
||||||
_countdownLabel = new RichTextLabel(){MinSize = new Vector2(0, 200)};
|
|
||||||
EmergencyShuttleButton = new Button();
|
|
||||||
EmergencyShuttleButton.OnPressed += (_) => Owner.EmergencyShuttleButtonPressed();
|
EmergencyShuttleButton.OnPressed += (_) => Owner.EmergencyShuttleButtonPressed();
|
||||||
EmergencyShuttleButton.Disabled = !owner.CanCall;
|
EmergencyShuttleButton.Disabled = !owner.CanCall;
|
||||||
|
|
||||||
var vbox = new BoxContainer
|
|
||||||
{
|
|
||||||
Orientation = LayoutOrientation.Vertical,
|
|
||||||
HorizontalExpand = true,
|
|
||||||
VerticalExpand = true
|
|
||||||
};
|
|
||||||
vbox.AddChild(_messageInput);
|
|
||||||
vbox.AddChild(new Control(){MinSize = new Vector2(0,10), HorizontalExpand = true});
|
|
||||||
vbox.AddChild(AnnounceButton);
|
|
||||||
vbox.AddChild(AlertLevelButton);
|
|
||||||
vbox.AddChild(new Control(){MinSize = new Vector2(0,10), HorizontalExpand = true});
|
|
||||||
vbox.AddChild(_countdownLabel);
|
|
||||||
vbox.AddChild(EmergencyShuttleButton);
|
|
||||||
|
|
||||||
var hbox = new BoxContainer
|
|
||||||
{
|
|
||||||
Orientation = LayoutOrientation.Horizontal,
|
|
||||||
HorizontalExpand = true,
|
|
||||||
VerticalExpand = true
|
|
||||||
};
|
|
||||||
hbox.AddChild(new Control(){MinSize = new Vector2(100,0), HorizontalExpand = true});
|
|
||||||
hbox.AddChild(vbox);
|
|
||||||
hbox.AddChild(new Control(){MinSize = new Vector2(100,0), HorizontalExpand = true});
|
|
||||||
|
|
||||||
Contents.AddChild(hbox);
|
|
||||||
|
|
||||||
UpdateCountdown();
|
UpdateCountdown();
|
||||||
Timer.SpawnRepeating(1000, UpdateCountdown, _timerCancelTokenSource.Token);
|
Timer.SpawnRepeating(1000, UpdateCountdown, _timerCancelTokenSource.Token);
|
||||||
}
|
}
|
||||||
@@ -126,13 +87,13 @@ namespace Content.Client.Communications.UI
|
|||||||
{
|
{
|
||||||
if (!Owner.CountdownStarted)
|
if (!Owner.CountdownStarted)
|
||||||
{
|
{
|
||||||
_countdownLabel.SetMessage("");
|
CountdownLabel.SetMessage("");
|
||||||
EmergencyShuttleButton.Text = Loc.GetString("comms-console-menu-call-shuttle");
|
EmergencyShuttleButton.Text = Loc.GetString("comms-console-menu-call-shuttle");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
EmergencyShuttleButton.Text = Loc.GetString("comms-console-menu-recall-shuttle");
|
EmergencyShuttleButton.Text = Loc.GetString("comms-console-menu-recall-shuttle");
|
||||||
_countdownLabel.SetMessage($"Time remaining\n{Owner.Countdown.ToString()}s");
|
CountdownLabel.SetMessage($"Time remaining\n{Owner.Countdown.ToString()}s");
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void Close()
|
public override void Close()
|
||||||
Reference in New Issue
Block a user