UNPKG

oceanic.js

Version:

A NodeJS library for interfacing with Discord.

296 lines 30.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const tslib_1 = require("tslib"); /** @module ModalSubmitInteraction */ const Interaction_1 = tslib_1.__importDefault(require("./Interaction")); const Member_1 = tslib_1.__importDefault(require("./Member")); const User_1 = tslib_1.__importDefault(require("./User")); const Permission_1 = tslib_1.__importDefault(require("./Permission")); const Message_1 = tslib_1.__importDefault(require("./Message")); const GuildChannel_1 = tslib_1.__importDefault(require("./GuildChannel")); const InteractionResolvedChannel_1 = tslib_1.__importDefault(require("./InteractionResolvedChannel")); const Role_1 = tslib_1.__importDefault(require("./Role")); const Attachment_1 = tslib_1.__importDefault(require("./Attachment")); const Constants_1 = require("../Constants"); const TypedCollection_1 = tslib_1.__importDefault(require("../util/TypedCollection")); const Errors_1 = require("../util/Errors"); const MessageInteractionResponse_1 = tslib_1.__importDefault(require("../util/interactions/MessageInteractionResponse")); const ModalSubmitInteractionComponentsWrapper_1 = tslib_1.__importDefault(require("../util/interactions/ModalSubmitInteractionComponentsWrapper")); /** Represents a modal submit interaction. */ class ModalSubmitInteraction extends Interaction_1.default { _cachedChannel; _cachedGuild; /** The permissions the bot has in the channel this interaction was sent from. If in a dm/group dm, this will contain `ATTACH_FILES`, `EMBED_LINKS`, and `MENTION_EVERYONE`. In addition, `USE_EXTERNAL_EMOJIS` will be included for DMs with the app's bot user. */ appPermissions; /** The maximum size limit per attachment. This will be 10MiB by default, unless the user that created this interaction has a Nitro subscription or the guild it was sent from has been boosted to level 2 or above. */ attachmentSizeLimit; /** Details about the authorizing user or server for the installation(s) relevant to the interaction. See [Discord's docs](https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-object-authorizing-integration-owners-object) for more information. */ authorizingIntegrationOwners; /** The ID of the channel this interaction was sent from. */ channelID; /** The context this interaction was sent from. */ context; /** The data associated with the interaction. */ data; /** The entitlements for the user that created this interaction, and the guild it was created in. */ entitlements; /** The id of the guild this interaction was sent from, if applicable. */ guildID; /** The preferred [locale](https://discord.com/developers/docs/reference#locales) of the guild this interaction was sent from, if applicable. */ guildLocale; /** The partial guild this interaction was sent from, if applicable. */ guildPartial; /** The [locale](https://discord.com/developers/docs/reference#locales) of the invoking user. */ locale; /** The member associated with the invoking user, if this interaction is sent from a guild. */ member; /** The permissions of the member associated with the invoking user, if this interaction is sent from a guild. */ memberPermissions; /** The message this interaction is from, if the modal was triggered from a component interaction. */ message; /** The user that invoked this interaction. */ user; constructor(data, client) { super(data, client); if (data.message !== undefined && data.guild_id !== undefined) { data.message.guild_id = data.guild_id; } this.appPermissions = new Permission_1.default(data.app_permissions ?? "0"); this.attachmentSizeLimit = data.attachment_size_limit; this.authorizingIntegrationOwners = data.authorizing_integration_owners; this.channelID = data.channel_id; this.context = data.context; this.entitlements = data.entitlements?.map(entitlement => client.util.updateEntitlement(entitlement)) ?? []; this.guildID = (data.guild_id ?? null); this.guildLocale = data.guild_locale; this.guildPartial = data.guild; this.locale = data.locale; this.member = (data.member === undefined ? null : this.client.util.updateMember(data.guild_id, data.member.user.id, data.member)); this.memberPermissions = (data.member === undefined ? null : new Permission_1.default(data.member.permissions)); if (data.message !== undefined) { this.message = (this.channel && "messages" in this.channel && this.channel.messages.update(data.message)) || new Message_1.default(data.message, client); } this.user = client.users.update(data.user ?? data.member.user); const resolved = { attachments: new TypedCollection_1.default(Attachment_1.default, client), channels: new TypedCollection_1.default(InteractionResolvedChannel_1.default, client), members: new TypedCollection_1.default(Member_1.default, client), roles: new TypedCollection_1.default(Role_1.default, client), users: new TypedCollection_1.default(User_1.default, client) }; if (data.data.resolved) { if (data.data.resolved.attachments) { for (const attachment of Object.values(data.data.resolved.attachments)) resolved.attachments.add(new Attachment_1.default(attachment, client)); } if (data.data.resolved.channels) { for (const channel of Object.values(data.data.resolved.channels)) resolved.channels.update(channel); } if (data.data.resolved.members) { for (const [id, member] of Object.entries(data.data.resolved.members)) { const m = member; m.user = data.data.resolved.users[id]; resolved.members.add(client.util.updateMember(data.guild_id, id, m)); } } if (data.data.resolved.roles) { for (const role of Object.values(data.data.resolved.roles)) { try { resolved.roles.add(this.guild?.roles.update(role, this.guildID) ?? new Role_1.default(role, client, this.guildID)); } catch { resolved.roles.add(new Role_1.default(role, client, this.guildID)); } } } if (data.data.resolved.users) { for (const user of Object.values(data.data.resolved.users)) resolved.users.add(client.users.update(user)); } } this.data = { components: new ModalSubmitInteractionComponentsWrapper_1.default(resolved, client.util.modalSubmitComponentsToParsed(data.data.components)), customID: data.data.custom_id, resolved }; } /** The channel this interaction was sent from. */ get channel() { return this._cachedChannel ??= this.client.getChannel(this.channelID); } /** The guild this interaction was sent from, if applicable. This will throw an error if the guild is not cached. */ get guild() { if (this.guildID !== null && this._cachedGuild !== null) { this._cachedGuild ??= this.client.guilds.get(this.guildID); if (!this._cachedGuild) { if (this.client.options.restMode) { throw new Errors_1.UncachedError(`${this.constructor.name}#guild is not present when rest mode is enabled.`); } if (!this.client.shards.connected) { throw new Errors_1.UncachedError(`${this.constructor.name}#guild is not present without a gateway connection.`); } throw new Errors_1.UncachedError(`${this.constructor.name}#guild is not present.`); } return this._cachedGuild; } return this._cachedGuild === null ? this._cachedGuild : (this._cachedGuild = null); } /** * Create a followup message. * Note that the returned class is not a message. It is a wrapper around the interaction response. The {@link MessageInteractionResponse#getMessage | getMessage} function can be used to get the message. * @param options The options for creating the followup message. */ async createFollowup(options) { const message = await this.client.rest.interactions.createFollowupMessage(this.applicationID, this.token, options); return new MessageInteractionResponse_1.default(this, message, "followup", null); } /** * Create a message through this interaction. This is an initial response, and more than one initial response cannot be used. Use {@link ModalSubmitInteraction#createFollowup | createFollowup}. * Note that the returned class is not a message. It is a wrapper around the interaction response. The {@link MessageInteractionResponse#getMessage | getMessage} function can be used to get the message. * @param options The options for the message. */ async createMessage(options) { if (this.acknowledged) { throw new TypeError("Interactions cannot have more than one initial response."); } this.acknowledged = true; const cb = await this.client.rest.interactions.createInteractionResponse(this.id, this.token, { type: Constants_1.InteractionResponseTypes.CHANNEL_MESSAGE_WITH_SOURCE, data: options }, true); return new MessageInteractionResponse_1.default(this, null, "initial", cb); } /** * Defer this interaction. This is an initial response, and more than one initial response cannot be used. * @param flags The [flags](https://discord.com/developers/docs/resources/channel#message-object-message-flags) to respond with. */ async defer(flags) { if (this.acknowledged) { throw new TypeError("Interactions cannot have more than one initial response."); } this.acknowledged = true; return this.client.rest.interactions.createInteractionResponse(this.id, this.token, { type: Constants_1.InteractionResponseTypes.DEFERRED_CHANNEL_MESSAGE_WITH_SOURCE, data: { flags } }, true); } /** * Defer this interaction with a `DEFERRED_UPDATE_MESSAGE` response. This is an initial response, and more than one initial response cannot be used. * @param flags The [flags](https://discord.com/developers/docs/resources/channel#message-object-message-flags) to respond with. */ async deferUpdate(flags) { if (this.acknowledged) { throw new TypeError("Interactions cannot have more than one initial response."); } this.acknowledged = true; return this.client.rest.interactions.createInteractionResponse(this.id, this.token, { type: Constants_1.InteractionResponseTypes.DEFERRED_UPDATE_MESSAGE, data: { flags } }, true); } /** * Delete a follow-up message. * @param messageID The ID of the message. */ async deleteFollowup(messageID) { return this.client.rest.interactions.deleteFollowupMessage(this.applicationID, this.token, messageID); } /** * Delete the original interaction response. */ async deleteOriginal() { return this.client.rest.interactions.deleteOriginalMessage(this.applicationID, this.token); } /** * Edit a followup message. * @param messageID The ID of the message. * @param options The options for editing the followup message. */ async editFollowup(messageID, options) { return this.client.rest.interactions.editFollowupMessage(this.applicationID, this.token, messageID, options); } /** * Edit the original interaction response. * @param options The options for editing the original message. */ async editOriginal(options) { return this.client.rest.interactions.editOriginalMessage(this.applicationID, this.token, options); } /** * Edit the message this interaction is from. If this interaction has already been acknowledged, use `createFollowup`. * @param options The options for editing the message. */ async editParent(options) { if (this.acknowledged) { throw new TypeError("Interactions cannot have more than one initial response."); } this.acknowledged = true; return this.client.rest.interactions.createInteractionResponse(this.id, this.token, { type: Constants_1.InteractionResponseTypes.UPDATE_MESSAGE, data: options }, true); } /** * Get a followup message. * @param messageID The ID of the message. */ async getFollowup(messageID) { return this.client.rest.interactions.getFollowupMessage(this.applicationID, this.token, messageID); } /** * Get the original interaction response. */ async getOriginal() { return this.client.rest.interactions.getOriginalMessage(this.applicationID, this.token); } /** Whether this interaction belongs to a cached guild channel. The only difference on using this method over a simple if statement is to easily update all the interaction properties typing definitions based on the channel it belongs to. */ inCachedGuildChannel() { return this.channel instanceof GuildChannel_1.default; } /** Whether this interaction belongs to a private channel (PrivateChannel or uncached). The only difference on using this method over a simple if statement is to easily update all the interaction properties typing definitions based on the channel it belongs to. */ inPrivateChannel() { return this.guildID === null; } /** * Launch the bot's activity. This is an initial response, and more than one initial response cannot be used. */ async launchActivity() { if (this.acknowledged) { throw new TypeError("Interactions cannot have more than one initial response."); } this.acknowledged = true; return this.client.rest.interactions.createInteractionResponse(this.id, this.token, { type: Constants_1.InteractionResponseTypes.LAUNCH_ACTIVITY }, true); } /** * Show a "premium required" response to the user. This is an initial response, and more than one initial response cannot be used. * @deprecated The {@link Constants~InteractionResponseTypes.PREMIUM_REQUIRED | PREMIUM_REQUIRED} interaction response type is now deprecated in favor of using {@link Types/Channels~PremiumButton | custom premium buttons}. */ async premiumRequired() { if (this.acknowledged) { throw new TypeError("Interactions cannot have more than one initial response."); } this.acknowledged = true; return this.client.rest.interactions.createInteractionResponse(this.id, this.token, { type: Constants_1.InteractionResponseTypes.PREMIUM_REQUIRED }, true); } /** * Reply to this interaction. If the interaction hasn't been acknowledged, {@link ModalSubmitInteraction#createMessage | createMessage} is used. Else, {@link ModalSubmitInteraction#createFollowup | createFollowup} is used. * Note that the returned class is not a message. It is a wrapper around the interaction response. The {@link MessageInteractionResponse#getMessage | getMessage} function can be used to get the message. * @param options The options for the message. */ async reply(options) { let useFollowup = this.acknowledged; if (!useFollowup && options.files && options.files.length !== 0) { await this.defer(options.flags); useFollowup = true; } return useFollowup ? this.createFollowup(options) : this.createMessage(options); } toJSON() { return { ...super.toJSON(), appPermissions: this.appPermissions.toJSON(), attachmentSizeLimit: this.attachmentSizeLimit, authorizingIntegrationOwners: this.authorizingIntegrationOwners, channelID: this.channelID, context: this.context, data: this.data, guildID: this.guildID ?? undefined, guildLocale: this.guildLocale, locale: this.locale, member: this.member?.toJSON(), type: this.type, user: this.user.toJSON() }; } } exports.default = ModalSubmitInteraction; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ModalSubmitInteraction.js","sourceRoot":"","sources":["../../../lib/structures/ModalSubmitInteraction.ts"],"names":[],"mappings":"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"}