SwiftlyS2

InputMenuOption

Class InputMenuOption

Namespace: SwiftlyS2.Core.Menus.OptionsBase

Assembly: SwiftlyS2.CS2.dll

Represents a menu option that allows text input from players.

public sealed class InputMenuOption : MenuOptionBase, IMenuOption, IDisposable

Inheritance

Implements

Inherited Members

Constructors

InputMenuOption(int, Func<string, bool>?, string, string?, int, int)

Creates an instance of SwiftlyS2.Core.Menus.OptionsBase.InputMenuOption.

public InputMenuOption(int maxLength = 16, Func<string, bool>? validator = null, string defaultValue = "", string? hintMessage = null, int updateIntervalMs = 120, int pauseIntervalMs = 1000)
Parameters
  • maxLength int — Maximum input length. Defaults to 16.
  • validator Func<string, bool>? — Optional function to validate input. Returns true if valid.
  • defaultValue string — The default input value. Defaults to empty string.
  • hintMessage string? — Optional hint message to display when waiting for input. Defaults to English prompt.
  • updateIntervalMs int — The interval in milliseconds between text updates. Defaults to 120ms.
  • pauseIntervalMs int — The pause duration in milliseconds before starting the next text update cycle. Defaults to 1000ms.
Remarks

When using this constructor, the SwiftlyS2.Core.Menus.OptionsBase.MenuOptionBase.Text property must be manually set to specify the initial text.

InputMenuOption(string, int, Func<string, bool>?, string, string?, int, int)

Creates an instance of SwiftlyS2.Core.Menus.OptionsBase.InputMenuOption.

public InputMenuOption(string text, int maxLength = 16, Func<string, bool>? validator = null, string defaultValue = "", string? hintMessage = null, int updateIntervalMs = 120, int pauseIntervalMs = 1000)
Parameters
  • text string — The text content to display.
  • maxLength int — Maximum input length. Defaults to 16.
  • validator Func<string, bool>? — Optional function to validate input. Returns true if valid.
  • defaultValue string — The default input value. Defaults to empty string.
  • hintMessage string? — Optional hint message to display when waiting for input. Defaults to English prompt.
  • updateIntervalMs int — The interval in milliseconds between text updates. Defaults to 120ms.
  • pauseIntervalMs int — The pause duration in milliseconds before starting the next text update cycle. Defaults to 1000ms.

Methods

Dispose()

Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.

public override void Dispose()

GetDisplayText(IPlayer, int)

Gets the display text for this option as it should appear to the specified player.

public override string GetDisplayText(IPlayer player, int displayLine = 0)
Parameters
  • player IPlayer — The player requesting the display text.
  • displayLine int — The display line index of the option.
Returns
  • string — The formatted display text for the option.
Remarks
  • When LineCount=1: The displayLine parameter is not needed; return the HTML-formatted string directly.
    • displayLine=0: Return all content
    • displayLine=1: Return only the first line content
    • displayLine=2: Return only the second line content
    • And so on...

GetValue(IPlayer)

Gets the current input value for the specified player.

public string GetValue(IPlayer player)
Parameters
  • player IPlayer — The player whose value to retrieve.
Returns
  • string — The current input value.

SetValue(IPlayer, string)

Sets the input value for the specified player and triggers validation.

public bool SetValue(IPlayer player, string value)
Parameters
  • player IPlayer — The player whose value to set.
  • value string — The value to set.
Returns
  • bool — True if the value is valid and was set, false otherwise.

ValueChanged

Occurs when a player submits a valid input value.

public event EventHandler<MenuOptionValueChangedEventArgs<string>>? ValueChanged
Event Type

On this page