Essem
40223ec8b5
* Load commands recursively * Sort commands * Missed a couple of spots * missed even more spots apparently * Ported commands in "fun" category to new class-based format, added babel eslint plugin * Ported general commands, removed old/unneeded stuff, replaced moment with day, many more fixes I lost track of * Missed a spot * Removed unnecessary abort-controller package, add deprecation warning for mongo database * Added imagereload, clarified premature end message * Fixed docker-compose path issue, added total bot uptime to stats, more fixes for various parts * Converted image commands into classes, fixed reload, ignore another WS event, cleaned up command handler and image runner * Converted music/soundboard commands to class format * Cleanup unnecessary logs * awful tag command class port * I literally somehow just learned that you can leave out the constructor in classes * Pass client directly to commands/events, cleaned up command handler * Migrated bot to eris-sharder, fixed some error handling stuff * Remove unused modules * Fixed type returning * Switched back to Eris stable * Some fixes and cleanup * might wanna correct this * Implement image command ratelimiting * Added Bot token prefix, added imagestats, added running endpoint to API
49 lines
No EOL
2.2 KiB
JavaScript
49 lines
No EOL
2.2 KiB
JavaScript
const fetch = require("node-fetch");
|
||
const day = require("dayjs");
|
||
const duration = require("dayjs/plugin/duration");
|
||
day.extend(duration);
|
||
const MusicCommand = require("../../classes/musicCommand.js");
|
||
|
||
class NowPlayingCommand extends MusicCommand {
|
||
async run() {
|
||
if (process.env.NODE_ENV === "production") return "Music commands are coming soon, but they aren't ready yet. Stay tuned to @esmBot_ on Twitter for updates!";
|
||
|
||
if (!this.message.channel.guild) return `${this.message.author.mention}, this command only works in servers!`;
|
||
if (!this.message.member.voiceState.channelID) return `${this.message.author.mention}, you need to be in a voice channel first!`;
|
||
if (!this.message.channel.guild.members.get(this.client.user.id).voiceState.channelID) return `${this.message.author.mention}, I'm not in a voice channel!`;
|
||
const player = this.connection.player;
|
||
if (!player) return `${this.message.author.mention}, I'm not playing anything!`;
|
||
const track = await fetch(`http://${player.node.host}:${player.node.port}/decodetrack?track=${encodeURIComponent(player.track)}`, { headers: { Authorization: player.node.password } }).then(res => res.json());
|
||
const parts = Math.floor((player.state.position / track.length) * 10);
|
||
return {
|
||
"embed": {
|
||
"color": 16711680,
|
||
"author": {
|
||
"name": "Now Playing",
|
||
"icon_url": this.client.user.avatarURL
|
||
},
|
||
"fields": [{
|
||
"name": "ℹ️ Title:",
|
||
"value": track.title ? track.title : "Unknown"
|
||
},
|
||
{
|
||
"name": "🎤 Artist:",
|
||
"value": track.author ? track.author : "Unknown"
|
||
},
|
||
{
|
||
"name": "💬 Channel:",
|
||
"value": this.message.channel.guild.channels.get(this.message.member.voiceState.channelID).name
|
||
},
|
||
{
|
||
"name": `${"▬".repeat(parts)}🔘${"▬".repeat(10 - parts)}`,
|
||
"value": `${day.duration(player.state.position).format("m:ss", { trim: false })}/${track.isStream ? "∞" : day.duration(track.length).format("m:ss", { trim: false })}`
|
||
}]
|
||
}
|
||
};
|
||
}
|
||
|
||
static description = "Shows the currently playing song";
|
||
static aliases = ["playing", "np"];
|
||
}
|
||
|
||
module.exports = NowPlayingCommand; |