mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-15 19:13:31 +01:00
docs(builders): Add some basic documentation (#9359)
This commit is contained in:
@@ -14,27 +14,63 @@ import { StringSelectMenuBuilder } from './selectMenu/StringSelectMenu.js';
|
||||
import { UserSelectMenuBuilder } from './selectMenu/UserSelectMenu.js';
|
||||
import { TextInputBuilder } from './textInput/TextInput.js';
|
||||
|
||||
/**
|
||||
* Components here are mapped to their respective builder.
|
||||
*/
|
||||
export interface MappedComponentTypes {
|
||||
/**
|
||||
* The action row component type is associated with an {@link ActionRowBuilder}.
|
||||
*/
|
||||
[ComponentType.ActionRow]: ActionRowBuilder<AnyComponentBuilder>;
|
||||
/**
|
||||
* The button component type is associated with an {@link ButtonBuilder}.
|
||||
*/
|
||||
[ComponentType.Button]: ButtonBuilder;
|
||||
/**
|
||||
* The string select component type is associated with an {@link StringSelectMenuBuilder}.
|
||||
*/
|
||||
[ComponentType.StringSelect]: StringSelectMenuBuilder;
|
||||
/**
|
||||
* The text inpiut component type is associated with an {@link TextInputBuilder}.
|
||||
*/
|
||||
[ComponentType.TextInput]: TextInputBuilder;
|
||||
/**
|
||||
* The user select component type is associated with an {@link UserSelectMenuBuilder}.
|
||||
*/
|
||||
[ComponentType.UserSelect]: UserSelectMenuBuilder;
|
||||
/**
|
||||
* The role select component type is associated with an {@link RoleSelectMenuBuilder}.
|
||||
*/
|
||||
[ComponentType.RoleSelect]: RoleSelectMenuBuilder;
|
||||
/**
|
||||
* The mentionable select component type is associated with an {@link MentionableSelectMenuBuilder}.
|
||||
*/
|
||||
[ComponentType.MentionableSelect]: MentionableSelectMenuBuilder;
|
||||
/**
|
||||
* The channel select component type is associated with an {@link ChannelSelectMenuBuilder}.
|
||||
*/
|
||||
[ComponentType.ChannelSelect]: ChannelSelectMenuBuilder;
|
||||
}
|
||||
|
||||
/**
|
||||
* Factory for creating components from API data
|
||||
* Factory for creating components from API data.
|
||||
*
|
||||
* @param data - The api data to transform to a component class
|
||||
* @typeParam T - The type of component to use
|
||||
* @param data - The API data to transform to a component class
|
||||
*/
|
||||
export function createComponentBuilder<T extends keyof MappedComponentTypes>(
|
||||
// eslint-disable-next-line @typescript-eslint/sort-type-union-intersection-members
|
||||
data: (APIModalComponent | APIMessageComponent) & { type: T },
|
||||
): MappedComponentTypes[T];
|
||||
|
||||
/**
|
||||
* Factory for creating components from API data.
|
||||
*
|
||||
* @typeParam C - The type of component to use
|
||||
* @param data - The API data to transform to a component class
|
||||
*/
|
||||
export function createComponentBuilder<C extends MessageComponentBuilder | ModalComponentBuilder>(data: C): C;
|
||||
|
||||
export function createComponentBuilder(
|
||||
data: APIMessageComponent | APIModalComponent | MessageComponentBuilder,
|
||||
): ComponentBuilder {
|
||||
@@ -60,7 +96,7 @@ export function createComponentBuilder(
|
||||
case ComponentType.ChannelSelect:
|
||||
return new ChannelSelectMenuBuilder(data);
|
||||
default:
|
||||
// @ts-expect-error: This case can still occur if we get a newer unsupported component type
|
||||
// @ts-expect-error This case can still occur if we get a newer unsupported component type
|
||||
throw new Error(`Cannot properly serialize component type: ${data.type}`);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user