grand commit que tutur attend ( marche pas le raidmode en dev)

sinon il y a pleins de truc comme les anti raid , des coorectif ect
This commit is contained in:
VALOU3336
2024-04-22 18:30:33 +02:00
parent d8912855ff
commit 9bd39c69ca
178 changed files with 9241 additions and 480 deletions
+45 -23
View File
@@ -9,25 +9,28 @@ module.exports = {
async execute(message) {
try {
const bans = await message.guild.bans.fetch();
const bansArray = Array.from(bans.values());
const embeds = [];
const maxPerPage = 10;
let currentPage = 0;
const maxPerPage = 15;
let index = 0;
for (let i = 0; i < bans.size; i += maxPerPage) {
for (let i = 0; i < bansArray.length; i += maxPerPage) {
const page = bansArray.slice(i, i + maxPerPage).map((ban) => {
const reason = ban.reason || 'Raison non disponible';
const entry = `**${index + 1}.** ${ban.user.tag} - **Raison: **\`${reason}\``;
index++;
return entry;
}).join('\n');
const embed = new EmbedBuilder()
.setTitle('Liste des utilisateurs bannis')
.setDescription(page)
.setColor('#ff0000');
bans.each((ban, index) => {
if (index >= i && index < i + maxPerPage) {
const reason = ban.reason || 'Raison non disponible';
embed.addFields({ name: ban.user.tag, value: `Raison: ${reason}` });
}
});
embeds.push(embed);
}
embeds.push(embed);
}
let currentPage = 0;
const row = new ActionRowBuilder()
.addComponents(
@@ -41,27 +44,46 @@ module.exports = {
.setStyle(ButtonStyle.Primary)
);
await message.channel.send({ embeds: [embeds[currentPage]], components: [row] });
const sentMessage = await message.channel.send({ embeds: [embeds[currentPage]], components: [row] });
const filter = i => i.customId === 'previous' || i.customId === 'next' && i.user.id === message.author.id;
const collector = message.channel.createMessageComponentCollector({ filter, time: 60000 });
const collector = sentMessage.createMessageComponentCollector({ filter, time: 60000 });
collector.on('collect', async i => {
if (i.customId === 'previous') {
currentPage = Math.max(currentPage - 1, 0);
currentPage--;
} else if (i.customId === 'next') {
currentPage = Math.min(currentPage + 1, embeds.length - 1);
currentPage++;
}
await i.update({ embeds: [embeds[currentPage]], components: [row] });
if (currentPage < 0) {
currentPage = 0;
} else if (currentPage >= embeds.length) {
currentPage = embeds.length - 1;
}
const newEmbed = embeds[currentPage];
const backButton = new ButtonBuilder()
.setCustomId('previous')
.setLabel('Précédent')
.setStyle(ButtonStyle.Primary);
const nextButton = new ButtonBuilder()
.setCustomId('next')
.setLabel('Suivant')
.setStyle(ButtonStyle.Primary);
const row = new ActionRowBuilder()
.addComponents(backButton, nextButton);
await i.update({ embeds: [newEmbed], components: [row] });
});
collector.on('end', collected => {
message.channel.send('Navigation terminée.');
sentMessage.edit({ components: [] });
});
} catch (error) {
console.error('Erreur lors de la récupération des utilisateurs bannis:', error);
message.reply('Une erreur est survenue lors de la récupération des utilisateurs bannis.');
}
},
};
};