-
Notifications
You must be signed in to change notification settings - Fork 598
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into 2024-12-26-Kegs
- Loading branch information
Showing
23 changed files
with
340 additions
and
100 deletions.
There are no files selected for viewing
41 changes: 41 additions & 0 deletions
41
Content.Client/Stack/StackCustomSplitBoundUserInterface.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,41 @@ | ||
// Cherry-picked from space-station-14#32938 courtesy of Ilya246 | ||
using JetBrains.Annotations; | ||
using Content.Shared.Stacks; | ||
using Robust.Client.GameObjects; | ||
using Robust.Client.UserInterface; | ||
|
||
namespace Content.Client.Stack | ||
{ | ||
[UsedImplicitly] | ||
public sealed class StackCustomSplitBoundUserInterface : BoundUserInterface | ||
{ | ||
private IEntityManager _entManager; | ||
private EntityUid _owner; | ||
[ViewVariables] | ||
private StackCustomSplitWindow? _window; | ||
|
||
public StackCustomSplitBoundUserInterface(EntityUid owner, Enum uiKey) : base(owner, uiKey) | ||
{ | ||
_owner = owner; | ||
_entManager = IoCManager.Resolve<IEntityManager>(); | ||
} | ||
|
||
protected override void Open() | ||
{ | ||
base.Open(); | ||
_window = this.CreateWindow<StackCustomSplitWindow>(); | ||
|
||
if (_entManager.TryGetComponent<StackComponent>(_owner, out var comp)) | ||
_window.SetMax(comp.Count); | ||
|
||
_window.ApplyButton.OnPressed += _ => | ||
{ | ||
if (int.TryParse(_window.AmountLineEdit.Text, out var i)) | ||
{ | ||
SendMessage(new StackCustomSplitAmountMessage(i)); | ||
_window.Close(); | ||
} | ||
}; | ||
} | ||
} | ||
} |
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,15 @@ | ||
<DefaultWindow xmlns="https://spacestation14.io" | ||
Title="{Loc 'ui-custom-stack-split-title'}" | ||
Resizable="False"> | ||
<!--Cherry-picked from space-station-14#32938 courtesy of Ilya246--> | ||
|
||
<BoxContainer Orientation="Vertical" SeparationOverride="4" MinSize="240 80"> | ||
<BoxContainer Orientation="Horizontal"> | ||
<LineEdit Name="AmountLineEdit" Access="Public" HorizontalExpand="True" PlaceHolder="{Loc 'ui-custom-stack-split-line-edit-placeholder'}"/> | ||
</BoxContainer> | ||
<BoxContainer Orientation="Horizontal"> | ||
<Label Name="MaximumAmount" Access="Public" /> | ||
</BoxContainer> | ||
<Button Name="ApplyButton" Access="Public" Text="{Loc 'ui-custom-stack-split-apply'}"/> | ||
</BoxContainer> | ||
</DefaultWindow> |
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,35 @@ | ||
// Cherry-picked from space-station-14#32938 courtesy of Ilya246 | ||
using Robust.Client.AutoGenerated; | ||
using Robust.Client.UserInterface.Controls; | ||
using Robust.Client.UserInterface.CustomControls; | ||
using Robust.Client.UserInterface.XAML; | ||
|
||
namespace Content.Client.Stack | ||
{ | ||
[GenerateTypedNameReferences] | ||
public sealed partial class StackCustomSplitWindow : DefaultWindow | ||
{ | ||
private int _max = Int32.MaxValue; | ||
private int _min = 1; | ||
|
||
public StackCustomSplitWindow() | ||
{ | ||
RobustXamlLoader.Load(this); | ||
AmountLineEdit.OnTextChanged += OnValueChanged; | ||
} | ||
|
||
public void SetMax(int max) | ||
{ | ||
_max = max; | ||
MaximumAmount.Text = Loc.GetString("comp-stack-split-size", ("size", _max)); | ||
} | ||
|
||
private void OnValueChanged(LineEdit.LineEditEventArgs args) | ||
{ | ||
if (!int.TryParse(AmountLineEdit.Text, out var amount) || amount > _max || amount < _min) | ||
ApplyButton.Disabled = true; | ||
else | ||
ApplyButton.Disabled = false; | ||
} | ||
} | ||
} |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
using Content.Shared.Chemistry.Components; | ||
using Robust.Shared.Random; | ||
|
||
namespace Content.Server._NF.Chemistry; | ||
|
||
public sealed class RandomPillSystem : EntitySystem | ||
{ | ||
[Dependency] private readonly IRobustRandom _random = default!; | ||
|
||
public const int MaxPillType = 21; | ||
|
||
public override void Initialize() | ||
{ | ||
base.Initialize(); | ||
SubscribeLocalEvent<PillComponent, MapInitEvent>(OnMapInit); | ||
} | ||
|
||
private void OnMapInit(Entity<PillComponent> ent, ref MapInitEvent componentInit) | ||
{ | ||
if (ent.Comp.Random) | ||
{ | ||
ent.Comp.PillType = (uint)_random.Next(MaxPillType); | ||
Dirty(ent); | ||
} | ||
} | ||
} |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
// Cherry-pick space-station-14#32938 courtesy of Ilya246 | ||
using Robust.Shared.Serialization; | ||
|
||
namespace Content.Shared.Stacks | ||
{ | ||
[Serializable, NetSerializable] | ||
public sealed class StackCustomSplitAmountMessage : BoundUserInterfaceMessage | ||
{ | ||
public int Amount; | ||
|
||
public StackCustomSplitAmountMessage(int amount) | ||
{ | ||
Amount = amount; | ||
} | ||
} | ||
|
||
[Serializable, NetSerializable] | ||
public enum StackCustomSplitUiKey | ||
{ | ||
Key, | ||
} | ||
} |
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 |
---|---|---|
@@ -1,81 +1,78 @@ | ||
using Robust.Shared; | ||
using Robust.Shared.Configuration; | ||
|
||
namespace Content.Shared._EE.CCVar | ||
namespace Content.Shared._EE.CCVar; | ||
|
||
[CVarDefs] // ReSharper disable once InconsistentNaming | ||
public sealed class EECCVars | ||
{ | ||
// ReSharper disable once InconsistentNaming | ||
[CVarDefs] | ||
public sealed class EECCVars : CVars | ||
{ | ||
#region Jetpack System | ||
#region Jetpack System | ||
|
||
/// <summary> | ||
/// When true, Jetpacks can be enabled anywhere, even in gravity. | ||
/// </summary> | ||
public static readonly CVarDef<bool> JetpackEnableAnywhere = | ||
CVarDef.Create("ee.jetpack.enable_anywhere", false, CVar.REPLICATED); | ||
/// <summary> | ||
/// When true, Jetpacks can be enabled anywhere, even in gravity. | ||
/// </summary> | ||
public static readonly CVarDef<bool> JetpackEnableAnywhere = | ||
CVarDef.Create("ee.jetpack.enable_anywhere", false, CVar.REPLICATED); | ||
|
||
/// <summary> | ||
/// When true, jetpacks can be enabled on grids that have zero gravity. | ||
/// </summary> | ||
public static readonly CVarDef<bool> JetpackEnableInNoGravity = | ||
CVarDef.Create("ee.jetpack.enable_in_no_gravity", true, CVar.REPLICATED); | ||
/// <summary> | ||
/// When true, jetpacks can be enabled on grids that have zero gravity. | ||
/// </summary> | ||
public static readonly CVarDef<bool> JetpackEnableInNoGravity = | ||
CVarDef.Create("ee.jetpack.enable_in_no_gravity", true, CVar.REPLICATED); | ||
|
||
#endregion | ||
#endregion | ||
|
||
#region Contests System | ||
#region Contests System | ||
|
||
/// <summary> | ||
/// The MASTER TOGGLE for the entire Contests System. | ||
/// ALL CONTESTS BELOW, regardless of type or setting will output 1f when false. | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoContestsSystem = | ||
CVarDef.Create("contests.do_contests_system", true, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// The MASTER TOGGLE for the entire Contests System. | ||
/// ALL CONTESTS BELOW, regardless of type or setting will output 1f when false. | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoContestsSystem = | ||
CVarDef.Create("ee.contests.do_contests_system", true, CVar.REPLICATED | CVar.SERVER); | ||
|
||
/// <summary> | ||
/// Contest functions normally include an optional override to bypass the clamp set by max_percentage. | ||
/// This CVar disables the bypass when false, forcing all implementations to comply with max_percentage. | ||
/// </summary> | ||
public static readonly CVarDef<bool> AllowClampOverride = | ||
CVarDef.Create("contests.allow_clamp_override", true, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// Toggles all MassContest functions. All mass contests output 1f when false | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoMassContests = | ||
CVarDef.Create("contests.do_mass_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// Contest functions normally include an optional override to bypass the clamp set by max_percentage. | ||
/// This CVar disables the bypass when false, forcing all implementations to comply with max_percentage. | ||
/// </summary> | ||
public static readonly CVarDef<bool> AllowClampOverride = | ||
CVarDef.Create("ee.contests.allow_clamp_override", true, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// Toggles all MassContest functions. All mass contests output 1f when false | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoMassContests = | ||
CVarDef.Create("ee.contests.do_mass_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
|
||
/// <summary> | ||
/// Toggles all StaminaContest functions. All stamina contests output 1f when false | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoStaminaContests = | ||
CVarDef.Create("contests.do_stamina_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// Toggles all StaminaContest functions. All stamina contests output 1f when false | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoStaminaContests = | ||
CVarDef.Create("ee.contests.do_stamina_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
|
||
/// <summary> | ||
/// Toggles all HealthContest functions. All health contests output 1f when false | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoHealthContests = | ||
CVarDef.Create("contests.do_health_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// Toggles all HealthContest functions. All health contests output 1f when false | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoHealthContests = | ||
CVarDef.Create("ee.contests.do_health_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
|
||
/// <summary> | ||
/// Toggles all MindContest functions. All mind contests output 1f when false. | ||
/// MindContests are not currently implemented, and are awaiting completion of the Psionic Refactor | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoMindContests = | ||
CVarDef.Create("contests.do_mind_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// Toggles all MindContest functions. All mind contests output 1f when false. | ||
/// MindContests are not currently implemented, and are awaiting completion of the Psionic Refactor | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoMindContests = | ||
CVarDef.Create("ee.contests.do_mind_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
|
||
/// <summary> | ||
/// Toggles all MoodContest functions. All mood contests output 1f when false. | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoMoodContests = | ||
CVarDef.Create("contests.do_mood_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// Toggles all MoodContest functions. All mood contests output 1f when false. | ||
/// </summary> | ||
public static readonly CVarDef<bool> DoMoodContests = | ||
CVarDef.Create("ee.contests.do_mood_contests", true, CVar.REPLICATED | CVar.SERVER); | ||
|
||
/// <summary> | ||
/// The maximum amount that Mass Contests can modify a physics multiplier, given as a +/- percentage | ||
/// Default of 0.25f outputs between * 0.75f and 1.25f | ||
/// </summary> | ||
public static readonly CVarDef<float> MassContestsMaxPercentage = | ||
CVarDef.Create("contests.max_percentage", 0.25f, CVar.REPLICATED | CVar.SERVER); | ||
/// <summary> | ||
/// The maximum amount that Mass Contests can modify a physics multiplier, given as a +/- percentage | ||
/// Default of 0.25f outputs between * 0.75f and 1.25f | ||
/// </summary> | ||
public static readonly CVarDef<float> MassContestsMaxPercentage = | ||
CVarDef.Create("ee.contests.max_percentage", 0.25f, CVar.REPLICATED | CVar.SERVER); | ||
|
||
#endregion | ||
} | ||
#endregion | ||
} |
Oops, something went wrong.