JaBa/commands/Music/nowplaying.js

295 lines
10 KiB
JavaScript
Raw Permalink Normal View History

const { SlashCommandBuilder, ActionRowBuilder, ButtonBuilder, ButtonStyle, StringSelectMenuBuilder, StringSelectMenuOptionBuilder } = require("discord.js"),
{ QueueRepeatMode } = require("discord-player");
const BaseCommand = require("../../base/BaseCommand");
class Nowplaying extends BaseCommand {
/**
*
2023-11-05 16:03:23 +05:00
* @param {import("../base/Client")} client
*/
constructor(client) {
super({
command: new SlashCommandBuilder()
.setName("nowplaying")
.setDescription(client.translate("music/nowplaying:DESCRIPTION"))
.setDescriptionLocalizations({
2023-07-05 00:58:06 +05:00
uk: client.translate("music/nowplaying:DESCRIPTION", null, "uk-UA"),
ru: client.translate("music/nowplaying:DESCRIPTION", null, "ru-RU"),
})
.setDMPermission(false),
dirname: __dirname,
ownerOnly: false,
});
}
/**
*
2023-11-05 16:03:23 +05:00
* @param {import("../../base/Client")} client
*/
async onLoad(client) {
client.on("interactionCreate", async interaction => {
if (!interaction.isButton()) return;
if (interaction.customId.startsWith("nowp_")) {
const locale = (await client.getGuildData(interaction.guildId)).language;
2024-02-09 23:26:57 +05:00
const voice = interaction.member.voice.channel;
2024-04-30 13:13:03 +05:00
if (!voice) return interaction.error("music/play:NO_VOICE_CHANNEL", null, { locale });
const queue = client.player.nodes.get(interaction.guildId);
2024-04-30 13:13:03 +05:00
if (!queue) return interaction.error("music/play:NOT_PLAYING", null, { locale });
const row1 = new ActionRowBuilder().addComponents(
new ButtonBuilder().setCustomId("nowp_prev_track").setStyle(ButtonStyle.Primary).setEmoji("⬅️"),
2023-11-04 23:52:05 +05:00
new ButtonBuilder().setCustomId("nowp_stop").setStyle(ButtonStyle.Danger).setEmoji("⏹️"),
new ButtonBuilder().setCustomId("nowp_add_track").setStyle(ButtonStyle.Success).setEmoji("▶️"),
new ButtonBuilder().setCustomId("nowp_next_track").setStyle(ButtonStyle.Primary).setEmoji("➡️"),
2023-11-04 23:52:05 +05:00
new ButtonBuilder().setCustomId("nowp_loop").setStyle(ButtonStyle.Secondary).setEmoji("🔁"),
);
const row2 = new ActionRowBuilder().addComponents(
new ButtonBuilder().setCustomId("nowp_queue").setStyle(ButtonStyle.Secondary).setEmoji(""),
);
if (interaction.customId === "nowp_prev_track") {
await interaction.deferUpdate();
2024-04-30 13:13:03 +05:00
if (queue.history.isEmpty()) return interaction.followUp({ content: interaction.translate("music/back:NO_PREV_SONG", null, locale), ephemeral: true });
queue.history.back();
2024-04-30 13:13:03 +05:00
await interaction.followUp({ content: interaction.translate("music/back:SUCCESS", null, locale), ephemeral: true });
const embed = await updateEmbed(interaction, queue);
interaction.editReply({
embeds: [embed],
});
} else if (interaction.customId === "nowp_loop") {
await interaction.deferUpdate();
const selectMenu = new StringSelectMenuBuilder()
.setCustomId("nowp_select")
2024-04-30 13:13:03 +05:00
.setPlaceholder(interaction.translate("common:NOTHING_SELECTED", null, locale))
.addOptions(
new StringSelectMenuOptionBuilder()
2024-04-30 13:13:03 +05:00
.setLabel(interaction.translate("music/loop:AUTOPLAY", null, locale))
.setValue("3"),
new StringSelectMenuOptionBuilder()
2024-04-30 13:13:03 +05:00
.setLabel(interaction.translate("music/loop:QUEUE", null, locale))
.setValue("2"),
new StringSelectMenuOptionBuilder()
2024-04-30 13:13:03 +05:00
.setLabel(interaction.translate("music/loop:TRACK", null, locale))
.setValue("1"),
new StringSelectMenuOptionBuilder()
2024-04-30 13:13:03 +05:00
.setLabel(interaction.translate("music/loop:DISABLE", null, locale))
.setValue("0"),
);
const selectRow = new ActionRowBuilder().addComponents(selectMenu),
msg = await interaction.followUp({
components: [selectRow],
ephemeral: true,
});
const filter = i => i.user.id === interaction.user.id,
collected = await msg.awaitMessageComponent({ filter, time: 10 * 1000 }),
2023-11-05 00:06:19 +05:00
mode = collected.values[0] === "3" ? QueueRepeatMode.AUTOPLAY : collected.values[0] === "2" ? QueueRepeatMode.QUEUE : collected.values[0] === "1" ? QueueRepeatMode.TRACK : QueueRepeatMode.OFF,
translated = {
2024-04-30 13:13:03 +05:00
"3": interaction.translate("music/loop:AUTOPLAY_ENABLED", null, locale),
"2": interaction.translate("music/loop:QUEUE_ENABLED", null, locale),
"1": interaction.translate("music/loop:TRACK_ENABLED", null, locale),
"0": interaction.translate("music/loop:LOOP_DISABLED", null, locale),
};
await collected.deferUpdate();
queue.setRepeatMode(mode);
2023-11-05 00:06:19 +05:00
await interaction.followUp({ content: translated[collected.values[0]] });
const embed = await updateEmbed(interaction, queue);
interaction.editReply({
embeds: [embed],
});
} else if (interaction.customId === "nowp_add_track") {
await interaction.deferUpdate();
await interaction.followUp({
2024-04-30 13:13:03 +05:00
content: interaction.translate("music/nowplaying:LINK", null, locale),
ephemeral: true,
});
const filter = m => m.author.id === interaction.user.id && m.content.startsWith("http"),
2024-02-09 23:26:57 +05:00
collect = await interaction.channel.awaitMessages({ filter, time: 10 * 1000, max: 1 });
if (collect.size < 1) return;
const collected = collect.first(),
query = collected.content.match(/https?:\/\/(www\.)?[-a-zA-Z0-9@:%._+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_+.~#?&//=]*)/g)[0],
searchResult = await client.player.search(query, {
requestedBy: interaction.user,
});
2024-02-09 23:26:57 +05:00
if (collected.deletable) collected.delete();
2024-04-30 13:13:03 +05:00
if (!searchResult.hasTracks()) return interaction.error("music/play:NO_RESULT", { query: query }, { edit: true, locale });
else queue.addTrack(searchResult);
await interaction.followUp({
content: interaction.translate("music/play:ADDED_QUEUE", {
songName: searchResult.hasPlaylist() ? searchResult.playlist.title : searchResult.tracks[0].title,
2024-04-30 13:13:03 +05:00
}, locale),
});
const embed = await updateEmbed(interaction, queue);
interaction.editReply({
embeds: [embed],
});
} else if (interaction.customId === "nowp_next_track") {
await interaction.deferUpdate();
queue.node.skip();
2024-04-30 13:13:03 +05:00
await interaction.followUp({
2024-05-02 16:55:26 +05:00
content: interaction.translate("music/skipto:SUCCESS", {
2024-04-30 13:13:03 +05:00
track: `${queue.tracks.at(0).title} - ${queue.tracks.at(0).author}`,
2024-05-02 16:55:26 +05:00
}, locale),
2024-04-30 13:13:03 +05:00
ephemeral: true,
});
const embed = await updateEmbed(interaction, queue);
interaction.editReply({
embeds: [embed],
});
} else if (interaction.customId === "nowp_queue") {
await interaction.deferUpdate();
client.commands.get("queue").execute(client, interaction);
} else if (interaction.customId === "nowp_stop") {
await interaction.deferUpdate();
2023-11-05 16:03:23 +05:00
queue.delete();
2024-04-30 13:13:03 +05:00
await interaction.followUp({ content: interaction.translate("music/stop:SUCCESS", null, locale) });
2023-11-05 16:03:23 +05:00
row1.components.forEach(component => {
component.setDisabled(true);
});
row2.components.forEach(component => {
component.setDisabled(true);
});
return interaction.editReply({
components: [row1, row2],
});
}
}
});
}
/**
*
2023-11-05 16:03:23 +05:00
* @param {import("../../base/Client")} client
* @param {import("discord.js").ChatInputCommandInteraction} interaction
2022-08-09 23:48:33 +05:00
* @param {Object} data
*/
async execute(client, interaction) {
await interaction.deferReply();
const queue = client.player.nodes.get(interaction.guildId);
if (!queue) return interaction.error("music/play:NOT_PLAYING", null, { edit: true });
const row1 = new ActionRowBuilder().addComponents(
new ButtonBuilder().setCustomId("nowp_prev_track").setStyle(ButtonStyle.Primary).setEmoji("⬅️"),
2023-11-04 23:52:05 +05:00
new ButtonBuilder().setCustomId("nowp_stop").setStyle(ButtonStyle.Danger).setEmoji("⏹️"),
new ButtonBuilder().setCustomId("nowp_add_track").setStyle(ButtonStyle.Success).setEmoji("▶️"),
new ButtonBuilder().setCustomId("nowp_next_track").setStyle(ButtonStyle.Primary).setEmoji("➡️"),
2023-11-04 23:52:05 +05:00
new ButtonBuilder().setCustomId("nowp_loop").setStyle(ButtonStyle.Secondary).setEmoji("🔁"),
);
const row2 = new ActionRowBuilder().addComponents(
new ButtonBuilder().setCustomId("nowp_queue").setStyle(ButtonStyle.Secondary).setEmoji(""),
);
const embed = await updateEmbed(interaction, queue);
2023-11-21 01:19:46 +05:00
const message = await interaction.editReply({
embeds: [embed],
components: [row1, row2],
});
2023-11-21 01:19:46 +05:00
const i = setInterval(async function () {
if (message && message.editable && queue.isPlaying()) {
const e = await updateEmbed(interaction, queue);
message.edit({
embeds: [e],
components: [row1, row2],
});
} else clearInterval(i);
2024-02-09 23:26:57 +05:00
}, 60 * 1000);
}
}
/**
*
* @param {import("discord.js").ChatInputCommandInteraction} interaction
* @param {import("discord-player").GuildQueue} queue
* @returns
*/
async function updateEmbed(interaction, queue) {
const progressBar = queue.node.createProgressBar(),
track = queue.currentTrack,
2023-11-05 00:06:19 +05:00
mode = queue.repeatMode === QueueRepeatMode.AUTOPLAY ? "3" : queue.repeatMode === QueueRepeatMode.QUEUE ? "2" : queue.repeatMode === QueueRepeatMode.TRACK ? "1" : "0",
translated = {
"3": interaction.translate("music/loop:AUTOPLAY"),
"2": interaction.translate("music/loop:QUEUE"),
"1": interaction.translate("music/loop:TRACK"),
"0": interaction.translate("common:DISABLED"),
};
const embed = interaction.client.embed({
author: interaction.translate("music/nowplaying:CURRENTLY_PLAYING"),
thumbnail: track.thumbnail || null,
fields: [
{
name: interaction.translate("music/nowplaying:T_TITLE"),
value: `[${track.title}](${track.url})`,
inline: true,
},
{
name: interaction.translate("music/nowplaying:T_AUTHOR"),
value: track.author || interaction.translate("common:UNKNOWN"),
inline: true,
},
{ name: "\u200B", value: "\u200B", inline: true },
{
name: interaction.translate("common:VIEWS"),
2024-02-09 23:26:57 +05:00
value: track.raw.live ? "Live" : new Intl.NumberFormat(interaction.client.defaultLanguage.moment, { notation: "standard" }).format(track.raw.views),
inline: true,
},
{
name: interaction.translate("music/queue:ADDED"),
value: track.requestedBy.toString(),
inline: true,
},
{
name: interaction.translate("music/nowplaying:T_DURATION"),
value: progressBar,
},
{
2024-04-07 15:29:16 +05:00
name: "\u200B",
2023-11-05 00:06:19 +05:00
value: `${interaction.translate("music/nowplaying:REPEAT")}: \`${translated[mode]}\``,
},
],
});
return embed;
}
2023-07-05 00:58:06 +05:00
module.exports = Nowplaying;