return str.charAt(0).toUpperCase() + str.slice(1)
}
+function isWebRTCDisabled () {
+ return !!((window as any).RTCPeerConnection || (window as any).mozRTCPeerConnection || (window as any).webkitRTCPeerConnection) === false
+}
+
// https://github.com/danrevah/ngx-pipes/blob/master/src/pipes/math/bytes.ts
// Don't import all Angular stuff, just copy the code with shame
const dictionaryBytes: Array<{max: number, type: string}> = [
return /iPhone|iPad|iPod|Android/i.test(navigator.userAgent)
}
-function buildVideoLink (time?: number, url?: string) {
- if (!url) url = window.location.origin + window.location.pathname.replace('/embed/', '/watch/')
+function buildVideoLink (options: {
+ baseUrl?: string,
+
+ startTime?: number,
+ stopTime?: number,
+
+ subtitle?: string,
+
+ loop?: boolean,
+ autoplay?: boolean,
+ muted?: boolean,
+
+ // Embed options
+ title?: boolean,
+ warningTitle?: boolean,
+ controls?: boolean
+} = {}) {
+ const { baseUrl } = options
- if (time) {
- const timeInt = Math.floor(time)
+ const url = baseUrl
+ ? baseUrl
+ : window.location.origin + window.location.pathname.replace('/embed/', '/watch/')
- const params = new URLSearchParams(window.location.search)
- params.set('start', secondsToTime(timeInt))
+ const params = new URLSearchParams(window.location.search)
+ // Remove these unused parameters when we are on a playlist page
+ params.delete('videoId')
+ params.delete('resume')
- return url + '?' + params.toString()
+ if (options.startTime) {
+ const startTimeInt = Math.floor(options.startTime)
+ params.set('start', secondsToTime(startTimeInt))
}
+ if (options.stopTime) {
+ const stopTimeInt = Math.floor(options.stopTime)
+ params.set('stop', secondsToTime(stopTimeInt))
+ }
+
+ if (options.subtitle) params.set('subtitle', options.subtitle)
+
+ if (options.loop === true) params.set('loop', '1')
+ if (options.autoplay === true) params.set('autoplay', '1')
+ if (options.muted === true) params.set('muted', '1')
+ if (options.title === false) params.set('title', '0')
+ if (options.warningTitle === false) params.set('warningTitle', '0')
+ if (options.controls === false) params.set('controls', '0')
+
+ let hasParams = false
+ params.forEach(() => hasParams = true)
+
+ if (hasParams) return url + '?' + params.toString()
+
return url
}
function buildVideoEmbed (embedUrl: string) {
return '<iframe width="560" height="315" ' +
- 'sandbox="allow-same-origin allow-scripts" ' +
+ 'sandbox="allow-same-origin allow-scripts allow-popups" ' +
'src="' + embedUrl + '" ' +
'frameborder="0" allowfullscreen>' +
'</iframe>'
toTitleCase,
timeToInt,
secondsToTime,
+ isWebRTCDisabled,
buildVideoLink,
buildVideoEmbed,
videoFileMaxByResolution,