2024-04-29 15:57:02 +05:00
|
|
|
const { SlashCommandBuilder } = require("discord.js");
|
2022-08-02 17:18:47 +05:00
|
|
|
const BaseCommand = require("../../base/BaseCommand");
|
|
|
|
|
|
|
|
class Loop extends BaseCommand {
|
|
|
|
/**
|
|
|
|
*
|
2023-11-05 16:03:23 +05:00
|
|
|
* @param {import("../base/Client")} client
|
2022-08-02 17:18:47 +05:00
|
|
|
*/
|
|
|
|
constructor(client) {
|
|
|
|
super({
|
|
|
|
command: new SlashCommandBuilder()
|
|
|
|
.setName("loop")
|
2022-09-30 23:35:21 +05:00
|
|
|
.setDescription(client.translate("music/loop:DESCRIPTION"))
|
2023-06-15 19:46:27 +05:00
|
|
|
.setDescriptionLocalizations({
|
2023-07-05 00:58:06 +05:00
|
|
|
uk: client.translate("music/loop:DESCRIPTION", null, "uk-UA"),
|
|
|
|
ru: client.translate("music/loop:DESCRIPTION", null, "ru-RU"),
|
2023-06-15 19:46:27 +05:00
|
|
|
})
|
2022-10-13 00:05:36 +05:00
|
|
|
.setDMPermission(false)
|
2023-07-05 00:58:06 +05:00
|
|
|
.addStringOption(option =>
|
|
|
|
option
|
|
|
|
.setName("option")
|
|
|
|
.setDescription(client.translate("music/loop:OPTION"))
|
|
|
|
.setDescriptionLocalizations({
|
|
|
|
uk: client.translate("music/loop:OPTION", null, "uk-UA"),
|
|
|
|
ru: client.translate("music/loop:OPTION", null, "ru-RU"),
|
|
|
|
})
|
|
|
|
.setRequired(true)
|
|
|
|
.setChoices(
|
2024-04-29 15:57:02 +05:00
|
|
|
// { name: client.translate("music/loop:AUTOPLAY"), value: "3" },
|
|
|
|
{ name: client.translate("music/loop:QUEUE"), value: "queue" },
|
|
|
|
{ name: client.translate("music/loop:TRACK"), value: "track" },
|
|
|
|
{ name: client.translate("music/loop:DISABLE"), value: "off" },
|
2023-07-05 00:58:06 +05:00
|
|
|
),
|
|
|
|
),
|
2022-08-02 17:18:47 +05:00
|
|
|
dirname: __dirname,
|
2022-12-15 21:02:38 +05:00
|
|
|
ownerOnly: false,
|
2022-08-02 17:18:47 +05:00
|
|
|
});
|
|
|
|
}
|
2024-02-06 21:45:53 +05:00
|
|
|
|
2022-08-02 17:18:47 +05:00
|
|
|
/**
|
|
|
|
*
|
2023-11-05 16:03:23 +05:00
|
|
|
* @param {import("../../base/Client")} client
|
2022-08-02 17:18:47 +05:00
|
|
|
* @param {import("discord.js").ChatInputCommandInteraction} interaction
|
|
|
|
*/
|
|
|
|
async execute(client, interaction) {
|
2024-04-29 15:57:02 +05:00
|
|
|
await interaction.deferReply();
|
|
|
|
|
2022-08-02 17:18:47 +05:00
|
|
|
const voice = interaction.member.voice.channel;
|
2022-09-13 22:19:51 +05:00
|
|
|
if (!voice) return interaction.error("music/play:NO_VOICE_CHANNEL", null, { edit: true });
|
2023-01-09 01:39:13 +05:00
|
|
|
|
2024-04-29 15:57:02 +05:00
|
|
|
const player = client.lavalink.getPlayer(interaction.guildId);
|
|
|
|
if (!player) return interaction.error("music/play:NOT_PLAYING", null, { edit: true });
|
|
|
|
|
|
|
|
const type = interaction.options.getString("option");
|
2022-08-02 17:18:47 +05:00
|
|
|
|
2023-11-04 16:56:10 +05:00
|
|
|
const translated = {
|
2024-04-29 15:57:02 +05:00
|
|
|
// "3": interaction.translate("music/loop:AUTOPLAY_ENABLED"),
|
|
|
|
"queue": interaction.translate("music/loop:QUEUE_ENABLED"),
|
|
|
|
"track": interaction.translate("music/loop:TRACK_ENABLED"),
|
|
|
|
"off": interaction.translate("music/loop:LOOP_DISABLED"),
|
2023-11-04 16:56:10 +05:00
|
|
|
};
|
|
|
|
|
2024-04-29 15:57:02 +05:00
|
|
|
await player.setRepeatMode(type);
|
|
|
|
interaction.editReply({ content: translated[type] });
|
2022-08-02 17:18:47 +05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-05 00:58:06 +05:00
|
|
|
module.exports = Loop;
|