Files
LazyBot/app/commands/avatar.js
T
2026-01-17 23:07:54 +01:00

100 lines
4.6 KiB
JavaScript

const addCommand = require("../fonctions/addCommand");
const { EmbedBuilder } = require("discord.js");
module.exports = addCommand({
name: "avatar",
description: "Affiche l'avatar d'un utilisateur.",
aliases: ["av", "pp", "pdp", "pfp"],
permissions: [],
botOwnerOnly: false,
dm: false,
scope: "global",
slashOptions: [
{
type: "USER",
name: "utilisateur",
description: "L'utilisateur dont vous voulez voir l'avatar",
required: false,
},
],
executePrefix: async (client, message, args) => {
const user = message.mentions.users.first() || (args[0] ? await client.users.fetch(args[0]).catch(() => null) : null) || message.author;
const member = message.guild.members.cache.get(user.id);
await sendAvatarEmbed(message, user, member, message.author);
},
executeSlash: async (client, interaction) => {
const user = interaction.options.getUser("utilisateur") || interaction.user;
const member = interaction.guild.members.cache.get(user.id);
await sendAvatarEmbedSlash(interaction, user, member);
},
});
async function sendAvatarEmbed(message, user, member, requestedBy) {
const globalAvatar = user.displayAvatarURL({ dynamic: true, size: 4096 });
const serverAvatar = member?.displayAvatarURL({ dynamic: true, size: 4096 });
const embed = new EmbedBuilder()
.setColor(0x5865F2)
.setTitle(`🖼️ Avatar de ${user.username}`)
.setImage(globalAvatar)
.addFields(
{ name: "🔗 Liens", value: `[PNG](${user.displayAvatarURL({ extension: "png", size: 4096 })}) • [JPG](${user.displayAvatarURL({ extension: "jpg", size: 4096 })}) • [WEBP](${user.displayAvatarURL({ extension: "webp", size: 4096 })})${user.avatar?.startsWith("a_") ? ` • [GIF](${user.displayAvatarURL({ extension: "gif", size: 4096 })})` : ""}`, inline: false }
)
.setFooter({ text: `Demandé par ${requestedBy.username}`, iconURL: requestedBy.displayAvatarURL({ dynamic: true }) })
.setTimestamp();
if (serverAvatar && serverAvatar !== globalAvatar) {
embed.setDescription("**Avatar global** (avatar de serveur ci-dessous)");
}
await message.reply({ embeds: [embed] });
if (serverAvatar && serverAvatar !== globalAvatar) {
const serverEmbed = new EmbedBuilder()
.setColor(0x5865F2)
.setTitle(`🖼️ Avatar serveur de ${user.username}`)
.setImage(serverAvatar)
.addFields(
{ name: "🔗 Liens", value: `[PNG](${member.displayAvatarURL({ extension: "png", size: 4096 })}) • [JPG](${member.displayAvatarURL({ extension: "jpg", size: 4096 })}) • [WEBP](${member.displayAvatarURL({ extension: "webp", size: 4096 })})${member.avatar?.startsWith("a_") ? ` • [GIF](${member.displayAvatarURL({ extension: "gif", size: 4096 })})` : ""}`, inline: false }
);
await message.channel.send({ embeds: [serverEmbed] });
}
}
async function sendAvatarEmbedSlash(interaction, user, member) {
const globalAvatar = user.displayAvatarURL({ dynamic: true, size: 4096 });
const serverAvatar = member?.displayAvatarURL({ dynamic: true, size: 4096 });
const embed = new EmbedBuilder()
.setColor(0x5865F2)
.setTitle(`🖼️ Avatar de ${user.username}`)
.setImage(globalAvatar)
.addFields(
{ name: "🔗 Liens", value: `[PNG](${user.displayAvatarURL({ extension: "png", size: 4096 })}) • [JPG](${user.displayAvatarURL({ extension: "jpg", size: 4096 })}) • [WEBP](${user.displayAvatarURL({ extension: "webp", size: 4096 })})${user.avatar?.startsWith("a_") ? ` • [GIF](${user.displayAvatarURL({ extension: "gif", size: 4096 })})` : ""}`, inline: false }
)
.setFooter({ text: `Demandé par ${interaction.user.username}`, iconURL: interaction.user.displayAvatarURL({ dynamic: true }) })
.setTimestamp();
if (serverAvatar && serverAvatar !== globalAvatar) {
embed.setDescription("**Avatar global** (avatar de serveur ci-dessous)");
}
await interaction.reply({ embeds: [embed] });
if (serverAvatar && serverAvatar !== globalAvatar) {
const serverEmbed = new EmbedBuilder()
.setColor(0x5865F2)
.setTitle(`🖼️ Avatar serveur de ${user.username}`)
.setImage(serverAvatar)
.addFields(
{ name: "🔗 Liens", value: `[PNG](${member.displayAvatarURL({ extension: "png", size: 4096 })}) • [JPG](${member.displayAvatarURL({ extension: "jpg", size: 4096 })}) • [WEBP](${member.displayAvatarURL({ extension: "webp", size: 4096 })})${member.avatar?.startsWith("a_") ? ` • [GIF](${member.displayAvatarURL({ extension: "gif", size: 4096 })})` : ""}`, inline: false }
);
await interaction.followUp({ embeds: [serverEmbed] });
}
}