mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-03 23:36:43 +02:00
Slash Commands Test
This commit is contained in:
@@ -4,6 +4,7 @@ const fs = require('fs');
|
||||
const path = require('path');
|
||||
const { stripIndents } = require('common-tags');
|
||||
const Registry = require('./Registry');
|
||||
const SlashRegistry = require('./slash/SlashRegistry');
|
||||
const Dispatcher = require('./Dispatcher');
|
||||
require('./Extensions');
|
||||
|
||||
@@ -16,6 +17,7 @@ module.exports = class CommandClient extends Client {
|
||||
this.owner = typeof options.owner === 'string' ? [options.owner] : options.owner;
|
||||
this.invite = options.invite || null;
|
||||
this.registry = new Registry(this);
|
||||
this.slashRegistry = new SlashRegistry(this);
|
||||
this.dispatcher = new Dispatcher(this);
|
||||
this.games = new Collection();
|
||||
this.blacklist = { user: [], guild: [] };
|
||||
@@ -23,6 +25,7 @@ module.exports = class CommandClient extends Client {
|
||||
|
||||
this.once('ready', this.onceReady);
|
||||
this.on('messageCreate', this.onMessage);
|
||||
this.on('interactionCreate', this.onInteractionCreate);
|
||||
}
|
||||
|
||||
isOwner(user) {
|
||||
@@ -149,6 +152,25 @@ module.exports = class CommandClient extends Client {
|
||||
}
|
||||
}
|
||||
|
||||
async onInteractionCreate(interaction) {
|
||||
if (!interaction.isChatInputCommand()) return;
|
||||
|
||||
const command = this.slashRegistry.commands.get(interaction.commandName);
|
||||
if (!command) return;
|
||||
|
||||
try {
|
||||
const result = await command.run(interaction);
|
||||
this.emit('commandRun', command, result, interaction);
|
||||
} catch (err) {
|
||||
this.emit('commandError', interaction, err);
|
||||
if (interaction.replied || interaction.deferred) {
|
||||
await interaction.followUp({ content: 'There was an error while executing this command!', ephemeral: true });
|
||||
} else {
|
||||
await interaction.reply({ content: 'There was an error while executing this command!', ephemeral: true });
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
importBlacklist() {
|
||||
const read = fs.readFileSync(path.join(__dirname, '..', 'blacklist.json'), { encoding: 'utf8' });
|
||||
const file = JSON.parse(read);
|
||||
|
||||
@@ -0,0 +1,14 @@
|
||||
module.exports = class SlashCommand {
|
||||
constructor(client, options) {
|
||||
Object.defineProperty(this, 'client', { value: client });
|
||||
|
||||
this.name = options.name.toLowerCase();
|
||||
this.description = options.description;
|
||||
this.credit = options.credit || [];
|
||||
this.credit.push({
|
||||
name: 'Dragon Fire',
|
||||
url: 'https://github.com/dragonfire535',
|
||||
reason: 'Code'
|
||||
});
|
||||
}
|
||||
};
|
||||
@@ -0,0 +1,45 @@
|
||||
const { SlashCommandBuilder, Routes } = require('discord.js');
|
||||
const { Collection } = require('@discordjs/collection');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
const { TEST_GUILD_ID } = process.env;
|
||||
|
||||
module.exports = class SlashRegistry {
|
||||
constructor(client) {
|
||||
Object.defineProperty(this, 'client', { value: client });
|
||||
|
||||
this.commands = new Collection();
|
||||
}
|
||||
|
||||
registerCommand(command) {
|
||||
const slashCmd = new SlashCommandBuilder()
|
||||
.setName(command.name)
|
||||
.setDescription(command.description);
|
||||
this.commands.set(command.name, { command, data: slashCmd });
|
||||
return this;
|
||||
}
|
||||
|
||||
registerCommandsIn(dir) {
|
||||
const commands = fs.readdirSync(dir);
|
||||
for (const command of commands) {
|
||||
if (!command.endsWith('.js')) continue;
|
||||
const Required = require(path.join(dir, command));
|
||||
this.registerCommand(new Required(this.client));
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
uploadTestCommands() {
|
||||
return this.client.rest.put(
|
||||
Routes.applicationGuildCommands(this.client.id, TEST_GUILD_ID),
|
||||
{ body: this.commands.map(cmd => cmd.data.toJSON()) }
|
||||
);
|
||||
}
|
||||
|
||||
uploadGlobalCommands() {
|
||||
return this.client.rest.put(
|
||||
Routes.applicationCommands(this.client.id),
|
||||
{ body: commands }
|
||||
);
|
||||
}
|
||||
};
|
||||
Reference in New Issue
Block a user