feat: /add and /remove commands

This commit is contained in:
Isaac 2022-10-28 17:32:28 +01:00
parent 1843400004
commit 15318df9e4
No known key found for this signature in database
GPG Key ID: 0DE40AE37BBA5C33
3 changed files with 233 additions and 2 deletions

View File

@ -1,5 +1,8 @@
const { SlashCommand } = require('@eartharoid/dbf');
const { ApplicationCommandOptionType } = require('discord.js');
const ExtendedEmbedBuilder = require('../../lib/embed');
const { isStaff } = require('../../lib/users');
const { logTicketEvent } = require('../../lib/logging');
module.exports = class AddSlashCommand extends SlashCommand {
constructor(client, options) {
@ -32,5 +35,110 @@ module.exports = class AddSlashCommand extends SlashCommand {
});
}
async run(interaction) { }
/**
* @param {import("discord.js").ChatInputCommandInteraction} interaction
*/
async run(interaction) {
/** @type {import("client")} */
const client = this.client;
await interaction.deferReply({ ephemeral: true });
const ticket = await client.prisma.ticket.findUnique({
include: { guild: true },
where: { id: interaction.options.getString('ticket', false) || interaction.channel.id },
});
if (!ticket) {
const settings = await client.prisma.guild.findUnique({ where: { id: interaction.guild.id } });
const getMessage = client.i18n.getLocale(settings.locale);
return await interaction.editReply({
embeds: [
new ExtendedEmbedBuilder({
iconURL: interaction.guild.iconURL(),
text: settings.footer,
})
.setColor(settings.errorColour)
.setTitle(getMessage('misc.invalid_ticket.title'))
.setDescription(getMessage('misc.invalid_ticket.description')),
],
});
}
const getMessage = client.i18n.getLocale(ticket.guild.locale);
if (
ticket.id !== interaction.channel.id &&
ticket.createdById !== interaction.member.id &&
!(await isStaff(interaction.guild, interaction.member.id))
) {
return await interaction.editReply({
embeds: [
new ExtendedEmbedBuilder({
iconURL: interaction.guild.iconURL(),
text: ticket.guild.footer,
})
.setColor(ticket.guild.errorColour)
.setTitle(getMessage('commands.slash.add.not_staff.title'))
.setDescription(getMessage('commands.slash.add.not_staff.description')),
],
});
}
/** @type {import("discord.js").TextChannel} */
const ticketChannel = await interaction.guild.channels.fetch(ticket.id);
const member = interaction.options.getMember('member', true);
await ticketChannel.permissionOverwrites.edit(
member,
{
AttachFiles: true,
EmbedLinks: true,
ReadMessageHistory: true,
SendMessages: true,
ViewChannel: true,
},
`${interaction.user.tag} added ${member.user.tag} to the ticket`,
);
await ticketChannel.send({
embeds: [
new ExtendedEmbedBuilder()
.setColor(ticket.guild.primaryColour)
.setDescription(getMessage('commands.slash.add.added', {
added: member.toString(),
by: interaction.member.toString(),
})),
],
});
await interaction.editReply({
embeds: [
new ExtendedEmbedBuilder({
iconURL: interaction.guild.iconURL(),
text: ticket.guild.footer,
})
.setColor(ticket.guild.successColour)
.setTitle(getMessage('commands.slash.add.success.title'))
.setDescription(getMessage('commands.slash.add.success.description', {
member: member.toString(),
ticket: ticketChannel.toString(),
})),
],
});
logTicketEvent(this.client, {
action: 'update',
diff: {
original: {},
updated: { [getMessage('log.ticket.added')]: member.user.tag },
},
target: {
id: ticket.id,
name: `<#${ticket.id}>`,
},
userId: interaction.user.id,
});
}
};

View File

@ -1,5 +1,8 @@
const { SlashCommand } = require('@eartharoid/dbf');
const { ApplicationCommandOptionType } = require('discord.js');
const ExtendedEmbedBuilder = require('../../lib/embed');
const { isStaff } = require('../../lib/users');
const { logTicketEvent } = require('../../lib/logging');
module.exports = class RemoveSlashCommand extends SlashCommand {
constructor(client, options) {
@ -32,5 +35,109 @@ module.exports = class RemoveSlashCommand extends SlashCommand {
});
}
async run(interaction) { }
/**
* @param {import("discord.js").ChatInputCommandInteraction} interaction
*/
async run(interaction) {
/** @type {import("client")} */
const client = this.client;
await interaction.deferReply({ ephemeral: true });
const ticket = await client.prisma.ticket.findUnique({
include: { guild: true },
where: { id: interaction.options.getString('ticket', false) || interaction.channel.id },
});
if (!ticket) {
const settings = await client.prisma.guild.findUnique({ where: { id: interaction.guild.id } });
const getMessage = client.i18n.getLocale(settings.locale);
return await interaction.editReply({
embeds: [
new ExtendedEmbedBuilder({
iconURL: interaction.guild.iconURL(),
text: settings.footer,
})
.setColor(settings.errorColour)
.setTitle(getMessage('misc.invalid_ticket.title'))
.setDescription(getMessage('misc.invalid_ticket.description')),
],
});
}
const getMessage = client.i18n.getLocale(ticket.guild.locale);
if (
ticket.id !== interaction.channel.id &&
ticket.createdById !== interaction.member.id &&
!(await isStaff(interaction.guild, interaction.member.id))
) {
return await interaction.editReply({
embeds: [
new ExtendedEmbedBuilder({
iconURL: interaction.guild.iconURL(),
text: ticket.guild.footer,
})
.setColor(ticket.guild.errorColour)
.setTitle(getMessage('commands.slash.remove.not_staff.title'))
.setDescription(getMessage('commands.slash.remove.not_staff.description')),
],
});
}
/** @type {import("discord.js").TextChannel} */
const ticketChannel = await interaction.guild.channels.fetch(ticket.id);
const member = interaction.options.getMember('member', true);
if (member.id === client.user.id) {
return await interaction.editReply({
embeds: [
new ExtendedEmbedBuilder()
.setColor(ticket.guild.errorColour)
.setTitle('❌'),
],
});
}
await ticketChannel.permissionOverwrites.delete(member, `${interaction.user.tag} removed ${member.user.tag} from the ticket`);
await ticketChannel.send({
embeds: [
new ExtendedEmbedBuilder()
.setColor(ticket.guild.primaryColour)
.setDescription(getMessage('commands.slash.remove.removed', {
by: interaction.member.toString(),
removed: member.toString(),
})),
],
});
await interaction.editReply({
embeds: [
new ExtendedEmbedBuilder({
iconURL: interaction.guild.iconURL(),
text: ticket.guild.footer,
})
.setColor(ticket.guild.successColour)
.setTitle(getMessage('commands.slash.remove.success.title'))
.setDescription(getMessage('commands.slash.remove.success.description', {
member: member.toString(),
ticket: ticketChannel.toString(),
})),
],
});
logTicketEvent(this.client, {
action: 'update',
diff: {
original: { [getMessage('log.ticket.removed')]: member.user.tag },
updated: {},
},
target: {
id: ticket.id,
name: `<#${ticket.id}>`,
},
userId: interaction.user.id,
});
}
};

View File

@ -39,8 +39,12 @@ commands:
title: ✅ Pinned message
slash:
add:
added: ➡️ {added} has been added by {by}.
description: Add a member to a ticket
name: add
not_staff:
description: Only staff members can add members to others' tickets.
title: ❌ Error
options:
member:
description: The member to add to the ticket
@ -48,6 +52,9 @@ commands:
ticket:
description: The ticket to add the member to
name: ticket
success:
description: "{member} has been added to {ticket}."
title: ✅ Added
claim:
description: Claim a ticket
name: claim
@ -144,8 +151,12 @@ commands:
description: Release (unclaim) a ticket
name: release
remove:
removed: ⬅️ {removed} has been removed by {by}.
description: Remove a member from a ticket
name: remove
not_staff:
description: Only staff members can removed members from others' tickets.
title: ❌ Error
options:
member:
description: The member to remove from the ticket
@ -153,6 +164,9 @@ commands:
ticket:
description: The ticket to remove the member from
name: ticket
success:
description: "{member} has been removed from {ticket}."
title: ✅ Added
tag:
description: Use a tag
name: tag
@ -243,7 +257,9 @@ log:
delete: deleted
update: updated
ticket:
added: Added members
description: "{user} {verb} a ticket"
removed: Removed members
ticket: Ticket
title: Ticket {verb}
verb: