2024-04-30 12:19:44 +05:00
|
|
|
const { SlashCommandBuilder, PermissionsBitField } = require("discord.js"),
|
|
|
|
{ QueryType } = require("discord-player");
|
2022-09-10 23:38:11 +05:00
|
|
|
const BaseCommand = require("../../base/BaseCommand");
|
2022-08-02 17:18:47 +05:00
|
|
|
|
|
|
|
class Play 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("play")
|
|
|
|
.setDescription(client.translate("music/play:DESCRIPTION"))
|
2023-06-15 19:46:27 +05:00
|
|
|
.setDescriptionLocalizations({
|
2023-07-05 00:58:06 +05:00
|
|
|
uk: client.translate("music/play:DESCRIPTION", null, "uk-UA"),
|
|
|
|
ru: client.translate("music/play: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("query")
|
|
|
|
.setDescription(client.translate("music/play:QUERY"))
|
|
|
|
.setDescriptionLocalizations({
|
|
|
|
uk: client.translate("music/play:QUERY", null, "uk-UA"),
|
|
|
|
ru: client.translate("music/play:QUERY", null, "ru-RU"),
|
|
|
|
})
|
2024-04-30 12:19:44 +05:00
|
|
|
.setRequired(true)
|
|
|
|
.setAutocomplete(true),
|
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) {
|
|
|
|
await interaction.deferReply();
|
2022-08-29 21:31:36 +05:00
|
|
|
|
2023-01-09 01:39:13 +05:00
|
|
|
const query = interaction.options.getString("query"),
|
2024-04-30 12:19:44 +05:00
|
|
|
voice = interaction.member.voice.channel;
|
|
|
|
if (!voice) return interaction.error("music/play:NO_VOICE_CHANNEL", null, { edit: true });
|
2023-01-09 01:39:13 +05:00
|
|
|
|
2024-04-30 12:19:44 +05:00
|
|
|
const perms = voice.permissionsFor(client.user);
|
2022-09-13 22:19:51 +05:00
|
|
|
if (!perms.has(PermissionsBitField.Flags.Connect) || !perms.has(PermissionsBitField.Flags.Speak)) return interaction.error("music/play:VOICE_CHANNEL_CONNECT", null, { edit: true });
|
2022-08-02 17:18:47 +05:00
|
|
|
|
2024-04-30 12:19:44 +05:00
|
|
|
const searchResult = await client.player.search(query, {
|
|
|
|
requestedBy: interaction.user,
|
2022-08-03 20:57:54 +05:00
|
|
|
});
|
|
|
|
|
2024-04-30 12:19:44 +05:00
|
|
|
if (!searchResult.hasTracks()) {
|
|
|
|
console.log(searchResult);
|
|
|
|
|
|
|
|
return interaction.error("music/play:NO_RESULT", { query }, { edit: true });
|
|
|
|
} else {
|
|
|
|
await client.player.play(voice, searchResult, {
|
|
|
|
nodeOptions: {
|
|
|
|
metadata: interaction,
|
|
|
|
},
|
|
|
|
selfDeaf: true,
|
|
|
|
leaveOnEnd: false,
|
|
|
|
leaveOnStop: true,
|
|
|
|
skipOnNoStream: true,
|
|
|
|
maxSize: 100,
|
|
|
|
maxHistorySize: 50,
|
|
|
|
});
|
|
|
|
|
|
|
|
interaction.editReply({
|
|
|
|
content: interaction.translate("music/play:ADDED_QUEUE", {
|
|
|
|
songName: searchResult.hasPlaylist() ? searchResult.playlist.title : `${searchResult.tracks[0].title} - ${searchResult.tracks[0].author}`,
|
|
|
|
}),
|
|
|
|
});
|
|
|
|
}
|
2023-03-24 00:09:26 +05:00
|
|
|
}
|
2022-08-02 17:18:47 +05:00
|
|
|
|
2023-03-24 00:09:26 +05:00
|
|
|
/**
|
|
|
|
*
|
2023-11-05 16:03:23 +05:00
|
|
|
* @param {import("../../base/Client")} client
|
2023-03-24 00:09:26 +05:00
|
|
|
* @param {import("discord.js").AutocompleteInteraction} interaction
|
|
|
|
* @returns
|
|
|
|
*/
|
2024-04-30 12:19:44 +05:00
|
|
|
async autocompleteRun(client, interaction) {
|
|
|
|
const query = interaction.options.getString("query");
|
|
|
|
if (query === "" || query === null) return;
|
|
|
|
|
|
|
|
const youtubeResults = await client.player.search(query, { searchEngine: QueryType.YOUTUBE });
|
|
|
|
const spotifyResults = await client.player.search(query, { searchEngine: QueryType.SPOTIFY_SEARCH });
|
|
|
|
const tracks = [];
|
|
|
|
|
|
|
|
youtubeResults.tracks
|
|
|
|
.slice(0, 5)
|
|
|
|
.map(t => ({
|
|
|
|
name: `YouTube: ${`${t.title} - ${t.author} (${t.duration})`.length > 75 ? `${`${t.title} - ${t.author}`.substring(0, 75)}... (${t.duration})` : `${t.title} - ${t.author} (${t.duration})`}`,
|
|
|
|
value: t.url,
|
|
|
|
}))
|
|
|
|
.forEach(t => tracks.push({ name: t.name, value: t.value }));
|
|
|
|
|
|
|
|
spotifyResults.tracks
|
|
|
|
.slice(0, 5)
|
|
|
|
.map(t => ({
|
|
|
|
name: `Spotify: ${`${t.title} - ${t.author} (${t.duration})`.length > 75 ? `${`${t.title} - ${t.author}`.substring(0, 75)}... (${t.duration})` : `${t.title} - ${t.author} (${t.duration})`}`,
|
|
|
|
value: t.url,
|
|
|
|
}))
|
|
|
|
.forEach(t => tracks.push({ name: t.name, value: t.value }));
|
|
|
|
|
|
|
|
return interaction.respond(tracks);
|
|
|
|
}
|
2022-08-02 17:18:47 +05:00
|
|
|
}
|
|
|
|
|
2023-07-05 00:58:06 +05:00
|
|
|
module.exports = Play;
|