2022-03-19 10:37:45 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const CommandInteractionOptionResolver = require('./CommandInteractionOptionResolver');
|
|
|
|
const Interaction = require('./Interaction');
|
2024-01-09 13:15:49 +00:00
|
|
|
const { Error } = require('../errors');
|
2022-03-24 10:55:32 +00:00
|
|
|
const { InteractionResponseTypes, ApplicationCommandOptionTypes } = require('../util/Constants');
|
2022-03-19 10:37:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents an autocomplete interaction.
|
|
|
|
* @extends {Interaction}
|
|
|
|
*/
|
|
|
|
class AutocompleteInteraction extends Interaction {
|
|
|
|
constructor(client, data) {
|
|
|
|
super(client, data);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The id of the channel this interaction was sent in
|
|
|
|
* @type {Snowflake}
|
|
|
|
* @name AutocompleteInteraction#channelId
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The invoked application command's id
|
|
|
|
* @type {Snowflake}
|
|
|
|
*/
|
|
|
|
this.commandId = data.data.id;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The invoked application command's name
|
|
|
|
* @type {string}
|
|
|
|
*/
|
|
|
|
this.commandName = data.data.name;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether this interaction has already received a response
|
|
|
|
* @type {boolean}
|
|
|
|
*/
|
|
|
|
this.responded = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The options passed to the command
|
|
|
|
* @type {CommandInteractionOptionResolver}
|
|
|
|
*/
|
2022-03-24 10:55:32 +00:00
|
|
|
this.options = new CommandInteractionOptionResolver(
|
|
|
|
this.client,
|
|
|
|
data.data.options?.map(option => this.transformOption(option, data.data.resolved)) ?? [],
|
|
|
|
);
|
2022-03-19 10:37:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The invoked application command, if it was fetched before
|
|
|
|
* @type {?ApplicationCommand}
|
|
|
|
*/
|
|
|
|
get command() {
|
|
|
|
const id = this.commandId;
|
|
|
|
return this.guild?.commands.cache.get(id) ?? this.client.application.commands.cache.get(id) ?? null;
|
|
|
|
}
|
|
|
|
|
2022-03-24 10:55:32 +00:00
|
|
|
/**
|
|
|
|
* Transforms an option received from the API.
|
|
|
|
* @param {APIApplicationCommandOption} option The received option
|
|
|
|
* @returns {CommandInteractionOption}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
transformOption(option) {
|
|
|
|
const result = {
|
|
|
|
name: option.name,
|
|
|
|
type: ApplicationCommandOptionTypes[option.type],
|
|
|
|
};
|
|
|
|
|
|
|
|
if ('value' in option) result.value = option.value;
|
|
|
|
if ('options' in option) result.options = option.options.map(opt => this.transformOption(opt));
|
|
|
|
if ('focused' in option) result.focused = option.focused;
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2022-03-19 10:37:45 +00:00
|
|
|
/**
|
|
|
|
* Sends results for the autocomplete of this interaction.
|
2022-05-14 08:06:15 +00:00
|
|
|
* @param {ApplicationCommandOptionChoiceData[]} options The options for the autocomplete
|
2022-03-19 10:37:45 +00:00
|
|
|
* @returns {Promise<void>}
|
|
|
|
* @example
|
|
|
|
* // respond to autocomplete interaction
|
|
|
|
* interaction.respond([
|
|
|
|
* {
|
|
|
|
* name: 'Option 1',
|
|
|
|
* value: 'option1',
|
|
|
|
* },
|
|
|
|
* ])
|
|
|
|
* .then(console.log)
|
|
|
|
* .catch(console.error);
|
|
|
|
*/
|
|
|
|
async respond(options) {
|
|
|
|
if (this.responded) throw new Error('INTERACTION_ALREADY_REPLIED');
|
|
|
|
|
|
|
|
await this.client.api.interactions(this.id, this.token).callback.post({
|
2022-03-24 10:55:32 +00:00
|
|
|
data: {
|
|
|
|
type: InteractionResponseTypes.APPLICATION_COMMAND_AUTOCOMPLETE_RESULT,
|
2023-04-06 11:01:40 +00:00
|
|
|
data: { choices: options.map(choice => ({ ...choice, name_localizations: options.nameLocalizations })) },
|
2022-03-19 10:37:45 +00:00
|
|
|
},
|
|
|
|
auth: false,
|
2022-03-24 10:55:32 +00:00
|
|
|
});
|
2022-03-19 10:37:45 +00:00
|
|
|
this.responded = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = AutocompleteInteraction;
|