[WIP] [Tweak] Ограничение раздатчиков реагентов и прочих жидкостей. (#498)
* Reapply "Add limited-reagent dispensers (#23907)" This reverts commit531becd592. # Conflicts: # Content.Client/Chemistry/UI/ReagentDispenserWindow.xaml.cs # Content.Server/Chemistry/EntitySystems/ReagentDispenserSystem.cs # Content.Shared/Chemistry/SharedReagentDispenser.cs # Content.Shared/Containers/ItemSlot/ItemSlotsComponent.cs # Resources/Prototypes/Catalog/ReagentDispensers/beverage.yml # Resources/Prototypes/Entities/Objects/Specific/chemical-containers.yml # Resources/Prototypes/Entities/Structures/Dispensers/chem.yml * Reapply "Fix comp.Owner (#24206)" This reverts commit2d2405ff93. * Reapply "Use old reagent dispenser beaker slot ID (#24209)" This reverts commit388424e2f3. * Add a container display to dispenser UI (#25391) * Implemented contents display for dispenser UI * Update Content.Client/Chemistry/UI/ReagentDispenserWindow.xaml.cs Co-authored-by: Nemanja <98561806+EmoGarbage404@users.noreply.github.com> * Resolve the netent into a euid first --------- Co-authored-by: Nemanja <98561806+EmoGarbage404@users.noreply.github.com> * Add prediction to hand labeler labels (#25869) Added prediction to labels * scoopable ash and foam, solution transfer prediction (#25832) * move SolutionTransfer to shared and predict as much as possible * fully move OpenableSystem to shared now that SolutionTransfer is * fix imports for everything * doc for solution transfer system * trolling * add scoopable system * make ash and foam scoopable * untroll * untroll real * make clickable it work * troll * the scooping room --------- Co-authored-by: deltanedas <@deltanedas:kde.org> Co-authored-by: metalgearsloth <comedian_vs_clown@hotmail.com> # Conflicts: # Resources/Prototypes/Entities/Effects/chemistry_effects.yml * Reagent dispenser UI (#27831) * reagent dispenser: fancy window * reagent dispenser: dispense button grid * reagent dispenser: rearrange containers & info * reagent dispenser: remove `reagent-dispenser-window-container-label` * reagent dispenser: add `Scrollcontainer` on right side * reagent dispenser: get rid of pointless actions * reagent dispenser: cleanup actions and `inventory` field on bound ui state * reagent dispenser: cool reagent cards & finishing touches * reagent dispenser: final cleanup and formatting * reagent dispenser: `ButtonGrid` and `ReagentDispenserSetDispenseAmountMessage` refactor * reagent dispenser: cleanup code & address minor concerns * reagent dispenser: text in reagent cards no longer clips * reagent dispenser: oh wait i forgot to change this and thats why the builds keep failing probably * reagent dispenser mayybe this * reagent dispenser: remove `using FastAccessors;` # Conflicts: # Content.Client/Chemistry/UI/ReagentDispenserWindow.xaml.cs * Reagent dispenser UI (Again) (#27958) * reagent dispenser: fancy window * reagent dispenser: dispense button grid * reagent dispenser: rearrange containers & info * reagent dispenser: remove `reagent-dispenser-window-container-label` * reagent dispenser: add `Scrollcontainer` on right side * reagent dispenser: get rid of pointless actions * reagent dispenser: cleanup actions and `inventory` field on bound ui state * reagent dispenser: cool reagent cards & finishing touches * reagent dispenser: final cleanup and formatting * reagent dispenser: `ButtonGrid` and `ReagentDispenserSetDispenseAmountMessage` refactor * reagent dispenser: cleanup code & address minor concerns * reagent dispenser: text in reagent cards no longer clips * reagent dispenser: oh wait i forgot to change this and thats why the builds keep failing probably * reagent dispenser mayybe this * reagent dispenser: remove `using FastAccessors;` * delete unused classes * disable reagent button when container is empty * Make things a bit bigger * remove obsolete text color override * пару фиксов поверх * переводики хихиххи * еще переводы * feat: химические картриджи --------- Co-authored-by: Tayrtahn <tayrtahn@gmail.com> Co-authored-by: Nemanja <98561806+EmoGarbage404@users.noreply.github.com> Co-authored-by: deltanedas <39013340+deltanedas@users.noreply.github.com> Co-authored-by: Brandon Li <48413902+aspiringLich@users.noreply.github.com>
This commit is contained in:
119
Content.Client/Chemistry/UI/ButtonGrid.cs
Normal file
119
Content.Client/Chemistry/UI/ButtonGrid.cs
Normal file
@@ -0,0 +1,119 @@
|
||||
using System;
|
||||
using Robust.Client.Graphics;
|
||||
using Robust.Client.UserInterface.Controls;
|
||||
|
||||
namespace Content.Client.Chemistry.UI;
|
||||
|
||||
/// <summary>
|
||||
/// Creates a grid of buttons given a comma-seperated list of Text
|
||||
/// </summary>
|
||||
public sealed class ButtonGrid : GridContainer
|
||||
{
|
||||
private string _buttonList = "";
|
||||
|
||||
/// <summary>
|
||||
/// A comma-seperated list of text to use for each button. These will be inserted sequentially.
|
||||
/// </summary>
|
||||
public string ButtonList
|
||||
{
|
||||
get => _buttonList;
|
||||
set
|
||||
{
|
||||
_buttonList = value;
|
||||
Update();
|
||||
}
|
||||
}
|
||||
|
||||
public bool RadioGroup { get; set; } = false;
|
||||
|
||||
private string? _selected;
|
||||
|
||||
/// <summary>
|
||||
/// Which button is currently selected. Only matters when <see cref="RadioGroup"/> is true.
|
||||
/// </summary>
|
||||
public string? Selected
|
||||
{
|
||||
get => _selected;
|
||||
set
|
||||
{
|
||||
_selected = value;
|
||||
Update();
|
||||
}
|
||||
}
|
||||
|
||||
public Action<string>? OnButtonPressed;
|
||||
|
||||
/// <summary>
|
||||
/// <see cref="GridContainer.Columns"/>
|
||||
/// </summary>
|
||||
public new int Columns
|
||||
{
|
||||
get => base.Columns;
|
||||
set
|
||||
{
|
||||
base.Columns = value;
|
||||
Update();
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// <see cref="GridContainer.Rows"/>
|
||||
/// </summary>
|
||||
public new int Rows
|
||||
{
|
||||
get => base.Rows;
|
||||
set
|
||||
{
|
||||
base.Rows = value;
|
||||
Update();
|
||||
}
|
||||
}
|
||||
|
||||
private void Update()
|
||||
{
|
||||
if (ButtonList == "")
|
||||
return;
|
||||
|
||||
this.Children.Clear();
|
||||
var i = 0;
|
||||
var list = ButtonList.Split(",");
|
||||
|
||||
var group = new ButtonGroup();
|
||||
|
||||
foreach (var button in list)
|
||||
{
|
||||
var btn = new Button();
|
||||
btn.Text = button;
|
||||
btn.OnPressed += _ =>
|
||||
{
|
||||
if (RadioGroup)
|
||||
btn.Pressed = true;
|
||||
Selected = button;
|
||||
OnButtonPressed?.Invoke(button);
|
||||
};
|
||||
if (button == Selected)
|
||||
btn.Pressed = true;
|
||||
var sep = HSeparationOverride ?? 0;
|
||||
// ReSharper disable once PossibleLossOfFraction
|
||||
// btn.SetWidth = (this.PixelWidth - sep * (Columns - 1)) / 3;
|
||||
btn.Group = group;
|
||||
|
||||
var row = i / Columns;
|
||||
var col = i % Columns;
|
||||
var last = i == list.Length - 1;
|
||||
var lastCol = i == Columns - 1;
|
||||
var lastRow = row == list.Length / Columns - 1;
|
||||
|
||||
if (row == 0 && (lastCol || last))
|
||||
btn.AddStyleClass("OpenLeft");
|
||||
else if (col == 0 && lastRow)
|
||||
btn.AddStyleClass("OpenRight");
|
||||
else
|
||||
btn.AddStyleClass("OpenBoth");
|
||||
|
||||
this.Children.Add(btn);
|
||||
|
||||
i++;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user