aboutsummaryrefslogblamecommitdiffhomepage
path: root/client/src/assets/player/shared/upnext/upnext-plugin.ts
blob: e12e8c5033ebe7370da1110cca733298550f99ca (plain) (tree)
1
2
3
4
5
6
7
8
                              
                                           
 
                                          
 
                                   
 
                                                                               





                                                 


                                                                      

     
                 
 


                                                                              









                                              
import videojs from 'video.js'
import { EndCardOptions } from './end-card'

const Plugin = videojs.getPlugin('plugin')

class UpNextPlugin extends Plugin {

  constructor (player: videojs.Player, options: Partial<EndCardOptions> = {}) {
    const settings = {
      next: options.next,
      getTitle: options.getTitle,
      timeout: options.timeout || 5000,
      cancelText: options.cancelText || 'Cancel',
      headText: options.headText || 'Up Next',
      suspendedText: options.suspendedText || 'Autoplay is suspended',
      condition: options.condition,
      suspended: options.suspended
    }

    super(player)

    // UpNext plugin can be called later, so ensure the player is not disposed
    if (this.player.isDisposed()) return

    this.player.ready(() => {
      player.addClass('vjs-upnext')
    })

    player.addChild('EndCard', settings)
  }
}

videojs.registerPlugin('upnext', UpNextPlugin)
export { UpNextPlugin }