Components
Discord provides several Message Components, allowing for more advanced forms of user interactions. Kord Extensions exposes these via its components system.
Understanding Components
As Discord states, components are a framework for adding interactive elements to the messages your app or bot sends. Several types of components exist, and they're only available in specific contexts:
Type | Units | Description | ||
---|---|---|---|---|
Action Row | Five | Container for other components, up to five rows per message or Modal. Each row has a width of five units. | ✅ Yes | ✅ Yes |
Button | One | Clickable button. | ✅ Yes | ❌ No |
Select Menu | Five | Dropdown menu for selecting zero, one, or multiple items. Supports multiple data types: channels, mentionables, roles, strings, and users. | ✅ Yes | ❌ No |
Text Input | Five | Field that a user may use to input one or multiple lines of text. | ❌ No | ✅ Yes |
Action Rows
Action rows act as a container for other components, and they must be used anywhere you wish to use a component. You may only have up to five rows of components in any single context.
data:image/s3,"s3://crabby-images/f5932/f5932625008c11ba7c85af95fc3ba423dc8e67c5" alt="Graphic depicting an action row. It shows a row with five empty slots. Graphic depicting an action row. It shows a row with five empty slots."
Each component has a width measured in "units." Action rows are five units wide, and thus may contain components up to a total width of five units. If an action row contains multiple components, there shouldn’t be any gaps between them.
data:image/s3,"s3://crabby-images/c234b/c234bda329fc20378be5b413079b3104891d684b" alt="Graphic depicting an example message with five empty action rows positioned below. Graphic depicting an example message with five empty action rows positioned below."
Buttons
Buttons are clickable/tappable components, which the user may interact with to trigger an action or open a link. They’re the only component type with a width of one unit, and thus they’re the only type of component that can appear multiple times in a single row.
You may only add Buttons to messages. You can't add them to Modals.
data:image/s3,"s3://crabby-images/c2508/c25080ec09d0ef32f013bcc85b59955161b43714" alt="Graphic depicting an action row with a single button and four empty slots. Graphic depicting an action row with a single button and four empty slots."
data:image/s3,"s3://crabby-images/f4ceb/f4ceb495dfb38a5e1389c115f96780ba3c5c1589" alt="Graphic depicting an action row with three buttons and two empty slots. Graphic depicting an action row with three buttons and two empty slots."
Several types of buttons exist:
Action Buttons: Buttons which trigger an event when interacted with, which your bot may react to.
Disabled Buttons: Buttons which don't do anything when interacted with.
Link Buttons: Buttons which open a predefined URL in the user's browser when interacted with.
Select Menus
Select Menus represent dropdown menus, allowing users to select zero, one, or multiple options from a set of 25. Select Menus have a width of five units, meaning they take up an entire row.
You may only add Select Menus to messages. You can't add them to Modals.
data:image/s3,"s3://crabby-images/34698/3469887106f6a3461b30693c9305153abb9b736a" alt="Graphic depicting an action row with a single select menu. The select menu spans all five slots, with no empty slots. Graphic depicting an action row with a single select menu. The select menu spans all five slots, with no empty slots."
Select menus support several types of data:
Channels
Mentionables (channels, roles and users)
Roles
Strings
Users
Text Inputs
Text Inputs represent editable text fields, allowing users to input arbitrary data. Text Inputs have a width of five units, meaning they take up an entire row.
You may only add Text Inputs to Modals. You can't add them to messages.
data:image/s3,"s3://crabby-images/5fb59/5fb599866e033bbec93d5d76d0cd26ff7a289936" alt="Graphic depicting an action row with a single text input. The text input spans all five slots, with no empty slots. Graphic depicting an action row with a single text input. The text input spans all five slots, with no empty slots."
Text Inputs support two different form factors:
Line: for a single line of text.
Paragraph: for a larger, multi-line block of text.