* health check * Update Dockerfile * simplifying the deployment * Update Bot.js makes the find team command public * test (#9) * Dev (#7) * health check * Update Dockerfile * simplifying the deployment * Dev (#8) * health check * Update Dockerfile * simplifying the deployment * Update Bot.js makes the find team command public * Update PlayerService.js * massive update???? could break stuff * Update Bot.js update
109 lines
3.0 KiB
JavaScript
109 lines
3.0 KiB
JavaScript
'use strict';
|
|
|
|
const { lazy } = require('@discordjs/util');
|
|
const BaseInteraction = require('./BaseInteraction');
|
|
const InteractionWebhook = require('./InteractionWebhook');
|
|
const InteractionResponses = require('./interfaces/InteractionResponses');
|
|
const { findComponentByCustomId } = require('../util/Components');
|
|
|
|
const getMessage = lazy(() => require('./Message').Message);
|
|
|
|
/**
|
|
* Represents a message component interaction.
|
|
* @extends {BaseInteraction}
|
|
* @implements {InteractionResponses}
|
|
*/
|
|
class MessageComponentInteraction extends BaseInteraction {
|
|
constructor(client, data) {
|
|
super(client, data);
|
|
|
|
/**
|
|
* The id of the channel this interaction was sent in
|
|
* @type {Snowflake}
|
|
* @name MessageComponentInteraction#channelId
|
|
*/
|
|
|
|
/**
|
|
* The message to which the component was attached
|
|
* @type {Message}
|
|
*/
|
|
this.message = this.channel?.messages._add(data.message) ?? new (getMessage())(client, data.message);
|
|
|
|
/**
|
|
* The custom id of the component which was interacted with
|
|
* @type {string}
|
|
*/
|
|
this.customId = data.data.custom_id;
|
|
|
|
/**
|
|
* The type of component which was interacted with
|
|
* @type {ComponentType}
|
|
*/
|
|
this.componentType = data.data.component_type;
|
|
|
|
/**
|
|
* Whether the reply to this interaction has been deferred
|
|
* @type {boolean}
|
|
*/
|
|
this.deferred = false;
|
|
|
|
/**
|
|
* Whether the reply to this interaction is ephemeral
|
|
* @type {?boolean}
|
|
*/
|
|
this.ephemeral = null;
|
|
|
|
/**
|
|
* Whether this interaction has already been replied to
|
|
* @type {boolean}
|
|
*/
|
|
this.replied = false;
|
|
|
|
/**
|
|
* An associated interaction webhook, can be used to further interact with this interaction
|
|
* @type {InteractionWebhook}
|
|
*/
|
|
this.webhook = new InteractionWebhook(this.client, this.applicationId, this.token);
|
|
}
|
|
|
|
/**
|
|
* Components that can be placed in an action row for messages.
|
|
* * ButtonComponent
|
|
* * StringSelectMenuComponent
|
|
* * UserSelectMenuComponent
|
|
* * RoleSelectMenuComponent
|
|
* * MentionableSelectMenuComponent
|
|
* * ChannelSelectMenuComponent
|
|
* @typedef {ButtonComponent|StringSelectMenuComponent|UserSelectMenuComponent|
|
|
* RoleSelectMenuComponent|MentionableSelectMenuComponent|ChannelSelectMenuComponent} MessageActionRowComponent
|
|
*/
|
|
|
|
/**
|
|
* The component which was interacted with
|
|
* @type {MessageActionRowComponent|APIComponentInMessageActionRow}
|
|
* @readonly
|
|
*/
|
|
get component() {
|
|
return findComponentByCustomId(this.message.components, this.customId);
|
|
}
|
|
|
|
// These are here only for documentation purposes - they are implemented by InteractionResponses
|
|
/* eslint-disable no-empty-function */
|
|
deferReply() {}
|
|
reply() {}
|
|
fetchReply() {}
|
|
editReply() {}
|
|
deleteReply() {}
|
|
followUp() {}
|
|
deferUpdate() {}
|
|
update() {}
|
|
launchActivity() {}
|
|
showModal() {}
|
|
sendPremiumRequired() {}
|
|
awaitModalSubmit() {}
|
|
}
|
|
|
|
InteractionResponses.applyToClass(MessageComponentInteraction);
|
|
|
|
module.exports = MessageComponentInteraction;
|