diff options
Diffstat (limited to 'demo/src/js')
-rw-r--r-- | demo/src/js/demo.js | 432 |
1 files changed, 217 insertions, 215 deletions
diff --git a/demo/src/js/demo.js b/demo/src/js/demo.js index 78d91390..438b2b8a 100644 --- a/demo/src/js/demo.js +++ b/demo/src/js/demo.js @@ -6,253 +6,255 @@ import Raven from 'raven-js'; -Raven.config('https://d4ad9866ad834437a4754e23937071e4@sentry.io/305555').install(); - -document.addEventListener('DOMContentLoaded', () => { - Raven.context(() => { - if (window.shr) { - window.shr.setup({ - count: { - classname: 'button__count', - }, +(() => { + const isLive = window.location.host === 'plyr.io'; + + // Raven / Sentry + // For demo site (https://plyr.io) only + if (isLive) { + Raven.config('https://d4ad9866ad834437a4754e23937071e4@sentry.io/305555').install(); + } + + document.addEventListener('DOMContentLoaded', () => { + Raven.context(() => { + if (window.shr) { + window.shr.setup({ + count: { + classname: 'button__count', + }, + }); + } + + // Setup tab focus + const tabClassName = 'tab-focus'; + + // Remove class on blur + document.addEventListener('focusout', event => { + event.target.classList.remove(tabClassName); }); - } - // Setup tab focus - const tabClassName = 'tab-focus'; + // Add classname to tabbed elements + document.addEventListener('keydown', event => { + if (event.keyCode !== 9) { + return; + } - // Remove class on blur - document.addEventListener('focusout', event => { - event.target.classList.remove(tabClassName); - }); + // Delay the adding of classname until the focus has changed + // This event fires before the focusin event + setTimeout(() => { + document.activeElement.classList.add(tabClassName); + }, 0); + }); - // Add classname to tabbed elements - document.addEventListener('keydown', event => { - if (event.keyCode !== 9) { - return; - } + // Setup the player + const player = new Plyr('#player', { + debug: true, + title: 'View From A Blue Moon', + iconUrl: '../dist/plyr.svg', + keyboard: { + global: true, + }, + tooltips: { + controls: true, + }, + captions: { + active: true, + }, + keys: { + google: 'AIzaSyDrNwtN3nLH_8rjCmu5Wq3ZCm4MNAVdc0c', + }, + ads: { + enabled: true, + publisherId: '918848828995742', + }, + }); - // Delay the adding of classname until the focus has changed - // This event fires before the focusin event - setTimeout(() => { - document.activeElement.classList.add(tabClassName); - }, 0); - }); + // Expose for tinkering in the console + window.player = player; - // Setup the player - const player = new Plyr('#player', { - debug: true, - title: 'View From A Blue Moon', - iconUrl: '../dist/plyr.svg', - keyboard: { - global: true, - }, - tooltips: { - controls: true, - }, - captions: { - active: true, - }, - keys: { - google: 'AIzaSyDrNwtN3nLH_8rjCmu5Wq3ZCm4MNAVdc0c', - }, - ads: { - enabled: true, - publisherId: '918848828995742', - }, - }); + // Setup type toggle + const buttons = document.querySelectorAll('[data-source]'); + const types = { + video: 'video', + audio: 'audio', + youtube: 'youtube', + vimeo: 'vimeo', + }; + let currentType = window.location.hash.replace('#', ''); + const historySupport = window.history && window.history.pushState; - // Expose for tinkering in the console - window.player = player; - - // Setup type toggle - const buttons = document.querySelectorAll('[data-source]'); - const types = { - video: 'video', - audio: 'audio', - youtube: 'youtube', - vimeo: 'vimeo', - }; - let currentType = window.location.hash.replace('#', ''); - const historySupport = window.history && window.history.pushState; - - // Toggle class on an element - function toggleClass(element, className, state) { - if (element) { - element.classList[state ? 'add' : 'remove'](className); + // Toggle class on an element + function toggleClass(element, className, state) { + if (element) { + element.classList[state ? 'add' : 'remove'](className); + } } - } - // Set a new source - function newSource(type, init) { - // Bail if new type isn't known, it's the current type, or current type is empty (video is default) and new type is video - if (!(type in types) || (!init && type === currentType) || (!currentType.length && type === types.video)) { - return; - } + // Set a new source + function newSource(type, init) { + // Bail if new type isn't known, it's the current type, or current type is empty (video is default) and new type is video + if (!(type in types) || (!init && type === currentType) || (!currentType.length && type === types.video)) { + return; + } - switch (type) { - case types.video: - player.source = { - type: 'video', - title: 'View From A Blue Moon', - sources: [ - { + switch (type) { + case types.video: + player.source = { + type: 'video', + title: 'View From A Blue Moon', + sources: [{ src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-HD.mp4', type: 'video/mp4', - }, - ], - poster: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-HD.jpg', - tracks: [ - { - kind: 'captions', - label: 'English', - srclang: 'en', - src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-HD.en.vtt', - default: true, - }, - { - kind: 'captions', - label: 'French', - srclang: 'fr', - src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-HD.fr.vtt', - }, - ], - }; - - break; - - case types.audio: - player.source = { - type: 'audio', - title: 'Kishi Bashi – “It All Began With A Burst”', - sources: [ - { - src: 'https://cdn.plyr.io/static/demo/Kishi_Bashi_-_It_All_Began_With_a_Burst.mp3', - type: 'audio/mp3', - }, - { - src: 'https://cdn.plyr.io/static/demo/Kishi_Bashi_-_It_All_Began_With_a_Burst.ogg', - type: 'audio/ogg', - }, - ], - }; - - break; - - case types.youtube: - player.source = { - type: 'video', - title: 'View From A Blue Moon', - sources: [ - { + }], + poster: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-HD.jpg', + tracks: [ + { + kind: 'captions', + label: 'English', + srclang: 'en', + src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-HD.en.vtt', + default: true, + }, + { + kind: 'captions', + label: 'French', + srclang: 'fr', + src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-HD.fr.vtt', + }, + ], + }; + + break; + + case types.audio: + player.source = { + type: 'audio', + title: 'Kishi Bashi – “It All Began With A Burst”', + sources: [ + { + src: 'https://cdn.plyr.io/static/demo/Kishi_Bashi_-_It_All_Began_With_a_Burst.mp3', + type: 'audio/mp3', + }, + { + src: 'https://cdn.plyr.io/static/demo/Kishi_Bashi_-_It_All_Began_With_a_Burst.ogg', + type: 'audio/ogg', + }, + ], + }; + + break; + + case types.youtube: + player.source = { + type: 'video', + title: 'View From A Blue Moon', + sources: [{ src: 'https://youtube.com/watch?v=bTqVqk7FSmY', provider: 'youtube', - }, - ], - }; + }], + }; - break; + break; - case types.vimeo: - player.source = { - type: 'video', - sources: [ - { + case types.vimeo: + player.source = { + type: 'video', + sources: [{ src: 'https://vimeo.com/76979871', provider: 'vimeo', - }, - ], - }; + }], + }; - break; + break; - default: - break; - } + default: + break; + } - // Set the current type for next time - currentType = type; + // Set the current type for next time + currentType = type; - // Remove active classes - Array.from(buttons).forEach(button => toggleClass(button.parentElement, 'active', false)); + // Remove active classes + Array.from(buttons).forEach(button => toggleClass(button.parentElement, 'active', false)); - // Set active on parent - toggleClass(document.querySelector(`[data-source="${type}"]`), 'active', true); + // Set active on parent + toggleClass(document.querySelector(`[data-source="${type}"]`), 'active', true); - // Show cite - Array.from(document.querySelectorAll('.plyr__cite')).forEach(cite => { - cite.setAttribute('hidden', ''); - }); - document.querySelector(`.plyr__cite--${type}`).removeAttribute('hidden'); - } + // Show cite + Array.from(document.querySelectorAll('.plyr__cite')).forEach(cite => { + cite.setAttribute('hidden', ''); + }); + document.querySelector(`.plyr__cite--${type}`).removeAttribute('hidden'); + } - // Bind to each button - Array.from(buttons).forEach(button => { - button.addEventListener('click', () => { - const type = button.getAttribute('data-source'); + // Bind to each button + Array.from(buttons).forEach(button => { + button.addEventListener('click', () => { + const type = button.getAttribute('data-source'); - newSource(type); + newSource(type); - if (historySupport) { - window.history.pushState({ type }, '', `#${type}`); - } + if (historySupport) { + window.history.pushState({ type }, '', `#${type}`); + } + }); }); - }); - // List for backwards/forwards - window.addEventListener('popstate', event => { - if (event.state && 'type' in event.state) { - newSource(event.state.type); - } - }); + // List for backwards/forwards + window.addEventListener('popstate', event => { + if (event.state && 'type' in event.state) { + newSource(event.state.type); + } + }); - // On load - if (historySupport) { - const video = !currentType.length; + // On load + if (historySupport) { + const video = !currentType.length; - // If there's no current type set, assume video - if (video) { - currentType = types.video; - } + // If there's no current type set, assume video + if (video) { + currentType = types.video; + } - // Replace current history state - if (currentType in types) { - window.history.replaceState( - { - type: currentType, - }, - '', - video ? '' : `#${currentType}`, - ); - } + // Replace current history state + if (currentType in types) { + window.history.replaceState( + { + type: currentType, + }, + '', + video ? '' : `#${currentType}`, + ); + } - // If it's not video, load the source - if (currentType !== types.video) { - newSource(currentType, true); + // If it's not video, load the source + if (currentType !== types.video) { + newSource(currentType, true); + } } - } + }); }); -}); - -// Google analytics -// For demo site (https://plyr.io) only -/* eslint-disable */ -if (window.location.host === 'plyr.io') { - (function(i, s, o, g, r, a, m) { - i.GoogleAnalyticsObject = r; - i[r] = - i[r] || - function() { - (i[r].q = i[r].q || []).push(arguments); - }; - i[r].l = 1 * new Date(); - a = s.createElement(o); - m = s.getElementsByTagName(o)[0]; - a.async = 1; - a.src = g; - m.parentNode.insertBefore(a, m); - })(window, document, 'script', 'https://www.google-analytics.com/analytics.js', 'ga'); - window.ga('create', 'UA-40881672-11', 'auto'); - window.ga('send', 'pageview'); -} -/* eslint-enable */ + + // Google analytics + // For demo site (https://plyr.io) only + /* eslint-disable */ + if (isLive) { + (function(i, s, o, g, r, a, m) { + i.GoogleAnalyticsObject = r; + i[r] = + i[r] || + function() { + (i[r].q = i[r].q || []).push(arguments); + }; + i[r].l = 1 * new Date(); + a = s.createElement(o); + m = s.getElementsByTagName(o)[0]; + a.async = 1; + a.src = g; + m.parentNode.insertBefore(a, m); + })(window, document, 'script', 'https://www.google-analytics.com/analytics.js', 'ga'); + window.ga('create', 'UA-40881672-11', 'auto'); + window.ga('send', 'pageview'); + } + /* eslint-enable */ +})(); |