const { SlashCommandBuilder, EmbedBuilder } = require('discord.js'); const db = require('../../functions/database/db.js'); module.exports = { category: 'moderation', data: new SlashCommandBuilder() .setName('mysanctions') .setDescription('Voir tes propres sanctions sur ce serveur.'), async execute(interaction) { await interaction.deferReply({ ephemeral: true }); const userId = interaction.user.id; try { const [rows] = await db.query( 'SELECT * FROM logs WHERE userId = ? AND guildId = ? ORDER BY timestamp DESC', [userId, interaction.guild.id] ); if (!rows.length) { return interaction.editReply({ content: '✅ Tu n\'as aucune sanction sur ce serveur.' }); } const { colors } = require('../../utils/constants'); // Découpe les sanctions en pages de 10 const pages = []; for (let i = 0; i < rows.length; i += 10) { pages.push(rows.slice(i, i + 10)); } const embeds = pages.map((page, pageIndex) => { const embed = new EmbedBuilder() .setTitle(`📋 Mes Sanctions - Page ${pageIndex + 1}/${pages.length}`) .setColor(colors.warning) .setThumbnail(interaction.user.displayAvatarURL({ dynamic: true })) .setFooter({ text: `Total: ${rows.length} sanction(s)` }) .setTimestamp(); page.forEach((row, index) => { const date = ``; const actionCapitalized = row.action.charAt(0).toUpperCase() + row.action.slice(1); embed.addFields({ name: `#${index + 1 + pageIndex * 10} - ${actionCapitalized}`, value: `**Modérateur:** <@${row.modId}> (${row.modTag || 'N/A'})\n` + `**Raison:** ${row.reason || 'N/A'}\n` + `**Date:** ${date}\n` + `**Type:** ${row.type || 'N/A'}`, inline: false }); }); return embed; }); // Si une seule page, pas besoin de boutons if (pages.length === 1) { return interaction.editReply({ embeds: [embeds[0]] }); } // Sinon, ajouter les boutons de navigation const { ActionRowBuilder, ButtonBuilder, ButtonStyle } = require('discord.js'); const row = new ActionRowBuilder().addComponents( new ButtonBuilder().setCustomId('prev').setLabel('⬅️ Précédent').setStyle(ButtonStyle.Primary), new ButtonBuilder().setCustomId('next').setLabel('Suivant ➡️').setStyle(ButtonStyle.Primary) ); let currentPage = 0; const message = await interaction.editReply({ embeds: [embeds[currentPage]], components: [row] }); // Collecteur de boutons const collector = message.createMessageComponentCollector({ time: 60_000 }); collector.on('collect', async i => { if (i.user.id !== interaction.user.id) { return i.reply({ content: '❌ Ce n\'est pas ton menu !', ephemeral: true }); } if (i.customId === 'next') { currentPage = (currentPage + 1) % embeds.length; } if (i.customId === 'prev') { currentPage = (currentPage - 1 + embeds.length) % embeds.length; } await i.update({ embeds: [embeds[currentPage]] }); }); collector.on('end', () => { message.edit({ components: [] }).catch(() => null); }); } catch (err) { console.error('Erreur lors de la récupération des sanctions:', err); await interaction.editReply({ content: '❌ Une erreur est survenue lors de la récupération de tes sanctions.' }); } }, };