]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/standalone/videos/test-embed.ts
Speed up client lint
[github/Chocobozzz/PeerTube.git] / client / src / standalone / videos / test-embed.ts
CommitLineData
99941732 1import './test-embed.scss'
9054a8b6 2import { PeerTubeResolution, PlayerEventType } from '../player/definitions'
902aa3a0 3import { PeerTubePlayer } from '../player/player'
99941732
WL
4
5window.addEventListener('load', async () => {
99941732 6 const urlParts = window.location.href.split('/')
9df52d66 7 const lastPart = urlParts[urlParts.length - 1]
9054a8b6
C
8
9 const isPlaylist = window.location.pathname.startsWith('/video-playlists/')
10
e5a818d3 11 const elementId = !lastPart.includes('?') ? lastPart : lastPart.split('?')[0]
99941732 12
c4710631 13 const iframe = document.createElement('iframe')
9054a8b6 14 iframe.src = isPlaylist
7a13d032
C
15 ? `/video-playlists/embed/${elementId}?api=1`
16 : `/videos/embed/${elementId}?api=1`
6377a9f2 17
c4710631 18 const mainElement = document.querySelector('#host')
902aa3a0 19 mainElement.appendChild(iframe)
99941732 20
9df52d66 21 console.log('Document finished loading.')
c4710631 22 const player = new PeerTubePlayer(document.querySelector('iframe'))
99941732 23
9df52d66 24 window['player'] = player
99941732 25
9df52d66 26 console.log('Awaiting player ready...')
99941732 27 await player.ready
9df52d66 28 console.log('Player is ready.')
99941732 29
c4710631 30 const monitoredEvents = [
902aa3a0
C
31 'pause',
32 'play',
33 'playbackStatusUpdate',
99941732
WL
34 'playbackStatusChange'
35 ]
36
37 monitoredEvents.forEach(e => {
5ab994fe 38 player.addEventListener(e as PlayerEventType, (param) => console.log(`PLAYER: event '${e}' received`, param))
99941732 39 console.log(`PLAYER: now listening for event '${e}'`)
9054a8b6
C
40
41 player.getCurrentPosition()
9df52d66
C
42 .then(position => {
43 document.getElementById('playlist-position').innerHTML = position + ''
44 })
99941732
WL
45 })
46
902aa3a0 47 let playbackRates: number[] = []
99941732
WL
48 let currentRate = await player.getPlaybackRate()
49
c4710631
C
50 const updateRates = async () => {
51 const rateListEl = document.querySelector('#rate-list')
99941732 52 rateListEl.innerHTML = ''
902aa3a0 53
99941732 54 playbackRates.forEach(rate => {
902aa3a0 55 if (currentRate === rate) {
c4710631 56 const itemEl = document.createElement('strong')
99941732
WL
57 itemEl.innerText = `${rate} (active)`
58 itemEl.style.display = 'block'
59 rateListEl.appendChild(itemEl)
60 } else {
c4710631 61 const itemEl = document.createElement('a')
99941732 62 itemEl.href = 'javascript:;'
a7c9cbb5 63 itemEl.innerText = rate.toString()
99941732
WL
64 itemEl.addEventListener('click', () => {
65 player.setPlaybackRate(rate)
66 currentRate = rate
67 updateRates()
68 })
69 itemEl.style.display = 'block'
70 rateListEl.appendChild(itemEl)
71 }
72 })
73 }
74
75 player.getPlaybackRates().then(rates => {
76 playbackRates = rates
77 updateRates()
78 })
79
1151f521
C
80 const updateCaptions = async () => {
81 const captions = await player.getCaptions()
82
83 const captionEl = document.querySelector('#caption-list')
84 captionEl.innerHTML = ''
85
86 captions.forEach(c => {
87 console.log(c)
88
89 if (c.mode === 'showing') {
90 const itemEl = document.createElement('strong')
91 itemEl.innerText = `${c.label} (active)`
92 itemEl.style.display = 'block'
93 captionEl.appendChild(itemEl)
94 } else {
95 const itemEl = document.createElement('a')
96 itemEl.href = 'javascript:;'
97 itemEl.innerText = c.label
98 itemEl.addEventListener('click', () => {
99 player.setCaption(c.id)
100 updateCaptions()
101 })
102 itemEl.style.display = 'block'
103 captionEl.appendChild(itemEl)
104 }
105 })
106 }
107
108 updateCaptions()
109
9df52d66 110 const updateResolutions = (resolutions: PeerTubeResolution[]) => {
c4710631 111 const resolutionListEl = document.querySelector('#resolution-list')
99941732
WL
112 resolutionListEl.innerHTML = ''
113
c199c427 114 resolutions.forEach(resolution => {
99941732 115 if (resolution.active) {
c4710631 116 const itemEl = document.createElement('strong')
99941732
WL
117 itemEl.innerText = `${resolution.label} (active)`
118 itemEl.style.display = 'block'
119 resolutionListEl.appendChild(itemEl)
120 } else {
c4710631 121 const itemEl = document.createElement('a')
99941732
WL
122 itemEl.href = 'javascript:;'
123 itemEl.innerText = resolution.label
124 itemEl.addEventListener('click', () => {
125 player.setResolution(resolution.id)
126 })
127 itemEl.style.display = 'block'
128 resolutionListEl.appendChild(itemEl)
129 }
130 })
9df52d66 131 }
99941732
WL
132
133 player.getResolutions().then(
134 resolutions => updateResolutions(resolutions))
902aa3a0 135 player.addEventListener('resolutionUpdate',
99941732 136 resolutions => updateResolutions(resolutions))
6377a9f2
C
137
138 const updateVolume = (volume: number) => {
139 const volumeEl = document.getElementById('volume')
140 volumeEl.innerText = (volume * 100) + '%'
141 }
142
143 player.getVolume().then(volume => updateVolume(volume))
144 player.addEventListener('volumeChange', volume => updateVolume(volume))
902aa3a0 145})