2022-11-11 09:27:12 +01:00
const { EmbedBuilder , SlashCommandBuilder } = require ( 'discord.js' ) ;
2022-11-09 14:44:05 +01:00
module . exports = {
data : new SlashCommandBuilder ( )
. setName ( 'info' )
. setDescription ( 'Obtenir des informations diverses.' )
. addSubcommand ( subcommand =>
subcommand
. setName ( 'user' )
. setDescription ( 'Obtenir des informations sur un utilisateur.' )
. addUserOption ( option =>
option . setName ( 'target' )
. setDescription ( 'Utilisateur ciblé' )
. setRequired ( true ) ) )
. addSubcommand ( subcommand =>
subcommand
. setName ( 'server' )
. setDescription ( 'Obtenir des informations sur le serveur.' ) )
. addSubcommand ( subcommand =>
subcommand
. setName ( 'april' )
. setDescription ( 'Obtenir des informations sur April' ) ) ,
async execute ( interaction , client ) {
switch ( interaction . options . getSubcommand ( ) ) {
case 'user' :
const user = interaction . options . getUser ( 'target' ) ;
const member = interaction . options . getMember ( 'target' ) //interaction.guild.members.cache.get(user.id);
const embedUSERINFO = new EmbedBuilder ( )
if ( user ) {
embedUSERINFO
. setAuthor ( {
name : user . tag ,
iconURL : user . avatarURL ( )
} )
. setColor ( "Blurple" )
. setThumbnail ( user . avatarURL ( ) )
. setDescription ( ` <@ ${ user . id } > ` )
. addFields ( [
{
name : "👤 Informations sur le compte" ,
value : ` `
+ ` <:invisibleSpacer:1038116840360120360><:iconID:1038063974807261195> **ID:** ${ user . id } \n `
+ ` <:invisibleSpacer:1038116840360120360><:iconProfile:1038064029064773724> **Nom complet:** ${ user . tag } \n `
+ ` <:invisibleSpacer:1038116840360120360><:iconTimer:1038063915151654932> **Créé:** <t: ${ Math . floor ( user . createdTimestamp / 1000 ) } :d> `
,
inline : false
}
] ) ;
if ( member ) {
embedUSERINFO . addFields ( [
{
name : "📋 Information sur le membre" ,
value :
` <:invisibleSpacer:1038116840360120360><:iconTimer:1038063915151654932> **A rejoint le serveur:** <t: ${ member . user . id == "697438073646088194" ? "1604430645" : Math . floor ( member . joinedTimestamp / 1000 ) } :R> \n `
+ ` <:invisibleSpacer:1038116840360120360><:iconProfile:1038064029064773724> **Nickname:** ${ member . nickname || ` Aucun ` } \n `
+ ` <:invisibleSpacer:1038116840360120360><:IconAnnouncement:1038063917026508881> **Plus haut rôle:** ${ member . roles . hoist ? member . roles . hoist . name : "Aucun" } `
,
inline : false
} ,
{
name : ` 📝 Rôles [ ${ member . roles . cache . size - 1 } ] ` ,
value : member . roles . cache . size ? member . roles . cache . map ( roles => ` ** ${ roles } ** ` ) . slice ( 0 , 20 ) . join ( " " ) : "None" ,
inline : false
} ] )
}
} else {
embedUSERINFO . setDescription ( "Utilisateur inconnu" )
}
await interaction . reply ( {
embeds : [ embedUSERINFO ] ,
ephemeral : false
} ) ;
break ;
case 'server' :
const owner = await interaction . guild . fetchOwner ( ) ;
let openticketqty = 0 ;
interaction . guild . channels . cache . forEach ( element => {
if ( element . name . includes ( "bénévole" ) || element . name . includes ( "rémunéné" ) ) openticketqty ++ ;
} ) ;
let takenticketsqty = 0 ;
interaction . guild . channels . cache . forEach ( element => {
if ( ( element . name . includes ( "bénévole" ) && ! element . name . startsWith ( "bénévole" ) ) || ( element . name . includes ( "rémunéré" ) && ! element . name . startsWith ( "rémunéré" ) ) ) takenticketsqty ++ ;
} ) ;
const embedSERVINFO = new EmbedBuilder ( )
. setAuthor ( {
name : interaction . guild . name
} )
. setColor ( "Blurple" )
. setThumbnail ( interaction . guild . iconURL ( ) )
. addFields (
{
name : ` Propriétaire ` ,
value : ` <@ ${ owner . user . id } > ` ,
inline : true
} ,
{
name : ` Date de création du serveur ` ,
value : ` <t: ${ Math . floor ( interaction . guild . createdAt / 1000 ) } :d> ` ,
inline : true
} ,
{
name : ` ID du serveur ` ,
value : ` ${ interaction . guild . id } ` ,
inline : false
} ,
{
name : ` Nombre total de membres ` ,
value : ` ${ interaction . guild . memberCount } ` ,
inline : true
} ,
{
name : "Nombre de salons" ,
value : ` ${ interaction . guild . channels . cache . size } ` ,
inline : true
} ,
{
name : "Tickets" ,
value : ` **Ouverts** : ${ openticketqty } \n **Pris en charge** : ${ takenticketsqty } ` ,
inline : true
}
)
await interaction . reply ( {
embeds : [ embedSERVINFO ] ,
ephemeral : false
} ) ;
break ;
case 'april' :
const embedBOTINFO = new EmbedBuilder ( )
. setAuthor ( {
name : "April"
} )
. setColor ( "Blurple" )
. setThumbnail ( "https://media.discordapp.net/attachments/867491241491038209/987292546180984832/april-welcome.png" )
. setDescription ( "Euh oui voilà april da best je ferais un description un jour :3" )
await interaction . reply ( {
embeds : [ embedBOTINFO ] ,
ephemeral : false
} )
break ;
}
}
2023-01-08 17:48:17 +01:00
} ;