Revamped event handlers
This commit is contained in:
@@ -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
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -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 }
|
||||||
|
|||||||
Reference in New Issue
Block a user