aboutsummaryrefslogtreecommitdiffhomepage
path: root/client/src/assets/player/playlist/playlist-plugin.ts
blob: b69d82e3c4bd69c11bc06e2fe123b5a733e767cf (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import videojs from 'video.js'
import { PlaylistPluginOptions } from '../peertube-videojs-typings'
import { PlaylistButton } from './playlist-button'
import { PlaylistMenu } from './playlist-menu'

const Plugin = videojs.getPlugin('plugin')

class PlaylistPlugin extends Plugin {
  private playlistMenu: PlaylistMenu
  private playlistButton: PlaylistButton
  private options: PlaylistPluginOptions

  constructor (player: videojs.Player, options?: PlaylistPluginOptions) {
    super(player, options)

    this.options = options

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

    this.playlistMenu = new PlaylistMenu(player, options)
    this.playlistButton = new PlaylistButton(player, Object.assign({}, options, { playlistMenu: this.playlistMenu }))

    player.addChild(this.playlistMenu, options)
    player.addChild(this.playlistButton, options)
  }

  updateSelected () {
    this.playlistMenu.updateSelected(this.options.getCurrentPosition())
  }
}

videojs.registerPlugin('playlist', PlaylistPlugin)
export { PlaylistPlugin }