Compare commits

...

11 Commits

Author SHA1 Message Date
Raven Scott e895ff8fbd first commit 2023-08-20 19:40:54 -04:00
Raven Scott 26621c9866 modal patch to interactionCreate 2023-04-22 23:11:37 +02:00
Raven Scott a31234b717 adding discord modal example 2023-04-22 23:08:04 +02:00
Raven Scott 1af66c7c00 Merge branch 'master' of git.codingvm.codes:snxraven/DiscordJS-v13-Template 2022-10-12 00:56:58 -04:00
Raven Scott 9420839679 Changing bitfield to no longer need privileged intents 2022-10-12 00:56:45 -04:00
Raven Scott 93c3dfa65e Adding an Example ContentMenu Command 2022-09-28 19:05:07 -04:00
Raven Scott cbc6740e46 Removing files 2022-09-28 18:02:34 -04:00
Raven Scott d88e07a7ed adding a private option within the command config and adding ephemeral support by default 2022-09-28 18:00:36 -04:00
Raven Scott 5d5c9e9a48 update 2022-09-22 12:01:36 -04:00
snxraven 0910992bdf Merge pull request 'Update 'README.md'' (#2) from LauraOrchid/DiscordJS-v14-Template:lauraorchid-patch-1 into master
Reviewed-on: https://git.codingvm.codes/snxraven/DiscordJS-v14-Template/pulls/2
2022-07-23 12:46:04 +00:00
LauraOrchid 560e62fa53 Update 'README.md'
Fixed few "obvious" typos.
2022-07-23 12:27:51 +00:00
6 changed files with 107 additions and 31 deletions

3
.gitignore vendored Normal file
View File

@ -0,0 +1,3 @@
node_modules
.env
package-lock.json

View File

@ -1,4 +1,4 @@
# Discord-Linx Discord.JS v14 Base Template
# WTTR BOT
Only 3 dependencies required to run this bot!
@ -25,9 +25,9 @@ Structure:
TOKEN = token
```
4) Go to Handler -- > index.js and change "GUIDIDHERE" to your Discord Servers Guild ID
4) Go to Handler -- > index.js and change "GUIDIDHERE" to your Discord Server's Guild ID
5) Go into https://discord.com/developers/applications and enable Privlaged Intents.
5) Go into https://discord.com/developers/applications and enable Privileged Intents.
6) Run the bot ```node index.js```

View File

@ -1,16 +1,25 @@
const { EmbedBuilder } = require('discord.js');
module.exports = {
name: "ping",
description: "Returns websocket latency",
name: "weather",
description: "Get the weather for a location",
private: false,
options: [{
name: "location",
description: "The data you would like inside of the QR",
required: true,
type: 3 // 6 is type USER
}],
run: async (client, interaction) => {
let encodedLocation = encodeURIComponent(interaction.options._hoistedOptions[0].value);
let location = interaction.options._hoistedOptions[0].value;
const embed = new EmbedBuilder()
.setColor("#FF0000")
.setTitle("🏓 Pong!")
.setDescription(`Latency : ${client.ws.ping}ms`)
.setTitle(`The weather for: ${location}`)
.setTimestamp()
.setImage(`https://wttr.in/${encodedLocation}.png`)
.setFooter({ text: `Requested by ${interaction.user.tag}`, iconURL: `${interaction.user.displayAvatarURL()}` });
interaction.followUp({ embeds: [embed] });
await interaction.editReply({ embeds: [embed] });
},
};

View File

@ -1,33 +1,97 @@
const client = require("../index");
require("dotenv").config();
const { glob } = require("glob");
const { promisify } = require("util");
const globPromise = promisify(glob);
client.on("interactionCreate", async (interaction) => {
// Slash Commands
const slashCommands = await globPromise(`${process.cwd()}/commands/*/*.js`);
const arrayOfSlashCommands = [];
// Map the slash commands into data to be processed
slashCommands.map((value) => {
const file = require(value);
const splitted = value.split("/");
const directory = splitted[splitted.length - 2];
if (!file?.name) return;
const properties = {
directory,
...file
};
client.slashCommands.set(file.name, properties);
if (["MESSAGE", "USER"].includes(file.type)) delete file.description;
// Push the data
arrayOfSlashCommands.push(file);
});
// Slash Command Handling
if (interaction.isChatInputCommand()) {
await interaction.deferReply({ ephemeral: false }).catch(() => { });
const cmd = client.slashCommands.get(interaction.commandName);
if (!cmd)
return interaction.followUp({ content: "An error has occurred " });
// Grabbing Command Data for this interaction
let commandData = []
const args = [];
// We use ForEach here to filter our array into the single commands info.
await arrayOfSlashCommands.forEach(command => {
if (command.name == interaction.commandName) {
commandData.push(command)
}
});
for (let option of interaction.options.data) {
if (option.type === "SUB_COMMAND") {
if (option.name) args.push(option.name);
option.options?.forEach((x) => {
if (x.value) args.push(x.value);
});
} else if (option.value) args.push(option.value);
// Process and Parse Data
let dataToProcess = JSON.stringify(commandData[0])
let parsedData = JSON.parse(dataToProcess)
if (interaction.commandName == "modal-example"){
console.log("Modal - Skipping defer")
} else {
// If the command is private, set ephemeral true else, set false
console.log(parsedData)
if (parsedData.private == true) {
await interaction.deferReply({
ephemeral: true
}).catch(() => {});
} else {
await interaction.deferReply({
ephemeral: false
}).catch(() => {});
}
}
interaction.member = interaction.guild.members.cache.get(interaction.user.id);
const cmd = client.slashCommands.get(interaction.commandName);
if (!cmd)
return interaction.followUp({
content: "An error has occurred "
});
cmd.run(client, interaction, args);
const args = [];
for (let option of interaction.options.data) {
if (option.type === "SUB_COMMAND") {
if (option.name) args.push(option.name);
option.options?.forEach((x) => {
if (x.value) args.push(x.value);
});
} else if (option.value) args.push(option.value);
}
interaction.member = interaction.guild.members.cache.get(interaction.user.id);
cmd.run(client, interaction, args);
}
// Context Menu Handling
if (interaction.isContextMenuCommand()) {
await interaction.deferReply({ ephemeral: false });
const command = client.slashCommands.get(interaction.commandName);
if (command) command.run(client, interaction);
await interaction.deferReply({
ephemeral: false
});
const command = client.slashCommands.get(interaction.commandName);
if (command) command.run(client, interaction);
}
});
});

View File

@ -27,11 +27,11 @@ module.exports = async (client) => {
// Slash Commands Register
client.on("ready", async () => {
// Register for a single guild
await client.guilds.cache.get("GUIDIDHERE").commands.set(arrayOfSlashCommands);
// // Register for a single guild
// await client.guilds.cache.get("GUIDIDHERE").commands.set(arrayOfSlashCommands);
// Register for all the guilds the bot is in
// await client.application.commands.set(arrayOfSlashCommands);
await client.application.commands.set(arrayOfSlashCommands);
});
};

View File

@ -1,7 +1,7 @@
require("dotenv").config();
const { Client, Collection } = require("discord.js");
const client = new Client({ intents: 32767 });
const client = new Client({ intents: 4097 });
module.exports = client;
// Global Variables