2022-08-29 20:56:26 +02:00
|
|
|
import { SlashCommandBuilder, ActionRowBuilder, ButtonBuilder, ButtonStyle } from 'discord.js';
|
|
|
|
import db from '../../models/index.js';
|
|
|
|
|
|
|
|
export default {
|
|
|
|
data: new SlashCommandBuilder()
|
|
|
|
.setName('optout')
|
2023-04-04 00:30:30 +02:00
|
|
|
.setDescription('Opt out of the non commands features and arguments logging (for debugging purposes)'),
|
2022-08-29 20:56:26 +02:00
|
|
|
category: 'utility',
|
|
|
|
async execute(interaction, args, client) {
|
|
|
|
const isOptOut = await db.optout.findOne({ where: { userID: interaction.user.id } });
|
|
|
|
|
|
|
|
if (!isOptOut) {
|
|
|
|
const body = { userID: interaction.user.id };
|
|
|
|
await db.optout.create(body);
|
2023-04-07 03:08:16 +02:00
|
|
|
await interaction.reply({ content: 'You have successfully been opt out.', ephemeral: true });
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
const row = new ActionRowBuilder()
|
|
|
|
.addComponents(
|
|
|
|
new ButtonBuilder()
|
|
|
|
.setCustomId(`yes${interaction.user.id}${interaction.id}`)
|
|
|
|
.setLabel('Yes')
|
|
|
|
.setStyle(ButtonStyle.Primary),
|
|
|
|
)
|
|
|
|
.addComponents(
|
|
|
|
new ButtonBuilder()
|
|
|
|
.setCustomId(`no${interaction.user.id}${interaction.id}`)
|
|
|
|
.setLabel('No')
|
|
|
|
.setStyle(ButtonStyle.Danger),
|
|
|
|
);
|
|
|
|
|
|
|
|
await interaction.reply({ content: 'You are already opt out, do you wish to opt in?', components: [row], ephemeral: true });
|
|
|
|
|
|
|
|
listenButton(client, interaction, interaction.user);
|
2022-08-29 20:56:26 +02:00
|
|
|
}
|
|
|
|
|
2023-04-07 03:08:16 +02:00
|
|
|
return interaction.followUp({
|
|
|
|
content:
|
|
|
|
'As a reminder here what opting out does:\n'
|
|
|
|
+ '- Your user ID will no longer be used for debug logging.\n'
|
|
|
|
+ '- servers will no longer be shown in added/kicked stats.\n'
|
|
|
|
+ '- Your messages won\'t be quoted.\n'
|
|
|
|
+ '- Won\'t show the arguments from commands.',
|
|
|
|
ephemeral: true,
|
|
|
|
},
|
|
|
|
);
|
2022-08-29 20:56:26 +02:00
|
|
|
},
|
|
|
|
};
|
2023-04-05 18:12:56 +02:00
|
|
|
|
|
|
|
|
|
|
|
async function listenButton(client, interaction, user = interaction.user, originalId = interaction.id) {
|
|
|
|
client.once('interactionCreate', async (interactionMenu) => {
|
|
|
|
if (user !== interactionMenu.user) return listenButton(client, interaction, user, originalId);
|
|
|
|
if (!interactionMenu.isButton()) return;
|
|
|
|
|
|
|
|
await interactionMenu.update({ components: [] });
|
|
|
|
|
|
|
|
if (interactionMenu.customId === `yes${interaction.user.id}${originalId}`) {
|
|
|
|
db.optout.destroy({ where: { userID: interaction.user.id } });
|
2023-04-07 03:08:16 +02:00
|
|
|
return interaction.editReply({ content: 'You have successfully been opt in', ephemeral: true });
|
2023-04-05 18:12:56 +02:00
|
|
|
}
|
|
|
|
else {
|
2023-04-07 03:08:16 +02:00
|
|
|
return interaction.editReply({ content: 'Nothing has been changed.', ephemeral: true });
|
2023-04-05 18:12:56 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|