JaBa/commands/Moderation/warn.c.js

200 lines
5.7 KiB
JavaScript
Raw Permalink Normal View History

const { ContextMenuCommandBuilder, ModalBuilder, ActionRowBuilder, TextInputBuilder, ApplicationCommandType, PermissionsBitField, TextInputStyle } = require("discord.js");
const BaseCommand = require("../../base/BaseCommand");
class WarnContext extends BaseCommand {
/**
*
2023-11-05 16:03:23 +05:00
* @param {import("../../base/Client")} client
*/
constructor() {
super({
command: new ContextMenuCommandBuilder()
2023-11-19 22:43:17 +05:00
.setName("Give Warn")
.setType(ApplicationCommandType.User)
.setDMPermission(false)
.setDefaultMemberPermissions(PermissionsBitField.Flags.ManageMessages),
dirname: __dirname,
ownerOnly: false,
});
}
/**
*
2023-11-05 16:03:23 +05:00
* @param {import("../../base/Client")} client
* @param {import("discord.js").UserContextMenuCommandInteraction} interaction
*/
2024-02-09 23:26:57 +05:00
async execute(client, interaction) {
const member = interaction.targetMember,
memberPosition = member.roles.highest.position,
moderationPosition = interaction.member.roles.highest.position;
if (member.user.bot) return interaction.error("misc:BOT_USER", null, { ephemeral: true });
if (member.id === interaction.member.id) return interaction.error("moderation/warn:YOURSELF", null, { ephemeral: true });
2023-07-07 17:34:23 +05:00
if (interaction.guild.ownerId !== interaction.member.id && !(moderationPosition > memberPosition)) return interaction.error("moderation/warn:SUPERIOR", null, { ephemeral: true });
const memberData = await client.getMemberData(member.id, interaction.guildId);
const modal = new ModalBuilder()
.setCustomId("warn_modal")
2023-07-05 00:58:06 +05:00
.setTitle(interaction.translate("moderation/warn:MODAL_TITLE", {
nickname: member.user.getUsername(),
}).normalize("NFKD"));
const reasonInput = new TextInputBuilder()
.setCustomId("warn_reason")
2022-08-08 18:19:56 +05:00
.setLabel(interaction.translate("moderation/warn:MODAL_REASON"))
.setMinLength(5)
.setMaxLength(200)
.setRequired(true)
.setStyle(TextInputStyle.Short);
modal.addComponents(new ActionRowBuilder().addComponents(reasonInput));
await interaction.showModal(modal);
2023-07-05 00:58:06 +05:00
const submitted = await interaction
.awaitModalSubmit({
time: 2 * 60 * 1000,
filter: i => i.user.id === interaction.member.id && i.customId === "warn_modal",
})
.catch(() => {
interaction.followUp({
content: interaction.translate("misc:TIMED_OUT"),
ephemeral: true,
});
});
2022-08-08 18:19:56 +05:00
if (submitted) {
const reason = submitted.fields.getTextInputValue("warn_reason");
2023-06-26 17:25:17 +05:00
// const sanctions = memberData.sanctions.filter(s => s.type === "warn").length;
// const banCount = data.guildData.plugins.warnsSanctions.ban;
// const kickCount = data.guildData.plugins.warnsSanctions.kick;
const caseInfo = {
moderator: interaction.member.id,
date: Date.now(),
type: "warn",
reason,
};
const embed = client.embed({
author: interaction.translate("moderation/warn:WARN"),
fields: [
{
name: interaction.translate("common:USER"),
2024-04-07 20:14:04 +05:00
value: member.user.toString(),
},
{
name: interaction.translate("common:MODERATOR"),
2024-04-07 20:14:04 +05:00
value: interaction.user.toString(),
},
{
name: interaction.translate("common:REASON"),
value: reason,
inline: true,
},
],
});
2023-06-26 17:25:17 +05:00
/*
if (banCount) {
if (sanctions >= banCount) {
member.send({
content: interaction.translate("moderation/ban:BANNED_DM", {
user: member.user,
moderator: interaction.user.getUsername(),
server: interaction.guild.name,
reason,
}),
});
caseInfo.type = "ban";
embed
.setAuthor({
name: interaction.translate("moderation/warn:BAN"),
})
.setColor(client.config.embed.color);
interaction.guild.members.ban(member).catch(() => {});
2023-06-26 17:25:17 +05:00
interaction.followUp({
content: interaction.translate("moderation/setwarns:AUTO_BAN", {
user: member.user.getUsername(),
count: `${banCount} ${client.functions.getNoun(banCount, interaction.translate("misc:NOUNS:WARNS:1"), interaction.translate("misc:NOUNS:WARNS:2"), interaction.translate("misc:NOUNS:WARNS:5"))}`,
}),
});
}
}
if (kickCount) {
if (sanctions >= kickCount) {
member.send({
content: interaction.translate("moderation/kick:KICKED_DM", {
user: member.user,
moderator: interaction.user.getUsername(),
server: interaction.guild.name,
reason,
}),
});
caseInfo.type = "kick";
embed
.setAuthor({
name: interaction.translate("moderation/warn:KICK"),
})
.setColor(client.config.embed.color);
member.kick().catch(() => {});
2023-06-26 17:25:17 +05:00
interaction.followUp({
content: interaction.translate("moderation/setwarns:AUTO_KICK", {
user: member.user.getUsername(),
count: `${kickCount} ${client.functions.getNoun(kickCount, interaction.translate("misc:NOUNS:WARNS:1"), interaction.translate("misc:NOUNS:WARNS:2"), interaction.translate("misc:NOUNS:WARNS:5"))}`,
}),
});
}
} */
try {
await member.send({
content: interaction.translate("moderation/warn:WARNED_DM", {
2024-04-07 20:14:04 +05:00
user: member.toString(),
server: interaction.guild.name,
2024-04-07 20:14:04 +05:00
moderator: interaction.user.toString(),
reason,
}),
});
} catch (e) {
interaction.followUp({ content: interaction.translate("misc:CANT_DM"), ephemeral: true });
}
memberData.sanctions.push(caseInfo);
2023-10-17 08:33:41 +05:00
await memberData.save();
2024-02-09 23:26:57 +05:00
const guildData = interaction.data.guild;
if (guildData.plugins.modlogs) {
const channel = interaction.guild.channels.cache.get(guildData.plugins.modlogs);
if (!channel) return;
channel.send({
embeds: [embed],
});
}
return submitted.reply({
content: interaction.translate("moderation/warn:WARNED", {
user: member.toString(),
reason,
}),
});
}
}
}
module.exports = WarnContext;