},
{
urls: 'stun:stun.framasoft.org'
- },
- {
- urls: 'stun:stun.l.google.com:19302'
}
]
}
this.playerElement = options.playerElement
this.player.ready(() => {
- this.initializePlayer(options)
+ this.initializePlayer()
this.runTorrentInfoScheduler()
this.runViewAdd()
})
const options = { autoplay: true, controls: true }
renderVideo(torrent.files[0], this.playerElement, options,(err, renderer) => {
+ this.renderer = renderer
+
if (err) return this.fallbackToHttp()
- this.renderer = renderer
if (!this.player.paused()) {
const playPromise = this.player.play()
if (playPromise !== undefined) return playPromise.then(done)
this.updateVideoFile(undefined, () => this.player.play())
}
- private initializePlayer (options: PeertubePluginOptions) {
+ private initializePlayer () {
+ this.initSmoothProgressBar()
+
if (this.autoplay === true) {
this.updateVideoFile(undefined, () => this.player.play())
} else {
private disableErrorDisplay () {
this.player.removeClass('vjs-error-display-enabled')
}
+
+ // Thanks: https://github.com/videojs/video.js/issues/4460#issuecomment-312861657
+ private initSmoothProgressBar () {
+ const SeekBar = videojsUntyped.getComponent('SeekBar')
+ SeekBar.prototype.getPercent = function getPercent () {
+ // Allows for smooth scrubbing, when player can't keep up.
+ // const time = (this.player_.scrubbing()) ?
+ // this.player_.getCache().currentTime :
+ // this.player_.currentTime()
+ const time = this.player_.currentTime()
+ const percent = time / this.player_.duration()
+ return percent >= 1 ? 1 : percent
+ }
+ SeekBar.prototype.handleMouseMove = function handleMouseMove (event) {
+ let newTime = this.calculateDistance(event) * this.player_.duration()
+ if (newTime === this.player_.duration()) {
+ newTime = newTime - 0.1
+ }
+ this.player_.currentTime(newTime)
+ this.update()
+ }
+ }
}
videojsUntyped.registerPlugin('peertube', PeerTubePlugin)