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

Annotation of /branches/3.x/src/services/Starboard.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (hide 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 rakinar2 577 /**
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