// ========================================================================== // Plyr.io demo // This code is purely for the https://plyr.io website // Please see readme.md in the root or github.com/sampotts/plyr // ========================================================================== import Raven from 'raven-js'; (() => { const { host } = window.location; const env = { prod: host === 'plyr.io', dev: host === 'dev.plyr.io', }; document.addEventListener('DOMContentLoaded', () => { Raven.context(() => { const selector = '#player'; const container = document.getElementById('container'); 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 => { if (!event.target.classList || container.contains(event.target)) { return; } event.target.classList.remove(tabClassName); }); // Add classname to tabbed elements document.addEventListener('keydown', event => { if (event.keyCode !== 9) { return; } // Delay the adding of classname until the focus has changed // This event fires before the focusin event setTimeout(() => { const focused = document.activeElement; if (!focused || !focused.classList || container.contains(focused)) { return; } focused.classList.add(tabClassName); }, 10); }); // Setup the player const player = new Plyr(selector, { 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: env.prod || env.dev, publisherId: '918848828995742', }, }); // 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); } } // 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: [ { src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-576p.mp4', type: 'video/mp4', size: 576, }, { src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-720p.mp4', type: 'video/mp4', size: 720, }, { src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-1080p.mp4', type: 'video/mp4', size: 1080, }, { src: 'https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-1440p.mp4', type: 'video/mp4', size: 1440, }, ], 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', sources: [ { src: 'https://youtube.com/watch?v=bTqVqk7FSmY', provider: 'youtube', }, ], }; break; case types.vimeo: player.source = { type: 'video', sources: [ { src: 'https://vimeo.com/76979871', provider: 'vimeo', }, ], }; break; default: break; } // Set the current type for next time currentType = type; // 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); // 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'); newSource(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); } }); // On load if (historySupport) { const video = !currentType.length; // 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}`, ); } // If it's not video, load the source if (currentType !== types.video) { newSource(currentType, true); } } }); }); // Raven / Sentry // For demo site (https://plyr.io) only if (env.prod) { Raven.config('https://d4ad9866ad834437a4754e23937071e4@sentry.io/305555').install(); } })();