- const promises = [ translationsPromise, captionsPromise, configPromise, PeertubePlayerManagerModulePromise ]
- const [ serverTranslations, captionsResponse, configResponse, PeertubePlayerManagerModule ] = await Promise.all(promises)
+ private nextVideoTitle () {
+ const next = this.getNextPlaylistElement()
+ if (!next) return ''
+
+ return next.video.name
+ }
+
+ private getNextPlaylistElement (position?: number): VideoPlaylistElement {
+ if (!position) position = this.currentPlaylistElement.position + 1
+
+ if (position > this.playlist.videosLength) {
+ return undefined
+ }
+
+ const next = this.playlistElements.find(e => e.position === position)
+
+ if (!next || !next.video) {
+ return this.getNextPlaylistElement(position + 1)
+ }
+
+ return next
+ }
+
+ private async buildVideoPlayer (videoResponse: Response, captionsPromise: Promise<Response>) {
+ let alreadyHadPlayer = false
+
+ if (this.player) {
+ this.player.dispose()
+ alreadyHadPlayer = true
+ }
+
+ this.playerElement = document.createElement('video')
+ this.playerElement.className = 'video-js vjs-peertube-skin'
+ this.playerElement.setAttribute('playsinline', 'true')
+ this.wrapperElement.appendChild(this.playerElement)
+
+ const videoInfoPromise = videoResponse.json()
+ .then((videoInfo: VideoDetails) => {
+ if (!alreadyHadPlayer) this.loadPlaceholder(videoInfo)
+
+ return videoInfo
+ })
+
+ const [ videoInfo, serverTranslations, captionsResponse, config, PeertubePlayerManagerModule ] = await Promise.all([
+ videoInfoPromise,
+ this.translationsPromise,
+ captionsPromise,
+ this.configPromise,
+ this.PeertubePlayerManagerModulePromise
+ ])