diff options
Diffstat (limited to 'src/commands/config/settings.ts')
-rw-r--r-- | src/commands/config/settings.ts | 104 |
1 files changed, 94 insertions, 10 deletions
diff --git a/src/commands/config/settings.ts b/src/commands/config/settings.ts index 003e118..032b4e5 100644 --- a/src/commands/config/settings.ts +++ b/src/commands/config/settings.ts @@ -1,4 +1,4 @@ -import { BushCommand, BushMessage, BushSlashMessage, guildSettings } from '@lib'; +import { BushCommand, BushMessage, BushSlashMessage, guildSettingsObj, settingsArr } from '@lib'; import { Message, MessageActionRow, @@ -20,6 +20,89 @@ export default class SettingsCommand extends BushCommand { examples: ['settings'] }, slash: true, + slashOptions: [ + { + name: 'view', + description: 'See a all settings or a particular setting', + type: 'SUB_COMMAND', + options: [ + { + name: 'setting', + description: 'What setting would you like to see?', + type: 'STRING', + required: false, + choices: settingsArr.map((s) => ({ name: guildSettingsObj[s].name, value: s })) + } + ] + }, + { + name: 'set', + description: 'Set a particular setting.', + type: 'SUB_COMMAND', + options: [ + { + name: 'setting', + description: 'What setting would you like to set?', + type: 'STRING', + required: true, + choices: settingsArr + .filter((s) => !guildSettingsObj[s].type.includes('array')) + .map((s) => ({ name: guildSettingsObj[s].name, value: s })) + }, + { + name: 'value', + description: 'What would you like the new value to be?', + type: 'STRING', + required: true + } + ] + }, + { + name: 'add', + description: 'Add a value to a particular setting.', + type: 'SUB_COMMAND', + options: [ + { + name: 'setting', + description: 'What setting would you like to add to?', + type: 'STRING', + required: true, + choices: settingsArr + .filter((s) => guildSettingsObj[s].type.includes('array')) + .map((s) => ({ name: guildSettingsObj[s].name, value: s })) + }, + { + name: 'value', + description: 'What would you like the new value to be?', + type: 'STRING', + required: true + } + ] + }, + { + name: 'remove', + description: 'Remove a value to a particular setting.', + type: 'SUB_COMMAND', + options: [ + { + name: 'setting', + description: 'What setting would you like to set?', + type: 'STRING', + required: true, + choices: settingsArr + .filter((s) => guildSettingsObj[s].type.includes('array')) + .map((s) => ({ name: guildSettingsObj[s].name, value: s })) + }, + { + name: 'value', + description: 'What would you like the new value to be?', + type: 'STRING', + required: true + } + ] + } + ], + slashGuilds: ['516977525906341928'], channel: 'guild', clientPermissions: ['SEND_MESSAGES'], userPermissions: ['SEND_MESSAGES', 'MANAGE_GUILD'], @@ -27,6 +110,8 @@ export default class SettingsCommand extends BushCommand { }); } + // *args(): any {} + public override async exec(message: BushMessage | BushSlashMessage): Promise<unknown> { if (!message.guild) return await message.util.reply(`${util.emojis.error} This command can only be used in servers.`); const messageOptions = await this.generateMessageOptions(message); @@ -46,7 +131,7 @@ export default class SettingsCommand extends BushCommand { if (!interaction.isSelectMenu()) return; return interaction.update( - await this.generateMessageOptions(message, interaction.values[0] as keyof typeof guildSettings) + await this.generateMessageOptions(message, interaction.values[0] as keyof typeof guildSettingsObj) ); } } @@ -58,22 +143,21 @@ export default class SettingsCommand extends BushCommand { public async generateMessageOptions( message: BushMessage | BushSlashMessage, - feature?: keyof typeof guildSettings + feature?: keyof typeof guildSettingsObj ): Promise<MessageOptions> { if (!message.guild) throw new Error('message.guild is null'); const settingsEmbed = new MessageEmbed().setTitle(`${message.guild!.name}'s Settings`).setColor(util.colors.default); if (!feature) { - const settingsArr = Object.keys(guildSettings) as (keyof typeof guildSettings)[]; - const desc = settingsArr.map((s) => `**${guildSettings[s].name}**`).join('\n'); + const desc = settingsArr.map((s) => `**${guildSettingsObj[s].name}**`).join('\n'); settingsEmbed.setDescription(desc); const selMenu = new MessageActionRow().addComponents( new MessageSelectMenu() .addOptions( ...settingsArr.map((s) => ({ - label: guildSettings[s].name, + label: guildSettingsObj[s].name, value: s, - description: guildSettings[s].description + description: guildSettingsObj[s].description })) ) .setPlaceholder('Select A Setting to View') @@ -86,10 +170,10 @@ export default class SettingsCommand extends BushCommand { const components = new MessageActionRow().addComponents( new MessageButton().setStyle('PRIMARY').setCustomId('command_settingsBack').setLabel('Back') ); - settingsEmbed.setDescription(guildSettings[feature].description); - switch (guildSettings[feature].type as 'string' | 'channel' | 'channel-array' | 'role' | 'role-array') { + settingsEmbed.setDescription(guildSettingsObj[feature].description); + switch (guildSettingsObj[feature].type as 'string' | 'channel' | 'channel-array' | 'role' | 'role-array') { case 'string': { - settingsEmbed.addField(guildSettings[feature].name, (await message.guild.getSetting(feature)).toString()); + settingsEmbed.addField(guildSettingsObj[feature].name, (await message.guild.getSetting(feature)).toString()); settingsEmbed.setFooter( `Run "${await message.guild.getSetting('prefix')}settings set ${feature} <value>" to set this setting.` ); |