diff options
| author | Max Isom <[email protected]> | 2022-02-24 18:24:56 -0500 |
|---|---|---|
| committer | Max Isom <[email protected]> | 2022-02-24 18:24:56 -0500 |
| commit | 3dfd16860be1f607a53d49e97cf68260497530d0 (patch) | |
| tree | 4c6b2aeebc83bc2a65cce4abd1d933254f173bea /src/commands | |
| parent | edc95ad5db67cbf75cb62f528545cf2c3a1090f0 (diff) | |
| parent | 4f0db62170398c542d23fcee3812f0887901f977 (diff) | |
| download | muse-3dfd16860be1f607a53d49e97cf68260497530d0.tar.xz muse-3dfd16860be1f607a53d49e97cf68260497530d0.zip | |
Merge branch 'master' of github.com:codetheweb/muse
Diffstat (limited to 'src/commands')
| -rw-r--r-- | src/commands/stop.ts | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/src/commands/stop.ts b/src/commands/stop.ts new file mode 100644 index 0000000..3c32c7f --- /dev/null +++ b/src/commands/stop.ts @@ -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'); + } +} |
