/[sudobot]/trunk/src/commands/moderation/ShotCommand.ts
ViewVC logotype

Diff of /trunk/src/commands/moderation/ShotCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/src/commands/moderation/BeanCommand.ts revision 51 by rakin, Mon Jul 29 17:28:23 2024 UTC trunk/src/commands/moderation/ShotCommand.ts revision 363 by rakin, Mon Jul 29 17:29:47 2024 UTC
# Line 1  Line 1 
1  import { BanOptions, CommandInteraction, GuildMember, Interaction, Message, User } from 'discord.js';  import { CommandInteraction, ContextMenuInteraction, GuildMember, Message, User } from 'discord.js';
2  import BaseCommand from '../../utils/structures/BaseCommand';  import BaseCommand from '../../utils/structures/BaseCommand';
3  import DiscordClient from '../../client/Client';  import DiscordClient from '../../client/Client';
4  import CommandOptions from '../../types/CommandOptions';  import CommandOptions from '../../types/CommandOptions';
5  import InteractionOptions from '../../types/InteractionOptions';  import InteractionOptions from '../../types/InteractionOptions';
6  import MessageEmbed from '../../client/MessageEmbed';  import MessageEmbed from '../../client/MessageEmbed';
 import getUser from '../../utils/getUser';  
7  import getMember from '../../utils/getMember';  import getMember from '../../utils/getMember';
8  import History from '../../automod/History';  import Punishment from '../../models/Punishment';
9    import PunishmentType from '../../types/PunishmentType';
10    
11  export default class BeanCommand extends BaseCommand {  export default class ShotCommand extends BaseCommand {
12      supportsInteractions: boolean = true;      supportsInteractions: boolean = true;
13        supportsContextMenu: boolean = true;
14    
15      constructor() {      constructor() {
16          super('bean', 'moderation', []);          super('shot', 'moderation', ['Shot']);
17      }      }
18    
19      async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {      async run(client: DiscordClient, msg: Message | CommandInteraction | ContextMenuInteraction, options: CommandOptions | InteractionOptions) {
20          if (!options.isInteraction && typeof options.args[0] === 'undefined') {          if (!options.isInteraction && typeof options.args[0] === 'undefined') {
21              await msg.reply({              await msg.reply({
22                  embeds: [                  embeds: [
# Line 29  export default class BeanCommand extends Line 30  export default class BeanCommand extends
30          }          }
31    
32          let user: GuildMember;          let user: GuildMember;
33            let dm = true;
34          let reason: string | undefined;          let reason: string | undefined;
35            
36          if (options.isInteraction) {          if (options.isInteraction) {
37              user = await <GuildMember> options.options.getMember('member');              user = await <GuildMember> (msg instanceof ContextMenuInteraction ? options.options.getMember('user') : options.options.getMember('member'));
38    
39              if (!user) {              if (!user) {
40                  await msg.reply({                  await msg.reply({
41                      embeds: [                      embeds: [
42                          new MessageEmbed()                          new MessageEmbed()
43                          .setColor('#f14a60')                          .setColor('#f14a60')
44                          .setDescription("Invalid user given.")                          .setDescription("Invalid member given.")
45                      ]                      ]
46                  });                  });
47            
# Line 81  export default class BeanCommand extends Line 83  export default class BeanCommand extends
83              }              }
84          }          }
85    
86          try {                      const anonymous = options.isInteraction ? options.options.getBoolean('anonymous') ?? false : false;
             await History.create(user.id, msg.guild!, 'bean', msg.member!.user.id, typeof reason === 'undefined' ? null : reason);  
87    
88              await user.send({          try {            
89                  embeds: [              await Punishment.create({
90                      new MessageEmbed()                  type: PunishmentType.SHOT,
91                      .setAuthor({                  user_id: user.id,
92                          iconURL: <string> msg.guild!.iconURL(),                  guild_id: msg.guild!.id,
93                          name: `\tYou have been beaned in ${msg.guild!.name}`                  mod_id: msg.member!.user.id,
94                      })                  mod_tag: (msg.member!.user as User).tag,
95                      .addFields([                  reason,
96                          {                  createdAt: new Date()
                             name: "Reason",  
                             value: typeof reason === 'undefined' ? '*No reason provided*' : reason  
                         }  
                     ])  
                 ]  
97              });              });
98    
99              await client.logger.logBeaned(user, typeof reason === 'undefined' ? '*No reason provided*' : reason, msg.member!.user as User);              // await History.create(user.id, msg.guild!, 'bean', msg.member!.user.id, typeof reason === 'undefined' ? null : reason);
100    
101                try {
102                    await user.send({
103                        embeds: [
104                            new MessageEmbed()
105                                .setAuthor({
106                                    iconURL: <string> msg.guild!.iconURL(),
107                                    name: `\tYou got a shot in ${msg.guild!.name}`
108                                })
109                                .addFields([
110                                    {
111                                        name: "Reason",
112                                        value: typeof reason === 'undefined' ? '*No reason provided*' : reason
113                                    },
114                                    ...(!anonymous ? [{
115                                        name: "💉 Doctor",
116                                        value: `${(msg.member?.user as User).tag}`
117                                    }] : [])
118                                ])
119                        ]
120                    });
121                }
122                catch (e) {
123                    console.log(e);
124                    dm = false;
125                }
126    
127                // await client.logger.logBeaned(user, typeof reason === 'undefined' ? '*No reason provided*' : reason, msg.member!.user as User);
128          }          }
129          catch (e) {          catch (e) {
130              console.log(e);                          console.log(e);            
# Line 113  export default class BeanCommand extends Line 137  export default class BeanCommand extends
137                      name: user.user.tag,                      name: user.user.tag,
138                      iconURL: user.user.displayAvatarURL(),                      iconURL: user.user.displayAvatarURL(),
139                  })                  })
140                  .setDescription(user.user.tag + " has been beaned.")                  .setDescription(user.user.tag + " got a shot." + (!dm ? "\nThey have DMs disabled. They will not know that they got a shot." : ''))
141                  .addFields([                  .addFields([
142                      {                      {
143                          name: "Beaned by",                          name: "💉 Doctor",
144                          value: (msg.member!.user as User).tag                          value: (msg.member!.user as User).tag
145                      },                      },
146                      {                      {
# Line 127  export default class BeanCommand extends Line 151  export default class BeanCommand extends
151              ]              ]
152          });          });
153      }      }
 }  
154    }

Legend:
Removed from v.51  
changed lines
  Added in v.363

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26