/[sudobot]/branches/3.x/src/commands/information/EmojiCommand.ts
ViewVC logotype

Contents of /branches/3.x/src/commands/information/EmojiCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months ago) by rakinar2
File MIME type: application/typescript
File size: 5203 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
1 /**
2 * This file is part of SudoBot.
3 *
4 * Copyright (C) 2021-2022 OSN Inc.
5 *
6 * SudoBot is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU Affero General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * SudoBot is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Affero General Public License for more details.
15 *
16 * You should have received a copy of the GNU Affero General Public License
17 * along with SudoBot. If not, see <https://www.gnu.org/licenses/>.
18 */
19
20 import { CommandInteraction, Message, Util } from 'discord.js';
21 import BaseCommand from '../../utils/structures/BaseCommand';
22 import DiscordClient from '../../client/Client';
23 import CommandOptions from '../../types/CommandOptions';
24 import InteractionOptions from '../../types/InteractionOptions';
25 import { timeSince } from '../../utils/util';
26 import MessageEmbed from '../../client/MessageEmbed';
27
28 export default class EmojiCommand extends BaseCommand {
29 supportsInteractions: boolean = true;
30
31 constructor() {
32 super('emoji', 'information', []);
33 }
34
35 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
36 if (!options.isInteraction && options.args[0] === undefined) {
37 await msg.reply({
38 embeds: [
39 new MessageEmbed()
40 .setColor('#f14a60')
41 .setDescription(':x: This command requires at least one argument.')
42 ]
43 });
44
45 return;
46 }
47
48 let emojiString: string;
49
50 if (options.isInteraction) {
51 emojiString = await <string> options.options.getString('emoji');
52 }
53 else {
54 emojiString = options.args[0];
55 }
56
57 const emojiSubString = emojiString.startsWith('<:') && emojiString.endsWith('>') ? emojiString.substring(2, emojiString.length - 1) : emojiString;
58
59 let emoji = await client.emojis.cache.find(e => e.name === emojiSubString || e.identifier === emojiSubString || e.id === emojiSubString);
60
61 if (!emoji) {
62 if ((emojiString.startsWith('<:') && emojiString.endsWith('>')) || /\d+/g.test(emojiString)) {
63 let parsedEmoji = emojiString.startsWith('<:') && emojiString.endsWith('>') ? Util.parseEmoji(emojiString) : { animated: undefined, id: emojiString, name: undefined };
64
65 if (!parsedEmoji) {
66 await msg.reply({
67 embeds: [
68 new MessageEmbed()
69 .setColor('#f14a60')
70 .setDescription('Invalid emoji!')
71 ]
72 });
73
74 return;
75 }
76
77 await msg.reply({
78 embeds: [
79 new MessageEmbed()
80 .setAuthor({
81 name: parsedEmoji.name ?? "Unknown Emoji",
82 iconURL: `https://cdn.discordapp.com/emojis/${parsedEmoji.id}`,
83 })
84 .setFields({
85 name: "Animated",
86 value: parsedEmoji.animated !== undefined ? parsedEmoji.animated ? 'Yes' : 'No' : "*The system could not load enough information*",
87 }, {
88 name: "Download",
89 value: `[Click Here](https://cdn.discordapp.com/emojis/${parsedEmoji.id})`
90 })
91 .setThumbnail(`https://cdn.discordapp.com/emojis/${parsedEmoji.id}`)
92 .setFooter({
93 text: `ID: ${parsedEmoji.id}`
94 })
95 ]
96 });
97 }
98 else {
99 await msg.reply({
100 embeds: [
101 new MessageEmbed()
102 .setColor('#f14a60')
103 .setDescription('No emoji found or not a guild based emoji!')
104 ]
105 });
106 }
107
108 return;
109 }
110
111 await msg.reply({
112 embeds: [
113 new MessageEmbed()
114 .setAuthor({
115 name: emoji.guild.name,
116 iconURL: emoji.guild.iconURL()!,
117 })
118 .setTitle(emoji.name ?? 'Emoji Information')
119 .addField('Name', emoji.name ?? '*No name set*')
120 .addField('Identifier', emoji.identifier ?? '*No identifier set*')
121 .addField('Available', emoji.available ? 'Yes' : 'No')
122 .addField('Created', timeSince(emoji.createdAt.getTime()))
123 .addField('Download', `[Click here](${emoji.url})`)
124 .setThumbnail(emoji.url)
125 .setFooter({
126 text: `ID: ${emoji.id}`
127 })
128 ]
129 });
130 }
131 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26