@jubbio/core 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +166 -0
- package/dist/Client.d.ts +147 -0
- package/dist/Client.js +471 -0
- package/dist/builders/ActionRowBuilder.d.ts +53 -0
- package/dist/builders/ActionRowBuilder.js +68 -0
- package/dist/builders/ButtonBuilder.d.ts +77 -0
- package/dist/builders/ButtonBuilder.js +96 -0
- package/dist/builders/EmbedBuilder.d.ts +157 -0
- package/dist/builders/EmbedBuilder.js +199 -0
- package/dist/builders/ModalBuilder.d.ts +122 -0
- package/dist/builders/ModalBuilder.js +162 -0
- package/dist/builders/SelectMenuBuilder.d.ts +123 -0
- package/dist/builders/SelectMenuBuilder.js +165 -0
- package/dist/builders/SlashCommandBuilder.d.ts +197 -0
- package/dist/builders/SlashCommandBuilder.js +324 -0
- package/dist/builders/index.d.ts +9 -0
- package/dist/builders/index.js +26 -0
- package/dist/enums.d.ts +196 -0
- package/dist/enums.js +216 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.js +128 -0
- package/dist/managers/BaseManager.d.ts +69 -0
- package/dist/managers/BaseManager.js +106 -0
- package/dist/managers/ChannelManager.d.ts +98 -0
- package/dist/managers/ChannelManager.js +209 -0
- package/dist/managers/GuildMemberManager.d.ts +74 -0
- package/dist/managers/GuildMemberManager.js +156 -0
- package/dist/managers/RoleManager.d.ts +84 -0
- package/dist/managers/RoleManager.js +207 -0
- package/dist/managers/index.d.ts +7 -0
- package/dist/managers/index.js +24 -0
- package/dist/rest/REST.d.ts +483 -0
- package/dist/rest/REST.js +805 -0
- package/dist/rest/index.d.ts +1 -0
- package/dist/rest/index.js +18 -0
- package/dist/sharding/ShardingManager.d.ts +179 -0
- package/dist/sharding/ShardingManager.js +375 -0
- package/dist/sharding/index.d.ts +4 -0
- package/dist/sharding/index.js +21 -0
- package/dist/structures/Channel.d.ts +120 -0
- package/dist/structures/Channel.js +224 -0
- package/dist/structures/Collection.d.ts +53 -0
- package/dist/structures/Collection.js +115 -0
- package/dist/structures/Guild.d.ts +59 -0
- package/dist/structures/Guild.js +90 -0
- package/dist/structures/GuildMember.d.ts +130 -0
- package/dist/structures/GuildMember.js +208 -0
- package/dist/structures/Interaction.d.ts +224 -0
- package/dist/structures/Interaction.js +404 -0
- package/dist/structures/Message.d.ts +93 -0
- package/dist/structures/Message.js +145 -0
- package/dist/structures/User.d.ts +37 -0
- package/dist/structures/User.js +65 -0
- package/dist/structures/index.d.ts +7 -0
- package/dist/structures/index.js +25 -0
- package/dist/structures.d.ts +1 -0
- package/dist/structures.js +19 -0
- package/dist/types.d.ts +255 -0
- package/dist/types.js +3 -0
- package/dist/utils/BitField.d.ts +66 -0
- package/dist/utils/BitField.js +138 -0
- package/dist/utils/Collection.d.ts +116 -0
- package/dist/utils/Collection.js +265 -0
- package/dist/utils/Collector.d.ts +152 -0
- package/dist/utils/Collector.js +314 -0
- package/dist/utils/DataResolver.d.ts +61 -0
- package/dist/utils/DataResolver.js +146 -0
- package/dist/utils/Formatters.d.ts +145 -0
- package/dist/utils/Formatters.js +213 -0
- package/dist/utils/IntentsBitField.d.ts +85 -0
- package/dist/utils/IntentsBitField.js +99 -0
- package/dist/utils/Partials.d.ts +105 -0
- package/dist/utils/Partials.js +149 -0
- package/dist/utils/PermissionsBitField.d.ts +118 -0
- package/dist/utils/PermissionsBitField.js +145 -0
- package/dist/utils/SnowflakeUtil.d.ts +63 -0
- package/dist/utils/SnowflakeUtil.js +93 -0
- package/dist/utils/Sweepers.d.ts +127 -0
- package/dist/utils/Sweepers.js +270 -0
- package/dist/utils/index.d.ts +13 -0
- package/dist/utils/index.js +30 -0
- package/package.json +37 -0
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ModalBuilder for creating modals
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* Text input styles
|
|
6
|
+
*/
|
|
7
|
+
export declare enum TextInputStyle {
|
|
8
|
+
Short = 1,
|
|
9
|
+
Paragraph = 2
|
|
10
|
+
}
|
|
11
|
+
export interface APITextInputComponent {
|
|
12
|
+
type: 4;
|
|
13
|
+
custom_id: string;
|
|
14
|
+
style: TextInputStyle;
|
|
15
|
+
label: string;
|
|
16
|
+
min_length?: number;
|
|
17
|
+
max_length?: number;
|
|
18
|
+
required?: boolean;
|
|
19
|
+
value?: string;
|
|
20
|
+
placeholder?: string;
|
|
21
|
+
}
|
|
22
|
+
export interface APIModalActionRow {
|
|
23
|
+
type: 1;
|
|
24
|
+
components: APITextInputComponent[];
|
|
25
|
+
}
|
|
26
|
+
export interface APIModal {
|
|
27
|
+
custom_id: string;
|
|
28
|
+
title: string;
|
|
29
|
+
components: APIModalActionRow[];
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* A builder for creating text inputs
|
|
33
|
+
*/
|
|
34
|
+
export declare class TextInputBuilder {
|
|
35
|
+
readonly data: Partial<APITextInputComponent>;
|
|
36
|
+
constructor(data?: Partial<APITextInputComponent>);
|
|
37
|
+
/**
|
|
38
|
+
* Sets the custom ID of this text input
|
|
39
|
+
* @param customId The custom ID
|
|
40
|
+
*/
|
|
41
|
+
setCustomId(customId: string): this;
|
|
42
|
+
/**
|
|
43
|
+
* Sets the label of this text input
|
|
44
|
+
* @param label The label
|
|
45
|
+
*/
|
|
46
|
+
setLabel(label: string): this;
|
|
47
|
+
/**
|
|
48
|
+
* Sets the style of this text input
|
|
49
|
+
* @param style The style
|
|
50
|
+
*/
|
|
51
|
+
setStyle(style: TextInputStyle): this;
|
|
52
|
+
/**
|
|
53
|
+
* Sets the minimum length of this text input
|
|
54
|
+
* @param minLength The minimum length
|
|
55
|
+
*/
|
|
56
|
+
setMinLength(minLength: number): this;
|
|
57
|
+
/**
|
|
58
|
+
* Sets the maximum length of this text input
|
|
59
|
+
* @param maxLength The maximum length
|
|
60
|
+
*/
|
|
61
|
+
setMaxLength(maxLength: number): this;
|
|
62
|
+
/**
|
|
63
|
+
* Sets whether this text input is required
|
|
64
|
+
* @param required Whether the text input is required
|
|
65
|
+
*/
|
|
66
|
+
setRequired(required?: boolean): this;
|
|
67
|
+
/**
|
|
68
|
+
* Sets the value of this text input
|
|
69
|
+
* @param value The value
|
|
70
|
+
*/
|
|
71
|
+
setValue(value: string): this;
|
|
72
|
+
/**
|
|
73
|
+
* Sets the placeholder of this text input
|
|
74
|
+
* @param placeholder The placeholder
|
|
75
|
+
*/
|
|
76
|
+
setPlaceholder(placeholder: string): this;
|
|
77
|
+
/**
|
|
78
|
+
* Returns the JSON representation of this text input
|
|
79
|
+
*/
|
|
80
|
+
toJSON(): APITextInputComponent;
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* A builder for creating modals
|
|
84
|
+
*/
|
|
85
|
+
export declare class ModalBuilder {
|
|
86
|
+
readonly data: Partial<APIModal>;
|
|
87
|
+
constructor(data?: Partial<APIModal>);
|
|
88
|
+
/**
|
|
89
|
+
* Sets the custom ID of this modal
|
|
90
|
+
* @param customId The custom ID
|
|
91
|
+
*/
|
|
92
|
+
setCustomId(customId: string): this;
|
|
93
|
+
/**
|
|
94
|
+
* Sets the title of this modal
|
|
95
|
+
* @param title The title
|
|
96
|
+
*/
|
|
97
|
+
setTitle(title: string): this;
|
|
98
|
+
/**
|
|
99
|
+
* Adds components (action rows with text inputs) to this modal
|
|
100
|
+
* @param components The components to add
|
|
101
|
+
*/
|
|
102
|
+
addComponents(...components: (APIModalActionRow | {
|
|
103
|
+
toJSON(): APIModalActionRow;
|
|
104
|
+
})[]): this;
|
|
105
|
+
/**
|
|
106
|
+
* Sets the components of this modal
|
|
107
|
+
* @param components The components to set
|
|
108
|
+
*/
|
|
109
|
+
setComponents(...components: (APIModalActionRow | {
|
|
110
|
+
toJSON(): APIModalActionRow;
|
|
111
|
+
})[]): this;
|
|
112
|
+
/**
|
|
113
|
+
* Returns the JSON representation of this modal
|
|
114
|
+
*/
|
|
115
|
+
toJSON(): APIModal;
|
|
116
|
+
/**
|
|
117
|
+
* Creates a new modal builder from existing data
|
|
118
|
+
* @param other The modal data to copy
|
|
119
|
+
*/
|
|
120
|
+
static from(other: Partial<APIModal> | ModalBuilder): ModalBuilder;
|
|
121
|
+
}
|
|
122
|
+
export default ModalBuilder;
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ModalBuilder for creating modals
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.ModalBuilder = exports.TextInputBuilder = exports.TextInputStyle = void 0;
|
|
7
|
+
/**
|
|
8
|
+
* Text input styles
|
|
9
|
+
*/
|
|
10
|
+
var TextInputStyle;
|
|
11
|
+
(function (TextInputStyle) {
|
|
12
|
+
TextInputStyle[TextInputStyle["Short"] = 1] = "Short";
|
|
13
|
+
TextInputStyle[TextInputStyle["Paragraph"] = 2] = "Paragraph";
|
|
14
|
+
})(TextInputStyle || (exports.TextInputStyle = TextInputStyle = {}));
|
|
15
|
+
/**
|
|
16
|
+
* A builder for creating text inputs
|
|
17
|
+
*/
|
|
18
|
+
class TextInputBuilder {
|
|
19
|
+
data;
|
|
20
|
+
constructor(data = {}) {
|
|
21
|
+
this.data = { type: 4, ...data };
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Sets the custom ID of this text input
|
|
25
|
+
* @param customId The custom ID
|
|
26
|
+
*/
|
|
27
|
+
setCustomId(customId) {
|
|
28
|
+
this.data.custom_id = customId;
|
|
29
|
+
return this;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Sets the label of this text input
|
|
33
|
+
* @param label The label
|
|
34
|
+
*/
|
|
35
|
+
setLabel(label) {
|
|
36
|
+
this.data.label = label;
|
|
37
|
+
return this;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Sets the style of this text input
|
|
41
|
+
* @param style The style
|
|
42
|
+
*/
|
|
43
|
+
setStyle(style) {
|
|
44
|
+
this.data.style = style;
|
|
45
|
+
return this;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Sets the minimum length of this text input
|
|
49
|
+
* @param minLength The minimum length
|
|
50
|
+
*/
|
|
51
|
+
setMinLength(minLength) {
|
|
52
|
+
this.data.min_length = minLength;
|
|
53
|
+
return this;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Sets the maximum length of this text input
|
|
57
|
+
* @param maxLength The maximum length
|
|
58
|
+
*/
|
|
59
|
+
setMaxLength(maxLength) {
|
|
60
|
+
this.data.max_length = maxLength;
|
|
61
|
+
return this;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Sets whether this text input is required
|
|
65
|
+
* @param required Whether the text input is required
|
|
66
|
+
*/
|
|
67
|
+
setRequired(required = true) {
|
|
68
|
+
this.data.required = required;
|
|
69
|
+
return this;
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Sets the value of this text input
|
|
73
|
+
* @param value The value
|
|
74
|
+
*/
|
|
75
|
+
setValue(value) {
|
|
76
|
+
this.data.value = value;
|
|
77
|
+
return this;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Sets the placeholder of this text input
|
|
81
|
+
* @param placeholder The placeholder
|
|
82
|
+
*/
|
|
83
|
+
setPlaceholder(placeholder) {
|
|
84
|
+
this.data.placeholder = placeholder;
|
|
85
|
+
return this;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Returns the JSON representation of this text input
|
|
89
|
+
*/
|
|
90
|
+
toJSON() {
|
|
91
|
+
return { ...this.data };
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
exports.TextInputBuilder = TextInputBuilder;
|
|
95
|
+
/**
|
|
96
|
+
* A builder for creating modals
|
|
97
|
+
*/
|
|
98
|
+
class ModalBuilder {
|
|
99
|
+
data;
|
|
100
|
+
constructor(data = {}) {
|
|
101
|
+
this.data = { ...data };
|
|
102
|
+
if (!this.data.components)
|
|
103
|
+
this.data.components = [];
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Sets the custom ID of this modal
|
|
107
|
+
* @param customId The custom ID
|
|
108
|
+
*/
|
|
109
|
+
setCustomId(customId) {
|
|
110
|
+
this.data.custom_id = customId;
|
|
111
|
+
return this;
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Sets the title of this modal
|
|
115
|
+
* @param title The title
|
|
116
|
+
*/
|
|
117
|
+
setTitle(title) {
|
|
118
|
+
this.data.title = title;
|
|
119
|
+
return this;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Adds components (action rows with text inputs) to this modal
|
|
123
|
+
* @param components The components to add
|
|
124
|
+
*/
|
|
125
|
+
addComponents(...components) {
|
|
126
|
+
if (!this.data.components)
|
|
127
|
+
this.data.components = [];
|
|
128
|
+
for (const component of components) {
|
|
129
|
+
if ('toJSON' in component && typeof component.toJSON === 'function') {
|
|
130
|
+
this.data.components.push(component.toJSON());
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
this.data.components.push(component);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
return this;
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Sets the components of this modal
|
|
140
|
+
* @param components The components to set
|
|
141
|
+
*/
|
|
142
|
+
setComponents(...components) {
|
|
143
|
+
this.data.components = [];
|
|
144
|
+
return this.addComponents(...components);
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* Returns the JSON representation of this modal
|
|
148
|
+
*/
|
|
149
|
+
toJSON() {
|
|
150
|
+
return { ...this.data };
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Creates a new modal builder from existing data
|
|
154
|
+
* @param other The modal data to copy
|
|
155
|
+
*/
|
|
156
|
+
static from(other) {
|
|
157
|
+
return new ModalBuilder(other instanceof ModalBuilder ? other.data : other);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
exports.ModalBuilder = ModalBuilder;
|
|
161
|
+
exports.default = ModalBuilder;
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ModalBuilder.js","sourceRoot":"","sources":["../../src/builders/ModalBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * ModalBuilder for creating modals\r\n */\r\n\r\n/**\r\n * Text input styles\r\n */\r\nexport enum TextInputStyle {\r\n  Short = 1,\r\n  Paragraph = 2,\r\n}\r\n\r\nexport interface APITextInputComponent {\r\n  type: 4;\r\n  custom_id: string;\r\n  style: TextInputStyle;\r\n  label: string;\r\n  min_length?: number;\r\n  max_length?: number;\r\n  required?: boolean;\r\n  value?: string;\r\n  placeholder?: string;\r\n}\r\n\r\nexport interface APIModalActionRow {\r\n  type: 1;\r\n  components: APITextInputComponent[];\r\n}\r\n\r\nexport interface APIModal {\r\n  custom_id: string;\r\n  title: string;\r\n  components: APIModalActionRow[];\r\n}\r\n\r\n/**\r\n * A builder for creating text inputs\r\n */\r\nexport class TextInputBuilder {\r\n  public readonly data: Partial<APITextInputComponent>;\r\n\r\n  constructor(data: Partial<APITextInputComponent> = {}) {\r\n    this.data = { type: 4, ...data };\r\n  }\r\n\r\n  /**\r\n   * Sets the custom ID of this text input\r\n   * @param customId The custom ID\r\n   */\r\n  setCustomId(customId: string): this {\r\n    this.data.custom_id = customId;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the label of this text input\r\n   * @param label The label\r\n   */\r\n  setLabel(label: string): this {\r\n    this.data.label = label;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the style of this text input\r\n   * @param style The style\r\n   */\r\n  setStyle(style: TextInputStyle): this {\r\n    this.data.style = style;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the minimum length of this text input\r\n   * @param minLength The minimum length\r\n   */\r\n  setMinLength(minLength: number): this {\r\n    this.data.min_length = minLength;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the maximum length of this text input\r\n   * @param maxLength The maximum length\r\n   */\r\n  setMaxLength(maxLength: number): this {\r\n    this.data.max_length = maxLength;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets whether this text input is required\r\n   * @param required Whether the text input is required\r\n   */\r\n  setRequired(required = true): this {\r\n    this.data.required = required;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the value of this text input\r\n   * @param value The value\r\n   */\r\n  setValue(value: string): this {\r\n    this.data.value = value;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the placeholder of this text input\r\n   * @param placeholder The placeholder\r\n   */\r\n  setPlaceholder(placeholder: string): this {\r\n    this.data.placeholder = placeholder;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Returns the JSON representation of this text input\r\n   */\r\n  toJSON(): APITextInputComponent {\r\n    return { ...this.data } as APITextInputComponent;\r\n  }\r\n}\r\n\r\n/**\r\n * A builder for creating modals\r\n */\r\nexport class ModalBuilder {\r\n  public readonly data: Partial<APIModal>;\r\n\r\n  constructor(data: Partial<APIModal> = {}) {\r\n    this.data = { ...data };\r\n    if (!this.data.components) this.data.components = [];\r\n  }\r\n\r\n  /**\r\n   * Sets the custom ID of this modal\r\n   * @param customId The custom ID\r\n   */\r\n  setCustomId(customId: string): this {\r\n    this.data.custom_id = customId;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the title of this modal\r\n   * @param title The title\r\n   */\r\n  setTitle(title: string): this {\r\n    this.data.title = title;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Adds components (action rows with text inputs) to this modal\r\n   * @param components The components to add\r\n   */\r\n  addComponents(...components: (APIModalActionRow | { toJSON(): APIModalActionRow })[]): this {\r\n    if (!this.data.components) this.data.components = [];\r\n    for (const component of components) {\r\n      if ('toJSON' in component && typeof component.toJSON === 'function') {\r\n        this.data.components.push(component.toJSON());\r\n      } else {\r\n        this.data.components.push(component as APIModalActionRow);\r\n      }\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the components of this modal\r\n   * @param components The components to set\r\n   */\r\n  setComponents(...components: (APIModalActionRow | { toJSON(): APIModalActionRow })[]): this {\r\n    this.data.components = [];\r\n    return this.addComponents(...components);\r\n  }\r\n\r\n  /**\r\n   * Returns the JSON representation of this modal\r\n   */\r\n  toJSON(): APIModal {\r\n    return { ...this.data } as APIModal;\r\n  }\r\n\r\n  /**\r\n   * Creates a new modal builder from existing data\r\n   * @param other The modal data to copy\r\n   */\r\n  static from(other: Partial<APIModal> | ModalBuilder): ModalBuilder {\r\n    return new ModalBuilder(other instanceof ModalBuilder ? other.data : other);\r\n  }\r\n}\r\n\r\nexport default ModalBuilder;\r\n"]}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SelectMenuBuilder for creating select menus
|
|
3
|
+
*/
|
|
4
|
+
export interface APISelectMenuOption {
|
|
5
|
+
label: string;
|
|
6
|
+
value: string;
|
|
7
|
+
description?: string;
|
|
8
|
+
emoji?: {
|
|
9
|
+
id?: string;
|
|
10
|
+
name?: string;
|
|
11
|
+
animated?: boolean;
|
|
12
|
+
};
|
|
13
|
+
default?: boolean;
|
|
14
|
+
}
|
|
15
|
+
export interface APISelectMenuComponent {
|
|
16
|
+
type: 3;
|
|
17
|
+
custom_id: string;
|
|
18
|
+
options?: APISelectMenuOption[];
|
|
19
|
+
placeholder?: string;
|
|
20
|
+
min_values?: number;
|
|
21
|
+
max_values?: number;
|
|
22
|
+
disabled?: boolean;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* A builder for creating string select menus
|
|
26
|
+
*/
|
|
27
|
+
export declare class StringSelectMenuBuilder {
|
|
28
|
+
readonly data: Partial<APISelectMenuComponent>;
|
|
29
|
+
constructor(data?: Partial<APISelectMenuComponent>);
|
|
30
|
+
/**
|
|
31
|
+
* Sets the custom ID of this select menu
|
|
32
|
+
* @param customId The custom ID
|
|
33
|
+
*/
|
|
34
|
+
setCustomId(customId: string): this;
|
|
35
|
+
/**
|
|
36
|
+
* Sets the placeholder of this select menu
|
|
37
|
+
* @param placeholder The placeholder
|
|
38
|
+
*/
|
|
39
|
+
setPlaceholder(placeholder: string): this;
|
|
40
|
+
/**
|
|
41
|
+
* Sets the minimum values of this select menu
|
|
42
|
+
* @param minValues The minimum values
|
|
43
|
+
*/
|
|
44
|
+
setMinValues(minValues: number): this;
|
|
45
|
+
/**
|
|
46
|
+
* Sets the maximum values of this select menu
|
|
47
|
+
* @param maxValues The maximum values
|
|
48
|
+
*/
|
|
49
|
+
setMaxValues(maxValues: number): this;
|
|
50
|
+
/**
|
|
51
|
+
* Sets whether this select menu is disabled
|
|
52
|
+
* @param disabled Whether the select menu is disabled
|
|
53
|
+
*/
|
|
54
|
+
setDisabled(disabled?: boolean): this;
|
|
55
|
+
/**
|
|
56
|
+
* Adds options to this select menu
|
|
57
|
+
* @param options The options to add
|
|
58
|
+
*/
|
|
59
|
+
addOptions(...options: APISelectMenuOption[]): this;
|
|
60
|
+
/**
|
|
61
|
+
* Sets the options of this select menu
|
|
62
|
+
* @param options The options to set
|
|
63
|
+
*/
|
|
64
|
+
setOptions(...options: APISelectMenuOption[]): this;
|
|
65
|
+
/**
|
|
66
|
+
* Removes, replaces, or inserts options
|
|
67
|
+
* @param index The index to start at
|
|
68
|
+
* @param deleteCount The number of options to remove
|
|
69
|
+
* @param options The options to insert
|
|
70
|
+
*/
|
|
71
|
+
spliceOptions(index: number, deleteCount: number, ...options: APISelectMenuOption[]): this;
|
|
72
|
+
/**
|
|
73
|
+
* Returns the JSON representation of this select menu
|
|
74
|
+
*/
|
|
75
|
+
toJSON(): APISelectMenuComponent;
|
|
76
|
+
/**
|
|
77
|
+
* Creates a new select menu builder from existing data
|
|
78
|
+
* @param other The select menu data to copy
|
|
79
|
+
*/
|
|
80
|
+
static from(other: Partial<APISelectMenuComponent> | StringSelectMenuBuilder): StringSelectMenuBuilder;
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* A builder for creating select menu options
|
|
84
|
+
*/
|
|
85
|
+
export declare class StringSelectMenuOptionBuilder {
|
|
86
|
+
readonly data: Partial<APISelectMenuOption>;
|
|
87
|
+
constructor(data?: Partial<APISelectMenuOption>);
|
|
88
|
+
/**
|
|
89
|
+
* Sets the label of this option
|
|
90
|
+
* @param label The label
|
|
91
|
+
*/
|
|
92
|
+
setLabel(label: string): this;
|
|
93
|
+
/**
|
|
94
|
+
* Sets the value of this option
|
|
95
|
+
* @param value The value
|
|
96
|
+
*/
|
|
97
|
+
setValue(value: string): this;
|
|
98
|
+
/**
|
|
99
|
+
* Sets the description of this option
|
|
100
|
+
* @param description The description
|
|
101
|
+
*/
|
|
102
|
+
setDescription(description: string): this;
|
|
103
|
+
/**
|
|
104
|
+
* Sets the emoji of this option
|
|
105
|
+
* @param emoji The emoji
|
|
106
|
+
*/
|
|
107
|
+
setEmoji(emoji: {
|
|
108
|
+
id?: string;
|
|
109
|
+
name?: string;
|
|
110
|
+
animated?: boolean;
|
|
111
|
+
} | string): this;
|
|
112
|
+
/**
|
|
113
|
+
* Sets whether this option is the default
|
|
114
|
+
* @param isDefault Whether this option is the default
|
|
115
|
+
*/
|
|
116
|
+
setDefault(isDefault?: boolean): this;
|
|
117
|
+
/**
|
|
118
|
+
* Returns the JSON representation of this option
|
|
119
|
+
*/
|
|
120
|
+
toJSON(): APISelectMenuOption;
|
|
121
|
+
}
|
|
122
|
+
export { StringSelectMenuBuilder as SelectMenuBuilder };
|
|
123
|
+
export default StringSelectMenuBuilder;
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* SelectMenuBuilder for creating select menus
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.SelectMenuBuilder = exports.StringSelectMenuOptionBuilder = exports.StringSelectMenuBuilder = void 0;
|
|
7
|
+
/**
|
|
8
|
+
* A builder for creating string select menus
|
|
9
|
+
*/
|
|
10
|
+
class StringSelectMenuBuilder {
|
|
11
|
+
data;
|
|
12
|
+
constructor(data = {}) {
|
|
13
|
+
this.data = { type: 3, ...data };
|
|
14
|
+
if (!this.data.options)
|
|
15
|
+
this.data.options = [];
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Sets the custom ID of this select menu
|
|
19
|
+
* @param customId The custom ID
|
|
20
|
+
*/
|
|
21
|
+
setCustomId(customId) {
|
|
22
|
+
this.data.custom_id = customId;
|
|
23
|
+
return this;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Sets the placeholder of this select menu
|
|
27
|
+
* @param placeholder The placeholder
|
|
28
|
+
*/
|
|
29
|
+
setPlaceholder(placeholder) {
|
|
30
|
+
this.data.placeholder = placeholder;
|
|
31
|
+
return this;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Sets the minimum values of this select menu
|
|
35
|
+
* @param minValues The minimum values
|
|
36
|
+
*/
|
|
37
|
+
setMinValues(minValues) {
|
|
38
|
+
this.data.min_values = minValues;
|
|
39
|
+
return this;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Sets the maximum values of this select menu
|
|
43
|
+
* @param maxValues The maximum values
|
|
44
|
+
*/
|
|
45
|
+
setMaxValues(maxValues) {
|
|
46
|
+
this.data.max_values = maxValues;
|
|
47
|
+
return this;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Sets whether this select menu is disabled
|
|
51
|
+
* @param disabled Whether the select menu is disabled
|
|
52
|
+
*/
|
|
53
|
+
setDisabled(disabled = true) {
|
|
54
|
+
this.data.disabled = disabled;
|
|
55
|
+
return this;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Adds options to this select menu
|
|
59
|
+
* @param options The options to add
|
|
60
|
+
*/
|
|
61
|
+
addOptions(...options) {
|
|
62
|
+
if (!this.data.options)
|
|
63
|
+
this.data.options = [];
|
|
64
|
+
this.data.options.push(...options);
|
|
65
|
+
return this;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Sets the options of this select menu
|
|
69
|
+
* @param options The options to set
|
|
70
|
+
*/
|
|
71
|
+
setOptions(...options) {
|
|
72
|
+
this.data.options = options;
|
|
73
|
+
return this;
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Removes, replaces, or inserts options
|
|
77
|
+
* @param index The index to start at
|
|
78
|
+
* @param deleteCount The number of options to remove
|
|
79
|
+
* @param options The options to insert
|
|
80
|
+
*/
|
|
81
|
+
spliceOptions(index, deleteCount, ...options) {
|
|
82
|
+
if (!this.data.options)
|
|
83
|
+
this.data.options = [];
|
|
84
|
+
this.data.options.splice(index, deleteCount, ...options);
|
|
85
|
+
return this;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Returns the JSON representation of this select menu
|
|
89
|
+
*/
|
|
90
|
+
toJSON() {
|
|
91
|
+
return { ...this.data };
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Creates a new select menu builder from existing data
|
|
95
|
+
* @param other The select menu data to copy
|
|
96
|
+
*/
|
|
97
|
+
static from(other) {
|
|
98
|
+
return new StringSelectMenuBuilder(other instanceof StringSelectMenuBuilder ? other.data : other);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
exports.StringSelectMenuBuilder = StringSelectMenuBuilder;
|
|
102
|
+
exports.SelectMenuBuilder = StringSelectMenuBuilder;
|
|
103
|
+
/**
|
|
104
|
+
* A builder for creating select menu options
|
|
105
|
+
*/
|
|
106
|
+
class StringSelectMenuOptionBuilder {
|
|
107
|
+
data;
|
|
108
|
+
constructor(data = {}) {
|
|
109
|
+
this.data = { ...data };
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Sets the label of this option
|
|
113
|
+
* @param label The label
|
|
114
|
+
*/
|
|
115
|
+
setLabel(label) {
|
|
116
|
+
this.data.label = label;
|
|
117
|
+
return this;
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Sets the value of this option
|
|
121
|
+
* @param value The value
|
|
122
|
+
*/
|
|
123
|
+
setValue(value) {
|
|
124
|
+
this.data.value = value;
|
|
125
|
+
return this;
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Sets the description of this option
|
|
129
|
+
* @param description The description
|
|
130
|
+
*/
|
|
131
|
+
setDescription(description) {
|
|
132
|
+
this.data.description = description;
|
|
133
|
+
return this;
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Sets the emoji of this option
|
|
137
|
+
* @param emoji The emoji
|
|
138
|
+
*/
|
|
139
|
+
setEmoji(emoji) {
|
|
140
|
+
if (typeof emoji === 'string') {
|
|
141
|
+
this.data.emoji = { name: emoji };
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
this.data.emoji = emoji;
|
|
145
|
+
}
|
|
146
|
+
return this;
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Sets whether this option is the default
|
|
150
|
+
* @param isDefault Whether this option is the default
|
|
151
|
+
*/
|
|
152
|
+
setDefault(isDefault = true) {
|
|
153
|
+
this.data.default = isDefault;
|
|
154
|
+
return this;
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Returns the JSON representation of this option
|
|
158
|
+
*/
|
|
159
|
+
toJSON() {
|
|
160
|
+
return { ...this.data };
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
exports.StringSelectMenuOptionBuilder = StringSelectMenuOptionBuilder;
|
|
164
|
+
exports.default = StringSelectMenuBuilder;
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SelectMenuBuilder.js","sourceRoot":"","sources":["../../src/builders/SelectMenuBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * SelectMenuBuilder for creating select menus\r\n */\r\n\r\nexport interface APISelectMenuOption {\r\n  label: string;\r\n  value: string;\r\n  description?: string;\r\n  emoji?: { id?: string; name?: string; animated?: boolean };\r\n  default?: boolean;\r\n}\r\n\r\nexport interface APISelectMenuComponent {\r\n  type: 3;\r\n  custom_id: string;\r\n  options?: APISelectMenuOption[];\r\n  placeholder?: string;\r\n  min_values?: number;\r\n  max_values?: number;\r\n  disabled?: boolean;\r\n}\r\n\r\n/**\r\n * A builder for creating string select menus\r\n */\r\nexport class StringSelectMenuBuilder {\r\n  public readonly data: Partial<APISelectMenuComponent>;\r\n\r\n  constructor(data: Partial<APISelectMenuComponent> = {}) {\r\n    this.data = { type: 3, ...data };\r\n    if (!this.data.options) this.data.options = [];\r\n  }\r\n\r\n  /**\r\n   * Sets the custom ID of this select menu\r\n   * @param customId The custom ID\r\n   */\r\n  setCustomId(customId: string): this {\r\n    this.data.custom_id = customId;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the placeholder of this select menu\r\n   * @param placeholder The placeholder\r\n   */\r\n  setPlaceholder(placeholder: string): this {\r\n    this.data.placeholder = placeholder;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the minimum values of this select menu\r\n   * @param minValues The minimum values\r\n   */\r\n  setMinValues(minValues: number): this {\r\n    this.data.min_values = minValues;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the maximum values of this select menu\r\n   * @param maxValues The maximum values\r\n   */\r\n  setMaxValues(maxValues: number): this {\r\n    this.data.max_values = maxValues;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets whether this select menu is disabled\r\n   * @param disabled Whether the select menu is disabled\r\n   */\r\n  setDisabled(disabled = true): this {\r\n    this.data.disabled = disabled;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Adds options to this select menu\r\n   * @param options The options to add\r\n   */\r\n  addOptions(...options: APISelectMenuOption[]): this {\r\n    if (!this.data.options) this.data.options = [];\r\n    this.data.options.push(...options);\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the options of this select menu\r\n   * @param options The options to set\r\n   */\r\n  setOptions(...options: APISelectMenuOption[]): this {\r\n    this.data.options = options;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Removes, replaces, or inserts options\r\n   * @param index The index to start at\r\n   * @param deleteCount The number of options to remove\r\n   * @param options The options to insert\r\n   */\r\n  spliceOptions(index: number, deleteCount: number, ...options: APISelectMenuOption[]): this {\r\n    if (!this.data.options) this.data.options = [];\r\n    this.data.options.splice(index, deleteCount, ...options);\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Returns the JSON representation of this select menu\r\n   */\r\n  toJSON(): APISelectMenuComponent {\r\n    return { ...this.data } as APISelectMenuComponent;\r\n  }\r\n\r\n  /**\r\n   * Creates a new select menu builder from existing data\r\n   * @param other The select menu data to copy\r\n   */\r\n  static from(other: Partial<APISelectMenuComponent> | StringSelectMenuBuilder): StringSelectMenuBuilder {\r\n    return new StringSelectMenuBuilder(other instanceof StringSelectMenuBuilder ? other.data : other);\r\n  }\r\n}\r\n\r\n/**\r\n * A builder for creating select menu options\r\n */\r\nexport class StringSelectMenuOptionBuilder {\r\n  public readonly data: Partial<APISelectMenuOption>;\r\n\r\n  constructor(data: Partial<APISelectMenuOption> = {}) {\r\n    this.data = { ...data };\r\n  }\r\n\r\n  /**\r\n   * Sets the label of this option\r\n   * @param label The label\r\n   */\r\n  setLabel(label: string): this {\r\n    this.data.label = label;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the value of this option\r\n   * @param value The value\r\n   */\r\n  setValue(value: string): this {\r\n    this.data.value = value;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the description of this option\r\n   * @param description The description\r\n   */\r\n  setDescription(description: string): this {\r\n    this.data.description = description;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the emoji of this option\r\n   * @param emoji The emoji\r\n   */\r\n  setEmoji(emoji: { id?: string; name?: string; animated?: boolean } | string): this {\r\n    if (typeof emoji === 'string') {\r\n      this.data.emoji = { name: emoji };\r\n    } else {\r\n      this.data.emoji = emoji;\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets whether this option is the default\r\n   * @param isDefault Whether this option is the default\r\n   */\r\n  setDefault(isDefault = true): this {\r\n    this.data.default = isDefault;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Returns the JSON representation of this option\r\n   */\r\n  toJSON(): APISelectMenuOption {\r\n    return { ...this.data } as APISelectMenuOption;\r\n  }\r\n}\r\n\r\n// Alias for DJS compatibility\r\nexport { StringSelectMenuBuilder as SelectMenuBuilder };\r\n\r\nexport default StringSelectMenuBuilder;\r\n"]}
|