This commit is contained in:
2026-03-15 12:22:42 +01:00
parent cd99275933
commit 311ba5e7f3
558 changed files with 55182 additions and 22981 deletions

View File

@@ -1,91 +1,70 @@
const { SlashCommandBuilder, EmbedBuilder } = require('discord.js');
const { colors, emojis } = require('../../utils/constants');
function getStatusFrench(presence) {
if (!presence || !presence.status) return { text: 'Hors ligne', emoji: '⚫' };
switch (presence.status) {
case 'online': return { text: 'En ligne', emoji: '🟢' };
case 'idle': return { text: 'Absent', emoji: '🟡' };
case 'dnd': return { text: 'Ne pas déranger', emoji: '🔴' };
default: return { text: 'Hors ligne', emoji: '⚫' };
}
}
module.exports = {
category: 'info',
data: new SlashCommandBuilder()
.setName('userinfo')
.setDescription('Affiche les informations d\'un utilisateur.')
.addUserOption(option =>
option.setName('user')
.setDescription('L\'utilisateur dont tu veux voir les informations')
.setRequired(false)),
async execute(interaction) {
const target = interaction.options.getUser('user') || interaction.user;
const member = await interaction.guild.members.fetch(target.id).catch(() => null);
category: 'info',
data: new SlashCommandBuilder()
.setName('userinfo')
.setDescription('Affiche les informations d\'un utilisateur.')
.addUserOption(option =>
option.setName('user')
.setDescription('L\'utilisateur dont tu veux voir les informations')
.setRequired(false)),
async execute(interaction) {
const target = interaction.options.getUser('user') || interaction.user;
const member = await interaction.guild.members.fetch(target.id).catch(() => null);
const { colors, emojis } = require('../../utils/constants');
const embed = new EmbedBuilder()
.setAuthor({
name: `${target.displayName}`,
iconURL: target.displayAvatarURL({ dynamic: true })
})
.setTitle(`${emojis.user} Informations Utilisateur`)
.setColor(colors.info)
.setThumbnail(target.displayAvatarURL({ dynamic: true, size: 256 }))
.addFields(
{ name: `${emojis.id} ID`, value: `\`${target.id}\``, inline: true },
{ name: `${emojis.calendar} Compte créé`, value: `<t:${Math.floor(target.createdTimestamp / 1000)}:F>`, inline: true },
{ name: '🤖 Bot', value: target.bot ? '`Oui`' : '`Non`', inline: true }
)
.setFooter({ text: `${interaction.guild.name}${interaction.client.user.username}`, iconURL: interaction.client.user.displayAvatarURL() })
.setTimestamp();
const embed = new EmbedBuilder()
.setAuthor({
name: target.displayName,
iconURL: target.displayAvatarURL({ dynamic: true })
})
.setTitle(`${emojis.user} Informations Utilisateur`)
.setColor(colors.info)
.setThumbnail(target.displayAvatarURL({ dynamic: true, size: 256 }))
.addFields(
{ name: `${emojis.id} ID`, value: `\`${target.id}\``, inline: true },
{ name: `${emojis.calendar} Compte créé`, value: `<t:${Math.floor(target.createdTimestamp / 1000)}:F>`, inline: true },
{ name: '🤖 Bot', value: target.bot ? '`Oui`' : '`Non`', inline: true }
)
.setFooter({ text: `${interaction.guild.name}${interaction.client.user.username}`, iconURL: interaction.client.user.displayAvatarURL() })
.setTimestamp();
if (member) {
// Récupérer le statut avec gestion des différents cas
let status = 'Hors ligne';
let statusEmoji = '';
if (member.presence) {
const presenceStatus = member.presence.status;
switch (presenceStatus) {
case 'online':
status = 'En ligne';
statusEmoji = '🟢';
break;
case 'idle':
status = 'Inactif';
statusEmoji = '🟡';
break;
case 'dnd':
status = 'Ne pas déranger';
statusEmoji = '🔴';
break;
case 'invisible':
status = 'Invisible';
statusEmoji = '⚫';
break;
case 'offline':
status = 'Hors ligne';
statusEmoji = '⚫';
break;
default:
status = 'Inconnu';
statusEmoji = '⚪';
}
}
if (member) {
const status = getStatusFrench(member.presence);
const roles = member.roles.cache.filter(r => r.id !== interaction.guild.id);
const rolesDisplay = roles.size > 0 ? roles.sort((a, b) => b.position - a.position).map(r => r.toString()).slice(0, 10).join(', ') : '`Aucun`';
embed.addFields(
{ name: '📥 A rejoint le', value: `<t:${Math.floor(member.joinedTimestamp / 1000)}:F>`, inline: true },
{ name: '⏰ Statut', value: `${statusEmoji} \`${status}\``, inline: true },
{ name: '👑 Rôle le plus élevé', value: member.roles.highest.toString(), inline: true },
{ name: '🎭 Rôles', value: member.roles.cache.size > 1 ? member.roles.cache.filter(r => r.id !== interaction.guild.id).map(r => r.toString()).slice(0, 10).join(', ') || '`Aucun`' : '`Aucun`', inline: false }
);
embed.addFields(
{ name: '📥 A rejoint le', value: `<t:${Math.floor(member.joinedTimestamp / 1000)}:F>`, inline: true },
{ name: '⏰ Statut', value: `${status.emoji} \`${status.text}\``, inline: true },
{ name: '👑 Rôle le plus élevé', value: member.roles.highest.toString(), inline: true },
{ name: '🎭 Rôles', value: rolesDisplay, inline: false }
);
if (member.nickname) {
embed.addFields({ name: '📝 Surnom', value: `\`${member.nickname}\``, inline: true });
}
if (member.nickname) {
embed.addFields({ name: '📝 Surnom', value: `\`${member.nickname}\``, inline: true });
}
if (member.roles.cache.size > 11) {
embed.addFields({ name: '📊 Total de rôles', value: `\`${member.roles.cache.size - 1}\``, inline: true });
}
}
if (roles.size > 10) {
embed.addFields({ name: '📊 Total de rôles', value: `\`${roles.size}\``, inline: true });
}
}
if (target.banner) {
embed.setImage(target.bannerURL({ dynamic: true, size: 1024 }));
}
await interaction.reply({ embeds: [embed] });
},
};
if (target.banner) {
embed.setImage(target.bannerURL({ dynamic: true, size: 1024 }));
}
await interaction.reply({ embeds: [embed] });
},
};