mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-27 06:37:32 +02:00
Role Info, Permissions Stuff
This commit is contained in:
@@ -0,0 +1,50 @@
|
||||
const Command = require('../../structures/Command');
|
||||
const { MessageEmbed } = require('discord.js');
|
||||
const moment = require('moment');
|
||||
const perms = require('../../assets/json/permissions');
|
||||
const { placeholder } = require('../../structures/Util');
|
||||
|
||||
module.exports = class RoleInfoCommand extends Command {
|
||||
constructor(client) {
|
||||
super(client, {
|
||||
name: 'role-info',
|
||||
aliases: ['role'],
|
||||
group: 'guild-info',
|
||||
memberName: 'role-info',
|
||||
description: 'Responds with detailed information on a role.',
|
||||
guildOnly: true,
|
||||
clientPermissions: ['EMBED_LINKS'],
|
||||
args: [
|
||||
{
|
||||
key: 'role',
|
||||
prompt: 'Which role would you like to get info on?',
|
||||
type: 'role'
|
||||
}
|
||||
]
|
||||
});
|
||||
}
|
||||
|
||||
run(msg, args) {
|
||||
const { role } = args;
|
||||
const embed = new MessageEmbed()
|
||||
.setColor(role.hexColor)
|
||||
.setThumbnail(placeholder({ color: role.hexColor.replace('#', '') }))
|
||||
.addField('❯ Name',
|
||||
role.name, true)
|
||||
.addField('❯ ID',
|
||||
role.id, true)
|
||||
.addField('❯ Creation Date',
|
||||
moment(role.createdAt).format('MMMM Do YYYY'), true)
|
||||
.addField('❯ Color',
|
||||
role.hexColor.toUpperCase(), true)
|
||||
.addField('❯ Hoisted',
|
||||
role.hoist ? 'Yes' : 'No', true)
|
||||
.addField('❯ Mentionable',
|
||||
role.mentionable ? 'Yes' : 'No', true)
|
||||
.addField('❯ Position',
|
||||
msg.guild.roles.size - role.calculatedPosition, true)
|
||||
.addField('❯ Permissions',
|
||||
Object.keys(role.serialize()).filter((perm) => role.serialize()[perm]).map((perm) => perms[perm]));
|
||||
return msg.embed(embed);
|
||||
}
|
||||
};
|
||||
Reference in New Issue
Block a user