Files
discordeno/site/tutorial/nodejs/CommandHandler/command-manager.md
Jonathan Ho 987b4058cb Site: update site structure and add architecture page (#2675)
* remove blog

* fix: license

* chore: bump docusaurus

* separate benchmark page

* move to sub folder

* fix blog path

* Chore: update site

* fix: only deploy on push and dispatch

* fix: on:

* ci: merge workflow

* ci: fix if

* refactor: dump preset
2022-12-04 08:36:10 -06:00

2.4 KiB

sidebar_position
sidebar_position
2

Command Manager

Currently, you probably have something like this in your code:

const Discord = require("discordeno.js");
// Ideally you should move to an `.env` file
const config = require("./config.json");

const bot = Discord.createBot({
  events: {
    messageCreate(client, message) {
      if (message.content === "!ping") {
        client.helpers.sendMessage(message.channelId, { content: "pong" });
      }
    },
  },
  intents: Discord.Intents.Guilds | Discord.Intents.GuildMessages,
  token: config.token,
});
const client = Discord.enableCachePlugin(bot, {});

Discord.startBot(client);

Of course, if you add more and more commands and as your code base grows, you can lose track very quickly.

To avoid this, it is recommended to store the commands in separate folders divided into different categories.

Previously, we introduced you to our plugin structure, which has a lot of advantages.

├Plugins/
├── General/
│   ├── commands/
│   │   ├── ping.js
│   │   └── ...
├── Developer/
│   ├── commands/
│   │   ├── eval.js
│   │   └── ...
└── ...

Get this file from the nodejs template

const CommandManager = require("./template/Managers/CommandManager.js");
const manager = new CommandManager({});
manager.load({ plugin: true }); // Load the commands
client.commands = manager;

client.commands.cache.get("ping"); // Get the `ping` command

The Manager will automatically iterate through all files in the folder and then load them into the cache property, which is mapped on the command name.

Take a look at Create Command to learn how to create a command.

Handle Command

The manager also contains a handler for executing the command when a message is received.

:::important

Currently checks for permissions, cooldowns, and rate limits are not covered, but these will be added soon.

:::

Message Create Event:

module.exports = async (client, message) => {
  client.commands.isCommand(message);
};

Interaction Create Event:

module.exports = async (client, interaction) => {
  client.commands.isInteraction(interaction);
};

You can also customize the isCommand function to your use case.