plyr/dist/plyr.js
Sam Potts 388cb4df39 Keyboard accessibility improvements (Fixes #66)
- Enter now works on checkboxes within the controls
2015-03-21 17:00:05 +11:00

1 line
19 KiB
JavaScript

!function(e){"use strict";function t(e,t){x.debug&&window.console&&console[t?"error":"log"](e)}function n(){var e,t,n,r=navigator.userAgent,s=navigator.appName,a=""+parseFloat(navigator.appVersion),o=parseInt(navigator.appVersion,10);return-1!==navigator.appVersion.indexOf("Windows NT")&&-1!==navigator.appVersion.indexOf("rv:11")?(s="IE",a="11;"):-1!==(t=r.indexOf("MSIE"))?(s="IE",a=r.substring(t+5)):-1!==(t=r.indexOf("Chrome"))?(s="Chrome",a=r.substring(t+7)):-1!==(t=r.indexOf("Safari"))?(s="Safari",a=r.substring(t+7),-1!==(t=r.indexOf("Version"))&&(a=r.substring(t+8))):-1!==(t=r.indexOf("Firefox"))?(s="Firefox",a=r.substring(t+8)):(e=r.lastIndexOf(" ")+1)<(t=r.lastIndexOf("/"))&&(s=r.substring(e,t),a=r.substring(t+1),s.toLowerCase()==s.toUpperCase()&&(s=navigator.appName)),-1!==(n=a.indexOf(";"))&&(a=a.substring(0,n)),-1!==(n=a.indexOf(" "))&&(a=a.substring(0,n)),o=parseInt(""+a,10),isNaN(o)&&(a=""+parseFloat(navigator.appVersion),o=parseInt(navigator.appVersion,10)),{name:s,version:o,ios:/(iPad|iPhone|iPod)/g.test(navigator.platform)}}function r(e,t){var n=e.media;if("video"==e.type)switch(t){case"video/webm":return!(!n.canPlayType||!n.canPlayType('video/webm; codecs="vp8, vorbis"').replace(/no/,""));case"video/mp4":return!(!n.canPlayType||!n.canPlayType('video/mp4; codecs="avc1.42E01E, mp4a.40.2"').replace(/no/,""));case"video/ogg":return!(!n.canPlayType||!n.canPlayType('video/ogg; codecs="theora"').replace(/no/,""))}else if("audio"==e.type)switch(t){case"audio/mpeg":return!(!n.canPlayType||!n.canPlayType("audio/mpeg;").replace(/no/,""));case"audio/ogg":return!(!n.canPlayType||!n.canPlayType('audio/ogg; codecs="vorbis"').replace(/no/,""));case"audio/wav":return!(!n.canPlayType||!n.canPlayType('audio/wav; codecs="1"').replace(/no/,""))}return!1}function s(e,t,n){return e.replace(new RegExp(t.replace(/([.*+?^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}function a(e,t){e.length||(e=[e]);for(var n=e.length-1;n>=0;n--){var r=n>0?t.cloneNode(!0):t,s=e[n],a=s.parentNode,o=s.nextSibling;r.appendChild(s),o?a.insertBefore(r,o):a.appendChild(r)}}function o(e){e.parentNode.removeChild(e)}function i(e,t){e.insertBefore(t,e.firstChild)}function l(e,t){for(var n in t)e.setAttribute(n,t[n])}function c(e,t,n){if(e)if(e.classList)e.classList[n?"add":"remove"](t);else{var r=(" "+e.className+" ").replace(/\s+/g," ").replace(" "+t+" ","");e.className=r+(n?" "+t:"")}}function u(e,t,n,r){if(t=t.split(" "),e instanceof NodeList)for(var s=0;s<e.length;s++)e[s]instanceof Node&&u(e[s],arguments[1],arguments[2],arguments[3]);else for(var a=0;a<t.length;a++)e[r?"addEventListener":"removeEventListener"](t[a],n,!1)}function p(e,t,n){u(e,t,n,!0)}function d(e,t,n){u(e,t,n,!1)}function f(e,t){var n=document.createEvent("MouseEvents");n.initEvent(t,!0,!0),e.dispatchEvent(n)}function m(e){return e.keyCode&&13!=e.keyCode?!0:(e.target.checked=!e.target.checked,e.target[e.target.checked?"setAttribute":"removeAttribute"]("checked",""),f(e.target,"change"),void 0)}function v(e,t){return 0===e||0===t||isNaN(e)||isNaN(t)?0:(e/t*100).toFixed(2)}function g(e,t){for(var n in t)t[n]&&t[n].constructor&&t[n].constructor===Object?(e[n]=e[n]||{},g(e[n],t[n])):e[n]=t[n];return e}function y(){var e={supportsFullScreen:!1,isFullScreen:function(){return!1},requestFullScreen:function(){},cancelFullScreen:function(){},fullScreenEventName:"",element:null,prefix:""},t="webkit moz o ms khtml".split(" ");if("undefined"!=typeof document.cancelFullScreen)e.supportsFullScreen=!0;else for(var n=0,r=t.length;r>n;n++){if(e.prefix=t[n],"undefined"!=typeof document[e.prefix+"CancelFullScreen"]){e.supportsFullScreen=!0;break}if("undefined"!=typeof document.msExitFullscreen&&document.msFullscreenEnabled){e.prefix="ms",e.supportsFullScreen=!0;break}}return"webkit"===e.prefix&&navigator.userAgent.match(/Version\/[\d\.]+.*Safari/)&&(e.supportsFullScreen=!1),e.supportsFullScreen&&(e.fullScreenEventName="ms"==e.prefix?"MSFullscreenChange":e.prefix+"fullscreenchange",e.isFullScreen=function(){switch(this.prefix){case"":return document.fullScreen;case"webkit":return document.webkitIsFullScreen;case"ms":return null!==document.msFullscreenElement;default:return document[this.prefix+"FullScreen"]}},e.requestFullScreen=function(e){return""===this.prefix?e.requestFullScreen():e[this.prefix+("ms"==this.prefix?"RequestFullscreen":"RequestFullScreen")]("webkit"===this.prefix?e.ALLOW_KEYBOARD_INPUT:null)},e.cancelFullScreen=function(){return""===this.prefix?document.cancelFullScreen():document[this.prefix+("ms"==this.prefix?"ExitFullscreen":"CancelFullScreen")]()},e.element=function(){return""===this.prefix?document.fullscreenElement:document[this.prefix+"FullscreenElement"]}),e}function b(){var e={supported:function(){try{return"localStorage"in window&&null!==window.localStorage}catch(e){return!1}}()};return e}function h(e){function u(e){if(!et.usingTextTracks&&"video"===et.type){for(et.subcount=0,e="number"==typeof e?e:et.media.currentTime;h(et.captions[et.subcount][0])<e.toFixed(1);)if(et.subcount++,et.subcount>et.captions.length-1){et.subcount=et.captions.length-1;break}et.media.currentTime.toFixed(1)>=g(et.captions[et.subcount][0])&&et.media.currentTime.toFixed(1)<=h(et.captions[et.subcount][0])?(et.currentCaption=et.captions[et.subcount][1],et.captionsContainer.innerHTML=et.currentCaption):et.captionsContainer.innerHTML=""}}function f(){c(et.container,x.classes.captions.enabled,!0),x.captions.defaultActive&&(c(et.container,x.classes.captions.active,!0),et.buttons.captions.setAttribute("checked",""))}function g(e){var t=[];return t=e.split(" --> "),w(t[0])}function h(e){var t=[];return t=e.split(" --> "),w(t[1])}function w(e){if(null===e||void 0===e)return 0;var t,n=[],r=[];return n=e.split(","),r=n[0].split(":"),t=Math.floor(60*r[0]*60)+Math.floor(60*r[1])+Math.floor(r[2])}function T(e){return et.container.querySelectorAll(e)}function S(e){return T(e)[0]}function F(){try{return window.self!==window.top}catch(e){return!0}}function C(){t("Injecting custom controls.");var e=x.html;if(e=s(e,"{seektime}",x.seekTime),e=s(e,"{id}",et.random),et.container.insertAdjacentHTML("beforeend",e),x.tooltips)for(var n=T(x.selectors.labels),r=n.length-1;r>=0;r--){var a=n[r];c(a,x.classes.hidden,!1),c(a,x.classes.tooltip,!0)}}function E(){try{return et.controls=S(x.selectors.controls),et.buttons={},et.buttons.seek=S(x.selectors.buttons.seek),et.buttons.play=S(x.selectors.buttons.play),et.buttons.pause=S(x.selectors.buttons.pause),et.buttons.restart=S(x.selectors.buttons.restart),et.buttons.rewind=S(x.selectors.buttons.rewind),et.buttons.forward=S(x.selectors.buttons.forward),et.buttons.fullscreen=S(x.selectors.buttons.fullscreen),et.buttons.mute=S(x.selectors.buttons.mute),et.buttons.captions=S(x.selectors.buttons.captions),et.checkboxes=T("[type='checkbox']"),et.progress={},et.progress.container=S(x.selectors.progress.container),et.progress.buffer={},et.progress.buffer.bar=S(x.selectors.progress.buffer),et.progress.buffer.text=et.progress.buffer.bar.getElementsByTagName("span")[0],et.progress.played={},et.progress.played.bar=S(x.selectors.progress.played),et.progress.played.text=et.progress.played.bar.getElementsByTagName("span")[0],et.volume=S(x.selectors.buttons.volume),et.duration=S(x.selectors.duration),et.seekTime=T(x.selectors.seekTime),!0}catch(e){return t("It looks like there's a problem with your controls html. Bailing.",!0),!1}}function A(){var e=et.buttons.play.innerText||"Play";"undefined"!=typeof x.title&&x.title.length&&(e+=", "+x.title),et.buttons.play.setAttribute("aria-label",e)}function N(){if(et.media=et.container.querySelectorAll("audio, video")[0],!et.media)return t("No audio or video element found!",!0),!1;if(et.media.removeAttribute("controls"),et.type=et.media.tagName.toLowerCase(),c(et.container,x.classes[et.type],!0),c(et.container,x.classes.stopped,null===et.media.getAttribute("autoplay")),et.browser.ios&&c(et.container,"ios",!0),"video"===et.type){var e=document.createElement("div");e.setAttribute("class",x.classes.videoWrapper),a(et.media,e),et.videoContainer=e}null!==et.media.getAttribute("autoplay")&&M()}function P(){if("video"===et.type){et.videoContainer.insertAdjacentHTML("afterbegin","<div class='"+x.selectors.captions.replace(".","")+"'></div>"),et.captionsContainer=S(x.selectors.captions),et.usingTextTracks=!1,et.media.textTracks&&(et.usingTextTracks=!0);for(var e,n="",r=et.media.childNodes,s=0;s<r.length;s++)"track"===r[s].nodeName.toLowerCase()&&(e=r[s].getAttribute("kind"),"captions"===e&&(n=r[s].getAttribute("src")));if(et.captionExists=!0,""===n?(et.captionExists=!1,t("No caption track found.")):t("Caption track found; URI: "+n),et.captionExists){for(var a=et.media.textTracks,o=0;o<a.length;o++)a[o].mode="hidden";if(f(et),("IE"===et.browser.name&&10===et.browser.version||"IE"===et.browser.name&&11===et.browser.version||"Firefox"===et.browser.name&&et.browser.version>=31||"Safari"===et.browser.name&&et.browser.version>=7)&&(t("Detected IE 10/11 or Firefox 31+ or Safari 7+."),et.usingTextTracks=!1),et.usingTextTracks){t("TextTracks supported.");for(var i=0;i<a.length;i++){var l=a[i];"captions"===l.kind&&p(l,"cuechange",function(){this.activeCues[0]&&this.activeCues[0].hasOwnProperty("text")&&(et.captionsContainer.innerHTML=this.activeCues[0].text)})}}else if(t("TextTracks not supported so rendering captions manually."),et.currentCaption="",et.captions=[],""!==n){var u=new XMLHttpRequest;u.onreadystatechange=function(){if(4===u.readyState)if(200===u.status){var e,n=[],r=u.responseText;n=r.split("\n\n");for(var s=0;s<n.length;s++)e=n[s],et.captions[s]=[],et.captions[s]=e.split("\n");et.captions.shift(),t("Successfully loaded the caption file via AJAX.")}else t("There was a problem loading the caption file via AJAX.",!0)},u.open("get",n,!0),u.send()}if("Safari"===et.browser.name&&et.browser.version>=7){t("Safari 7+ detected; removing track from DOM."),a=et.media.getElementsByTagName("track");for(var d=0;d<a.length;d++)et.media.removeChild(a[d])}}else c(et.container,x.classes.captions.enabled)}}function L(){if("video"===et.type&&x.fullscreen.enabled){var e=k.supportsFullScreen;e||x.fullscreen.fallback&&!F()?(t((e?"Native":"Fallback")+" fullscreen enabled."),c(et.container,x.classes.fullscreen.enabled,!0)):t("Fullscreen not supported and fallback disabled.")}}function M(){et.media.play()}function I(){et.media.pause()}function O(e){"number"!=typeof e&&(e=x.seekTime),V(et.media.currentTime-e)}function q(e){"number"!=typeof e&&(e=x.seekTime),V(et.media.currentTime+e)}function V(e){var n=0;"number"==typeof e?n=e:"object"!=typeof e||"change"!==e.type&&"input"!==e.type||(n=e.target.value/e.target.max*et.media.duration),0>n?n=0:n>et.media.duration&&(n=et.media.duration);try{et.media.currentTime=n.toFixed(1)}catch(r){}t("Seeking to "+et.media.currentTime+" seconds"),u(n)}function H(){c(et.container,x.classes.playing,!et.media.paused),c(et.container,x.classes.stopped,et.media.paused)}function B(e){var t=k.supportsFullScreen;e&&e.type===k.fullScreenEventName?x.fullscreen.active=k.isFullScreen():t?(k.isFullScreen()?k.cancelFullScreen():k.requestFullScreen(et.container),x.fullscreen.active=k.isFullScreen()):(x.fullscreen.active=!x.fullscreen.active,x.fullscreen.active?(p(document,"keyup",R),document.body.style.overflow="hidden"):(d(document,"keyup",R),document.body.style.overflow="")),c(et.container,x.classes.fullscreen.active,x.fullscreen.active)}function R(e){27===(e.which||e.charCode||e.keyCode)&&x.fullscreen.active&&B()}function j(e){"undefined"==typeof e&&(e=x.storage.enabled&&b().supported?window.localStorage[x.storage.key]||x.volume:x.volume),e>10&&(e=10),et.volume.value=e,et.media.volume=parseFloat(e/10),D(),x.storage.enabled&&b().supported&&(window.localStorage.plyr_volume=e)}function W(e){"undefined"==typeof active&&(e=!et.media.muted,et.buttons.mute.checked=e),et.media.muted=e,D()}function _(e){"undefined"==typeof e&&(e=-1===et.container.className.indexOf(x.classes.captions.active),et.buttons.captions.checked=e),e?c(et.container,x.classes.captions.active,!0):c(et.container,x.classes.captions.active)}function D(){c(et.container,x.classes.muted,0===et.media.volume||et.media.muted)}function U(e){var t="waiting"===e.type;clearTimeout(et.loadingTimer),et.loadingTimer=setTimeout(function(){c(et.container,x.classes.loading,t)},t?250:0)}function X(e){var t=et.progress.played.bar,n=et.progress.played.text,r=0;if(e)switch(e.type){case"timeupdate":case"seeking":r=v(et.media.currentTime,et.media.duration),"timeupdate"==e.type&&(et.buttons.seek.value=r);break;case"change":case"input":r=e.target.value;break;case"playing":case"progress":t=et.progress.buffer.bar,n=et.progress.buffer.text,r=function(){var e=et.media.buffered;return e.length?v(e.end(0),et.media.duration):0}()}t.value=r,n.innerHTML=r}function J(){et.secs=parseInt(et.media.currentTime%60),et.mins=parseInt(et.media.currentTime/60%60),et.secs=("0"+et.secs).slice(-2),et.mins=("0"+et.mins).slice(-2),et.duration.innerHTML=et.mins+":"+et.secs}function $(e){J(),X(e)}function z(){for(var e=et.media.querySelectorAll("source"),t=e.length-1;t>=0;t--)o(e[t]);et.media.removeAttribute("src")}function K(e){if(e.src){var t=document.createElement("source");l(t,e),i(et.media,t)}}function Y(e){if(I(),V(),H(),z(),"string"==typeof e)et.media.setAttribute("src",e);else if(e.constructor===Array)for(var t in e)K(e[t]);$(),et.media.load(),null!==et.media.getAttribute("autoplay")&&M()}function G(e){"video"===et.type&&et.media.setAttribute("poster",e)}function Q(){p(et.buttons.play,"click",function(){M(),setTimeout(function(){et.buttons.pause.focus()},100)}),p(et.buttons.pause,"click",function(){I(),setTimeout(function(){et.buttons.play.focus()},100)}),p(et.buttons.restart,"click",V),p(et.buttons.rewind,"click",O),p(et.buttons.forward,"click",q),p(et.volume,"change input",function(){j(this.value)}),p(et.buttons.mute,"change",function(){W(this.checked)}),p(et.buttons.fullscreen,"click",B),p(document,k.fullScreenEventName,B),p(et.media,"timeupdate seeking",$),p(et.media,"timeupdate",u),p(et.buttons.seek,"change input",V),p(et.buttons.captions,"change",function(){_(this.checked)}),p(et.media,"ended",function(){"video"===et.type&&(et.captionsContainer.innerHTML=""),H()}),p(et.media,"progress",X),p(et.media,"playing",X),p(et.media,"volumechange",D),p(et.media,"play pause",H),p(et.media,"waiting canplay seeked",U),p(et.checkboxes,"keyup",m),"video"===et.type&&x.click&&p(et.videoContainer,"click",function(){et.media.paused?M():et.media.ended?(V(),M()):I()})}function Z(){return k=y(),et.browser=n(),t(et.browser.name+" "+et.browser.version),"IE"!==et.browser.name||8!==et.browser.version&&9!==et.browser.version?(N(),et.random=Math.floor(1e4*Math.random()),C(),E()?(A(),P(),j(),L(),Q(),!0):!1):(t("Browser not suppported.",!0),!1)}var et=this;return et.container=e,Z()?{media:et.media,play:M,pause:I,restart:V,rewind:O,forward:q,seek:V,setVolume:j,toggleMute:W,toggleCaptions:_,source:Y,poster:G,support:function(e){return r(et,e)}}:{}}var k,x,w={enabled:!0,debug:!1,seekTime:10,volume:5,click:!0,tooltips:!1,selectors:{container:".player",controls:".player-controls",labels:"[data-player] .sr-only, label .sr-only",buttons:{seek:"[data-player='seek']",play:"[data-player='play']",pause:"[data-player='pause']",restart:"[data-player='restart']",rewind:"[data-player='rewind']",forward:"[data-player='fast-forward']",mute:"[data-player='mute']",volume:"[data-player='volume']",captions:"[data-player='captions']",fullscreen:"[data-player='fullscreen']"},progress:{container:".player-progress",buffer:".player-progress-buffer",played:".player-progress-played"},captions:".player-captions",duration:".player-duration"},classes:{video:"player-video",videoWrapper:"player-video-wrapper",audio:"player-audio",stopped:"stopped",playing:"playing",muted:"muted",loading:"loading",tooltip:"player-tooltip",hidden:"sr-only",captions:{enabled:"captions-enabled",active:"captions-active"},fullscreen:{enabled:"fullscreen-enabled",active:"fullscreen-active"}},captions:{defaultActive:!1},fullscreen:{enabled:!0,fallback:!0},storage:{enabled:!0,key:"plyr_volume"},html:function(){return["<div class='player-controls'>","<div class='player-progress'>","<label for='seek{id}' class='sr-only'>Seek</label>","<input id='seek{id}' class='player-progress-seek' type='range' min='0' max='100' step='0.5' value='0' data-player='seek'>","<progress class='player-progress-played' max='100' value='0'>","<span>0</span>% played","</progress>","<progress class='player-progress-buffer' max='100' value='0'>","<span>0</span>% buffered","</progress>","</div>","<span class='player-controls-left'>","<button type='button' data-player='restart'>","<svg><use xlink:href='#icon-restart'></use></svg>","<span class='sr-only'>Restart</span>","</button>","<button type='button' data-player='rewind'>","<svg><use xlink:href='#icon-rewind'></use></svg>","<span class='sr-only'>Rewind {seektime} secs</span>","</button>","<button type='button' data-player='play'>","<svg><use xlink:href='#icon-play'></use></svg>","<span class='sr-only'>Play</span>","</button>","<button type='button' data-player='pause'>","<svg><use xlink:href='#icon-pause'></use></svg>","<span class='sr-only'>Pause</span>","</button>","<button type='button' data-player='fast-forward'>","<svg><use xlink:href='#icon-fast-forward'></use></svg>","<span class='sr-only'>Forward {seektime} secs</span>","</button>","<span class='player-time'>","<span class='sr-only'>Time</span>","<span class='player-duration'>00:00</span>","</span>","</span>","<span class='player-controls-right'>","<input class='inverted sr-only' id='mute{id}' type='checkbox' data-player='mute'>","<label id='mute{id}' for='mute{id}'>","<svg class='icon-muted'><use xlink:href='#icon-muted'></use></svg>","<svg><use xlink:href='#icon-volume'></use></svg>","<span class='sr-only'>Toggle Mute</span>","</label>","<label for='volume{id}' class='sr-only'>Volume</label>","<input id='volume{id}' class='player-volume' type='range' min='0' max='10' value='5' data-player='volume'>","<input class='sr-only' id='captions{id}' type='checkbox' data-player='captions'>","<label for='captions{id}'>","<svg class='icon-captions-on'><use xlink:href='#icon-captions-on'></use></svg>","<svg><use xlink:href='#icon-captions-off'></use></svg>","<span class='sr-only'>Toggle Captions</span>","</label>","<button type='button' data-player='fullscreen'>","<svg class='icon-exit-fullscreen'><use xlink:href='#icon-exit-fullscreen'></use></svg>","<svg><use xlink:href='#icon-enter-fullscreen'></use></svg>","<span class='sr-only'>Toggle Fullscreen</span>","</button>","</span>","</div>"].join("\n")}()};e.setup=function(e){if(x=g(w,e),!x.enabled)return!1;for(var t=document.querySelectorAll(x.selectors.container),n=[],r=t.length-1;r>=0;r--){var s=t[r];if("video"!==s.querySelectorAll("audio, video")[0].tagName.toLowerCase()||!/iPhone/i.test(navigator.userAgent)){if("undefined"==typeof s.plyr){var a=new h(s);s.plyr=Object.keys(a).length?a:!1}n.push(s.plyr)}}return n}}(this.plyr=this.plyr||{});