DiscordPHP Documentation

UserSelect extends SelectMenu
in package

Select menu for users.

Tags
link
https://discord.com/developers/docs/components/reference#user-select
since
10.0.0
@property

?string|null $placeholder Placeholder text if nothing is selected; max 150 characters.

@property

?array|null $default_values List of default values for auto-populated select menu components; number of default values must be in the range defined by min_values and max_values.

@property

?int|null $min_values Minimum number of items that must be chosen (defaults to 1); min 0, max 25.

@property

?int|null $max_values Maximum number of items that can be chosen (defaults to 1); max 25.

@property

?bool|null $disabled Whether select menu is disabled (defaults to false).

Table of Contents

Constants

TYPE_ACTION_ROW  = 1
Container to display a row of interactive components.
TYPE_BUTTON  = 2
Button object.
TYPE_CHANNEL_SELECT  = 8
Select menu for channels.
TYPE_CHECKPOINT_CARD  = 20
Undocumented.
TYPE_CONTAINER  = 17
Container that visually groups a set of components.
TYPE_CONTENT_INVENTORY_ENTRY  = 16
Undocumented.
TYPE_FILE  = 13
Displays an attached file.
TYPE_FILE_UPLOAD  = 19
Component for uploading files.
TYPE_LABEL  = 18
Container associating a label and description with a component.
TYPE_MEDIA_GALLERY  = 12
Display images and other media.
TYPE_MENTIONABLE_SELECT  = 7
Select menu for mentionables (users and roles).
TYPE_ROLE_SELECT  = 6
Select menu for roles.
TYPE_SECTION  = 9
Container to display text alongside an accessory component.
TYPE_SELECT_MENU  = 3
TYPE_SEPARATOR  = 14
Component to add vertical padding between other components.
TYPE_STRING_SELECT  = 3
Select menu for picking from defined text options.
TYPE_TEXT_DISPLAY  = 10
Markdown text.
TYPE_TEXT_INPUT  = 4
Text input object.
TYPE_THUMBNAIL  = 11
Small image that can be used as an accessory.
TYPE_USER_SELECT  = 5
Select menu for users.
USAGE  = ['Message', 'Modal']

Properties

$custom_id  : string
Custom ID to identify the select menu.
$channel_types  : array<string|int, mixed>|null
List of channel types to include in the channel select component (type 8).
$default_values  : array<string|int, mixed>|null
List of default values for auto-populated select menu components; number of default values must be in the range defined by min_values and max_values.
$disabled  : bool|null
Whether the select menu should be disabled.
$discord  : Discord|null
Discord instance when the listener is set.
$id  : int|null
32 bit integer used as an optional identifier for component.
$listener  : callable|null
Callback used to listen for `INTERACTION_CREATE` events.
$max_values  : int|null
Maximum number of options that must be selected.
$min_values  : int|null
Minimum number of options that must be selected.
$options  : array<string|int, mixed>|null
Specified choices in a select menu (only required and available for string selects (type 3); max 25.
$placeholder  : string|null
Placeholder string to display if nothing is selected. Maximum 150 characters.
$required  : bool|null
Whether the select menu is required. Defaults to true. (Modal only).
$type  : int
Component type.

Methods

__construct()  : mixed
Creates a new select menu.
__get()  : mixed
Handles dynamic get calls onto the part.
__set()  : void
Handles dynamic set calls onto the part.
fromPart()  : self
Creates a new instance of the builder from a given Part.
getChannelTypes()  : array<string|int, mixed>|null
Returns the channel types of the select menu.
getCustomId()  : string
Returns the Custom ID of the select menu.
getDefaultValues()  : array<string|int, mixed>|null
Returns the default values of the select menu.
getMaxValues()  : int|null
Returns the maximum number of options that must be selected.
getMinValues()  : int|null
Returns the minimum number of options that must be selected.
getOptions()  : array<string|int, mixed>|null
Returns the options of the select menu.
getPlaceholder()  : string|null
Returns the placeholder string of the select menu.
getType()  : int
Retrieves the type of the component.
isDisabled()  : bool|null
Returns whether the select menu is disabled.
jsonSerialize()  : array<string|int, mixed>
new()  : static
Creates a new select menu.
removeListener()  : $this
Removes the listener from the button.
setChannelTypes()  : $this
Sets the channel types for the select menu.
setCustomId()  : $this
Sets the custom ID for the interactive component.
setDefaultValues()  : self
setDisabled()  : $this
Sets the select menus disabled state. (Message only).
setListener()  : $this
Sets the callable listener for the select menu. The `$callback` function will be called when the selection of the menu is changed.
setMaxValues()  : $this
Sets the maximum number of options which must be chosen.
setMinValues()  : $this
Sets the minimum number of options which must be chosen.
setOptions()  : $this
Specified choices in a select menu (only required and available for string selects (type 3); max 25.
setPlaceholder()  : $this
Sets the placeholder string to display if nothing is selected.
setRequired()  : $this
Set if this component is required to be filled, default false. (Modal only).
setType()  : string
Sets the type for the select menu.
checkForGetMutator()  : string|false
Checks if there is a get mutator present.
checkForSetMutator()  : string|false
Checks if there is a set mutator present.
createListener()  : callable
Creates a listener callback for handling select menu interactions.
generateUuid()  : string
Generates a UUID which can be used for component custom IDs.
getId()  : int|null
Retrieves the ID associated with the interactive component.
getProperty()  : mixed
Gets a property on the parent part.
setId()  : self
The id field is optional and is used to identify components in the response from an interaction. The id must be unique within the message and is generated sequentially if left empty. Generation of ids won't use another id that exists in the message if you have one defined for another component. Sending components with an id of 0 is allowed but will be treated as empty and replaced by the API. 32 bit integer used as an optional identifier for component.
setProperty()  : void
Sets an property on the parent part.
studly()  : string
Converts a string to studlyCase.

Constants

TYPE_ACTION_ROW

Container to display a row of interactive components.

public mixed TYPE_ACTION_ROW = 1

TYPE_BUTTON

Button object.

public mixed TYPE_BUTTON = 2

TYPE_CHANNEL_SELECT

Select menu for channels.

public mixed TYPE_CHANNEL_SELECT = 8

TYPE_CHECKPOINT_CARD

Undocumented.

public mixed TYPE_CHECKPOINT_CARD = 20

TYPE_CONTAINER

Container that visually groups a set of components.

public mixed TYPE_CONTAINER = 17

TYPE_CONTENT_INVENTORY_ENTRY

Undocumented.

public mixed TYPE_CONTENT_INVENTORY_ENTRY = 16

TYPE_FILE

Displays an attached file.

public mixed TYPE_FILE = 13

TYPE_FILE_UPLOAD

Component for uploading files.

public mixed TYPE_FILE_UPLOAD = 19

TYPE_LABEL

Container associating a label and description with a component.

public mixed TYPE_LABEL = 18

Display images and other media.

public mixed TYPE_MEDIA_GALLERY = 12

TYPE_MENTIONABLE_SELECT

Select menu for mentionables (users and roles).

public mixed TYPE_MENTIONABLE_SELECT = 7

TYPE_ROLE_SELECT

Select menu for roles.

public mixed TYPE_ROLE_SELECT = 6

TYPE_SECTION

Container to display text alongside an accessory component.

public mixed TYPE_SECTION = 9

TYPE_SELECT_MENU

Use Component::TYPE_STRING_SELECT

public mixed TYPE_SELECT_MENU = 3

TYPE_SEPARATOR

Component to add vertical padding between other components.

public mixed TYPE_SEPARATOR = 14

TYPE_STRING_SELECT

Select menu for picking from defined text options.

public mixed TYPE_STRING_SELECT = 3

TYPE_TEXT_DISPLAY

Markdown text.

public mixed TYPE_TEXT_DISPLAY = 10

TYPE_TEXT_INPUT

Text input object.

public mixed TYPE_TEXT_INPUT = 4

TYPE_THUMBNAIL

Small image that can be used as an accessory.

public mixed TYPE_THUMBNAIL = 11

TYPE_USER_SELECT

Select menu for users.

public mixed TYPE_USER_SELECT = 5

Properties

$custom_id

Custom ID to identify the select menu.

public string $custom_id

ID for the select menu; max 100 characters.

$channel_types

List of channel types to include in the channel select component (type 8).

protected array<string|int, mixed>|null $channel_types

$default_values

List of default values for auto-populated select menu components; number of default values must be in the range defined by min_values and max_values.

protected array<string|int, mixed>|null $default_values

$disabled

Whether the select menu should be disabled.

protected bool|null $disabled

$discord

Discord instance when the listener is set.

protected Discord|null $discord

$id

32 bit integer used as an optional identifier for component.

protected int|null $id

$listener

Callback used to listen for `INTERACTION_CREATE` events.

protected callable|null $listener

$max_values

Maximum number of options that must be selected.

protected int|null $max_values

Default 1, maximum 25.

$min_values

Minimum number of options that must be selected.

protected int|null $min_values

Default 1, minimum 0, maximum 25.

$options

Specified choices in a select menu (only required and available for string selects (type 3); max 25.

protected array<string|int, mixed>|null $options

$placeholder

Placeholder string to display if nothing is selected. Maximum 150 characters.

protected string|null $placeholder

$required

Whether the select menu is required. Defaults to true. (Modal only).

protected bool|null $required

$type

Component type.

protected int $type = \Discord\Builders\Components\Component::TYPE_USER_SELECT

Methods

__construct()

Creates a new select menu.

public __construct(string|null $custom_id) : mixed
Parameters
$custom_id : string|null

The custom ID of the select menu. If not given, a UUID will be used

__get()

Handles dynamic get calls onto the part.

public __get(string $key) : mixed
Parameters
$key : string

The attributes key.

Tags
throws
Exception
see
self::getAttribute()

This function forwards onto getAttribute.

Return values
mixed

The value of the attribute.

__set()

Handles dynamic set calls onto the part.

public __set(string $key, mixed $value) : void
Parameters
$key : string

The attributes key.

$value : mixed

The attributes value.

Tags
see
self::setAttribute()

This function forwards onto setAttribute.

fromPart()

Creates a new instance of the builder from a given Part.

public static fromPart(Part $part) : self
Parameters
$part : Part
Return values
self

getChannelTypes()

Returns the channel types of the select menu.

public getChannelTypes() : array<string|int, mixed>|null
Return values
array<string|int, mixed>|null

getCustomId()

Returns the Custom ID of the select menu.

public getCustomId() : string
Return values
string

getDefaultValues()

Returns the default values of the select menu.

public getDefaultValues() : array<string|int, mixed>|null
Return values
array<string|int, mixed>|null

getMaxValues()

Returns the maximum number of options that must be selected.

public getMaxValues() : int|null
Return values
int|null

getMinValues()

Returns the minimum number of options that must be selected.

public getMinValues() : int|null
Return values
int|null

getOptions()

Returns the options of the select menu.

public getOptions() : array<string|int, mixed>|null
Return values
array<string|int, mixed>|null

getPlaceholder()

Returns the placeholder string of the select menu.

public getPlaceholder() : string|null
Return values
string|null

getType()

Retrieves the type of the component.

public getType() : int
Return values
int

isDisabled()

Returns whether the select menu is disabled.

public isDisabled() : bool|null
Return values
bool|null

jsonSerialize()

public jsonSerialize() : array<string|int, mixed>
Tags
inheritDoc
Return values
array<string|int, mixed>

new()

Creates a new select menu.

public static new([string|null $custom_id = null ]) : static
Parameters
$custom_id : string|null = null

The custom ID of the select menu.

Return values
static

removeListener()

Removes the listener from the button.

public removeListener() : $this
Return values
$this

setChannelTypes()

Sets the channel types for the select menu.

public setChannelTypes(array<string|int, mixed> $channel_types) : $this

This method is only applicable if the select menu type is TYPE_CHANNEL_SELECT. If the select menu type is not TYPE_CHANNEL_SELECT, an InvalidArgumentException will be thrown.

Parameters
$channel_types : array<string|int, mixed>
Tags
throws
InvalidArgumentException

If the select menu type is not TYPE_CHANNEL_SELECT.

Return values
$this

setCustomId()

Sets the custom ID for the interactive component.

public setCustomId(string|null $custom_id) : $this
Parameters
$custom_id : string|null
Tags
throws
LengthException

If the custom ID is longer than 100 characters.

Return values
$this

setDefaultValues()

public setDefaultValues(array<string|int, mixed>|null $default_values) : self
Parameters
$default_values : array<string|int, mixed>|null
Return values
self

setDisabled()

Sets the select menus disabled state. (Message only).

public setDisabled([bool|null $disabled = true ]) : $this
Parameters
$disabled : bool|null = true
Return values
$this

setListener()

Sets the callable listener for the select menu. The `$callback` function will be called when the selection of the menu is changed.

public setListener(callable $callback, Discord $discord[, bool $oneOff = false ][, int|float|null $timeout = null ]) : $this

The callback function is called with the Interaction object as well as a Collection of selected options.

If you do not respond to or acknowledge the Interaction, it will be acknowledged for you. Note that if you intend to respond to or acknowledge the interaction inside a promise, you should return a promise that resolves after you respond or acknowledge.

The callback will only be called once with the $oneOff parameter set to true. This can be changed to false, and the callback will be called each time the selection is changed. To remove the listener, you can pass $callback as null.

The select menu listener will not persist when the bot restarts.

Parameters
$callback : callable

Callback to call when the selection is changed. Will be called with the interaction object and collection of options.

$discord : Discord

Discord client.

$oneOff : bool = false

Whether the listener should be removed after the selection is changed for the first time.

$timeout : int|float|null = null
Tags
todo

setListener callback return for each type.

Return values
$this

setMaxValues()

Sets the maximum number of options which must be chosen.

public setMaxValues(int|null $max_values) : $this
Parameters
$max_values : int|null

Default 1 and maximum 25. null to set as default.

Tags
throws
LengthException
Return values
$this

setMinValues()

Sets the minimum number of options which must be chosen.

public setMinValues(int|null $min_values) : $this
Parameters
$min_values : int|null

Default 1, minimum 0 and maximum 25. null to set as default.

Tags
throws
LengthException
Return values
$this

setOptions()

Specified choices in a select menu (only required and available for string selects (type 3); max 25.

public setOptions(array<string|int, mixed> $options) : $this
Parameters
$options : array<string|int, mixed>
Tags
throws
InvalidArgumentException

If the select menu type is not TYPE_STRING_SELECT.

Return values
$this

setPlaceholder()

Sets the placeholder string to display if nothing is selected.

public setPlaceholder(string|null $placeholder) : $this
Parameters
$placeholder : string|null

Maximum 150 characters. null to clear placeholder.

Tags
throws
LengthException
Return values
$this

setRequired()

Set if this component is required to be filled, default false. (Modal only).

public setRequired([bool|null $required = null ]) : $this
Parameters
$required : bool|null = null
Return values
$this

setType()

Sets the type for the select menu.

public setType(int $type) : string

(text: 3, user: 5, role: 6, mentionable: 7, channels: 8).

Parameters
$type : int
Tags
throws
InvalidArgumentException
Return values
string

checkForGetMutator()

Checks if there is a get mutator present.

protected checkForGetMutator(string $key) : string|false
Parameters
$key : string

The property name to check.

Return values
string|false

Either a string if it is a method or false.

checkForSetMutator()

Checks if there is a set mutator present.

protected checkForSetMutator(string $key) : string|false
Parameters
$key : string

The property name to check.

Return values
string|false

Either a string if it is a method or false.

createListener()

Creates a listener callback for handling select menu interactions.

protected createListener(callable $callback[, bool $oneOff = false ][, int|float|null $timeout = null ]) : callable
Parameters
$callback : callable

The callback to execute when the interaction is received. If the select menu has options, the callback receives ($interaction, $options), otherwise just ($interaction).

$oneOff : bool = false

Whether the listener should be removed after being triggered once.

$timeout : int|float|null = null

Optional timeout in seconds after which the listener will be removed.

Return values
callable

The listener closure to be registered for interaction events.

generateUuid()

Generates a UUID which can be used for component custom IDs.

protected static generateUuid() : string
Return values
string

getId()

Retrieves the ID associated with the interactive component.

protected getId() : int|null

Always returns null as this component does not have an ID.

Return values
int|null

getProperty()

Gets a property on the parent part.

protected getProperty(string $key) : mixed
Parameters
$key : string

The name of the property.

Tags
throws
Exception
Return values
mixed

Either the property if it exists or void.

setId()

The id field is optional and is used to identify components in the response from an interaction. The id must be unique within the message and is generated sequentially if left empty. Generation of ids won't use another id that exists in the message if you have one defined for another component. Sending components with an id of 0 is allowed but will be treated as empty and replaced by the API. 32 bit integer used as an optional identifier for component.

protected setId([string|null $id = null ]) : self
Parameters
$id : string|null = null

32 bit integer used as an optional identifier for component.

Return values
self

setProperty()

Sets an property on the parent part.

protected setProperty(string $key, mixed $value) : void
Parameters
$key : string

The name of the property.

$value : mixed

The value of the property.

studly()

Converts a string to studlyCase.

private static studly(string $string) : string

This is a port of updated Laravel's implementation, a non-regex with static cache. This method is private static as we may move it outside this class in future.

Parameters
$string : string

The string to convert.

Tags
since
10.0.0
Return values
string

        
On this page

Search results