mirror of
https://github.com/veganhacktivists/arabot.git
synced 2025-05-19 02:54:14 +02:00
feat(arabot): add book club command
This commit is contained in:
parent
1e62fdf540
commit
bf16170871
154
src/commands/roles/bookClub.ts
Normal file
154
src/commands/roles/bookClub.ts
Normal file
@ -0,0 +1,154 @@
|
||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||
/*
|
||||
Animal Rights Advocates Discord Bot
|
||||
Copyright (C) 2023 Anthony Berg
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
import { Args, Command, RegisterBehavior } from '@sapphire/framework';
|
||||
import type { GuildMember, Message } from 'discord.js';
|
||||
import IDs from '../../utils/ids';
|
||||
|
||||
class BookClubCommand extends Command {
|
||||
public constructor(context: Command.Context, options: Command.Options) {
|
||||
super(context, {
|
||||
...options,
|
||||
name: 'bookclub',
|
||||
description: 'Gives the Book Club role',
|
||||
preconditions: ['EventCoordinatorOnly'],
|
||||
});
|
||||
}
|
||||
|
||||
// Registers that this is a slash command
|
||||
public override registerApplicationCommands(registry: Command.Registry) {
|
||||
registry.registerChatInputCommand(
|
||||
(builder) => builder
|
||||
.setName(this.name)
|
||||
.setDescription(this.description)
|
||||
.addUserOption((option) => option.setName('user')
|
||||
.setDescription('User to give Book Club to')
|
||||
.setRequired(true)),
|
||||
{
|
||||
behaviorWhenNotIdentical: RegisterBehavior.Overwrite,
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
// Command run
|
||||
public async chatInputRun(interaction: Command.ChatInputCommandInteraction) {
|
||||
// TODO add database updates
|
||||
// Get the arguments
|
||||
const user = interaction.options.getUser('user');
|
||||
const { guild } = interaction;
|
||||
|
||||
// Checks if all the variables are of the right type
|
||||
if (user === null || guild === null) {
|
||||
await interaction.reply({
|
||||
content: 'Error fetching user!',
|
||||
ephemeral: true,
|
||||
fetchReply: true,
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
// Gets guildMember whilst removing the ability of each other variables being null
|
||||
const guildMember = guild.members.cache.get(user.id);
|
||||
const bookClub = guild.roles.cache.get(IDs.roles.bookClub);
|
||||
|
||||
// Checks if guildMember is null
|
||||
if (guildMember === undefined || bookClub === undefined) {
|
||||
await interaction.reply({
|
||||
content: 'Error fetching user!',
|
||||
ephemeral: true,
|
||||
fetchReply: true,
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
// Checks if the user has Book Club and to give them or remove them based on if they have it
|
||||
if (guildMember.roles.cache.has(IDs.roles.bookClub)) {
|
||||
// Remove the Book Club role from the user
|
||||
await guildMember.roles.remove(bookClub);
|
||||
await interaction.reply({
|
||||
content: `Removed the ${bookClub.name} role from ${user}`,
|
||||
fetchReply: true,
|
||||
});
|
||||
return;
|
||||
}
|
||||
// Give Book Club role to the user
|
||||
await guildMember.roles.add(bookClub);
|
||||
await interaction.reply({
|
||||
content: `Gave ${user} the ${bookClub.name} role!`,
|
||||
fetchReply: true,
|
||||
});
|
||||
}
|
||||
|
||||
public async messageRun(message: Message, args: Args) {
|
||||
// Get arguments
|
||||
let user: GuildMember;
|
||||
try {
|
||||
user = await args.pick('member');
|
||||
} catch {
|
||||
await message.react('❌');
|
||||
await message.reply('User was not provided!');
|
||||
return;
|
||||
}
|
||||
|
||||
const mod = message.member;
|
||||
|
||||
if (mod === null) {
|
||||
await message.react('❌');
|
||||
await message.reply('Event coordinator not found! Try again or contact a developer!');
|
||||
return;
|
||||
}
|
||||
|
||||
const { guild } = message;
|
||||
|
||||
if (guild === null) {
|
||||
await message.react('❌');
|
||||
await message.reply('Guild not found! Try again or contact a developer!');
|
||||
return;
|
||||
}
|
||||
|
||||
const bookClub = guild.roles.cache.get(IDs.roles.bookClub);
|
||||
|
||||
if (bookClub === undefined) {
|
||||
await message.react('❌');
|
||||
await message.reply('Role not found! Try again or contact a developer!');
|
||||
return;
|
||||
}
|
||||
|
||||
// Checks if the user has Book Club and to give them or remove them based on if they have it
|
||||
if (user.roles.cache.has(IDs.roles.bookClub)) {
|
||||
// Remove the Book Club role from the user
|
||||
await user.roles.remove(bookClub);
|
||||
await message.reply({
|
||||
content: `Removed the ${bookClub.name} role from ${user}`,
|
||||
});
|
||||
} else {
|
||||
// Give Book Club role to the user
|
||||
await user.roles.add(bookClub);
|
||||
await message.reply({
|
||||
content: `Gave ${user} the ${bookClub.name} role!`,
|
||||
});
|
||||
await user.send(`You have been given the ${bookClub.name} role by ${mod}!`)
|
||||
.catch(() => {});
|
||||
}
|
||||
|
||||
await message.react('✅');
|
||||
}
|
||||
}
|
||||
|
||||
export default BookClubCommand;
|
@ -58,6 +58,7 @@ const devIDs = {
|
||||
patron: '999431675098447935',
|
||||
patreon: '999431675098447936',
|
||||
verifyBlock: '1007477161835372574',
|
||||
bookClub: '999431675140382803',
|
||||
},
|
||||
channels: {
|
||||
information: {
|
||||
|
@ -61,6 +61,7 @@ let IDs = {
|
||||
patron: '765370219207852055',
|
||||
patreon: '993848684640997406',
|
||||
verifyBlock: '1032765019269640203',
|
||||
bookClub: '955516408249352212',
|
||||
},
|
||||
channels: {
|
||||
information: {
|
||||
|
Loading…
x
Reference in New Issue
Block a user