/[sudobot]/branches/8.x/src/commands/automation/BallotCreateCommand.ts
ViewVC logotype

Contents of /branches/8.x/src/commands/automation/BallotCreateCommand.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: 6001 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-2023 OSN Developers.
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 {
21 ActionRowBuilder,
22 ButtonBuilder,
23 ButtonStyle,
24 ChannelType,
25 Message,
26 User
27 } from "discord.js";
28 import Command, { BasicCommandContext, CommandMessage, CommandReturn } from "../../core/Command";
29 import { logError } from "../../utils/Logger";
30 import { getComponentEmojiResolvable, isTextableChannel } from "../../utils/utils";
31
32 export default class BallotCreateCommand extends Command {
33 public readonly name = "ballot__create";
34 public readonly permissions = [];
35 public readonly description = "Sends a poll/ballot embed.";
36 public readonly supportsInteractions: boolean = true;
37 public readonly supportsLegacy: boolean = true;
38
39 async execute(message: CommandMessage, context: BasicCommandContext): Promise<CommandReturn> {
40 if (context.isLegacy && context.args[0] === undefined) {
41 await this.error(message, "Please provide the content to put inside the ballot/poll!");
42 return;
43 }
44
45 await this.deferIfInteraction(message, { ephemeral: true });
46
47 const content = context.isLegacy
48 ? (message as Message).content
49 .substring(
50 this.client.configManager.config[message.guildId!]?.prefix?.length ?? 1
51 )
52 .trimStart()
53 .substring(context.argv[0] === "ballot" ? "ballot".length : 0)
54 .trimStart()
55 .substring(
56 context.argv[0] === "ballot"
57 ? this.name.replace("ballot__", "").length
58 : context.argv[0].length
59 )
60 .trim()
61 : context.options.getString("content", true);
62
63 const anonymous =
64 (context.isLegacy ? null : context.options.getBoolean("anonymous")) ?? false;
65 const channel =
66 (context.isLegacy
67 ? null
68 : context.options.getChannel<ChannelType.GuildText>("channel")) ?? message.channel!;
69
70 if (!isTextableChannel(channel)) {
71 await this.error(message, "Cannot send messages into a non-text based channel!");
72 return;
73 }
74
75 try {
76 const ballotMessage = await channel.send({
77 embeds: [
78 {
79 author: {
80 icon_url: anonymous
81 ? message.guild?.iconURL() ?? undefined
82 : (message.member?.user as User).displayAvatarURL(),
83 name: anonymous ? "Staff" : message.member!.user.username
84 },
85 color: 0x007bff,
86 description: content,
87 footer: {
88 text: "0 Votes • React to vote!"
89 }
90 }
91 ],
92 files:
93 message instanceof Message
94 ? message.attachments.map(({ name, proxyURL }) => ({
95 name,
96 attachment: proxyURL
97 }))
98 : undefined,
99 components: [
100 new ActionRowBuilder<ButtonBuilder>().addComponents(
101 new ButtonBuilder()
102 .setCustomId("ballot__upvote")
103 .setEmoji(getComponentEmojiResolvable(this.client, "ArrowTop") ?? "⬆️")
104 .setStyle(ButtonStyle.Secondary),
105 new ButtonBuilder()
106 .setCustomId("ballot__downvote")
107 .setEmoji(getComponentEmojiResolvable(this.client, "ArrowDown") ?? "⬇️")
108 .setStyle(ButtonStyle.Secondary)
109 )
110 ]
111 });
112
113 try {
114 const ballot = await this.client.ballotManager.create({
115 content,
116 guildId: message.guildId!,
117 userId: message.member!.user.id,
118 channelId: channel.id,
119 messageId: ballotMessage.id,
120 anonymous,
121 files:
122 message instanceof Message
123 ? [...message.attachments.map(a => a.proxyURL).values()]
124 : []
125 });
126
127 await this.success(
128 message,
129 `The ballot/poll has been created successfully.\nID: \`${ballot.id}\`\n${
130 message instanceof Message && message.attachments.size > 0
131 ? "Please do not delete your message, otherwise the attachments will be lost."
132 : ""
133 }`
134 );
135 } catch (e) {
136 logError(e);
137 return;
138 }
139 } catch (e) {
140 logError(e);
141
142 await this.error(
143 message,
144 "An error has occurred while sending the message. Make sure I have enough permissions to send messages here!"
145 );
146
147 return;
148 }
149 }
150 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26