From 0227dfa7d8d2dd51ec3bc9ab58e014b3267a71ce Mon Sep 17 00:00:00 2001 From: Sam Potts Date: Fri, 6 Mar 2015 01:51:12 +1100 Subject: [PATCH] Working on source() api method --- dist/plyr.js | 2 +- src/js/plyr.js | 100 ++++++++++++++++++++++++++++++++++++++++++++++--- 2 files changed, 95 insertions(+), 7 deletions(-) diff --git a/dist/plyr.js b/dist/plyr.js index 38eda61d..ca900787 100644 --- a/dist/plyr.js +++ b/dist/plyr.js @@ -1 +1 @@ -!function(e){"use strict";function t(e,t){b.debug&&window.console&&console[t?"error":"log"](e)}function n(){var e,t,n,s=navigator.userAgent,r=navigator.appName,a=""+parseFloat(navigator.appVersion),o=parseInt(navigator.appVersion,10);return-1!==navigator.appVersion.indexOf("Windows NT")&&-1!==navigator.appVersion.indexOf("rv:11")?(r="IE",a="11;"):-1!==(t=s.indexOf("MSIE"))?(r="IE",a=s.substring(t+5)):-1!==(t=s.indexOf("Chrome"))?(r="Chrome",a=s.substring(t+7)):-1!==(t=s.indexOf("Safari"))?(r="Safari",a=s.substring(t+7),-1!==(t=s.indexOf("Version"))&&(a=s.substring(t+8))):-1!==(t=s.indexOf("Firefox"))?(r="Firefox",a=s.substring(t+8)):(e=s.lastIndexOf(" ")+1)<(t=s.lastIndexOf("/"))&&(r=s.substring(e,t),a=s.substring(t+1),r.toLowerCase()==r.toUpperCase()&&(r=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)),[r,o]}function s(e,t,n){return e.replace(new RegExp(t.replace(/([.*+?^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}function r(e,t){e.length||(e=[e]);for(var n=e.length-1;n>=0;n--){var s=n>0?t.cloneNode(!0):t,r=e[n],a=r.parentNode,o=r.nextSibling;s.appendChild(r),o?a.insertBefore(s,o):a.appendChild(s)}}function a(e,t,n){if(e)if(e.classList)e.classList[n?"add":"remove"](t);else{var s=(" "+e.className+" ").replace(/\s+/g," ").replace(" "+t+" ","");e.className=s+(n?" "+t:"")}}function o(e,t,n,s){t=t.split(" ");for(var r=0;rn;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 d(){var e={supported:function(){try{return"localStorage"in window&&null!==window.localStorage}catch(e){return!1}}()};return e}function f(e){function o(){for(U.subcount=0;v(U.captions[U.subcount][0])U.captions.length-1){U.subcount=U.captions.length-1;break}}function u(){a(U.container,b.classes.captions.enabled,!0),b.captions.defaultActive&&(a(U.container,b.classes.captions.active,!0),U.buttons.captions.setAttribute("checked","checked"))}function f(e){var t=[];return t=e.split(" --> "),g(t[0])}function v(e){var t=[];return t=e.split(" --> "),g(t[1])}function g(e){if(null===e||void 0===e)return 0;var t,n=[],s=[];return n=e.split(","),s=n[0].split(":"),t=Math.floor(60*s[0]*60)+Math.floor(60*s[1])+Math.floor(s[2])}function y(e){return U.container.querySelectorAll(e)}function h(e){return y(e)[0]}function k(){try{return window.self!==window.top}catch(e){return!0}}function x(){t("Injecting custom controls.");var e=b.html;e=s(e,"{seektime}",b.seekTime),e=s(e,"{id}",U.random),U.container.insertAdjacentHTML("beforeend",e)}function w(){try{return U.controls=h(b.selectors.controls),U.buttons={},U.buttons.seek=h(b.selectors.buttons.seek),U.buttons.play=h(b.selectors.buttons.play),U.buttons.pause=h(b.selectors.buttons.pause),U.buttons.restart=h(b.selectors.buttons.restart),U.buttons.rewind=h(b.selectors.buttons.rewind),U.buttons.forward=h(b.selectors.buttons.forward),U.buttons.mute=h(b.selectors.buttons.mute),U.buttons.captions=h(b.selectors.buttons.captions),U.buttons.fullscreen=h(b.selectors.buttons.fullscreen),U.progress={},U.progress.container=h(b.selectors.progress.container),U.progress.buffer={},U.progress.buffer.bar=h(b.selectors.progress.buffer),U.progress.buffer.text=U.progress.buffer.bar.getElementsByTagName("span")[0],U.progress.played={},U.progress.played.bar=h(b.selectors.progress.played),U.progress.played.text=U.progress.played.bar.getElementsByTagName("span")[0],U.volume=h(b.selectors.buttons.volume),U.duration=h(b.selectors.duration),U.seekTime=y(b.selectors.seekTime),!0}catch(e){return t("It looks like there's a problem with your controls html. Bailing.",!0),!1}}function T(){var e=U.buttons.play.innerText||"Play";"undefined"!=typeof b.title&&b.title.length&&(e+=", "+b.title),U.buttons.play.setAttribute("aria-label",e)}function S(){if(U.media=U.container.querySelectorAll("audio, video")[0],!U.media)return t("No audio or video element found!",!0),!1;if(U.media.removeAttribute("controls"),U.type="video"==U.media.tagName.toLowerCase()?"video":"audio",a(U.container,b.classes[U.type],!0),a(U.container,b.classes.stopped,null===U.media.getAttribute("autoplay")),"video"===U.type){var e=document.createElement("div");e.setAttribute("class",b.classes.videoWrapper),r(U.media,e),U.videoContainer=e}}function F(){if("video"===U.type){U.videoContainer.insertAdjacentHTML("afterbegin","
"),U.captionsContainer=h(b.selectors.captions),U.isTextTracks=!1,U.media.textTracks&&(U.isTextTracks=!0);for(var e,n="",s=U.media.childNodes,r=0;r=31||"Safari"===U.browserName&&U.browserMajorVersion>=7)&&(t("Detected IE 10/11 or Firefox 31+ or Safari 7+."),U.isTextTracks=!1),U.isTextTracks){t("TextTracks supported.");for(var c=0;cf(U.captions[U.subcount][0])&&U.media.currentTime.toFixed(1)v(U.captions[U.subcount][0])&&U.subcount=7){t("Safari 7+ detected; removing track from DOM."),o=U.media.getElementsByTagName("track");for(var m=0;m10&&(e=10),U.volume.value=e,U.media.volume=parseFloat(e/10),R(),b.storage.enabled&&d().supported&&(window.localStorage.plyr_volume=e)}function q(e){"undefined"==typeof active&&(e=!U.media.muted,U.buttons.mute.checked=e),U.media.muted=e,R()}function H(e){"undefined"==typeof e&&(e=-1===U.container.className.indexOf(b.classes.captions.active),U.buttons.captions.checked=e),e?a(U.container,b.classes.captions.active,!0):a(U.container,b.classes.captions.active)}function R(){a(U.container,b.classes.muted,0===U.media.volume||U.media.muted)}function B(e){var t,n,s=0;switch(e.type){case"timeupdate":case"seeking":t=U.progress.played.bar,n=U.progress.played.text,s=c(U.media.currentTime,U.media.duration),"timeupdate"==e.type&&(U.buttons.seek.value=s);break;case"change":case"input":t=U.progress.played.bar,n=U.progress.played.text,s=e.target.value;break;case"playing":case"progress":t=U.progress.buffer.bar,n=U.progress.buffer.text,s=function(){var e=U.media.buffered;return e.length?c(e.end(0),U.media.duration):0}()}t&&s>0&&(t.value=s,n.innerHTML=s)}function P(){U.secs=parseInt(U.media.currentTime%60),U.mins=parseInt(U.media.currentTime/60%60),U.secs=("0"+U.secs).slice(-2),U.mins=("0"+U.mins).slice(-2),U.duration.innerHTML=U.mins+":"+U.secs}function W(e){P(),B(e)}function _(){i(U.buttons.play,"click",function(){C(),setTimeout(function(){U.buttons.pause.focus()},100)}),i(U.buttons.pause,"click",function(){E(),setTimeout(function(){U.buttons.play.focus()},100)}),i(U.buttons.restart,"click",M),i(U.buttons.rewind,"click",A),i(U.buttons.forward,"click",I),i(U.volume,"change input",function(){j(this.value)}),i(U.buttons.mute,"change",function(){q(this.checked)}),i(U.buttons.fullscreen,"click",L),i(document,m.fullScreenEventName,L),"video"===U.type&&b.click&&i(U.videoContainer,"click",function(){U.media.paused?C():U.media.ended?M():E()}),i(U.media,"timeupdate seeking",W),i(U.buttons.seek,"change input",X),i(U.buttons.captions,"click",function(){H(this.checked)}),i(U.media,"ended",function(){"video"===U.type&&(U.captionsContainer.innerHTML=""),V()}),i(U.media,"progress",B),i(U.media,"playing",B),i(U.media,"volumechange",R),i(U.media,"play pause",V)}function D(){return m=p(),U.browserInfo=n(),U.browserName=U.browserInfo[0],U.browserMajorVersion=U.browserInfo[1],t(U.browserName+" "+U.browserMajorVersion),"IE"!==U.browserName||8!==U.browserMajorVersion&&9!==U.browserMajorVersion?(S(),U.random=Math.floor(1e4*Math.random()),x(),w()?(T(),F(),j(),N(),_(),void 0):!1):(t("Browser not suppported.",!0),!1)}var U=this;U.container=e;var X=function(e){var n=0;"undefined"!=typeof e&&("number"==typeof e?n=e:("change"===e.type||"input"===e.type)&&(n=(this.value/this.max*U.media.duration).toFixed(1)),U.media.currentTime=n,t("Seeking to "+U.media.currentTime+" seconds"),U.isTextTracks||"video"!==U.type||o(U))};return D(),{media:U.media,play:C,pause:E,restart:M,rewind:A,forward:I,seek:X,setVolume:j,toggleMute:q,toggleCaptions:H}}var m,b,v={enabled:!0,debug:!1,seekTime:10,volume:5,click:!0,selectors:{container:".player",controls:".player-controls",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",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},html:function(){return["
","
","","","","0% played","","","0% buffered","","
","","","","","","","","Time","00:00","","","","","","","","","","","","
"].join("\n")}()};e.setup=function(e){if(b=u(v,e),!b.enabled)return!1;for(var t=document.querySelectorAll(b.selectors.container),n=[],s=t.length-1;s>=0;s--){var r=t[s];"undefined"==typeof r.plyr&&(r.plyr=new f(r)),n.push(r.plyr)}return n}}(this.plyr=this.plyr||{}); \ No newline at end of file +!function(e){"use strict";function t(e,t){y.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)),[s,o]}function r(e,t,n){return e.replace(new RegExp(t.replace(/([.*+?^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}function s(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 a(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 o(e,t,n,r){t=t.split(" ");for(var s=0;sn;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 m(){var e={supported:function(){try{return"localStorage"in window&&null!==window.localStorage}catch(e){return!1}}()};return e}function b(e){function o(){for(G.subcount=0;g(G.captions[G.subcount][0])G.captions.length-1){G.subcount=G.captions.length-1;break}}function d(){a(G.container,y.classes.captions.enabled,!0),y.captions.defaultActive&&(a(G.container,y.classes.captions.active,!0),G.buttons.captions.setAttribute("checked","checked"))}function b(e){var t=[];return t=e.split(" --> "),h(t[0])}function g(e){var t=[];return t=e.split(" --> "),h(t[1])}function h(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 k(e){return G.container.querySelectorAll(e)}function x(e){return k(e)[0]}function w(){try{return window.self!==window.top}catch(e){return!0}}function T(){t("Injecting custom controls.");var e=y.html;e=r(e,"{seektime}",y.seekTime),e=r(e,"{id}",G.random),G.container.insertAdjacentHTML("beforeend",e)}function S(){try{return G.controls=x(y.selectors.controls),G.buttons={},G.buttons.seek=x(y.selectors.buttons.seek),G.buttons.play=x(y.selectors.buttons.play),G.buttons.pause=x(y.selectors.buttons.pause),G.buttons.restart=x(y.selectors.buttons.restart),G.buttons.rewind=x(y.selectors.buttons.rewind),G.buttons.forward=x(y.selectors.buttons.forward),G.buttons.mute=x(y.selectors.buttons.mute),G.buttons.captions=x(y.selectors.buttons.captions),G.buttons.fullscreen=x(y.selectors.buttons.fullscreen),G.progress={},G.progress.container=x(y.selectors.progress.container),G.progress.buffer={},G.progress.buffer.bar=x(y.selectors.progress.buffer),G.progress.buffer.text=G.progress.buffer.bar.getElementsByTagName("span")[0],G.progress.played={},G.progress.played.bar=x(y.selectors.progress.played),G.progress.played.text=G.progress.played.bar.getElementsByTagName("span")[0],G.volume=x(y.selectors.buttons.volume),G.duration=x(y.selectors.duration),G.seekTime=k(y.selectors.seekTime),!0}catch(e){return t("It looks like there's a problem with your controls html. Bailing.",!0),!1}}function F(){var e=G.buttons.play.innerText||"Play";"undefined"!=typeof y.title&&y.title.length&&(e+=", "+y.title),G.buttons.play.setAttribute("aria-label",e)}function N(){if(G.media=G.container.querySelectorAll("audio, video")[0],!G.media)return t("No audio or video element found!",!0),!1;if(G.media.removeAttribute("controls"),G.type="video"==G.media.tagName.toLowerCase()?"video":"audio",a(G.container,y.classes[G.type],!0),a(G.container,y.classes.stopped,null===G.media.getAttribute("autoplay")),"video"===G.type){var e=document.createElement("div");e.setAttribute("class",y.classes.videoWrapper),s(G.media,e),G.videoContainer=e}null!==G.media.getAttribute("autoplay")&&E()}function C(){if("video"===G.type){G.videoContainer.insertAdjacentHTML("afterbegin","
"),G.captionsContainer=x(y.selectors.captions),G.isTextTracks=!1,G.media.textTracks&&(G.isTextTracks=!0);for(var e,n="",r=G.media.childNodes,s=0;s=31||"Safari"===G.browserName&&G.browserMajorVersion>=7)&&(t("Detected IE 10/11 or Firefox 31+ or Safari 7+."),G.isTextTracks=!1),G.isTextTracks){t("TextTracks supported.");for(var l=0;lb(G.captions[G.subcount][0])&&G.media.currentTime.toFixed(1)g(G.captions[G.subcount][0])&&G.subcount=7){t("Safari 7+ detected; removing track from DOM."),o=G.media.getElementsByTagName("track");for(var f=0;f10&&(e=10),G.volume.value=e,G.media.volume=parseFloat(e/10),P(),y.storage.enabled&&m().supported&&(window.localStorage.plyr_volume=e)}function H(e){"undefined"==typeof active&&(e=!G.media.muted,G.buttons.mute.checked=e),G.media.muted=e,P()}function R(e){"undefined"==typeof e&&(e=-1===G.container.className.indexOf(y.classes.captions.active),G.buttons.captions.checked=e),e?a(G.container,y.classes.captions.active,!0):a(G.container,y.classes.captions.active)}function P(){a(G.container,y.classes.muted,0===G.media.volume||G.media.muted)}function W(e){var t,n,r=0;switch(e.type){case"timeupdate":case"seeking":t=G.progress.played.bar,n=G.progress.played.text,r=p(G.media.currentTime,G.media.duration),"timeupdate"==e.type&&(G.buttons.seek.value=r);break;case"change":case"input":t=G.progress.played.bar,n=G.progress.played.text,r=e.target.value;break;case"playing":case"progress":t=G.progress.buffer.bar,n=G.progress.buffer.text,r=function(){var e=G.media.buffered;return e.length?p(e.end(0),G.media.duration):0}()}t&&r>0&&(t.value=r,n.innerHTML=r)}function _(){G.secs=parseInt(G.media.currentTime%60),G.mins=parseInt(G.media.currentTime/60%60),G.secs=("0"+G.secs).slice(-2),G.mins=("0"+G.mins).slice(-2),G.duration.innerHTML=G.mins+":"+G.secs}function D(e){_(),W(e)}function U(e){e.parentNode.removeChild(e)}function X(){for(var e=G.media.querySelectorAll("source"),t=e.length-1;t>=0;t--)U(e[t]);G.media.removeAttribute("src")}function J(e){var t=document.createElement("source");i(t,e),l(G.media,t)}function $(e){if(X(),"string"==typeof e)G.media.setAttribute("src",e);else if("object"==typeof e)J(e);else if(e.constructor===Array)for(var t in e)J(e[t]);I(),null!==G.media.getAttribute("autoplay")&&E()}function z(e){"video"===G.type&&G.media.setAttribute("poster",e)}function K(){c(G.buttons.play,"click",function(){E(),setTimeout(function(){G.buttons.pause.focus()},100)}),c(G.buttons.pause,"click",function(){M(),setTimeout(function(){G.buttons.play.focus()},100)}),c(G.buttons.restart,"click",I),c(G.buttons.rewind,"click",V),c(G.buttons.forward,"click",L),c(G.volume,"change input",function(){B(this.value)}),c(G.buttons.mute,"change",function(){H(this.checked)}),c(G.buttons.fullscreen,"click",j),c(document,v.fullScreenEventName,j),"video"===G.type&&y.click&&c(G.videoContainer,"click",function(){G.media.paused?E():G.media.ended?(I(),E()):M()}),c(G.media,"timeupdate seeking",D),c(G.buttons.seek,"change input",Q),c(G.buttons.captions,"click",function(){R(this.checked)}),c(G.media,"ended",function(){"video"===G.type&&(G.captionsContainer.innerHTML=""),O()}),c(G.media,"progress",W),c(G.media,"playing",W),c(G.media,"volumechange",P),c(G.media,"play pause",O)}function Y(){return v=f(),G.browserInfo=n(),G.browserName=G.browserInfo[0],G.browserMajorVersion=G.browserInfo[1],t(G.browserName+" "+G.browserMajorVersion),"IE"!==G.browserName||8!==G.browserMajorVersion&&9!==G.browserMajorVersion?(N(),G.random=Math.floor(1e4*Math.random()),T(),S()?(F(),C(),B(),A(),K(),void 0):!1):(t("Browser not suppported.",!0),!1)}var G=this;G.container=e;var Q=function(e){var n=0;"undefined"!=typeof e&&("number"==typeof e?n=e:("change"===e.type||"input"===e.type)&&(n=(this.value/this.max*G.media.duration).toFixed(1)),G.media.currentTime=n,t("Seeking to "+G.media.currentTime+" seconds"),G.isTextTracks||"video"!==G.type||o(G))};return Y(),{media:G.media,play:E,pause:M,restart:I,rewind:V,forward:L,seek:Q,setVolume:B,toggleMute:H,toggleCaptions:R,source:$,poster:z}}var v,y,g={enabled:!0,debug:!1,seekTime:10,volume:5,click:!0,selectors:{container:".player",controls:".player-controls",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",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},html:function(){return["
","
","","","","0% played","","","0% buffered","","
","","","","","","","","Time","00:00","","","","","","","","","","","","
"].join("\n")}()};e.setup=function(e){if(y=d(g,e),!y.enabled)return!1;for(var t=document.querySelectorAll(y.selectors.container),n=[],r=t.length-1;r>=0;r--){var s=t[r];"undefined"==typeof s.plyr&&(s.plyr=new b(s)),n.push(s.plyr)}return n}}(this.plyr=this.plyr||{}); \ No newline at end of file diff --git a/src/js/plyr.js b/src/js/plyr.js index b16eb021..a8434ca4 100644 --- a/src/js/plyr.js +++ b/src/js/plyr.js @@ -264,6 +264,18 @@ } } + // Set attributes + function _setAttributes(element, attributes) { + for(var key in attributes) { + element.setAttribute(key, attributes[key]); + } + } + + // Prepend child + function _prependChild(parent, element) { + parent.insertBefore(element, parent.firstChild); + } + // Bind event function _on(element, events, callback) { _toggleHandler(element, events, callback, true); @@ -571,6 +583,11 @@ // Cache the container player.videoContainer = wrapper; } + + // Autoplay + if(player.media.getAttribute("autoplay") !== null) { + _play(); + } } // Setup captions @@ -772,9 +789,6 @@ if (!player.isTextTracks) { player.subcount = 0; } - - // Play and ensure the play button is in correct state - _play(); } // Rewind @@ -991,8 +1005,6 @@ progress.value = value; text.innerHTML = value; } - - //_log(event); } // Update the displayed play time @@ -1008,6 +1020,7 @@ player.duration.innerHTML = player.mins + ":" + player.secs; } + // Handle time change event function _timeUpdate(event) { // Duration _updateTimeDisplay(); @@ -1015,6 +1028,78 @@ _updateProgress(event); } + // Remove an element + function _remove(element) { + element.parentNode.removeChild(element); + } + + // Remove sources + function _removeSources() { + // Remove child elements + var sources = player.media.querySelectorAll("source"); + for (var i = sources.length - 1; i >= 0; i--) { + _remove(sources[i]); + } + + // Remove src attribute + player.media.removeAttribute("src"); + } + + // Inject a source + function _addSource(attributes) { + // Create a new + var element = document.createElement("source"); + + // Set all passed attributes + _setAttributes(element, attributes); + + // Inject the new source + _prependChild(player.media, element); + } + + // Update source + function _updateSource(sources) { + // Pause on update + // Play automatically if autoplay set or already playing + + // Remove current sources + _removeSources(); + + // If a single source is provided + // ("path/to/src.mp4") + if(typeof sources === "string") { + // Set src attribute on the element + player.media.setAttribute("src", sources); + } + // Single source but using object to pass attributes + // ({ src: "path/to/src.mp4", type: "video/mp4" }) + else if (typeof sources === "object") { + _addSource(sources); + } + // Array of source objects to pass attributes + // ([{ src: "path/to/src.mp4", type: "video/mp4" },{ src: "path/to/src.webm", type: "video/webm" }]) + else if (sources.constructor === Array) { + for (var key in sources) { + _addSource(sources[key]); + } + } + + // Restart + _restart(); + + // Play if autoplay attribute is present + if(player.media.getAttribute("autoplay") !== null) { + _play(); + } + } + + // Update poster + function _updatePoster(source) { + if(player.type === "video") { + player.media.setAttribute("poster", source); + } + } + // Listen for events function _listeners() { // Play @@ -1063,6 +1148,7 @@ } else if(player.media.ended) { _restart(); + _play(); } else { _pause(); @@ -1163,7 +1249,9 @@ seek: _seek, setVolume: _setVolume, toggleMute: _toggleMute, - toggleCaptions: _toggleCaptions + toggleCaptions: _toggleCaptions, + source: _updateSource, + poster: _updatePoster } }