diff --git a/.github/workflows/close-master-pr.yml b/.github/workflows/close-master-pr.yml index 66843d35dd6..36a88fac573 100644 --- a/.github/workflows/close-master-pr.yml +++ b/.github/workflows/close-master-pr.yml @@ -12,7 +12,7 @@ jobs: steps: - uses: superbrothers/close-pull-request@v3 with: - comment: "Thank you for contributing to the Space Station 14 repository. Unfortunately, it looks like you submitted your pull request from the master branch. We suggest you follow [our git usage documentation](https://docs.spacestation14.com/en/general-development/setup/git-for-the-ss14-developer.html) \n\n You can move your current work from the master branch to another branch by doing `git branch ` и сбросив измененив в master-ветке." # If you prefer to just comment on the pr and not close it, uncomment the bellow and comment the above diff --git a/Content.Client/Ame/UI/AmeControllerBoundUserInterface.cs b/Content.Client/Ame/UI/AmeControllerBoundUserInterface.cs index 3b4c9fa224d..e84cf5d34de 100644 --- a/Content.Client/Ame/UI/AmeControllerBoundUserInterface.cs +++ b/Content.Client/Ame/UI/AmeControllerBoundUserInterface.cs @@ -1,6 +1,5 @@ -using Content.Shared.Ame; +using Content.Shared.Ame.Components; using JetBrains.Annotations; -using Robust.Client.GameObjects; namespace Content.Client.Ame.UI { diff --git a/Content.Client/Ame/UI/AmeWindow.xaml.cs b/Content.Client/Ame/UI/AmeWindow.xaml.cs index 8f5103e6cf7..8b91ec59660 100644 --- a/Content.Client/Ame/UI/AmeWindow.xaml.cs +++ b/Content.Client/Ame/UI/AmeWindow.xaml.cs @@ -1,5 +1,5 @@ using Content.Client.UserInterface; -using Content.Shared.Ame; +using Content.Shared.Ame.Components; using Robust.Client.AutoGenerated; using Robust.Client.UserInterface.CustomControls; using Robust.Client.UserInterface.XAML; diff --git a/Content.Client/Atmos/UI/SpaceHeaterBoundUserInterface.cs b/Content.Client/Atmos/UI/SpaceHeaterBoundUserInterface.cs new file mode 100644 index 00000000000..4d8d1191e91 --- /dev/null +++ b/Content.Client/Atmos/UI/SpaceHeaterBoundUserInterface.cs @@ -0,0 +1,90 @@ +using Content.Shared.Atmos.Piping.Portable.Components; +using JetBrains.Annotations; +using Robust.Client.UserInterface.Controls; + +namespace Content.Client.Atmos.UI; + +/// +/// Initializes a and updates it when new server messages are received. +/// +[UsedImplicitly] +public sealed class SpaceHeaterBoundUserInterface : BoundUserInterface +{ + [ViewVariables] + private SpaceHeaterWindow? _window; + + public SpaceHeaterBoundUserInterface(EntityUid owner, Enum uiKey) : base(owner, uiKey) + { + } + + protected override void Open() + { + base.Open(); + + _window = new SpaceHeaterWindow(); + + if (State != null) + UpdateState(State); + + _window.OpenCentered(); + + _window.OnClose += Close; + + _window.ToggleStatusButton.OnPressed += _ => OnToggleStatusButtonPressed(); + _window.IncreaseTempRange.OnPressed += _ => OnTemperatureRangeChanged(_window.TemperatureChangeDelta); + _window.DecreaseTempRange.OnPressed += _ => OnTemperatureRangeChanged(-_window.TemperatureChangeDelta); + _window.ModeSelector.OnItemSelected += OnModeChanged; + + _window.PowerLevelSelector.OnItemSelected += OnPowerLevelChange; + } + + private void OnToggleStatusButtonPressed() + { + _window?.SetActive(!_window.Active); + SendMessage(new SpaceHeaterToggleMessage()); + } + + private void OnTemperatureRangeChanged(float changeAmount) + { + SendMessage(new SpaceHeaterChangeTemperatureMessage(changeAmount)); + } + + private void OnModeChanged(OptionButton.ItemSelectedEventArgs args) + { + _window?.ModeSelector.SelectId(args.Id); + SendMessage(new SpaceHeaterChangeModeMessage((SpaceHeaterMode)args.Id)); + } + + private void OnPowerLevelChange(RadioOptionItemSelectedEventArgs args) + { + _window?.PowerLevelSelector.Select(args.Id); + SendMessage(new SpaceHeaterChangePowerLevelMessage((SpaceHeaterPowerLevel)args.Id)); + } + + /// + /// Update the UI state based on server-sent info + /// + /// + protected override void UpdateState(BoundUserInterfaceState state) + { + base.UpdateState(state); + if (_window == null || state is not SpaceHeaterBoundUserInterfaceState cast) + return; + + _window.SetActive(cast.Enabled); + _window.ModeSelector.SelectId((int)cast.Mode); + _window.PowerLevelSelector.Select((int)cast.PowerLevel); + + _window.MinTemp = cast.MinTemperature; + _window.MaxTemp = cast.MaxTemperature; + _window.SetTemperature(cast.TargetTemperature); + } + + protected override void Dispose(bool disposing) + { + base.Dispose(disposing); + if (!disposing) + return; + _window?.Dispose(); + } +} diff --git a/Content.Client/Atmos/UI/SpaceHeaterWindow.xaml b/Content.Client/Atmos/UI/SpaceHeaterWindow.xaml new file mode 100644 index 00000000000..1b7bd490b85 --- /dev/null +++ b/Content.Client/Atmos/UI/SpaceHeaterWindow.xaml @@ -0,0 +1,34 @@ + + + + + + +