forward error in event
This commit is contained in:
parent
0bd665b64d
commit
42c2b22d10
1 changed files with 12 additions and 6 deletions
|
@ -1145,7 +1145,9 @@ export class Player extends EventEmitter {
|
||||||
queue.tracks.push(track);
|
queue.tracks.push(track);
|
||||||
this.emit(PlayerEvents.QUEUE_CREATE, message, queue);
|
this.emit(PlayerEvents.QUEUE_CREATE, message, queue);
|
||||||
resolve(queue);
|
resolve(queue);
|
||||||
this._playTrack(queue, true);
|
this._playTrack(queue, true).catch((e) => {
|
||||||
|
this.emit(PlayerEvents.ERROR, e, queue.firstMessage, queue.playing);
|
||||||
|
});
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
this.queues.delete(message.guild.id);
|
this.queues.delete(message.guild.id);
|
||||||
|
@ -1164,7 +1166,7 @@ export class Player extends EventEmitter {
|
||||||
private async _playTrack(queue: Queue, firstPlay: boolean): Promise<void> {
|
private async _playTrack(queue: Queue, firstPlay: boolean): Promise<void> {
|
||||||
if (queue.stopped) return;
|
if (queue.stopped) return;
|
||||||
|
|
||||||
if (!(queue.autoPlay && ['youtube', 'spotify'].includes(queue.playing.source)) && queue.tracks.length === 1 && !queue.loopMode && !queue.repeatMode && !firstPlay) {
|
if (!(queue.autoPlay && ['youtube', 'spotify'].includes(queue.playing?.source)) && queue.tracks.length === 1 && !queue.loopMode && !queue.repeatMode && !firstPlay) {
|
||||||
if (this.options.leaveOnEnd && !queue.stopped) {
|
if (this.options.leaveOnEnd && !queue.stopped) {
|
||||||
this.queues.delete(queue.guildID);
|
this.queues.delete(queue.guildID);
|
||||||
const timeout = setTimeout(() => {
|
const timeout = setTimeout(() => {
|
||||||
|
@ -1185,7 +1187,7 @@ export class Player extends EventEmitter {
|
||||||
if (queue.autoPlay && !queue.repeatMode && !firstPlay) {
|
if (queue.autoPlay && !queue.repeatMode && !firstPlay) {
|
||||||
const oldTrack = queue.tracks.shift();
|
const oldTrack = queue.tracks.shift();
|
||||||
|
|
||||||
const info = ['youtube', 'spotify'].includes(oldTrack.raw.source) ? await ytdl.getInfo((oldTrack as any).backupLink ?? oldTrack.url).catch((e) => {}) : null;
|
const info = ['youtube', 'spotify'].includes(oldTrack?.raw.source) ? await ytdl.getInfo((oldTrack as any).backupLink ?? oldTrack.url).catch((e) => {}) : null;
|
||||||
if (info) {
|
if (info) {
|
||||||
const res = await Util.ytSearch(info.related_videos[0].title, {
|
const res = await Util.ytSearch(info.related_videos[0].title, {
|
||||||
player: this,
|
player: this,
|
||||||
|
@ -1210,8 +1212,12 @@ export class Player extends EventEmitter {
|
||||||
const track = queue.playing;
|
const track = queue.playing;
|
||||||
|
|
||||||
queue.lastSkipped = false;
|
queue.lastSkipped = false;
|
||||||
this._playStream(queue, false).then(() => {
|
this._playStream(queue, false)
|
||||||
|
.then(() => {
|
||||||
if (!firstPlay) this.emit(PlayerEvents.TRACK_START, queue.firstMessage, track, queue);
|
if (!firstPlay) this.emit(PlayerEvents.TRACK_START, queue.firstMessage, track, queue);
|
||||||
|
})
|
||||||
|
.catch((e) => {
|
||||||
|
this.emit(PlayerEvents.ERROR, e, queue.firstMessage, queue.playing);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue