import * as vjs from 'video.js'
import * as Channel from 'jschannel'
-import { VideoDetails } from '../../../../shared'
+import { ResultList, VideoDetails } from '../../../../shared'
import { addContextMenu, getVideojsOptions, loadLocale } from '../../assets/player/peertube-player'
import { PeerTubeResolution } from '../player/definitions'
+import { VideoJSCaption } from '../../assets/player/peertube-videojs-typings'
+import { VideoCaption } from '../../../../shared/models/videos/video-caption.model'
/**
* Embed API exposes control of the embed player to the outside world via
return fetch(this.getVideoUrl(videoId))
}
+ loadVideoCaptions (videoId: string): Promise<Response> {
+ return fetch(this.getVideoUrl(videoId) + '/captions')
+ }
+
removeElement (element: HTMLElement) {
element.parentElement.removeChild(element)
}
const videoId = lastPart.indexOf('?') === -1 ? lastPart : lastPart.split('?')[ 0 ]
await loadLocale(window.location.origin, vjs, navigator.language)
- let response = await this.loadVideoInfo(videoId)
+ const [ videoResponse, captionsResponse ] = await Promise.all([
+ this.loadVideoInfo(videoId),
+ this.loadVideoCaptions(videoId)
+ ])
- if (!response.ok) {
- if (response.status === 404) return this.videoNotFound(this.videoElement)
+ if (!videoResponse.ok) {
+ if (videoResponse.status === 404) return this.videoNotFound(this.videoElement)
return this.videoFetchError(this.videoElement)
}
- const videoInfo: VideoDetails = await response.json()
+ const videoInfo: VideoDetails = await videoResponse.json()
+ let videoCaptions: VideoJSCaption[] = []
+ if (captionsResponse.ok) {
+ const { data } = (await captionsResponse.json()) as ResultList<VideoCaption>
+ videoCaptions = data.map(c => ({
+ label: c.language.label,
+ language: c.language.id,
+ src: window.location.origin + c.captionPath
+ }))
+ }
this.loadParams()
loop: this.loop,
startTime: this.startTime,
+ videoCaptions,
inactivityTimeout: 1500,
videoViewUrl: this.getVideoUrl(videoId) + '/views',
playerElement: this.videoElement,
}
addContextMenu(this.player, window.location.origin + videoInfo.embedPath)
+
this.initializeApi()
})
}