aboutsummaryrefslogtreecommitdiffhomepage
path: root/client/src/standalone/videos
diff options
context:
space:
mode:
Diffstat (limited to 'client/src/standalone/videos')
-rw-r--r--client/src/standalone/videos/embed.html2
-rw-r--r--client/src/standalone/videos/embed.ts58
2 files changed, 34 insertions, 26 deletions
diff --git a/client/src/standalone/videos/embed.html b/client/src/standalone/videos/embed.html
index b7cf13ec2..f79cf68df 100644
--- a/client/src/standalone/videos/embed.html
+++ b/client/src/standalone/videos/embed.html
@@ -13,7 +13,7 @@
13 <body> 13 <body>
14 14
15 <div id="error-block"> 15 <div id="error-block">
16 <h1 id="error-title">Sorry</h1> 16 <h1 id="error-title"></h1>
17 17
18 <div id="error-content"></div> 18 <div id="error-content"></div>
19 </div> 19 </div>
diff --git a/client/src/standalone/videos/embed.ts b/client/src/standalone/videos/embed.ts
index 7daa03f23..54b8fb543 100644
--- a/client/src/standalone/videos/embed.ts
+++ b/client/src/standalone/videos/embed.ts
@@ -157,10 +157,11 @@ class PeerTubeEmbed {
157 player: any 157 player: any
158 playerOptions: any 158 playerOptions: any
159 api: PeerTubeEmbedApi = null 159 api: PeerTubeEmbedApi = null
160 autoplay = false 160 autoplay: boolean
161 controls = true 161 controls: boolean
162 muted = false 162 muted: boolean
163 loop = false 163 loop: boolean
164 subtitle: string
164 enableApi = false 165 enableApi = false
165 startTime: number | string = 0 166 startTime: number | string = 0
166 scope = 'peertube' 167 scope = 'peertube'
@@ -191,34 +192,40 @@ class PeerTubeEmbed {
191 element.parentElement.removeChild(element) 192 element.parentElement.removeChild(element)
192 } 193 }
193 194
194 displayError (text: string) { 195 displayError (text: string, translations?: { [ id: string ]: string }) {
195 // Remove video element 196 // Remove video element
196 if (this.videoElement) this.removeElement(this.videoElement) 197 if (this.videoElement) this.removeElement(this.videoElement)
197 198
198 document.title = 'Sorry - ' + text 199 const translatedText = peertubeTranslate(text, translations)
200 const translatedSorry = peertubeTranslate('Sorry', translations)
201
202 document.title = translatedSorry + ' - ' + translatedText
199 203
200 const errorBlock = document.getElementById('error-block') 204 const errorBlock = document.getElementById('error-block')
201 errorBlock.style.display = 'flex' 205 errorBlock.style.display = 'flex'
202 206
207 const errorTitle = document.getElementById('error-title')
208 errorTitle.innerHTML = peertubeTranslate('Sorry', translations)
209
203 const errorText = document.getElementById('error-content') 210 const errorText = document.getElementById('error-content')
204 errorText.innerHTML = text 211 errorText.innerHTML = translatedText
205 } 212 }
206 213
207 videoNotFound () { 214 videoNotFound (translations?: { [ id: string ]: string }) {
208 const text = 'This video does not exist.' 215 const text = 'This video does not exist.'
209 this.displayError(text) 216 this.displayError(text, translations)
210 } 217 }
211 218
212 videoFetchError () { 219 videoFetchError (translations?: { [ id: string ]: string }) {
213 const text = 'We cannot fetch the video. Please try again later.' 220 const text = 'We cannot fetch the video. Please try again later.'
214 this.displayError(text) 221 this.displayError(text, translations)
215 } 222 }
216 223
217 getParamToggle (params: URLSearchParams, name: string, defaultValue: boolean) { 224 getParamToggle (params: URLSearchParams, name: string, defaultValue?: boolean) {
218 return params.has(name) ? (params.get(name) === '1' || params.get(name) === 'true') : defaultValue 225 return params.has(name) ? (params.get(name) === '1' || params.get(name) === 'true') : defaultValue
219 } 226 }
220 227
221 getParamString (params: URLSearchParams, name: string, defaultValue: string) { 228 getParamString (params: URLSearchParams, name: string, defaultValue?: string) {
222 return params.has(name) ? params.get(name) : defaultValue 229 return params.has(name) ? params.get(name) : defaultValue
223 } 230 }
224 231
@@ -241,15 +248,15 @@ class PeerTubeEmbed {
241 try { 248 try {
242 let params = new URL(window.location.toString()).searchParams 249 let params = new URL(window.location.toString()).searchParams
243 250
244 this.autoplay = this.getParamToggle(params, 'autoplay', this.autoplay) 251 this.autoplay = this.getParamToggle(params, 'autoplay')
245 this.controls = this.getParamToggle(params, 'controls', this.controls) 252 this.controls = this.getParamToggle(params, 'controls')
246 this.muted = this.getParamToggle(params, 'muted', this.muted) 253 this.muted = this.getParamToggle(params, 'muted')
247 this.loop = this.getParamToggle(params, 'loop', this.loop) 254 this.loop = this.getParamToggle(params, 'loop')
248 this.enableApi = this.getParamToggle(params, 'api', this.enableApi) 255 this.enableApi = this.getParamToggle(params, 'api', this.enableApi)
249 this.scope = this.getParamString(params, 'scope', this.scope)
250 256
251 const startTimeParamString = params.get('start') 257 this.scope = this.getParamString(params, 'scope', this.scope)
252 if (startTimeParamString) this.startTime = startTimeParamString 258 this.subtitle = this.getParamString(params, 'subtitle')
259 this.startTime = this.getParamString(params, 'start')
253 } catch (err) { 260 } catch (err) {
254 console.error('Cannot get params from URL.', err) 261 console.error('Cannot get params from URL.', err)
255 } 262 }
@@ -267,9 +274,9 @@ class PeerTubeEmbed {
267 ]) 274 ])
268 275
269 if (!videoResponse.ok) { 276 if (!videoResponse.ok) {
270 if (videoResponse.status === 404) return this.videoNotFound() 277 if (videoResponse.status === 404) return this.videoNotFound(serverTranslations)
271 278
272 return this.videoFetchError() 279 return this.videoFetchError(serverTranslations)
273 } 280 }
274 281
275 const videoInfo: VideoDetails = await videoResponse.json() 282 const videoInfo: VideoDetails = await videoResponse.json()
@@ -291,6 +298,7 @@ class PeerTubeEmbed {
291 muted: this.muted, 298 muted: this.muted,
292 loop: this.loop, 299 loop: this.loop,
293 startTime: this.startTime, 300 startTime: this.startTime,
301 subtitle: this.subtitle,
294 302
295 videoCaptions, 303 videoCaptions,
296 inactivityTimeout: 1500, 304 inactivityTimeout: 1500,
@@ -306,7 +314,7 @@ class PeerTubeEmbed {
306 314
307 this.playerOptions = videojsOptions 315 this.playerOptions = videojsOptions
308 this.player = vjs(this.videoContainerId, videojsOptions, () => { 316 this.player = vjs(this.videoContainerId, videojsOptions, () => {
309 this.player.on('customError', (event: any, data: any) => this.handleError(data.err)) 317 this.player.on('customError', (event: any, data: any) => this.handleError(data.err, serverTranslations))
310 318
311 window[ 'videojsPlayer' ] = this.player 319 window[ 'videojsPlayer' ] = this.player
312 320
@@ -323,11 +331,11 @@ class PeerTubeEmbed {
323 }) 331 })
324 } 332 }
325 333
326 private handleError (err: Error) { 334 private handleError (err: Error, translations?: { [ id: string ]: string }) {
327 if (err.message.indexOf('from xs param') !== -1) { 335 if (err.message.indexOf('from xs param') !== -1) {
328 this.player.dispose() 336 this.player.dispose()
329 this.videoElement = null 337 this.videoElement = null
330 this.displayError('This video is not available because the remote instance is not responding.') 338 this.displayError('This video is not available because the remote instance is not responding.', translations)
331 return 339 return
332 } 340 }
333 } 341 }