Revamped event handlers

This commit is contained in:
2023-12-12 17:42:40 +01:00
parent 325f4a9c0e
commit db9a1e6c54
8 changed files with 57 additions and 36 deletions

View File

@@ -6,7 +6,6 @@ module.exports = {
/** @param { import("discord.js").AutocompleteInteraction } interaction */ /** @param { import("discord.js").AutocompleteInteraction } interaction */
async execute(interaction) { async execute(interaction) {
if (interaction.commandName !== "unban") return
const focusedOption = interaction.options.getFocused(true) const focusedOption = interaction.options.getFocused(true)
if (focusedOption.name !== "user") return if (focusedOption.name !== "user") return

View File

@@ -1,4 +1,4 @@
const { InteractionType, EmbedBuilder, ActionRowBuilder, ButtonBuilder, ButtonStyle } = require("discord.js") const { EmbedBuilder, ActionRowBuilder, ButtonBuilder, ButtonStyle } = require("discord.js")
const { color } = require("../../../config/options.json") const { color } = require("../../../config/options.json")
const guildapp = require("../../schemas/guildAppSchema.js") const guildapp = require("../../schemas/guildAppSchema.js")
@@ -10,10 +10,6 @@ module.exports = {
/** @param { import('discord.js').ModalSubmitInteraction } interaction */ /** @param { import('discord.js').ModalSubmitInteraction } interaction */
async execute(interaction) { async execute(interaction) {
if (interaction.type !== InteractionType.ModalSubmit) return
if (interaction.customId !== "denyreasonbox") return
interaction.deferReply() interaction.deferReply()
const guild = interaction.guild const guild = interaction.guild

View File

@@ -1,4 +1,4 @@
const { InteractionType, EmbedBuilder, ActionRowBuilder, ButtonBuilder, ButtonStyle } = require("discord.js") const { EmbedBuilder, ActionRowBuilder, ButtonBuilder, ButtonStyle } = require("discord.js")
const { color } = require("../../../config/options.json") const { color } = require("../../../config/options.json")
const staffapp = require("../../schemas/staffAppSchema.js") const staffapp = require("../../schemas/staffAppSchema.js")
@@ -10,10 +10,6 @@ module.exports = {
/** @param { import('discord.js').ModalSubmitInteraction } interaction */ /** @param { import('discord.js').ModalSubmitInteraction } interaction */
async execute(interaction) { async execute(interaction) {
if (interaction.type !== InteractionType.ModalSubmit) return
if (interaction.customId !== "staffdenyreasonbox") return
interaction.deferReply() interaction.deferReply()
const guild = interaction.guild const guild = interaction.guild

View File

@@ -1,4 +1,3 @@
const { InteractionType } = require("discord.js")
const { getUUID, getPlayer, getGuild, getHeadURL } = require("../../utils/utils.js") const { getUUID, getPlayer, getGuild, getHeadURL } = require("../../utils/utils.js")
const { color, hypixelGuildID, devMessage } = require("../../../config/options.json") const { color, hypixelGuildID, devMessage } = require("../../../config/options.json")
const verify = require("../../schemas/verifySchema.js") const verify = require("../../schemas/verifySchema.js")
@@ -12,7 +11,6 @@ module.exports = {
/** @param { import('discord.js').ModalSubmitInteraction } interaction */ /** @param { import('discord.js').ModalSubmitInteraction } interaction */
async execute(interaction) { async execute(interaction) {
if (interaction.type !== InteractionType.ModalSubmit) return
await interaction.deferReply({ ephemeral: true }) await interaction.deferReply({ ephemeral: true })
const user1 = interaction.user const user1 = interaction.user

View File

@@ -24,8 +24,9 @@ const client = new Client({
}) })
client.commands = new Collection() client.commands = new Collection()
client.events = new Collection() client.buttons = new Collection()
client.modals = new Collection() client.modals = new Collection()
client.autocomplete = new Collection()
init() init()
loadSlashCommandsEvents(client) loadSlashCommandsEvents(client)

View File

@@ -14,22 +14,31 @@ function loadAutocompleteEvents(client) {
const autocomplete = require(filePath) const autocomplete = require(filePath)
if ("name" in autocomplete && "execute" in autocomplete && autocomplete.type === "autocomplete") { if ("name" in autocomplete && "execute" in autocomplete && autocomplete.type === "autocomplete") {
client.on(Events.InteractionCreate, async interaction => { client.autocomplete.set(autocomplete.name, autocomplete)
if (!interaction.isAutocomplete()) return
try {
await autocomplete.execute(interaction)
} catch (error) {
console.error(error)
await interaction.respond({
content: "There was an error while executing this command!",
ephemeral: true
})
}
})
} else { } else {
console.log(`[WARNING] The autocomplete at ${filePath} is missing a required "name", "execute" or "type" property.`) console.log(`[WARNING] The autocomplete at ${filePath} is missing a required "name", "execute" or "type" property.`)
} }
client.on(Events.InteractionCreate, async interaction => {
if (!interaction.isAutocomplete()) return
const autocomplete = interaction.client.autocomplete.get(interaction.commandName)
if (!autocomplete) {
console.error(`No autocomplete matching ${interaction.commandName} was found.`)
return
}
try {
await autocomplete.execute(interaction, client)
} catch (error) {
console.error(error)
await interaction.respond({
content: "There was an error while executing this autocomplete!",
ephemeral: true
})
}
})
} }
} }

View File

@@ -14,28 +14,28 @@ function loadButtonEvents(client) {
const btn = require(filePath) const btn = require(filePath)
if ("name" in btn && "execute" in btn && btn.type === "button") { if ("name" in btn && "execute" in btn && btn.type === "button") {
client.events.set(btn.name, btn) client.buttons.set(btn.name, btn)
} else { } else {
console.log(`[WARNING] The button at ${filePath} is missing a required "name", "execute" or "type" property.`) console.log(`[WARNING] The button at ${filePath} is missing a required "name", "execute" or "type" property.`)
} }
} }
client.on(Events.InteractionCreate, async event => { client.on(Events.InteractionCreate, async interaction => {
if (!event.isButton()) if (!interaction.isButton())
return return
const event2 = event.client.events.get(event.customId) const button = interaction.client.buttons.get(interaction.customId)
if (!event2) { if (!button) {
console.error(`No event matching ${event.customId} was found.`) console.error(`No event matching ${interaction.customId} was found.`)
return return
} }
try { try {
await event2.execute(event) await button.execute(interaction)
} catch (error) { } catch (error) {
console.error(error) console.error(error)
await event.reply({ await interaction.reply({
content: "There was an error while executing this event!", content: "There was an error while executing this event!",
ephemeral: true ephemeral: true
}) })

View File

@@ -14,11 +14,33 @@ function loadModalEvents(client) {
const modal = require(filePath) const modal = require(filePath)
if ("name" in modal && "execute" in modal && modal.type === "modal") { if ("name" in modal && "execute" in modal && modal.type === "modal") {
client.on(Events.InteractionCreate, modal.execute) client.modals.set(modal.name, modal)
} else { } else {
console.log(`[WARNING] The modal at ${filePath} is missing a required "name", "execute" or "type" property.`) console.log(`[WARNING] The modal at ${filePath} is missing a required "name", "execute" or "type" property.`)
} }
} }
client.on(Events.InteractionCreate, async interaction => {
if (!interaction.isModalSubmit())
return
const modal = interaction.client.modals.get(interaction.customId)
if (!modal) {
console.error(`No modal matching ${interaction.customId} was found.`)
return
}
try {
await modal.execute(interaction)
} catch (error) {
console.error(error)
await interaction.reply({
content: "There was an error while executing this modal!",
ephemeral: true
})
}
})
} }
module.exports = { loadModalEvents } module.exports = { loadModalEvents }