completed the queue system

This commit is contained in:
Hazem Krimi
2020-05-08 15:53:05 +01:00
parent c8a9ddf8d2
commit a2994edb7f
2 changed files with 98 additions and 1 deletions
+46
View File
@@ -0,0 +1,46 @@
const { Command } = require('discord.js-commando');
const { MessageEmbed } = require('discord.js');
module.exports = class Play extends Command {
constructor(client) {
super(client, {
name: 'queue',
memberName: 'queue',
group: 'music',
description: 'shows the queue',
guildOnly: true,
throttling: {
usages: 1,
duration: 5
}
});
}
run = async message => {
try {
if (message.guild.music.queue.length === 0 && !message.guild.music.nowPlaying) {
const embed = new MessageEmbed().setColor('#000099').setTitle(':musical_note: Queue is empty');
return await message.say({ embed });
} else {
const embed = new MessageEmbed().setColor('#000099').setTitle(':musical_note: Queue');
embed.addField('Now playing', message.guild.music.nowPlaying.title).addField('Duration', `${message.guild.music.nowPlaying.playingFor.string}/${message.guild.music.nowPlaying.duration.string}`);
if (message.guild.music.queue.length === 0) embed.addField('Queue', 'nothing in the queue');
else embed.addField('Queue', `${message.guild.music.queue.length} track(s)`);
message.guild.music.queue.forEach((item, index) => {
let itemString = `${item.title}`;
if (item.type === 'youtube' || item.type === 'search' || item.type === 'facebook') itemString += ` By ${item.by}`;
embed.addField(index + 1, itemString);
});
return await message.say({ embed });
}
} catch(err) {
console.error(err);
const embed = new MessageEmbed().setColor('#ff0000').setTitle(':x: Error occured, if you are my creator please fix me soon');
return message.say({ embed });
}
}
}
+52 -1
View File
@@ -11,9 +11,60 @@ Structures.extend('Guild', Guild => {
isPlaying: false, isPlaying: false,
nowPlaying: null, nowPlaying: null,
volume: 1, volume: 1,
dispatcher: null dispatcher: null,
sfx: {
earrape: false
}
}; };
} }
startCounter = message => {
if (!message.guild.music.nowPlaying.playingFor) message.guild.music.nowPlaying.playingFor = { hours: 0, minutes: 0, seconds: 0, string: '00:00:00' };
const interval = setInterval(() => {
if (!message.guild.music.nowPlaying || message.guild.music.paused) clearInterval(interval);
else if (message.guild.music.nowPlaying.playingFor.seconds === 60) {
message.guild.music.nowPlaying.playingFor = {
hours: message.guild.music.nowPlaying.playingFor.hours,
minutes: message.guild.music.nowPlaying.playingFor.minutes + 1,
seconds: 0,
string: this.formatDuration({
hours: message.guild.music.nowPlaying.playingFor.hours,
minutes: message.guild.music.nowPlaying.playingFor.minutes + 1,
seconds: 0
})
};
}
else if (message.guild.music.nowPlaying.playingFor.minutes === 60) {
message.guild.music.nowPlaying.playingFor = {
hours: message.guild.music.nowPlaying.playingFor.hours + 1,
minutes: 0,
seconds: 0,
string: this.formatDuration({
hours: message.guild.music.nowPlaying.playingFor.hours + 1,
minutes: 0,
seconds: 0
})
};
}
else {
message.guild.music.nowPlaying.playingFor = {
hours: message.guild.music.nowPlaying.playingFor.hours,
minutes: message.guild.music.nowPlaying.playingFor.minutes,
seconds: message.guild.music.nowPlaying.playingFor.seconds + 1,
string: this.formatDuration({
hours: message.guild.music.nowPlaying.playingFor.hours,
minutes: message.guild.music.nowPlaying.playingFor.minutes,
seconds: message.guild.music.nowPlaying.playingFor.seconds + 1
})
};
}
}, 1000);
}
formatDuration = durationObject => {
return `${durationObject.hours < 10 ? '0' + durationObject.hours : durationObject.hours ? durationObject.hours : '00'}:${durationObject.minutes < 10 ? '0' + durationObject.minutes : durationObject.minutes ? durationObject.minutes : '00'}:${durationObject.seconds < 10 ? '0' + durationObject.seconds : durationObject.seconds ? durationObject.seconds : '00'}`;
}
} }
return MusicGuild; return MusicGuild;