Add timecodes for createProgressBar() method

Co-Authored-By: LePtitMetalleux <leptitmetalleux@users.noreply.github.com>
This commit is contained in:
Androz2091 2020-08-14 14:43:49 +02:00
parent 8278940e46
commit 8911bc46f1
2 changed files with 17 additions and 4 deletions

View file

@ -30,6 +30,7 @@
"dependencies": { "dependencies": {
"discord-ytdl-core": "^4.0.2", "discord-ytdl-core": "^4.0.2",
"merge-options": "^2.0.0", "merge-options": "^2.0.0",
"moment": "^2.27.0",
"node-fetch": "^2.6.0", "node-fetch": "^2.6.0",
"spotify-url-info": "^1.3.1", "spotify-url-info": "^1.3.1",
"ytpl": "^0.2.4", "ytpl": "^0.2.4",

View file

@ -3,6 +3,7 @@ const Discord = require('discord.js')
const ytsr = require('ytsr') const ytsr = require('ytsr')
const ytpl = require('ytpl') const ytpl = require('ytpl')
const spotify = require('spotify-url-info') const spotify = require('spotify-url-info')
const moment = require('moment')
const Queue = require('./Queue') const Queue = require('./Queue')
const Track = require('./Track') const Track = require('./Track')
const Util = require('./Util') const Util = require('./Util')
@ -434,25 +435,36 @@ class Player extends EventEmitter {
}) })
} }
createProgressBar (message) { createProgressBar (message, options) {
// Gets guild queue // Gets guild queue
const queue = this.queues.get(message.guild.id) const queue = this.queues.get(message.guild.id)
if (!queue) return if (!queue) return
const timecodes = options && typeof options === 'object' ? options.timecodes : false
// Stream time of the dispatcher // Stream time of the dispatcher
const currentStreamTime = queue.voiceConnection.dispatcher const currentStreamTime = queue.voiceConnection.dispatcher
? queue.voiceConnection.dispatcher.streamTime + queue.additionalStreamTime ? queue.voiceConnection.dispatcher.streamTime + queue.additionalStreamTime
: 0 : 0
// Total stream time // Total stream time
const totalTime = queue.tracks[0].durationMS const totalTime = queue.playing.durationMS
// Stream progress // Stream progress
const index = Math.round((currentStreamTime / totalTime) * 15) const index = Math.round((currentStreamTime / totalTime) * 15)
// conditions // conditions
if ((index >= 1) && (index <= 15)) { if ((index >= 1) && (index <= 15)) {
const bar = '▬▬▬▬▬▬▬▬▬▬▬▬▬▬'.split('') const bar = '▬▬▬▬▬▬▬▬▬▬▬▬▬▬'.split('')
bar.splice(index, 0, '🔘') bar.splice(index, 0, '🔘')
return bar.join('') if (timecodes) {
const currentTimecode = (currentStreamTime >= 3600000 ? moment(currentStreamTime).format('H:mm:ss') : moment(currentStreamTime).format('m:ss'))
return `${currentTimecode}${bar.join('')}${queue.playing.duration}`
} else {
return `${bar.join('')}`
}
} else { } else {
return '🔘▬▬▬▬▬▬▬▬▬▬▬▬▬▬' if (timecodes) {
const currentTimecode = (currentStreamTime >= 3600000 ? moment(currentStreamTime).format('H:mm:ss') : moment(currentStreamTime).format('m:ss'))
return `${currentTimecode} ┃ 🔘▬▬▬▬▬▬▬▬▬▬▬▬▬▬ ┃ ${queue.playing.duration}`
} else {
return '🔘▬▬▬▬▬▬▬▬▬▬▬▬▬▬'
}
} }
} }