mirror of https://github.com/clickscodes/nucleus
parent
01cba76c6d
commit
baee2c19da
@ -0,0 +1,96 @@
|
|||||||
|
import { ActionRowBuilder, ButtonBuilder, ButtonStyle, ChannelSelectMenuBuilder, CommandInteraction, SlashCommandSubcommandBuilder } from "discord.js";
|
||||||
|
import type Discord from "discord.js";
|
||||||
|
import client from "../../utils/client.js";
|
||||||
|
import { LoadingEmbed } from "../../utils/defaults.js";
|
||||||
|
import compare from "lodash"
|
||||||
|
import EmojiEmbed from "../../utils/generateEmojiEmbed.js";
|
||||||
|
|
||||||
|
export const command = new SlashCommandSubcommandBuilder()
|
||||||
|
.setName("autopublish")
|
||||||
|
.setDescription("Automatically publish messages posted in announcement channels");
|
||||||
|
|
||||||
|
export const callback = async (interaction: CommandInteraction): Promise<void> => {
|
||||||
|
await interaction.reply({
|
||||||
|
embeds: LoadingEmbed,
|
||||||
|
ephemeral: true,
|
||||||
|
fetchReply: true
|
||||||
|
});
|
||||||
|
|
||||||
|
let closed = false;
|
||||||
|
let config = await client.database.guilds.read(interaction.guild!.id);
|
||||||
|
let data = Object.assign({}, config.autoPublish);
|
||||||
|
do {
|
||||||
|
const buttons = new ActionRowBuilder<ButtonBuilder>()
|
||||||
|
.addComponents(
|
||||||
|
new ButtonBuilder()
|
||||||
|
.setCustomId("switch")
|
||||||
|
.setLabel(data.enabled ? "Disabled" : "Enabled")
|
||||||
|
.setStyle(data.enabled ? ButtonStyle.Danger : ButtonStyle.Success)
|
||||||
|
.setEmoji(data.enabled ? "✅" : "❌"),
|
||||||
|
new ButtonBuilder()
|
||||||
|
.setCustomId("save")
|
||||||
|
.setLabel("Save")
|
||||||
|
.setStyle(ButtonStyle.Success)
|
||||||
|
.setEmoji("💾")
|
||||||
|
.setDisabled(compare.isEqual(data, config.autoPublish))
|
||||||
|
);
|
||||||
|
|
||||||
|
const channelSelect = new ActionRowBuilder<ChannelSelectMenuBuilder>()
|
||||||
|
.addComponents(
|
||||||
|
new ChannelSelectMenuBuilder()
|
||||||
|
.setCustomId("channel")
|
||||||
|
.setPlaceholder("Select a channel")
|
||||||
|
.setMinValues(1)
|
||||||
|
);
|
||||||
|
|
||||||
|
const embed = new EmojiEmbed()
|
||||||
|
|
||||||
|
await interaction.editReply({
|
||||||
|
embeds: [embed],
|
||||||
|
components: [channelSelect, buttons]
|
||||||
|
});
|
||||||
|
|
||||||
|
let i: Discord.ButtonInteraction | Discord.ChannelSelectMenuInteraction;
|
||||||
|
try {
|
||||||
|
i = await interaction.channel!.awaitMessageComponent({
|
||||||
|
filter: (i) => i.user.id === interaction.user.id,
|
||||||
|
time: 300000
|
||||||
|
}) as Discord.ButtonInteraction | Discord.ChannelSelectMenuInteraction;
|
||||||
|
} catch (e) {
|
||||||
|
closed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(i.isButton()) {
|
||||||
|
switch(i.customId) {
|
||||||
|
case "switch": {
|
||||||
|
data.enabled = !data.enabled;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "save": {
|
||||||
|
await client.database.guilds.write(interaction.guild!.id, { "autoPublish": data });
|
||||||
|
config = await client.database.guilds.read(interaction.guild!.id);
|
||||||
|
data = Object.assign({}, config.autoPublish);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for(const channel of i.values) {
|
||||||
|
data.channels.includes(channel) ? data.channels.splice(data.channels.indexOf(channel), 1) : data.channels.push(channel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} while (!closed);
|
||||||
|
|
||||||
|
await interaction.deleteReply();
|
||||||
|
}
|
||||||
|
|
||||||
|
export const check = (interaction: CommandInteraction, _partial: boolean = false) => {
|
||||||
|
const member = interaction.member as Discord.GuildMember;
|
||||||
|
const me = interaction.guild!.members.me as Discord.GuildMember;
|
||||||
|
if (!member.permissions.has("ManageMessages"))
|
||||||
|
return "You must have the *Manage Messages* permission to use this command";
|
||||||
|
if (_partial) return true;
|
||||||
|
if (!me.permissions.has("ManageMessages")) return "I do not have the *Manage Messages* permission";
|
||||||
|
return true;
|
||||||
|
};
|
||||||
Loading…
Reference in new issue