/[sudobot]/branches/4.x/src/commands/moderation/SendReplyCommand.ts
ViewVC logotype

Contents of /branches/4.x/src/commands/moderation/SendReplyCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months, 1 week ago) by rakinar2
File MIME type: application/typescript
File size: 5847 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, ContextMenuInteraction, Message, MessageActionRow, Modal, ModalSubmitInteraction, NewsChannel, Permissions, TextChannel, TextInputComponent, ThreadChannel, User } from 'discord.js';
21 import BaseCommand from '../../utils/structures/BaseCommand';
22 import DiscordClient from '../../client/Client';
23 import InteractionOptions from '../../types/InteractionOptions';
24 import MessageEmbed from '../../client/MessageEmbed';
25 import { LogLevel } from '../../services/DebugLogger';
26
27 let globalInteraction: CommandInteraction | ContextMenuInteraction;
28 let globalMessage: Message;
29
30 export default class SendReplyCommand extends BaseCommand {
31 supportsContextMenu: boolean = true;
32 supportsInteractions: boolean = true;
33 supportsLegacy: boolean = false;
34 permissions = [Permissions.FLAGS.MANAGE_MESSAGES];
35
36 constructor() {
37 super('reply', 'moderation', ['Send Reply']);
38 }
39
40 async innerRun(interaction: ModalSubmitInteraction) {
41 if (!this.filter(interaction)) {
42 return;
43 }
44
45 try {
46 await (globalMessage.channel as TextChannel).sendTyping();
47 await globalMessage.reply({ content: interaction.fields.getTextInputValue('content') });
48 await interaction.reply({ ephemeral: true, content: "Message sent!" });
49 }
50 catch (e) {
51 console.log(e);
52
53 await interaction.reply({
54 embeds: [
55 new MessageEmbed()
56 .setColor('#f14a60')
57 .setDescription(`Failed to send message. Maybe missing permissions or invalid embed schema?`)
58 ],
59 ephemeral: true
60 });
61
62 return;
63 }
64 }
65
66 filter(i: ModalSubmitInteraction) {
67 return i.user.id === globalInteraction.user.id && i.customId === 'send_reply_modal';
68 }
69
70 async run(client: DiscordClient, interaction: CommandInteraction | ContextMenuInteraction, options: InteractionOptions) {
71 let message: Message;
72
73 if (interaction.isMessageContextMenu()) {
74 globalInteraction = interaction;
75 message = <Message> interaction.targetMessage;
76 globalMessage = message;
77
78 const modal = new Modal()
79 .setCustomId("send_reply_modal")
80 .setTitle("Send Reply")
81 .addComponents(
82 new MessageActionRow<TextInputComponent>()
83 .addComponents(
84 new TextInputComponent()
85 .setCustomId("content")
86 .setLabel("Message Content")
87 .setMinLength(1)
88 .setPlaceholder("Type your message...")
89 .setRequired(true)
90 .setStyle("PARAGRAPH")
91 )
92 );
93
94 await interaction.showModal(modal);
95 }
96 else if (interaction.isCommand()) {
97 const channel = <TextChannel | NewsChannel | ThreadChannel> interaction.options.getChannel("channel") ?? interaction.channel!;
98
99 if (channel.type !== 'GUILD_NEWS' && channel.type !== "GUILD_TEXT" && !channel.type.toString().endsWith('_THREAD')) {
100 await interaction.reply({ content: "You must select a valid text channel, where the bot can send messages.", ephemeral: true });
101 return;
102 }
103
104 await interaction.deferReply({ ephemeral: true });
105
106 try {
107 message = await channel.messages.fetch(interaction.options.getString("message_id", true));
108
109 if (!message) {
110 throw new Error();
111 }
112 }
113 catch (e) {
114 console.log(e);
115
116 await this.deferReply(interaction, {
117 content: "No such message found with the given ID."
118 });
119
120 return;
121 }
122
123 const content = interaction.options.getString("content", true);
124
125 const log = `======== ${(interaction.member!.user as User).tag} (ID: ${(interaction.member!.user as User).id}) executed send reply command (Guild: ${interaction.guildId}) =====`;
126 console.log(log);
127 client.debugLogger.logApp(LogLevel.INFO, log);
128
129 try {
130 await message.reply({ content });
131 await this.deferReply(interaction, {
132 content: "Reply sent!"
133 });
134 }
135 catch (e) {
136 console.log(e);
137
138 await this.deferReply(interaction, {
139 embeds: [
140 new MessageEmbed()
141 .setColor('#f14a60')
142 .setDescription(`Failed to send message. Maybe missing permissions or invalid embed schema?`)
143 ],
144 });
145
146 return;
147 }
148 }
149 }
150 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26