mirror of
https://github.com/hazemKrimi/discord-bot.git
synced 2026-05-01 18:30:25 +00:00
55 lines
2.4 KiB
JavaScript
55 lines
2.4 KiB
JavaScript
const { Command } = require('discord.js-commando');
|
|
const { MessageEmbed } = require('discord.js');
|
|
const winston = require('winston');
|
|
|
|
const logger = winston.createLogger({
|
|
transports: [
|
|
new winston.transports.Console(),
|
|
new winston.transports.File({ filename: 'logs.log' }),
|
|
],
|
|
format: winston.format.combine(
|
|
winston.format.printf(log => `${new Date().toLocaleDateString()} ${new Date().toLocaleTimeString()} - [${log.level.toUpperCase()}] - ${log.message}`),
|
|
)
|
|
});
|
|
|
|
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: 3
|
|
}
|
|
});
|
|
}
|
|
|
|
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');
|
|
const time = message.guild.music.seek ? message.guild.music.dispatcher.streamTime + message.guild.music.seek * 1000 : message.guild.music.dispatcher.streamTime;
|
|
const timeString = message.guild.formatDurationString(new Date(time).getUTCHours(), new Date(time).getUTCMinutes(), new Date(time).getSeconds());
|
|
|
|
embed.addField('Now playing', message.guild.music.nowPlaying.title).addField('Duration', `${timeString}/${message.guild.music.nowPlaying.duration}`);
|
|
|
|
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) => embed.addField(index + 1, `${item.title} ${item.by && `By ${item.by}`}`));
|
|
|
|
return await message.say({ embed });
|
|
}
|
|
} catch(err) {
|
|
logger.log('error', err);
|
|
const embed = new MessageEmbed().setColor('#ff0000').setTitle(`:x: Error occured: ${err.message}`);
|
|
return message.say({ embed });
|
|
}
|
|
}
|
|
} |