diff options
author | Sam Potts <sam@potts.es> | 2020-04-11 16:23:14 +1000 |
---|---|---|
committer | Sam Potts <sam@potts.es> | 2020-04-11 16:23:14 +1000 |
commit | 502d5977d79148957828cbf313b7ef4c9f31973f (patch) | |
tree | 71bbffcffc9745c5b672a122f3937519ba67c1c4 /demo/src/js | |
parent | 8f5b59c18cc7837bde9af55d24d12e1fd939043d (diff) | |
download | plyr-502d5977d79148957828cbf313b7ef4c9f31973f.tar.lz plyr-502d5977d79148957828cbf313b7ef4c9f31973f.tar.xz plyr-502d5977d79148957828cbf313b7ef4c9f31973f.zip |
Converted to 2 space indentation
Diffstat (limited to 'demo/src/js')
-rw-r--r-- | demo/src/js/demo.js | 241 | ||||
-rw-r--r-- | demo/src/js/sources.js | 148 | ||||
-rw-r--r-- | demo/src/js/tab-focus.js | 32 | ||||
-rw-r--r-- | demo/src/js/toggle-class.js | 2 |
4 files changed, 210 insertions, 213 deletions
diff --git a/demo/src/js/demo.js b/demo/src/js/demo.js index 7f7cec28..62c1ee0c 100644 --- a/demo/src/js/demo.js +++ b/demo/src/js/demo.js @@ -16,137 +16,134 @@ import sources from './sources'; import toggleClass from './toggle-class'; (() => { - const production = 'plyr.io'; - - // Sentry for demo site (https://plyr.io) only - if (window.location.host === production) { - Sentry.init({ - dsn: 'https://d4ad9866ad834437a4754e23937071e4@sentry.io/305555', - whitelistUrls: [production].map(d => new RegExp(`https://(([a-z0-9])+(.))*${d}`)), - }); - } + const production = 'plyr.io'; - document.addEventListener('DOMContentLoaded', () => { - const selector = '#player'; - - // Setup share buttons - Shr.setup('.js-shr', { - count: { - className: 'button__count', - }, - wrapper: { - className: 'button--with-count', - }, - }); - - // Setup the player - const player = new Plyr(selector, { - debug: true, - title: 'View From A Blue Moon', - iconUrl: 'dist/demo.svg', - keyboard: { - global: true, - }, - tooltips: { - controls: true, - }, - captions: { - active: true, - }, - ads: { - enabled: window.location.host.includes(production), - publisherId: '918848828995742', - }, - previewThumbnails: { - enabled: true, - src: [ - 'https://cdn.plyr.io/static/demo/thumbs/100p.vtt', - 'https://cdn.plyr.io/static/demo/thumbs/240p.vtt', - ], - }, - vimeo: { - // Prevent Vimeo blocking plyr.io demo site - referrerPolicy: 'no-referrer', - }, - }); - - // Expose for tinkering in the console - window.player = player; - - // Setup type toggle - const buttons = document.querySelectorAll('[data-source]'); - const types = Object.keys(sources); - const historySupport = Boolean(window.history && window.history.pushState); - let currentType = window.location.hash.substring(1); - const hasInitialType = currentType.length; - - function render(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 => { - // eslint-disable-next-line no-param-reassign - cite.hidden = true; - }); - - document.querySelector(`.plyr__cite--${type}`).hidden = false; - } + // Sentry for demo site (https://plyr.io) only + if (window.location.host === production) { + Sentry.init({ + dsn: 'https://d4ad9866ad834437a4754e23937071e4@sentry.io/305555', + whitelistUrls: [production].map(d => new RegExp(`https://(([a-z0-9])+(.))*${d}`)), + }); + } + + document.addEventListener('DOMContentLoaded', () => { + const selector = '#player'; + + // Setup share buttons + Shr.setup('.js-shr', { + count: { + className: 'button__count', + }, + wrapper: { + className: 'button--with-count', + }, + }); - // Set a new source - function setSource(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 (!types.includes(type) || (!init && type === currentType) || (!currentType.length && type === 'video')) { - return; - } + // Setup the player + const player = new Plyr(selector, { + debug: true, + title: 'View From A Blue Moon', + iconUrl: 'dist/demo.svg', + keyboard: { + global: true, + }, + tooltips: { + controls: true, + }, + captions: { + active: true, + }, + ads: { + enabled: window.location.host.includes(production), + publisherId: '918848828995742', + }, + previewThumbnails: { + enabled: true, + src: ['https://cdn.plyr.io/static/demo/thumbs/100p.vtt', 'https://cdn.plyr.io/static/demo/thumbs/240p.vtt'], + }, + vimeo: { + // Prevent Vimeo blocking plyr.io demo site + referrerPolicy: 'no-referrer', + }, + }); - // Set the new source - player.source = sources[type]; + // Expose for tinkering in the console + window.player = player; - // Set the current type for next time - currentType = type; + // Setup type toggle + const buttons = document.querySelectorAll('[data-source]'); + const types = Object.keys(sources); + const historySupport = Boolean(window.history && window.history.pushState); + let currentType = window.location.hash.substring(1); + const hasInitialType = currentType.length; - render(type); - } + function render(type) { + // Remove active classes + Array.from(buttons).forEach(button => toggleClass(button.parentElement, 'active', false)); - // Bind to each button - Array.from(buttons).forEach(button => { - button.addEventListener('click', () => { - const type = button.getAttribute('data-source'); - - setSource(type); - - if (historySupport) { - window.history.pushState({ type }, '', `#${type}`); - } - }); - }); - - // List for backwards/forwards - window.addEventListener('popstate', event => { - if (event.state && Object.keys(event.state).includes('type')) { - setSource(event.state.type); - } - }); - - // If there's no current type set, assume video - if (!hasInitialType) { - currentType = 'video'; - } + // Set active on parent + toggleClass(document.querySelector(`[data-source="${type}"]`), 'active', true); - // Replace current history state - if (historySupport && types.includes(currentType)) { - window.history.replaceState({ type: currentType }, '', hasInitialType ? `#${currentType}` : ''); - } + // Show cite + Array.from(document.querySelectorAll('.plyr__cite')).forEach(cite => { + // eslint-disable-next-line no-param-reassign + cite.hidden = true; + }); + + document.querySelector(`.plyr__cite--${type}`).hidden = false; + } + + // Set a new source + function setSource(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 (!types.includes(type) || (!init && type === currentType) || (!currentType.length && type === 'video')) { + return; + } + + // Set the new source + player.source = sources[type]; + + // Set the current type for next time + currentType = type; - // If it's not video, load the source - if (currentType !== 'video') { - setSource(currentType, true); + render(type); + } + + // Bind to each button + Array.from(buttons).forEach(button => { + button.addEventListener('click', () => { + const type = button.getAttribute('data-source'); + + setSource(type); + + if (historySupport) { + window.history.pushState({ type }, '', `#${type}`); } + }); + }); - render(currentType); + // List for backwards/forwards + window.addEventListener('popstate', event => { + if (event.state && Object.keys(event.state).includes('type')) { + setSource(event.state.type); + } }); + + // If there's no current type set, assume video + if (!hasInitialType) { + currentType = 'video'; + } + + // Replace current history state + if (historySupport && types.includes(currentType)) { + window.history.replaceState({ type: currentType }, '', hasInitialType ? `#${currentType}` : ''); + } + + // If it's not video, load the source + if (currentType !== 'video') { + setSource(currentType, true); + } + + render(currentType); + }); })(); diff --git a/demo/src/js/sources.js b/demo/src/js/sources.js index f0ec3515..6cec59c9 100644 --- a/demo/src/js/sources.js +++ b/demo/src/js/sources.js @@ -1,78 +1,78 @@ const sources = { - video: { - 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', - }, - ], - }, - audio: { - 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', - }, - ], - }, - youtube: { - type: 'video', - sources: [ - { - src: 'https://youtube.com/watch?v=bTqVqk7FSmY', - provider: 'youtube', - }, - ], - }, - vimeo: { - type: 'video', - sources: [ - { - src: 'https://vimeo.com/40648169', - provider: 'vimeo', - }, - ], - }, + video: { + 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', + }, + ], + }, + audio: { + 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', + }, + ], + }, + youtube: { + type: 'video', + sources: [ + { + src: 'https://youtube.com/watch?v=bTqVqk7FSmY', + provider: 'youtube', + }, + ], + }, + vimeo: { + type: 'video', + sources: [ + { + src: 'https://vimeo.com/40648169', + provider: 'vimeo', + }, + ], + }, }; export default sources; diff --git a/demo/src/js/tab-focus.js b/demo/src/js/tab-focus.js index c1602cf0..b13049bc 100644 --- a/demo/src/js/tab-focus.js +++ b/demo/src/js/tab-focus.js @@ -4,28 +4,28 @@ const tabClassName = 'tab-focus'; // Remove class on blur document.addEventListener('focusout', event => { - if (!event.target.classList || container.contains(event.target)) { - return; - } + if (!event.target.classList || container.contains(event.target)) { + return; + } - event.target.classList.remove(tabClassName); + event.target.classList.remove(tabClassName); }); // Add classname to tabbed elements document.addEventListener('keydown', event => { - if (event.keyCode !== 9) { - return; - } + 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; + // 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; - } + if (!focused || !focused.classList || container.contains(focused)) { + return; + } - focused.classList.add(tabClassName); - }, 10); + focused.classList.add(tabClassName); + }, 10); }); diff --git a/demo/src/js/toggle-class.js b/demo/src/js/toggle-class.js index 1661433b..bd10c246 100644 --- a/demo/src/js/toggle-class.js +++ b/demo/src/js/toggle-class.js @@ -1,5 +1,5 @@ // Toggle class on an element const toggleClass = (element, className = '', toggle = false) => - element && element.classList[toggle ? 'add' : 'remove'](className); + element && element.classList[toggle ? 'add' : 'remove'](className); export default toggleClass; |