mirror of
https://github.com/BluemediaDev/muse.git
synced 2025-06-27 09:12:43 +02:00
parent
237086245b
commit
4f0db62170
4 changed files with 47 additions and 0 deletions
37
src/commands/stop.ts
Normal file
37
src/commands/stop.ts
Normal file
|
@ -0,0 +1,37 @@
|
|||
import {CommandInteraction} from 'discord.js';
|
||||
import {SlashCommandBuilder} from '@discordjs/builders';
|
||||
import {TYPES} from '../types.js';
|
||||
import {inject, injectable} from 'inversify';
|
||||
import PlayerManager from '../managers/player.js';
|
||||
import {STATUS} from '../services/player.js';
|
||||
import Command from '.';
|
||||
|
||||
@injectable()
|
||||
export default class implements Command {
|
||||
public readonly slashCommand = new SlashCommandBuilder()
|
||||
.setName('stop')
|
||||
.setDescription('stop playback, disconnect, and clear all songs in the queue');
|
||||
|
||||
public requiresVC = true;
|
||||
|
||||
private readonly playerManager: PlayerManager;
|
||||
|
||||
constructor(@inject(TYPES.Managers.Player) playerManager: PlayerManager) {
|
||||
this.playerManager = playerManager;
|
||||
}
|
||||
|
||||
public async execute(interaction: CommandInteraction) {
|
||||
const player = this.playerManager.get(interaction.guild!.id);
|
||||
|
||||
if (!player.voiceConnection) {
|
||||
throw new Error('not connected');
|
||||
}
|
||||
|
||||
if (player.status !== STATUS.PLAYING) {
|
||||
throw new Error('not currently playing');
|
||||
}
|
||||
|
||||
player.stop();
|
||||
await interaction.reply('u betcha');
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue