blob: dc224e8c85acd1a756e42ce445118633704549a0 [file] [log] [blame]
import { MessageButton } from "discord.js";
import EmojiEmbed from "../utils/generateEmojiEmbed.js";
import { MessageActionRow, MessageSelectMenu } from "discord.js";
import getEmojiByName from "../utils/getEmojiByName.js";
import client from "../utils/client.js";
import { LoadingEmbed } from "../utils/defaultEmbeds.js";
export async function callback(interaction) {
const config = await client.database.guilds.read(interaction.guild.id);
if (!config.roleMenu.enabled)
return await interaction.reply({
embeds: [
new EmojiEmbed()
.setTitle("Roles")
.setDescription(
"Self roles are currently disabled. Please contact a staff member or try again later."
)
.setStatus("Danger")
.setEmoji("CONTROL.BLOCKCROSS")
],
ephemeral: true
});
if (config.roleMenu.options.length === 0)
return await interaction.reply({
embeds: [
new EmojiEmbed()
.setTitle("Roles")
.setDescription(
"There are no roles available. Please contact a staff member or try again later."
)
.setStatus("Danger")
.setEmoji("CONTROL.BLOCKCROSS")
],
ephemeral: true
});
await interaction.reply({ embeds: LoadingEmbed, ephemeral: true });
let m;
if (config.roleMenu.allowWebUI) {
let code = "";
let length = 5;
let itt = 0;
const chars =
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
let valid = false;
while (!valid) {
itt += 1;
code = "";
for (let i = 0; i < length; i++) {
code += chars.charAt(Math.floor(Math.random() * chars.length));
}
if (code in client.roleMenu) continue;
if (itt > 1000) {
itt = 0;
length += 1;
continue;
}
valid = true;
}
client.roleMenu[code] = {
guild: interaction.guild.id,
guildName: interaction.guild.name,
guildIcon: interaction.guild.iconURL({ format: "png" }),
user: interaction.member.user.id,
username: interaction.member.user.username,
data: config.roleMenu.options,
interaction: interaction
};
let up = true;
try {
const status = await fetch(client.config.baseUrl).then(
(res) => res.status
);
if (status !== 200) up = false;
} catch {
up = false;
}
m = await interaction.editReply({
embeds: [
new EmojiEmbed()
.setTitle("Roles")
.setDescription("Select how to choose your roles")
.setStatus("Success")
.setEmoji("GUILD.GREEN")
],
components: [
new MessageActionRow().addComponents([
new MessageButton()
.setLabel("Online")
.setStyle("LINK")
.setDisabled(!up)
.setURL(
`${client.config.baseUrl}nucleus/rolemenu?code=${code}`
),
new MessageButton()
.setLabel("Manual")
.setStyle("PRIMARY")
.setCustomId("manual")
])
]
});
}
let component;
try {
component = await m.awaitMessageComponent({ time: 300000 });
} catch (e) {
return;
}
component.deferUpdate();
let rolesToAdd = [];
for (let i = 0; i < config.roleMenu.options.length; i++) {
const object = config.roleMenu.options[i];
const m = await interaction.editReply({
embeds: [
new EmojiEmbed()
.setTitle("Roles")
.setEmoji("GUILD.GREEN")
.setDescription(
`**${object.name}**` +
(object.description
? `\n${object.description}`
: "") +
`\n\nSelect ${object.min}` +
(object.min !== object.max
? ` to ${object.max}`
: "") +
` role${object.max === 1 ? "" : "s"} to add.`
)
.setStatus("Success")
.setFooter({
text: `Step ${i + 1}/${config.roleMenu.options.length}`
})
],
components: [
new MessageActionRow().addComponents(
[
new MessageButton()
.setLabel("Cancel")
.setStyle("DANGER")
.setCustomId("cancel")
.setEmoji(getEmojiByName("CONTROL.CROSS", "id"))
].concat(
object.min === 0
? [
new MessageButton()
.setLabel("Skip")
.setStyle("SECONDARY")
.setCustomId("skip")
.setEmoji(
getEmojiByName("CONTROL.RIGHT", "id")
)
]
: []
)
)
].concat([
new MessageActionRow().addComponents([
new MessageSelectMenu()
.setPlaceholder(`${object.name}`)
.setCustomId("rolemenu")
.setMinValues(object.min)
.setMaxValues(object.max)
.setOptions(
object.options.map((o) => {
return {
label: o.name,
description: o.description,
value: o.role
};
})
)
])
])
});
let component;
try {
component = await m.awaitMessageComponent({ time: 300000 });
} catch (e) {
return;
}
component.deferUpdate();
if (component.customId === "rolemenu") {
rolesToAdd = rolesToAdd.concat(component.values);
} else if (component.customId === "cancel") {
return await interaction.editReply({
embeds: [
new EmojiEmbed()
.setTitle("Roles")
.setDescription("Cancelled. No changes were made.")
.setStatus("Danger")
.setEmoji("GUILD.RED")
],
components: []
});
}
}
let rolesToRemove = config.roleMenu.options
.map((o) => o.options.map((o) => o.role))
.flat();
const memberRoles = interaction.member.roles.cache.map((r) => r.id);
rolesToRemove = rolesToRemove
.filter((r) => memberRoles.includes(r))
.filter((r) => !rolesToAdd.includes(r));
rolesToAdd = rolesToAdd.filter((r) => !memberRoles.includes(r));
try {
await interaction.member.roles.remove(rolesToRemove);
await interaction.member.roles.add(rolesToAdd);
} catch (e) {
return await interaction.reply({
embeds: [
new EmojiEmbed()
.setTitle("Roles")
.setDescription(
"Something went wrong and your roles were not added. Please contact a staff member or try again later."
)
.setStatus("Danger")
.setEmoji("GUILD.RED")
],
components: []
});
}
await interaction.editReply({
embeds: [
new EmojiEmbed()
.setTitle("Roles")
.setDescription(
"Roles have been added. You may close this message."
)
.setStatus("Success")
.setEmoji("GUILD.GREEN")
],
components: []
});
return;
}