Konpeki-Discord-Bot/commands/avatar.js

70 lines
2.4 KiB
JavaScript
Raw Normal View History

2022-12-15 13:07:35 -06:00
/*
* Konpeki Shiho - Slash Command Definition File
* avatar.js - A primative Discord avatar grabbing function
*
* Todo: Allow users to choose between the sizes as an optional dropdown
* Todo: Allow users to choose if they want to avatar to be ephemeral or sent in the channel
*/
const { SlashCommandBuilder } = require('discord.js');
module.exports = {
data: new SlashCommandBuilder()
.setName('avatar')
.setDescription('Shares a users current avatar')
// Optional user selection for avatar target; target selves if none.
.addUserOption(option =>
option.setName('user')
.setDescription('The user to get the avatar from'))
// Optional choice for user to choose avatar size; 4096 if no selection.
.addStringOption(option =>
option.setName('format')
.setDescription('The gif category')
.addChoices(
{ name: '4096px', value: '4096' },
{ name: '2048px', value: '2048' },
{ name: '1024px', value: '1024' },
{ name: '600px', value: '600' },
{ name: '512px', value: '512' },
{ name: '300px', value: '300' },
{ name: '256px', value: '256' },
{ name: '128px', value: '128' },
{ name: '96px', value: '96' },
{ name: '64px', value: '64' },
{ name: '56px', value: '56' },
{ name: '32px', value: '32' },
{ name: '16px', value: '16' },
))
// Optional choice for user to choose avatar format; webp if no selection.
.addStringOption(option =>
option.setName('size')
.setDescription('The gif category')
.addChoices(
{ name: 'WebP', value: 'webp' },
{ name: 'PNG', value: 'png' },
{ name: 'JPEG', value: 'jpg' },
))
// Optional Ephemeral check to allow user to choose command results to be shared publicly or private; send to self only if no selection.
.addStringOption(option =>
option.setName('ephemeral')
.setDescription('Post the avatar in the current channel')
.addChoices(
{ name: 'Send to me only', value: 'true' },
{ name: 'Send in channel', value: 'false' },
)),
async execute(interaction) {
const discordUser = interaction.options.getUser('user') ?? interaction.user;
const avatarFormat = interaction.options.getString('format') ?? 'webp';
const avatarSize = interaction.options.getString('size') ?? 4096;
const isEphemeral = interaction.options.getString('ephemeral') ?? true;
await interaction.reply({ content: `${discordUser.avatarURL({ format:avatarFormat, size:avatarSize, dynamic:true })}`, ephemeral: isEphemeral });
},
};