aboutsummaryrefslogtreecommitdiff
path: root/src/commands
diff options
context:
space:
mode:
authorIRONM00N <64110067+IRONM00N@users.noreply.github.com>2021-08-27 10:33:38 -0400
committerIRONM00N <64110067+IRONM00N@users.noreply.github.com>2021-08-27 10:33:38 -0400
commiteae976c648cfaae11dcb6e03be3fb263ced6260c (patch)
treef5420998c0ddc777d526a3168ab7f12dd8ac1ad8 /src/commands
parent921e98369c8a8aa58220a232eb8b711be59f9884 (diff)
downloadtanzanite-eae976c648cfaae11dcb6e03be3fb263ced6260c.tar.gz
tanzanite-eae976c648cfaae11dcb6e03be3fb263ced6260c.tar.bz2
tanzanite-eae976c648cfaae11dcb6e03be3fb263ced6260c.zip
testing sub commands
Diffstat (limited to 'src/commands')
-rw-r--r--src/commands/config/settings.ts104
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.`
);