aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorFederico fuji97 Rapetti <[email protected]>2021-12-27 18:26:37 +0100
committerFederico fuji97 Rapetti <[email protected]>2021-12-27 18:26:37 +0100
commit65e1f975b9653a8baafdf023d6e14bac2856fc19 (patch)
tree3ab5ecc453a4752785bc385691278abfa325059a /src
parente7a87c4f529b85cf03a8a8cfc009336fd85334c9 (diff)
downloadmuse-65e1f975b9653a8baafdf023d6e14bac2856fc19.tar.xz
muse-65e1f975b9653a8baafdf023d6e14bac2856fc19.zip
Refactor seek command as slash command
Diffstat (limited to 'src')
-rw-r--r--src/commands/seek.ts57
1 files changed, 31 insertions, 26 deletions
diff --git a/src/commands/seek.ts b/src/commands/seek.ts
index 5578aca..708567f 100644
--- a/src/commands/seek.ts
+++ b/src/commands/seek.ts
@@ -1,21 +1,22 @@
-import {Message, TextChannel} from 'discord.js';
+import {CommandInteraction} from 'discord.js';
import {TYPES} from '../types.js';
import {inject, injectable} from 'inversify';
import PlayerManager from '../managers/player.js';
-import LoadingMessage from '../utils/loading-message.js';
import errorMsg from '../utils/error-msg.js';
import Command from '.';
-import {parseTime} from '../utils/time.js';
+import {parseTime, prettyTime} from '../utils/time.js';
+import {SlashCommandBuilder} from '@discordjs/builders';
@injectable()
export default class implements Command {
- public name = 'seek';
- public aliases = [];
- public examples = [
- ['seek 10', 'seeks to 10 seconds from beginning of song'],
- ['seek 1:30', 'seeks to 1 minute and 30 seconds from beginning of song'],
- ['seek 1:00:00', 'seeks to 1 hour from beginning of song'],
- ];
+ public readonly slashCommand = new SlashCommandBuilder()
+ .setName('seek')
+ .setDescription('seek to a position from beginning of song')
+ .addStringOption(option =>
+ option.setName('time')
+ .setDescription('time to seek')
+ .setRequired(true),
+ );
public requiresVC = true;
@@ -25,22 +26,28 @@ export default class implements Command {
this.playerManager = playerManager;
}
- public async execute(msg: Message, args: string []): Promise<void> {
- const player = this.playerManager.get(msg.guild!.id);
+ public async executeFromInteraction(interaction: CommandInteraction): Promise<void> {
+ const player = this.playerManager.get(interaction.guild!.id);
const currentSong = player.getCurrent();
if (!currentSong) {
- await msg.channel.send(errorMsg('nothing is playing'));
+ await interaction.reply({
+ content: errorMsg('nothing is playing'),
+ ephemeral: true,
+ });
return;
}
if (currentSong.isLive) {
- await msg.channel.send(errorMsg('can\'t seek in a livestream'));
+ await interaction.reply({
+ content: errorMsg('can\'t seek in a livestream'),
+ ephemeral: true,
+ });
return;
}
- const time = args[0];
+ const time = interaction.options.getString('time')!;
let seekTime = 0;
@@ -51,20 +58,18 @@ export default class implements Command {
}
if (seekTime > currentSong.length) {
- await msg.channel.send(errorMsg('can\'t seek past the end of the song'));
+ await interaction.reply({
+ content: errorMsg('can\'t seek past the end of the song'),
+ ephemeral: true,
+ });
return;
}
- const loading = new LoadingMessage(msg.channel as TextChannel);
+ await Promise.all([
+ player.seek(seekTime),
+ interaction.deferReply(),
+ ]);
- await loading.start();
-
- try {
- await player.seek(seekTime);
-
- await loading.stop();
- } catch (error: unknown) {
- await loading.stop(errorMsg(error as Error));
- }
+ await interaction.editReply(`👍 seeked to ${prettyTime(player.getPosition())}`);
}
}