1 import './test-embed.scss'
2 import { PeerTubeResolution, PlayerEventType } from '../player/definitions'
3 import { PeerTubePlayer } from '../player/player'
5 window.addEventListener('load', async () => {
6 const urlParts = window.location.href.split('/')
7 const lastPart = urlParts[urlParts.length - 1]
9 const isPlaylist = window.location.pathname.startsWith('/video-playlists/')
11 const elementId = !lastPart.includes('?') ? lastPart : lastPart.split('?')[0]
13 const iframe = document.createElement('iframe')
14 iframe.src = isPlaylist
15 ? `/video-playlists/embed/${elementId}?api=1`
16 : `/videos/embed/${elementId}?api=1`
18 const mainElement = document.querySelector('#host')
19 mainElement.appendChild(iframe)
21 console.log('Document finished loading.')
22 const player = new PeerTubePlayer(document.querySelector('iframe'))
24 window['player'] = player
26 console.log('Awaiting player ready...')
28 console.log('Player is ready.')
30 const monitoredEvents = [
33 'playbackStatusUpdate',
34 'playbackStatusChange'
37 monitoredEvents.forEach(e => {
38 player.addEventListener(e as PlayerEventType, (param) => console.log(`PLAYER: event '${e}' received`, param))
39 console.log(`PLAYER: now listening for event '${e}'`)
41 player.getCurrentPosition()
43 document.getElementById('playlist-position').innerHTML = position + ''
47 let playbackRates: number[] = []
48 let currentRate = await player.getPlaybackRate()
50 const updateRates = () => {
51 const rateListEl = document.querySelector('#rate-list')
52 rateListEl.innerHTML = ''
54 playbackRates.forEach(rate => {
55 if (currentRate === rate) {
56 const itemEl = document.createElement('strong')
57 itemEl.innerText = `${rate} (active)`
58 itemEl.style.display = 'block'
59 rateListEl.appendChild(itemEl)
61 const itemEl = document.createElement('a')
62 itemEl.href = 'javascript:;'
63 itemEl.innerText = rate.toString()
64 itemEl.addEventListener('click', () => {
65 player.setPlaybackRate(rate)
69 itemEl.style.display = 'block'
70 rateListEl.appendChild(itemEl)
75 player.getPlaybackRates().then(rates => {
80 const updateCaptions = async () => {
81 const captions = await player.getCaptions()
83 const captionEl = document.querySelector('#caption-list')
84 captionEl.innerHTML = ''
86 captions.forEach(c => {
87 if (c.mode === 'showing') {
88 const itemEl = document.createElement('strong')
89 itemEl.innerText = `${c.label} (active)`
90 itemEl.style.display = 'block'
91 captionEl.appendChild(itemEl)
93 const itemEl = document.createElement('a')
94 itemEl.href = 'javascript:;'
95 itemEl.innerText = c.label
96 itemEl.addEventListener('click', () => {
97 player.setCaption(c.id)
100 itemEl.style.display = 'block'
101 captionEl.appendChild(itemEl)
108 const updateResolutions = (resolutions: PeerTubeResolution[]) => {
109 const resolutionListEl = document.querySelector('#resolution-list')
110 resolutionListEl.innerHTML = ''
112 resolutions.forEach(resolution => {
113 if (resolution.active) {
114 const itemEl = document.createElement('strong')
115 itemEl.innerText = `${resolution.label} (active)`
116 itemEl.style.display = 'block'
117 resolutionListEl.appendChild(itemEl)
119 const itemEl = document.createElement('a')
120 itemEl.href = 'javascript:;'
121 itemEl.innerText = resolution.label
122 itemEl.addEventListener('click', () => {
123 player.setResolution(resolution.id)
125 itemEl.style.display = 'block'
126 resolutionListEl.appendChild(itemEl)
131 player.getResolutions().then(
132 resolutions => updateResolutions(resolutions))
133 player.addEventListener('resolutionUpdate',
134 resolutions => updateResolutions(resolutions))
136 const updateVolume = (volume: number) => {
137 const volumeEl = document.getElementById('volume')
138 volumeEl.innerText = (volume * 100) + '%'
141 player.getVolume().then(volume => updateVolume(volume))
142 player.addEventListener('volumeChange', volume => updateVolume(volume))