const { EmbedBuilder, StringSelectMenuBuilder, ActionRowBuilder } = require("discord.js") module.exports = { name: 'help', description: 'Affiche la liste des commandes', category: 'other', emote: '📚', utilisation: '', async execute(message, args, client) { const categories = { antiraid: [], botcontrol: [], game: [], gestion: [], utils: [], other: [], // Ajoutez plus de catégories si nécessaire }; // Organisez les commandes par catégorie for (const command of client.commands.values()) { if (command.category) { categories[command.category].push({ name: command.name, description: command.description, emote: command.emote, utilisation: command.utilisation}); } } let description = 'Sélectionnez une catégorie parmi les options ci-dessous pour obtenir de l\'aide sur les commandes correspondantes.\n\n'; for (const [category, commands] of Object.entries(categories)) { description += `**Catégorie ${category}**\n`; description += commands.length > 0 ? '> ' + commands.map(command => `\`${command.name}\``).join(', ') : '> Aucune commande dans cette catégorie'; description += '\n\n'; } const embeds = { home: new EmbedBuilder() .setColor('#0099ff') .setTitle('📚 Information') .setDescription(description) .setThumbnail(message.guild.iconURL()) }; // Créez un embed pour chaque catégorie for (const [category, commands] of Object.entries(categories)) { let description; if (commands.length > 0) { description = commands.map(command => `${command.emote ? ` ${command.emote}` : '🔧'} \`+${command.name}${command.utilisation ? ` ${command.utilisation}` : ''}\`\n ${command.description}`).join('\n'); } else { description = 'Aucune commande dans cette catégorie.'; } embeds[category] = new EmbedBuilder() .setColor('#0099ff') .setTitle(`Catégorie ${category}`) .setDescription(description); } const menu = new StringSelectMenuBuilder() .setCustomId('help_menu') .setPlaceholder('Sélectionnez une catégorie') .addOptions([ { label: 'Accueil', value: 'home' }, ...Object.keys(categories).map(category => ({ label: `Catégorie ${category}`, value: category })), ]); const row = new ActionRowBuilder() .addComponents(menu); const sentMessage = await message.reply({ embeds: [embeds.home], components: [row] }); const filter = i => i.customId === 'help_menu' && i.user.id === message.author.id; const collector = sentMessage.createMessageComponentCollector({ filter, time: 15000 }); collector.on('collect', async (interaction) => { await interaction.update({ embeds: [embeds[interaction.values[0]]] }); }); collector.on('end', () => { sentMessage.edit({ components: [] }); }); }, };