/[sudobot]/branches/3.x/src/services/Starboard.ts
ViewVC logotype

Contents of /branches/3.x/src/services/Starboard.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: 2880 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 { MessageAttachment, MessageReaction, TextChannel } from "discord.js";
21 import MessageEmbed from "../client/MessageEmbed";
22 import Service from "../utils/structures/Service";
23
24 export default class Starboard extends Service {
25 async handle(reaction: MessageReaction) {
26 if (this.client.config.get('starboard').enabled) {
27 let emoji = reaction.emoji.name;
28
29 console.log(emoji);
30
31 if (emoji === '⭐' && reaction.message.channel.id !== this.client.config.get('starboard').channel && reaction.count === this.client.config.get('starboard').reactions) {
32 try {
33 const channel = <TextChannel> await reaction.message.guild!.channels.fetch(this.client.config.get('starboard').channel);
34
35 let props = {
36 embeds: reaction.message.embeds || []
37 };
38
39 const msg = await channel.send({
40 embeds: [
41 ...props.embeds,
42 new MessageEmbed()
43 .setAuthor({
44 name: reaction.message.author!.tag,
45 iconURL: reaction.message.author!.displayAvatarURL(),
46 })
47 .setDescription(reaction.message.content!)
48 .addField('URL', `[Click here](${reaction.message.url})`)
49 .setTimestamp()
50 .setFooter({
51 text: reaction.message.id + ''
52 })
53 ],
54 files: reaction.message.attachments.map(a => {
55 return {
56 name: a.name,
57 attachment: a.proxyURL
58 } as MessageAttachment
59 })
60 });
61
62 await msg.react('⭐');
63 }
64 catch (e) {
65 console.log(e);
66 }
67 }
68 }
69 }
70 };

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26