mirror of
https://github.com/JonnyBro/JaBa.git
synced 2024-11-25 14:44:58 +05:00
131 lines
No EOL
3.7 KiB
JavaScript
131 lines
No EOL
3.7 KiB
JavaScript
const { SlashCommandBuilder, EmbedBuilder, ActionRowBuilder, ButtonBuilder, ButtonStyle, PermissionFlagsBits } = require("discord.js");
|
|
const BaseCommand = require("../../base/BaseCommand");
|
|
|
|
class Poll extends BaseCommand {
|
|
/**
|
|
*
|
|
* @param {import("../../base/JaBa")} client
|
|
*/
|
|
constructor(client) {
|
|
super({
|
|
command: new SlashCommandBuilder()
|
|
.setName("poll")
|
|
.setDescription(client.translate("moderation/poll:DESCRIPTION"))
|
|
.setDefaultMemberPermissions(PermissionFlagsBits.ModerateMembers && PermissionFlagsBits.ManageMessages)
|
|
.addStringOption(option => option.setName("question")
|
|
.setDescription(client.translate("moderation/poll:QUESTION"))
|
|
.setRequired(true)),
|
|
aliases: [],
|
|
dirname: __dirname,
|
|
guildOnly: true
|
|
});
|
|
}
|
|
/**
|
|
*
|
|
* @param {import("../../base/JaBa")} client
|
|
*/
|
|
async onLoad() {
|
|
//...
|
|
}
|
|
/**
|
|
*
|
|
* @param {import("../../base/JaBa")} client
|
|
* @param {import("discord.js").ChatInputCommandInteraction} interaction
|
|
* @param {Array} data
|
|
*/
|
|
async execute(client, interaction) {
|
|
const question = interaction.options.getString("question");
|
|
|
|
const row = new ActionRowBuilder()
|
|
.addComponents(
|
|
new ButtonBuilder()
|
|
.setCustomId("poll_everyone")
|
|
.setLabel(interaction.translate("moderation/poll:EVERYONE"))
|
|
.setStyle(ButtonStyle.Primary),
|
|
new ButtonBuilder()
|
|
.setCustomId("poll_here")
|
|
.setLabel(interaction.translate("moderation/poll:HERE"))
|
|
.setStyle(ButtonStyle.Primary),
|
|
new ButtonBuilder()
|
|
.setCustomId("poll_nothing")
|
|
.setLabel(interaction.translate("moderation/poll:NOTHING"))
|
|
.setStyle(ButtonStyle.Primary),
|
|
new ButtonBuilder()
|
|
.setCustomId("poll_cancel")
|
|
.setLabel(interaction.translate("common:CANCEL"))
|
|
.setStyle(ButtonStyle.Danger),
|
|
);
|
|
|
|
|
|
await interaction.reply({
|
|
content: interaction.translate("moderation/poll:SELECT_MENTION"),
|
|
ephemeral: true,
|
|
components: [row]
|
|
});
|
|
|
|
let mention = null;
|
|
const filter = i => i.user.id === interaction.user.id;
|
|
const collector = interaction.channel.createMessageComponentCollector({ filter, time: 15000 });
|
|
|
|
collector.on("collect", async i => {
|
|
if (i.isButton()) {
|
|
if (i.customId === "poll_everyone") {
|
|
mention = "@everyone";
|
|
i.update({
|
|
content: interaction.translate("moderation/poll:POLL_SENDED"),
|
|
components: []
|
|
});
|
|
} else if (i.customId === "poll_here") {
|
|
mention = "@here";
|
|
i.update({
|
|
content: interaction.translate("moderation/poll:POLL_SENDED"),
|
|
components: []
|
|
});
|
|
} else if (i.customId === "poll_nothing") {
|
|
mention = null;
|
|
i.update({
|
|
content: interaction.translate("moderation/poll:POLL_SENDED"),
|
|
components: []
|
|
});
|
|
} else if (i.customId === "poll_cancel") {
|
|
return i.update({
|
|
content: interaction.translate("misc:SELECT_CANCELED"),
|
|
components: []
|
|
});
|
|
}
|
|
|
|
const cool = client.emojis.cache.find(e => e.name === client.customEmojis.cool.split(":")[1]);
|
|
const notcool = client.emojis.cache.find(e => e.name === client.customEmojis.notcool.split(":")[1]);
|
|
|
|
const embed = new EmbedBuilder()
|
|
.setAuthor({
|
|
name: interaction.translate("moderation/poll:TITLE")
|
|
})
|
|
.setColor(client.config.embed.color)
|
|
.addFields([
|
|
{
|
|
name: "\u200b",
|
|
value: question
|
|
},
|
|
{
|
|
name: "\u200b",
|
|
value: interaction.translate("moderation/poll:REACT", {
|
|
success: cool.toString(),
|
|
error: notcool.toString()
|
|
})
|
|
}
|
|
]);
|
|
|
|
return interaction.channel.send({
|
|
content: mention,
|
|
embeds: [embed]
|
|
}).then(async m => {
|
|
await m.react(cool);
|
|
await m.react(notcool);
|
|
});
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
module.exports = Poll; |