From c21f25a981fdcea3357c37e48393fa4f70aa41db Mon Sep 17 00:00:00 2001 From: Egor Date: Tue, 10 Aug 2021 00:22:09 +1000 Subject: [PATCH] chore(docs): examples --- .npmignore | 1 + README.md | 8 ++-- docs/classes/PagesBuilder.html | 6 +-- docs/index.html | 6 ++- docs/modules.html | 6 ++- examples/buttons/customButtons.js | 64 +++++++++++++++++++++++++++++++ examples/buttons/dynamicUpdate.js | 45 ++++++++++++++++++++++ examples/buttons/quickActions.js | 30 +++++++++++++++ examples/files.js | 30 +++++++++++++++ examples/initialization.js | 44 +++++++++++++++++++++ examples/rootEmbed.js | 30 +++++++++++++++ src/PagesBuilder.ts | 6 +-- 12 files changed, 263 insertions(+), 13 deletions(-) create mode 100644 examples/buttons/customButtons.js create mode 100644 examples/buttons/dynamicUpdate.js create mode 100644 examples/buttons/quickActions.js create mode 100644 examples/files.js create mode 100644 examples/initialization.js create mode 100644 examples/rootEmbed.js diff --git a/.npmignore b/.npmignore index 2898d6b..9f1d1b1 100644 --- a/.npmignore +++ b/.npmignore @@ -4,6 +4,7 @@ /src /build /scripts +/examples .eslintrc.json .gitignore tsconfig.json diff --git a/README.md b/README.md index 892277a..9a33885 100644 --- a/README.md +++ b/README.md @@ -9,8 +9,8 @@ npm version -| 📖 [Documentation](https://mrzillagold.github.io/discord.js-pages/index.html) | -| ---------------------------------------------------------------------------- | +| 📖 [Documentation](https://mrzillagold.github.io/discord.js-pages/index.html) | [🤖 Examples](https://github.com/MrZillaGold/discord.js-pages) | +| --- | --- |

@@ -19,7 +19,7 @@ ### Usage 📦 ```js -import { PagesBuilder } from 'discord.js-pages'; +import { PagesBuilder, PagesManager } from 'discord.js-pages'; import { Client, MessageEmbed } from 'discord.js'; const client = new Client({ @@ -28,6 +28,8 @@ const client = new Client({ ] }); +const pagesManager = new PagesManager(); + // Middleware is useful in bots with modular commands client.on('interactionCreate', (interaction) => { pagesManager.middleware(interaction); diff --git a/docs/classes/PagesBuilder.html b/docs/classes/PagesBuilder.html index 312687c..afa1ef4 100644 --- a/docs/classes/PagesBuilder.html +++ b/docs/classes/PagesBuilder.html @@ -3978,9 +3978,9 @@

setDefaultButtons

example
builder.setDefaultButtons(['first', {
-  'stop': new MessageButton()
-  .setLabel('Stop')
-  .setStyle('PRIMARY')
+  stop: new MessageButton()
+     .setLabel('Stop')
+     .setStyle('PRIMARY')
 }]);
 
diff --git a/docs/index.html b/docs/index.html index 3f6df04..834b9f7 100644 --- a/docs/index.html +++ b/docs/index.html @@ -2738,7 +2738,7 @@

📖 Documentation - 🤖 Examples + 🤖 Examples @@ -2750,7 +2750,7 @@

Install 📦

Usage 📦

-
import { PagesBuilder } from 'discord.js-pages';
+			
import { PagesBuilder, PagesManager } from 'discord.js-pages';
 import { Client, MessageEmbed } from 'discord.js';
 
 const client = new Client({
@@ -2759,6 +2759,8 @@ 

Usage 📦

] }); +const pagesManager = new PagesManager(); + // Middleware is useful in bots with modular commands client.on('interactionCreate', (interaction) => { pagesManager.middleware(interaction); diff --git a/docs/modules.html b/docs/modules.html index 4e8a8af..1307759 100644 --- a/docs/modules.html +++ b/docs/modules.html @@ -2738,7 +2738,7 @@

📖 Documentation - 🤖 Examples + 🤖 Examples @@ -2750,7 +2750,7 @@

Install 📦

Usage 📦

-
import { PagesBuilder } from 'discord.js-pages';
+			
import { PagesBuilder, PagesManager } from 'discord.js-pages';
 import { Client, MessageEmbed } from 'discord.js';
 
 const client = new Client({
@@ -2759,6 +2759,8 @@ 

Usage 📦

] }); +const pagesManager = new PagesManager(); + // Middleware is useful in bots with modular commands client.on('interactionCreate', (interaction) => { pagesManager.middleware(interaction); diff --git a/examples/buttons/customButtons.js b/examples/buttons/customButtons.js new file mode 100644 index 0000000..ad17909 --- /dev/null +++ b/examples/buttons/customButtons.js @@ -0,0 +1,64 @@ +import { Client, MessageEmbed, MessageButton, MessageActionRow } from 'discord.js'; +import { PagesBuilder } from 'discord.js-pages'; + +const client = new Client({ + intents: [ + 'GUILDS' + ] +}); + +client.on('interactionCreate', (interaction) => { + // Custom buttons & select + new PagesBuilder(interaction) + .setTitle('Global title') + .setPages([ + new MessageEmbed() + .setDescription('First page'), + new MessageEmbed() + .setDescription('Second page') + ]) + .setComponents([ + new MessageActionRow() + .setComponents( + new MessageButton() + .setCustomId('custom') + .setLabel('Custom button') + .setStyle('PRIMARY') + ) + ]) + // You can add buttons/selects to the end of the list. + // The library itself will find the component in which there is a place or create new for the element and add it. + // Support array. + .addComponents( + new MessageButton() + .setCustomId('awesome') + .setLabel('Awesome button') + .setStyle('SECONDARY') + ) + // Add triggers for handling interactions with buttons/selects. + // Support array. + .setTriggers({ + name: 'custom', + callback(interactionCallback, button) { + button.setDisabled(true); + + interaction.followUp({ + content: 'Custom button callback!' + }); + } + }) + .addTriggers({ + name: 'awesome', + callback(interactionCallback, button) { + button.setDisabled(true) + .setLabel('¯\\_(ツ)_/¯'); + + interaction.followUp({ + content: 'Awesome button callback!' + }); + } + }) + .build(); +}); + +client.login(process.env.TOKEN); \ No newline at end of file diff --git a/examples/buttons/dynamicUpdate.js b/examples/buttons/dynamicUpdate.js new file mode 100644 index 0000000..ef312c0 --- /dev/null +++ b/examples/buttons/dynamicUpdate.js @@ -0,0 +1,45 @@ +import { Client, MessageEmbed, MessageButton, MessageActionRow } from 'discord.js'; +import { PagesBuilder } from 'discord.js-pages'; + +const client = new Client({ + intents: [ + 'GUILDS' + ] +}); + +client.on('interactionCreate', (interaction) => { + const link = new MessageButton() + .setLabel('Dynamic link') + .setStyle('LINK'); + + // Dynamic buttons update + const builder = new PagesBuilder(interaction) + .setTitle('Global title'); + + builder.setPages([ + () => { + link.setURL('https://google.com/'); + + builder.setComponents( + new MessageActionRow() + .addComponents(link) + ); + + return new MessageEmbed() + .setDescription('First page'); + }, + () => { + link.setURL('https://discord.com/'); + + builder.setComponents( + new MessageActionRow() + .addComponents(link) + ); + + return new MessageEmbed() + .setDescription('Second page'); + } + ]); +}); + +client.login(process.env.TOKEN); \ No newline at end of file diff --git a/examples/buttons/quickActions.js b/examples/buttons/quickActions.js new file mode 100644 index 0000000..c7695c0 --- /dev/null +++ b/examples/buttons/quickActions.js @@ -0,0 +1,30 @@ +import { Client, MessageEmbed, MessageButton } from 'discord.js'; +import { PagesBuilder } from 'discord.js-pages'; + +const client = new Client({ + intents: [ + 'GUILDS' + ] +}); + +client.on('interactionCreate', (interaction) => { + // Quick actions + new PagesBuilder(interaction) + .setTitle('Global title') + .setPages([ + new MessageEmbed() + .setDescription('First page'), + new MessageEmbed() + .setDescription('Second page') + ]) + // Add buttons with quick pagination actions, also you can customize it. + // There is no need to set customId, the library does it for you. + .setDefaultButtons(['first', { + stop: new MessageButton() + .setLabel('Stop') + .setStyle('PRIMARY') + }]) + .build(); +}); + +client.login(process.env.TOKEN); \ No newline at end of file diff --git a/examples/files.js b/examples/files.js new file mode 100644 index 0000000..3c2e284 --- /dev/null +++ b/examples/files.js @@ -0,0 +1,30 @@ +import { Client, MessageAttachment, MessageEmbed } from 'discord.js'; +import { PagesBuilder } from 'discord.js-pages'; + +const client = new Client({ + intents: [ + 'GUILDS' + ] +}); + +client.on('interactionCreate', (interaction) => { + // To start using the files, you must add them to PagesBuilder, after adding you can use them on each page. + new PagesBuilder(interaction) + .setPages([ + new MessageEmbed() + .setDescription('First page') + .setThumbnail('attachment://discord.png'), + new MessageEmbed() + .setDescription('Second page') + ]) + // Supports array. + .setFiles( + new MessageAttachment( + Buffer.from('', 'base64'), + 'discord.png' + ) + ) + .build(); +}); + +client.login(process.env.TOKEN); \ No newline at end of file diff --git a/examples/initialization.js b/examples/initialization.js new file mode 100644 index 0000000..a08e83c --- /dev/null +++ b/examples/initialization.js @@ -0,0 +1,44 @@ +import { Client, MessageEmbed } from 'discord.js'; +import { PagesBuilder, PagesManager } from 'discord.js-pages'; + +const client = new Client({ + intents: [ + 'GUILDS' + ] +}); + +const pagesManager = new PagesManager(); + +// Middleware is useful in bots with modular commands +client.on('interactionCreate', (interaction) => { + pagesManager.middleware(interaction); + + interaction.pagesBuilder() + .setTitle('Global title') + .setPages([ + new MessageEmbed() + .setDescription('First page'), + new MessageEmbed() + .setDescription('Second page') + ]) + .addField('Global field', 'discord.js-pages', true) + .setColor('GREEN') + .build(); +}); + +// Also you can create PagesBuilder instance directly +client.on('interactionCreate', (interaction) => { + new PagesBuilder(interaction) + .setTitle('Global title') + .setPages([ + new MessageEmbed() + .setDescription('First page'), + new MessageEmbed() + .setDescription('Second page') + ]) + .addField('Global field', 'discord.js-pages', true) + .setColor('GREEN') + .build(); +}); + +client.login(process.env.TOKEN); \ No newline at end of file diff --git a/examples/rootEmbed.js b/examples/rootEmbed.js new file mode 100644 index 0000000..3160484 --- /dev/null +++ b/examples/rootEmbed.js @@ -0,0 +1,30 @@ +import { Client, MessageEmbed } from 'discord.js'; +import { PagesBuilder } from 'discord.js-pages'; + +const client = new Client({ + intents: [ + 'GUILDS' + ] +}); + +client.on('interactionCreate', (interaction) => { + // PagesBuilder extends the MessageEmbed class, it inherits all of its methods and properties. + // You can add new properties using methods. + // + // When you add properties in this way, + // they will be prioritized and will replace/supplement the properties of the child MessageEmbed + // that are set via the setPages/addPages method. + new PagesBuilder(interaction) + .setTitle('Global title') + .setPages([ + new MessageEmbed() + .setDescription('First page'), + new MessageEmbed() + .setDescription('Second page') + ]) + .addField('Global field', 'discord.js-pages', true) + .setColor('GREEN') + .build(); +}); + +client.login(process.env.TOKEN); \ No newline at end of file diff --git a/src/PagesBuilder.ts b/src/PagesBuilder.ts index ebd76f8..9a2d112 100644 --- a/src/PagesBuilder.ts +++ b/src/PagesBuilder.ts @@ -278,9 +278,9 @@ export class PagesBuilder extends MessageEmbed { * @example * ``` * builder.setDefaultButtons(['first', { - * 'stop': new MessageButton() - * .setLabel('Stop') - * .setStyle('PRIMARY') + * stop: new MessageButton() + * .setLabel('Stop') + * .setStyle('PRIMARY') * }]); * ``` */