aboutsummaryrefslogtreecommitdiffhomepage
path: root/client/src/assets/player/theater-button.ts
diff options
context:
space:
mode:
authorChocobozzz <me@florianbigard.com>2019-01-23 15:36:45 +0100
committerChocobozzz <chocobozzz@cpy.re>2019-02-11 09:13:02 +0100
commit2adfc7ea9a1f858db874df9fe322e7ae833db77c (patch)
treee27c6ebe01b7c96ea0e053839a38fc1f824d1284 /client/src/assets/player/theater-button.ts
parent7eeb6a0ba4028d0e20847b846332dd0b7747c7f8 (diff)
downloadPeerTube-2adfc7ea9a1f858db874df9fe322e7ae833db77c.tar.gz
PeerTube-2adfc7ea9a1f858db874df9fe322e7ae833db77c.tar.zst
PeerTube-2adfc7ea9a1f858db874df9fe322e7ae833db77c.zip
Refractor videojs player
Add fake p2p-media-loader plugin
Diffstat (limited to 'client/src/assets/player/theater-button.ts')
-rw-r--r--client/src/assets/player/theater-button.ts50
1 files changed, 0 insertions, 50 deletions
diff --git a/client/src/assets/player/theater-button.ts b/client/src/assets/player/theater-button.ts
deleted file mode 100644
index 4f8fede3d..000000000
--- a/client/src/assets/player/theater-button.ts
+++ /dev/null
@@ -1,50 +0,0 @@
1// FIXME: something weird with our path definition in tsconfig and typings
2// @ts-ignore
3import * as videojs from 'video.js'
4
5import { VideoJSComponentInterface, videojsUntyped } from './peertube-videojs-typings'
6import { saveTheaterInStore, getStoredTheater } from './peertube-player-local-storage'
7
8const Button: VideoJSComponentInterface = videojsUntyped.getComponent('Button')
9class TheaterButton extends Button {
10
11 private static readonly THEATER_MODE_CLASS = 'vjs-theater-enabled'
12
13 constructor (player: videojs.Player, options: any) {
14 super(player, options)
15
16 const enabled = getStoredTheater()
17 if (enabled === true) {
18 this.player_.addClass(TheaterButton.THEATER_MODE_CLASS)
19 this.handleTheaterChange()
20 }
21 }
22
23 buildCSSClass () {
24 return `vjs-theater-control ${super.buildCSSClass()}`
25 }
26
27 handleTheaterChange () {
28 if (this.isTheaterEnabled()) {
29 this.controlText('Normal mode')
30 } else {
31 this.controlText('Theater mode')
32 }
33
34 saveTheaterInStore(this.isTheaterEnabled())
35 }
36
37 handleClick () {
38 this.player_.toggleClass(TheaterButton.THEATER_MODE_CLASS)
39
40 this.handleTheaterChange()
41 }
42
43 private isTheaterEnabled () {
44 return this.player_.hasClass(TheaterButton.THEATER_MODE_CLASS)
45 }
46}
47
48TheaterButton.prototype.controlText_ = 'Theater mode'
49
50TheaterButton.registerComponent('TheaterButton', TheaterButton)