{"version":3,"sources":["player.js"],"names":["const","lsKeys","page","urlPrefix","urlIdentifier","urlInput","document","querySelector","reloadBtn","downloadBtn","uploadRoot","titleFormat","videoContainer","player","window","HELP_IMPROVE_VIDEOJS","onError","error","console","content","createElement","innerHTML","toString","swal","title","icon","onAxiosError","statusText","response","status","description","data","toggleReloadBtn","enabled","classList","remove","removeAttribute","add","setAttribute","reloadVideo","value","src","axios","head","then","includes","type","headers","isvideo","startsWith","isaudio","dispose","videoElement","id","className","appendChild","options","language","playbackRates","responsive","plugins","wavesurfer","videojs","let","message","getPluginVersion","WaveSurfer","log","seekButtons","forward","back","replace","history","pushState","catch","addEventListener","mainScript","dataset","location","protocol","host","match","pathname","substring","indexOf","form","event","preventDefault","checkValidity"],"mappings":"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","file":"player.js","sourcesContent":["/* global swal, axios, videojs, WaveSurfer */\n\n// eslint-disable-next-line no-unused-vars\nconst lsKeys = {}\n\n// eslint-disable-next-line no-unused-vars\nconst page = {\n urlPrefix: null,\n urlIdentifier: null,\n\n urlInput: document.querySelector('#identifier'),\n reloadBtn: document.querySelector('#reloadBtn'),\n downloadBtn: document.querySelector('#downloadBtn'),\n uploadRoot: null,\n titleFormat: null,\n\n videoContainer: document.querySelector('#playerContainer'),\n player: null\n}\n\n// Disable video.js telemetry (should already be disabled by default since v7 though)\nwindow.HELP_IMPROVE_VIDEOJS = false\n\n// Handler for regular JS errors\npage.onError = error => {\n console.error(error)\n\n const content = document.createElement('div')\n content.innerHTML = `\n

${error.toString()}

\n

Please check your console for more information.

\n `\n return swal({\n title: 'An error occurred!',\n icon: 'error',\n content\n })\n}\n\n// Handler for Axios errors\npage.onAxiosError = error => {\n // Better Cloudflare errors\n const cloudflareErrors = {\n 520: 'Unknown Error',\n 521: 'Web Server Is Down',\n 522: 'Connection Timed Out',\n 523: 'Origin Is Unreachable',\n 524: 'A Timeout Occurred',\n 525: 'SSL Handshake Failed',\n 526: 'Invalid SSL Certificate',\n 527: 'Railgun Error',\n 530: 'Origin DNS Error'\n }\n\n const statusText = cloudflareErrors[error.response.status] || error.response.statusText\n\n const description = error.response.data && error.response.data.description\n ? error.response.data.description\n : ''\n return swal(`${error.response.status} ${statusText}`, description, 'error')\n}\n\npage.toggleReloadBtn = enabled => {\n if (enabled) {\n page.reloadBtn.classList.remove('is-loading')\n page.reloadBtn.removeAttribute('disabled')\n } else {\n page.reloadBtn.classList.add('is-loading')\n page.reloadBtn.setAttribute('disabled', 'disabled')\n }\n}\n\npage.reloadVideo = () => {\n if (!page.urlInput.value) return\n\n page.toggleReloadBtn(false)\n const src = `${page.uploadRoot}/${page.urlInput.value}`\n\n axios.head(src).then(response => {\n if (![200, 304].includes(response.status)) {\n page.toggleReloadBtn(true)\n return page.onAxiosError(response)\n }\n\n const type = response.headers['content-type'] || ''\n const isvideo = type.startsWith('video/')\n const isaudio = type.startsWith('audio/')\n if (!isvideo && !isaudio) {\n page.toggleReloadBtn(true)\n return swal('An error occurred!', 'The requested upload does not appear to be a media file.', 'error')\n }\n\n page.urlIdentifier = page.urlInput.value\n\n if (page.player) {\n page.player.dispose()\n page.videoContainer.innerHTML = ''\n }\n\n const videoElement = document.createElement('video-js')\n videoElement.id = 'video-js'\n videoElement.className = 'video-js vjs-default-skin vjs-fluid vjs-big-play-centered'\n videoElement.setAttribute('controls', true)\n videoElement.setAttribute('preload', 'auto')\n\n page.videoContainer.appendChild(videoElement)\n\n const options = {\n language: 'en',\n playbackRates: [0.25, 0.5, 0.75, 1, 1.25, 1.5, 1.75, 2],\n responsive: true\n }\n\n if (isaudio) {\n options.plugins = {\n wavesurfer: {\n responsive: true\n }\n }\n }\n\n page.player = videojs('video-js', options, () => {\n let message = `Using video.js ${videojs.VERSION}`\n if (isaudio) {\n message += ` with videojs-wavesurfer ${videojs.getPluginVersion('wavesurfer')} and wavesurfer.js ${WaveSurfer.VERSION}`\n }\n videojs.log(message)\n page.player.src({ src, type })\n })\n page.player.seekButtons({ forward: 10, back: 10 })\n\n if (page.titleFormat) {\n document.title = page.titleFormat.replace(/%identifier%/g, page.urlIdentifier)\n }\n\n if (page.downloadBtn) {\n page.downloadBtn.setAttribute('href', src)\n }\n\n window.history.pushState(null, null, page.urlPrefix + page.urlIdentifier)\n page.toggleReloadBtn(true)\n }).catch(error => {\n page.toggleReloadBtn(true)\n if (typeof error.response !== 'undefined') page.onAxiosError(error)\n else page.onError(error)\n })\n}\n\nwindow.addEventListener('DOMContentLoaded', () => {\n const mainScript = document.querySelector('#mainScript')\n if (!mainScript || typeof mainScript.dataset.uploadRoot === 'undefined') return\n\n page.uploadRoot = mainScript.dataset.uploadRoot\n page.titleFormat = mainScript.dataset.titleFormat\n\n let urlPrefix = window.location.protocol + '//' + window.location.host\n const match = window.location.pathname.match(/.*\\/(.*)$/)\n if (!match || !match[1]) {\n return swal('An error occurred!', 'Failed to parse upload identifier from URL.', 'error')\n }\n\n page.urlIdentifier = match[1]\n urlPrefix += window.location.pathname.substring(0, window.location.pathname.indexOf(match[1]))\n page.urlPrefix = urlPrefix\n\n if (!page.urlInput) return\n page.urlInput.value = page.urlIdentifier\n\n // Prevent default form's submit actio\n const form = document.querySelector('#inputForm')\n form.addEventListener('submit', event => {\n event.preventDefault()\n })\n\n if (!page.videoContainer) return\n\n page.reloadBtn = document.querySelector('#reloadBtn')\n if (page.reloadBtn) {\n page.reloadBtn.addEventListener('click', event => {\n if (!form.checkValidity()) return\n page.reloadVideo()\n })\n }\n\n page.reloadVideo()\n})\n"]}