From 37322df4d72756e7189d329a1036e4e89d509e68 Mon Sep 17 00:00:00 2001 From: Jeroen Claassens Date: Thu, 13 Apr 2023 20:49:59 +0200 Subject: [PATCH] fix: mention `loadMessageCommandListeners` in the guide Closes #235 --- .../creating-a-basic-command.mdx | 37 ++++++++++++++++++- .../getting-started-with-sapphire.mdx | 33 +++++++++++++++++ 2 files changed, 68 insertions(+), 2 deletions(-) diff --git a/docs/Guide/getting-started/creating-a-basic-command.mdx b/docs/Guide/getting-started/creating-a-basic-command.mdx index 5038875b..542885f5 100644 --- a/docs/Guide/getting-started/creating-a-basic-command.mdx +++ b/docs/Guide/getting-started/creating-a-basic-command.mdx @@ -74,11 +74,36 @@ Let's go over what is defined in the constructor in this code: - `aliases`: other ways users can call the command. You can have as many as you want! - `description`: some text that you can use to display when a "help" command is used. -There are many other properties available, all of which can be seen in the [`CommandOptions`] interface, but will also -be explained in upcoming sections. +There are many other properties available, all of which can be seen in the [`CommandOptions`][commandoptions] interface, +but will also be explained in upcoming sections. ## Creating the `messageRun` method +:::danger + +If you want to use message commands in your Sapphire bot, you have to make sure you meet the following prerequisites: + +1. Enable the `Message Content Intent` under `Privileged Gateway Intents` on the [Discord Developer Portal][dev-portal] + for your application. +2. In your Sapphire client options, set the [`intents`] property to include the intents + [`GatewayIntentBits.GuildMessages`][guild_messages_intent], [`GatewayIntentBits.Guilds`][guilds_intent], and + [`GatewayIntentBits.MessageContent`][message_content_intent]. +3. In your Sapphire client options set [`loadMessageCommandListeners`][loadMessageCommandListeners] to `true`. + +All in all your code should look something like this: + +```typescript ts2esm2cjs|{4-12}|{4-12} +import { SapphireClient } from '@sapphire/framework'; +import { GatewayIntentBits } from 'discord.js'; + +const client = new SapphireClient({ + intents: [GatewayIntentBits.MessageContent, GatewayIntentBits.Guilds, GatewayIntentBits.GuildMessages], + loadMessageCommandListeners: true +}); +``` + +::: + Commands have a `messageRun` method, which executes the command logic when it is invoked from a message. Define this below the command's constructor: @@ -150,3 +175,11 @@ For handling subcommands, please refer to the [Sapphire Plugin Subcommands][saph [load-message-commands-option]: ../../Documentation/api-framework/interfaces/SapphireClientOptions#loadmessagecommandlisteners [saph-plug-subcom]: ../plugins/Subcommands/getting-started +[guild_messages_intent]: https://discord-api-types.dev/api/discord-api-types-v10/enum/GatewayIntentBits#GuildMessages +[guilds_intent]: https://discord-api-types.dev/api/discord-api-types-v10/enum/GatewayIntentBits#Guilds +[message_content_intent]: https://discord-api-types.dev/api/discord-api-types-v10/enum/GatewayIntentBits#MessageContent +[`intents`]: + https://old.discordjs.dev/#/docs/discord.js/main/typedef/ClientOptions:~:text=use%20upon%20login-,intents,-IntentsResolvable +[dev-portal]: https://discord.com/developers +[loadMessageCommandListeners]: + ../../Documentation/api-framework/interfaces/SapphireClientOptions#loadmessagecommandlisteners diff --git a/docs/Guide/getting-started/getting-started-with-sapphire.mdx b/docs/Guide/getting-started/getting-started-with-sapphire.mdx index 394bcca8..b08cda6b 100644 --- a/docs/Guide/getting-started/getting-started-with-sapphire.mdx +++ b/docs/Guide/getting-started/getting-started-with-sapphire.mdx @@ -43,6 +43,31 @@ Here is an example of a package.json file: ::: +:::danger + +If you want to use message commands in your Sapphire bot, you have to make sure you meet the following prerequisites: + +1. Enable the `Message Content Intent` under `Privileged Gateway Intents` on the [Discord Developer Portal][dev-portal] + for your application. +2. In your Sapphire client options, set the [`intents`] property to include the intents + [`GatewayIntentBits.GuildMessages`][guild_messages_intent], [`GatewayIntentBits.Guilds`][guilds_intent], and + [`GatewayIntentBits.MessageContent`][message_content_intent]. +3. In your Sapphire client options set [`loadMessageCommandListeners`][loadMessageCommandListeners] to `true`. + +All in all your code should look something like this: + +```typescript ts2esm2cjs|{4-12}|{4-12} +import { SapphireClient } from '@sapphire/framework'; +import { GatewayIntentBits } from 'discord.js'; + +const client = new SapphireClient({ + intents: [GatewayIntentBits.MessageContent, GatewayIntentBits.Guilds, GatewayIntentBits.GuildMessages], + loadMessageCommandListeners: true +}); +``` + +::: + ## Creating an `index.js` file While it doesn't have to be called `index.js`, this file will be the main file for your bot (otherwise known as the @@ -91,3 +116,11 @@ And that's it for your `index.js` file! In the end, your directory should look l [djs-client]: https://old.discordjs.dev/#/docs/discord.js/main/class/Client [baseuserdirectory]: ../../Documentation/api-framework/interfaces/SapphireClientOptions#baseuserdirectory [securing-your-token]: https://discordjs.guide/preparations/setting-up-a-bot-application.html#your-token +[guild_messages_intent]: https://discord-api-types.dev/api/discord-api-types-v10/enum/GatewayIntentBits#GuildMessages +[guilds_intent]: https://discord-api-types.dev/api/discord-api-types-v10/enum/GatewayIntentBits#Guilds +[message_content_intent]: https://discord-api-types.dev/api/discord-api-types-v10/enum/GatewayIntentBits#MessageContent +[`intents`]: + https://old.discordjs.dev/#/docs/discord.js/main/typedef/ClientOptions:~:text=use%20upon%20login-,intents,-IntentsResolvable +[dev-portal]: https://discord.com/developers +[loadMessageCommandListeners]: + ../../Documentation/api-framework/interfaces/SapphireClientOptions#loadmessagecommandlisteners