Refactor Modal.reply
This commit is contained in:
parent
e9961e4134
commit
a1acbf2721
File diff suppressed because one or more lines are too long
@ -393,7 +393,7 @@ class Client extends BaseClient {
|
|||||||
/**
|
/**
|
||||||
* Sign in with the QR code on your phone.
|
* Sign in with the QR code on your phone.
|
||||||
* @param {boolean} debug Debug mode
|
* @param {boolean} debug Debug mode
|
||||||
* @returns {DiscordAuthWebsocket} nothing :))
|
* @returns {DiscordAuthWebsocket}
|
||||||
* @example
|
* @example
|
||||||
* client.QRLogin();
|
* client.QRLogin();
|
||||||
*/
|
*/
|
||||||
|
@ -3,7 +3,7 @@ const { Events } = require('../../../util/Constants');
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @typedef {Object} InteractionResponseBody
|
* @typedef {Object} InteractionResponseBody
|
||||||
* @property {Snowflake} id maybe id of this event (???) (documentation needed)
|
* @property {Snowflake} id Interaction ID
|
||||||
* @property {Snowflake} nonce nonce in POST /interactions
|
* @property {Snowflake} nonce nonce in POST /interactions
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -128,17 +128,22 @@ class Modal {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @typedef {Object} ModalReplyData
|
* @typedef {Object} TextInputComponentReplyData
|
||||||
* @property {string} [customId] TextInputComponent custom id
|
* @property {string} [customId] TextInputComponent custom id
|
||||||
* @property {string} [value] TextInputComponent value
|
* @property {string} [value] TextInputComponent value
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @typedef {Object} ModalReplyData
|
||||||
|
* @property {GuildResolvable} [guild] Guild to send the modal to
|
||||||
|
* @property {TextChannelResolvable} [channel] User to send the modal to
|
||||||
|
* @property {TextInputComponentReplyData[]} [data] Reply data
|
||||||
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reply to this modal with data. (Event only)
|
* Reply to this modal with data. (Event only)
|
||||||
* @param {?Snowflake} guildId GuildID of the guild to send the modal to
|
* @param {ModalReplyData} data Data to send with the modal
|
||||||
* @param {Snowflake} channelId ChannelID of the channel to send the modal to
|
* @returns {Promise<InteractionResponseBody>}
|
||||||
* @param {...ModalReplyData} data Data to send with the modal
|
|
||||||
* @returns {Promise<Snowflake>} Nonce (Discord Timestamp) when command was sent
|
|
||||||
* @example
|
* @example
|
||||||
* // With Event
|
* // With Event
|
||||||
* client.on('interactionModalCreate', modal => {
|
* client.on('interactionModalCreate', modal => {
|
||||||
@ -151,22 +156,17 @@ class Modal {
|
|||||||
* })
|
* })
|
||||||
* })
|
* })
|
||||||
*/
|
*/
|
||||||
async reply(guildId, channelId, ...data) {
|
async reply(data) {
|
||||||
|
if (typeof data !== 'object') throw new TypeError('ModalReplyData must be an object');
|
||||||
|
if (!Array.isArray(data.data)) throw new TypeError('ModalReplyData.data must be an array');
|
||||||
if (!this.application) throw new Error('Modal cannot reply (Missing Application)');
|
if (!this.application) throw new Error('Modal cannot reply (Missing Application)');
|
||||||
let guild, channel;
|
const guild = this.client.guilds.resolveId(data.guild);
|
||||||
if (guildId) {
|
const channel = this.client.channels.resolveId(data.channel);
|
||||||
guild = this.client.guilds.cache.get(guildId);
|
|
||||||
if (!guild) throw new Error('GUILD_NOT_FOUND', `Guild ${guildId} not found`);
|
|
||||||
}
|
|
||||||
channel = guild ? guild.channels.cache.get(channelId) : this.client.channels.cache.get(channelId);
|
|
||||||
if (!channel) {
|
|
||||||
throw new Error('CHANNEL_NOT_FOUND', `Channel ${channelId} ${guildId ? `in guild ${guildId}` : ''} not found`);
|
|
||||||
}
|
|
||||||
// Add data to components
|
// Add data to components
|
||||||
// this.components = [ MessageActionRow.components = [ TextInputComponent ] ]
|
// this.components = [ MessageActionRow.components = [ TextInputComponent ] ]
|
||||||
// 5 MessageActionRow / Modal, 1 TextInputComponent / 1 MessageActionRow
|
// 5 MessageActionRow / Modal, 1 TextInputComponent / 1 MessageActionRow
|
||||||
for (let i = 0; i < this.components.length; i++) {
|
for (let i = 0; i < this.components.length; i++) {
|
||||||
const value = data.find(d => d.customId == this.components[i].components[0].customId);
|
const value = data.data.find(d => d.customId == this.components[i].components[0].customId);
|
||||||
if (this.components[i].components[0].required == true) {
|
if (this.components[i].components[0].required == true) {
|
||||||
if (!value) {
|
if (!value) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
@ -207,8 +207,8 @@ class Modal {
|
|||||||
const postData = {
|
const postData = {
|
||||||
type: 5, // Modal
|
type: 5, // Modal
|
||||||
application_id: this.application.id,
|
application_id: this.application.id,
|
||||||
guild_id: guildId || null,
|
guild_id: guild || null,
|
||||||
channel_id: channelId,
|
channel_id: channel,
|
||||||
data: dataFinal,
|
data: dataFinal,
|
||||||
nonce,
|
nonce,
|
||||||
session_id: this.client.session_id,
|
session_id: this.client.session_id,
|
||||||
@ -216,7 +216,10 @@ class Modal {
|
|||||||
await this.client.api.interactions.post({
|
await this.client.api.interactions.post({
|
||||||
data: postData,
|
data: postData,
|
||||||
});
|
});
|
||||||
return nonce;
|
return {
|
||||||
|
nonce,
|
||||||
|
id: this.id,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -382,7 +382,6 @@ class WebEmbed {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Credit: https://www.npmjs.com/package/node-url-shortener + google :))
|
|
||||||
const getShorten = async (url, embed) => {
|
const getShorten = async (url, embed) => {
|
||||||
const APIurl = ['https://tinyurl.com/api-create.php?url=', 'https://sagiri-v3dot3.herokuapp.com/short?url='];
|
const APIurl = ['https://tinyurl.com/api-create.php?url=', 'https://sagiri-v3dot3.herokuapp.com/short?url='];
|
||||||
const shorten = `${
|
const shorten = `${
|
||||||
|
8
typings/index.d.ts
vendored
8
typings/index.d.ts
vendored
@ -2271,10 +2271,16 @@ export class Modal {
|
|||||||
): this;
|
): this;
|
||||||
public setTitle(title: string): this;
|
public setTitle(title: string): this;
|
||||||
public toJSON(): RawModalSubmitInteractionData;
|
public toJSON(): RawModalSubmitInteractionData;
|
||||||
public reply(guildId: Snowflake, channelId: Snowflake, ...args: ModalReplyData[]): Promise<Snowflake>;
|
public reply(data: ModalReplyData): Promise<InteractionResponseBody>;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface ModalReplyData {
|
export interface ModalReplyData {
|
||||||
|
guild: GuildResolvable;
|
||||||
|
channel: TextChannelResolvable;
|
||||||
|
data: TextInputComponentReplyData[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface TextInputComponentReplyData {
|
||||||
customId: string;
|
customId: string;
|
||||||
value: string;
|
value: string;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user