/[sudobot]/branches/3.x/src/commands/moderation/EchoCommand.ts
ViewVC logotype

Contents of /branches/3.x/src/commands/moderation/EchoCommand.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: 4159 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, EmojiIdentifierResolvable, FileOptions, Message, TextChannel } 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 MessageEmbed from '../../client/MessageEmbed';
26 import { fetchEmoji } from '../../utils/Emoji';
27 import { parseEmbedsInString } from '../../utils/util';
28
29 export default class EchoCommand extends BaseCommand {
30 supportsInteractions: boolean = true;
31
32 constructor() {
33 super('echo', 'moderation', []);
34 }
35
36 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
37 if (!options.isInteraction && typeof options.args[0] === 'undefined') {
38 await msg.reply({
39 embeds: [
40 new MessageEmbed()
41 .setColor('#f14a60')
42 .setDescription(`This command requires at least one argument.`)
43 ]
44 });
45
46 return;
47 }
48
49 let content: string;
50 let channel: TextChannel = <TextChannel> msg.channel;
51
52 if (options.isInteraction) {
53 content = await <string> options.options.getString('content');
54
55 if (options.options.getChannel('channel')) {
56 channel = await <TextChannel> options.options.getChannel('channel');
57 }
58 }
59 else {
60 if ((msg as Message).mentions.channels.last()) {
61 channel = await <TextChannel> (msg as Message).mentions.channels.last();
62 await options.args.pop();
63 }
64
65 content = await options.args.join(' ');
66 }
67
68 if (!channel.send) {
69 await msg.reply({
70 content: 'Invalid text channel.',
71 ephemeral: true
72 });
73
74 return;
75 }
76
77 try {
78 let { embeds, content: parsedContent } = parseEmbedsInString(content);
79
80 await channel.send({
81 content: parsedContent.trim() === '' ? undefined : parsedContent,
82 embeds,
83 files: msg instanceof CommandInteraction ? undefined : [...msg.attachments.map(a => ({
84 attachment: a.proxyURL,
85 description: a.description,
86 name: a.name
87 } as FileOptions)).values()]
88 });
89
90 if (options.isInteraction) {
91 const emoji = await fetchEmoji('check');
92
93 console.log(emoji);
94
95 await msg.reply({
96 content: emoji!.toString() + " Message sent!",
97 ephemeral: true
98 });
99 }
100 else {
101 await (msg as Message).react(await fetchEmoji('check') as EmojiIdentifierResolvable);
102 }
103 }
104 catch (e) {
105 console.log(e);
106
107 await msg.reply({
108 embeds: [
109 new MessageEmbed()
110 .setColor('#f14a60')
111 .setDescription(`Failed to send message. Maybe missing permissions or invalid embed schema?`)
112 ],
113 ephemeral: true
114 });
115
116 return;
117 }
118 }
119 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26