mirror of
https://github.com/BluemediaDev/muse.git
synced 2025-01-19 03:18:56 +01:00
Add play immediate feature
This commit is contained in:
parent
91da6d0064
commit
d61107aedd
|
@ -21,7 +21,9 @@ export default class implements Command {
|
||||||
['play https://www.youtube.com/watch?list=PLi9drqWffJ9FWBo7ZVOiaVy0UQQEm4IbP', 'adds the playlist to the queue'],
|
['play https://www.youtube.com/watch?list=PLi9drqWffJ9FWBo7ZVOiaVy0UQQEm4IbP', 'adds the playlist to the queue'],
|
||||||
['play https://open.spotify.com/track/3ebXMykcMXOcLeJ9xZ17XH?si=tioqSuyMRBWxhThhAW51Ig', 'plays a song from Spotify'],
|
['play https://open.spotify.com/track/3ebXMykcMXOcLeJ9xZ17XH?si=tioqSuyMRBWxhThhAW51Ig', 'plays a song from Spotify'],
|
||||||
['play https://open.spotify.com/album/5dv1oLETxdsYOkS2Sic00z?si=bDa7PaloRx6bMIfKdnvYQw', 'adds all songs from album to the queue'],
|
['play https://open.spotify.com/album/5dv1oLETxdsYOkS2Sic00z?si=bDa7PaloRx6bMIfKdnvYQw', 'adds all songs from album to the queue'],
|
||||||
['play https://open.spotify.com/playlist/37i9dQZF1DX94qaYRnkufr?si=r2fOVL_QQjGxFM5MWb84Xw', 'adds all songs from playlist to the queue']
|
['play https://open.spotify.com/playlist/37i9dQZF1DX94qaYRnkufr?si=r2fOVL_QQjGxFM5MWb84Xw', 'adds all songs from playlist to the queue'],
|
||||||
|
['play cool music immediate', 'adds the first search result for "cool music" to the front of the queue'],
|
||||||
|
['play cool music i', 'adds the first search result for "cool music" to the front of the queue']
|
||||||
];
|
];
|
||||||
|
|
||||||
public requiresVC = true;
|
public requiresVC = true;
|
||||||
|
@ -64,6 +66,8 @@ export default class implements Command {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const addToFrontOfQueue = args[args.length - 1] === 'i' || args[args.length - 1] === 'immediate';
|
||||||
|
|
||||||
const newSongs: QueuedSong[] = [];
|
const newSongs: QueuedSong[] = [];
|
||||||
let extraMsg = '';
|
let extraMsg = '';
|
||||||
|
|
||||||
|
@ -112,7 +116,7 @@ export default class implements Command {
|
||||||
}
|
}
|
||||||
} catch (_: unknown) {
|
} catch (_: unknown) {
|
||||||
// Not a URL, must search YouTube
|
// Not a URL, must search YouTube
|
||||||
const query = args.join(' ');
|
const query = addToFrontOfQueue ? args.slice(0, args.length - 1).join(' ') : args.join(' ');
|
||||||
|
|
||||||
const song = await this.getSongs.youtubeVideoSearch(query);
|
const song = await this.getSongs.youtubeVideoSearch(query);
|
||||||
|
|
||||||
|
@ -129,7 +133,7 @@ export default class implements Command {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
newSongs.forEach(song => player.add(song));
|
newSongs.forEach(song => player.add(song, {immediate: addToFrontOfQueue}));
|
||||||
|
|
||||||
const firstSong = newSongs[0];
|
const firstSong = newSongs[0];
|
||||||
|
|
||||||
|
@ -138,7 +142,7 @@ export default class implements Command {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (newSongs.length === 1) {
|
if (newSongs.length === 1) {
|
||||||
await res.stop(`u betcha, **${firstSong.title}** added to the queue${extraMsg}`);
|
await res.stop(`u betcha, **${firstSong.title}** added to the${addToFrontOfQueue ? ' front of the' : ''} queue${extraMsg}`);
|
||||||
} else {
|
} else {
|
||||||
await res.stop(`u betcha, **${firstSong.title}** and ${newSongs.length - 1} other songs were added to the queue${extraMsg}`);
|
await res.stop(`u betcha, **${firstSong.title}** and ${newSongs.length - 1} other songs were added to the queue${extraMsg}`);
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,9 @@ export default class implements Command {
|
||||||
const queueSize = player.queueSize();
|
const queueSize = player.queueSize();
|
||||||
const queuePage = args[0] ? parseInt(args[0], 10) : 1;
|
const queuePage = args[0] ? parseInt(args[0], 10) : 1;
|
||||||
|
|
||||||
if (queuePage * PAGE_SIZE > queueSize && queuePage > Math.ceil((queueSize + 1) / PAGE_SIZE)) {
|
const maxQueuePage = Math.ceil((queueSize + 1) / PAGE_SIZE);
|
||||||
|
|
||||||
|
if (queuePage > maxQueuePage) {
|
||||||
await msg.channel.send(errorMsg('the queue isn\'t that big'));
|
await msg.channel.send(errorMsg('the queue isn\'t that big'));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -70,6 +72,8 @@ export default class implements Command {
|
||||||
embed.addField(`${(i + 1 + queuePageBegin).toString()}/${queueSize.toString()}`, song.title, false);
|
embed.addField(`${(i + 1 + queuePageBegin).toString()}/${queueSize.toString()}`, song.title, false);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
embed.addField('Page', `${queuePage} out of ${maxQueuePage}`, false);
|
||||||
|
|
||||||
await msg.channel.send(embed);
|
await msg.channel.send(embed);
|
||||||
} else {
|
} else {
|
||||||
await msg.channel.send('queue empty');
|
await msg.channel.send('queue empty');
|
||||||
|
|
Loading…
Reference in a new issue