client/src/standalone/videos/test-embed.ts
import './test-embed.scss'
import { PeerTubeResolution, PlayerEventType } from '../embed-player-api/definitions'
import { PeerTubePlayer } from '../embed-player-api/player'
import { logger } from '../../root-helpers'
window.addEventListener('load', async () => {
const urlParts = window.location.href.split('/')
const lastPart = urlParts[urlParts.length - 1]
const isPlaylist = window.location.pathname.startsWith('/video-playlists/')
const elementId = !lastPart.includes('?') ? lastPart : lastPart.split('?')[0]
const iframe = document.createElement('iframe')
iframe.src = isPlaylist
? `/video-playlists/embed/${elementId}?api=1`
: `/videos/embed/${elementId}?api=1&waitPasswordFromEmbedAPI=1`
iframe.sandbox.add('allow-same-origin', 'allow-scripts', 'allow-popups', 'allow-forms')
const mainElement = document.querySelector('#host')
mainElement.appendChild(iframe)
logger.info('Document finished loading.')
const player = new PeerTubePlayer(document.querySelector('iframe'));
(window as any)['player'] = player
logger.info('Awaiting player ready...')
await player.setVideoPassword('toto')
await player.ready
logger.info('Player is ready.')
const updatePlaylistPosition = () => {
player.getCurrentPosition()
.then(position => {
document.getElementById('playlist-position').innerHTML = position + ''
})
}
const monitoredEvents = [
'pause',
'play',
'playbackStatusUpdate',
'playbackStatusChange'
]
monitoredEvents.forEach(e => {
player.addEventListener(e as PlayerEventType, param => {
logger.info(`PLAYER: event '${e}' received`, { param })
if (e === 'playbackStatusChange' && isPlaylist) {
updatePlaylistPosition()
}
})
if (isPlaylist) {
updatePlaylistPosition()
}
logger.info(`PLAYER: now listening for event '${e}'`)
})
let playbackRates: number[] = []
let currentRate = await player.getPlaybackRate()
const updateRates = () => {
const rateListEl = document.querySelector('#rate-list')
rateListEl.innerHTML = ''
playbackRates.forEach(rate => {
if (currentRate === rate) {
const itemEl = document.createElement('strong')
itemEl.innerText = `${rate} (active)`
itemEl.style.display = 'block'
rateListEl.appendChild(itemEl)
} else {
const itemEl = document.createElement('a')
itemEl.href = 'javascript:;'
itemEl.innerText = rate.toString()
itemEl.addEventListener('click', () => {
player.setPlaybackRate(rate)
currentRate = rate
updateRates()
})
itemEl.style.display = 'block'
rateListEl.appendChild(itemEl)
}
})
}
player.getPlaybackRates().then(rates => {
playbackRates = rates
updateRates()
})
const updateCaptions = async () => {
const captions = await player.getCaptions()
const captionEl = document.querySelector('#caption-list')
captionEl.innerHTML = ''
captions.forEach(c => {
if (c.mode === 'showing') {
const itemEl = document.createElement('strong')
itemEl.innerText = `${c.label} (active)`
itemEl.style.display = 'block'
captionEl.appendChild(itemEl)
} else {
const itemEl = document.createElement('a')
itemEl.href = 'javascript:;'
itemEl.innerText = c.label
itemEl.addEventListener('click', () => {
player.setCaption(c.id)
updateCaptions()
})
itemEl.style.display = 'block'
captionEl.appendChild(itemEl)
}
})
}
updateCaptions()
const updateResolutions = (resolutions: PeerTubeResolution[]) => {
const resolutionListEl = document.querySelector('#resolution-list')
resolutionListEl.innerHTML = ''
resolutions.forEach(resolution => {
if (resolution.active) {
const itemEl = document.createElement('strong')
itemEl.innerText = `${resolution.label} (active)`
itemEl.style.display = 'block'
resolutionListEl.appendChild(itemEl)
} else {
const itemEl = document.createElement('a')
itemEl.href = 'javascript:;'
itemEl.innerText = resolution.label
itemEl.addEventListener('click', () => {
player.setResolution(resolution.id)
})
itemEl.style.display = 'block'
resolutionListEl.appendChild(itemEl)
}
})
}
player.getResolutions().then(
resolutions => updateResolutions(resolutions))
player.addEventListener('resolutionUpdate',
resolutions => updateResolutions(resolutions))
const updateVolume = (volume: number) => {
const volumeEl = document.getElementById('volume')
volumeEl.innerText = (volume * 100) + '%'
}
player.getVolume().then(volume => updateVolume(volume))
player.addEventListener('volumeChange', volume => updateVolume(volume))
})