'use strict';
const Discord = require('discord.js');
// eslint-disable-next-line no-unused-vars
const Typings = require('../typings');
const { dateTimeGroup } = require('../modules');
const { findGuildConfiguration, sendMsg } = require('../handlers');
/**
* @member {events.EventModule} events.onRoleInteraction Event handler to log whenever a \<Role> is created/deleted
*/
/**
* @type {Typings.EventModule}
*/
module.exports = {
bot: ['roleCreate', 'roleDelete'],
process: [],
/**
* @param {'roleCreate' | 'roleDelete'} event The event that was emitted
* @param {Discord.Role} role The \<Role> that was created/deleted
*/
async handler(event, role) {
const { bot } = require('../pronto');
const { ids: { logId }, colours } = await findGuildConfiguration(role.guild);
// Create log embed
const logEmbed = new Discord.MessageEmbed()
.setAuthor(role.guild.name, role.guild.iconURL({ dynamic: true }))
// Set colour and description dynamically, depending on the emitted event
.setColor((event === 'roleCreate') ? colours.success : colours.error)
.setDescription(`**Role ${(event === 'roleCreate') ? 'Created' : 'Deleted'}: ${role.name}**`)
.setFooter(`Id: ${role.id} | ${await dateTimeGroup(role.guild)}`);
// Get the guild's log channel and send the log embed
const logChannel = bot.channels.cache.get(logId);
sendMsg(logChannel, { embeds: [logEmbed] });
},
};
source