aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSam Potts <me@sampotts.me>2015-04-06 13:25:36 +1000
committerSam Potts <me@sampotts.me>2015-04-06 13:25:36 +1000
commit99cabd545dda501fa23f4f1e917c3a586adea2a2 (patch)
treee6ba228c99b24dcf48ff7ada79d12273ab6b6388
parent1f7f7b10dec4d1fd28de900fc1f4c7f71650c51b (diff)
downloadplyr-99cabd545dda501fa23f4f1e917c3a586adea2a2.tar.lz
plyr-99cabd545dda501fa23f4f1e917c3a586adea2a2.tar.xz
plyr-99cabd545dda501fa23f4f1e917c3a586adea2a2.zip
Fix for generated IDs for controls, UI tweak for audio
-rw-r--r--changelog.md4
-rw-r--r--dist/plyr.css2
-rw-r--r--dist/plyr.js2
-rw-r--r--docs/error.html2
-rw-r--r--docs/index.html10
-rw-r--r--package.json2
-rw-r--r--readme.md8
-rw-r--r--src/js/plyr.js31
-rw-r--r--src/less/plyr.less12
-rw-r--r--src/sass/plyr.scss12
10 files changed, 56 insertions, 29 deletions
diff --git a/changelog.md b/changelog.md
index 5e54864e..35645f59 100644
--- a/changelog.md
+++ b/changelog.md
@@ -1,5 +1,9 @@
# Changelog
+## v1.1.3
+- Fixes for random id used in controls with multiple instances and one call to setup
+- Audio player UI improvements
+
## v1.1.2
- Added an onSetup callback option
- Added fullscreen API methods toggleFullscreen() (must be user iniated), and isFullscreen()
diff --git a/dist/plyr.css b/dist/plyr.css
index e2a66ed9..e385c71f 100644
--- a/dist/plyr.css
+++ b/dist/plyr.css
@@ -1 +1 @@
-.sr-only{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0!important;border:0!important;height:1px!important;width:1px!important;overflow:hidden}@-webkit-keyframes progress{to{background-position:40px 0}}@keyframes progress{to{background-position:40px 0}}.player{position:relative;max-width:100%;min-width:290px}.player,.player *,.player ::after,.player ::before{box-sizing:border-box}.player-video-wrapper{position:relative}.player video{width:100%;height:auto;vertical-align:middle}.player-captions{display:none;position:absolute;bottom:0;left:0;width:100%;padding:20px;min-height:2.5em;color:#fff;font-size:16px;font-weight:600;text-shadow:-1px -1px 0 #565d64,1px -1px 0 #565d64,-1px 1px 0 #565d64,1px 1px 0 #565d64;text-align:center;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}@media (min-width:768px){.player-captions{font-size:24px}}.player.captions-active .player-captions{display:block}.player-controls{zoom:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;position:relative;padding:10px;background:#343f4a;line-height:1;text-align:center}.player-controls:after,.player-controls:before{content:"";display:table}.player-controls:after{clear:both}.player-controls-right{display:block;margin:10px auto 0}@media (min-width:560px){.player-controls-left{float:left}.player-controls-right{float:right;margin-top:0}}.player-controls button,.player-controls input+label{display:inline-block;vertical-align:middle;margin:0 2px;padding:5px 10px;transition:background .3s ease;border-radius:3px;cursor:pointer}.player-controls button svg,.player-controls input+label svg{width:18px;height:18px;display:block;fill:currentColor;transition:fill .3s ease}.player-controls .inverted:checked+label,.player-controls input+label{color:#565d64}.player-controls .inverted+label,.player-controls button,.player-controls input:checked+label{color:#cbd0d3}.player-controls button{border:0;background:0 0;overflow:hidden}.player-controls [type=checkbox]+label:hover,.player-controls [type=checkbox]:focus+label,.player-controls button:focus,.player-controls button:hover{background:#3498db;color:#fff}.player-controls button:focus,.player-controls input:focus+label{outline:0}.player-controls .icon-captions-on,.player-controls .icon-exit-fullscreen,.player-controls .icon-muted{display:none}.player-controls .player-time{display:inline-block;vertical-align:middle;margin-left:10px;color:#cbd0d3;font-weight:600;font-size:14px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.player-controls .player-time+.player-time{display:none}@media (min-width:560px){.player-controls .player-time+.player-time{display:inline-block}}.player-controls .player-time+.player-time::before{content:"\2044";margin-right:10px;color:#78858d}.player-tooltip{visibility:hidden;position:absolute;z-index:2;bottom:100%;margin-bottom:10px;padding:10px 15px;opacity:0;background:#343f4a;border-radius:3px;color:#fff;font-size:14px;line-height:1.5;font-weight:600;-webkit-transform:translate(-50%,30px);transform:translate(-50%,30px);transition:-webkit-transform .2s .2s ease,opacity .2s .2s ease;transition:transform .2s .2s ease,opacity .2s .2s ease}.player-tooltip::after{content:"";display:block;position:absolute;left:50%;bottom:-5px;margin-left:-5px;width:0;height:0;transition:inherit;border-style:solid;border-width:5px 5px 0;border-color:#343f4a transparent transparent}.player button:focus .player-tooltip,.player button:hover .player-tooltip,.player input:focus+label .player-tooltip,.player label:hover .player-tooltip{visibility:visible;opacity:1;-webkit-transform:translate(-50%,0);transform:translate(-50%,0)}.player button:hover .player-tooltip,.player label:hover .player-tooltip{z-index:3}.player-progress{position:absolute;bottom:100%;left:0;right:0;width:100%;height:10px;background:rgba(86,93,100,.2)}.player-progress-buffer[value],.player-progress-played[value],.player-progress-seek[type=range]{position:absolute;left:0;top:0;width:100%;height:10px;margin:0;padding:0;vertical-align:top;-webkit-appearance:none;-moz-appearance:none;border:none;background:0 0}.player-progress-buffer[value]::-webkit-progress-bar,.player-progress-played[value]::-webkit-progress-bar{background:0 0}.player-progress-buffer[value]::-webkit-progress-value,.player-progress-played[value]::-webkit-progress-value{background:currentColor}.player-progress-buffer[value]::-moz-progress-bar,.player-progress-played[value]::-moz-progress-bar{background:currentColor}.player-progress-played[value]{z-index:2;color:#3498db}.player-progress-buffer[value]{color:rgba(86,93,100,.25)}.player-progress-seek[type=range]{z-index:4;cursor:pointer;outline:0}.player-progress-seek[type=range]::-webkit-slider-runnable-track{background:0 0;border:0}.player-progress-seek[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:0 0;border:0;width:20px;height:10px}.player-progress-seek[type=range]::-moz-range-track{background:0 0;border:0}.player-progress-seek[type=range]::-moz-range-thumb{-moz-appearance:none;background:0 0;border:0;width:20px;height:10px}.player-progress-seek[type=range]::-ms-track{color:transparent;background:0 0;border:0}.player-progress-seek[type=range]::-ms-fill-lower,.player-progress-seek[type=range]::-ms-fill-upper{background:0 0;border:0}.player-progress-seek[type=range]::-ms-thumb{background:0 0;border:0;width:20px;height:10px}.player-progress-seek[type=range]:focus{outline:0}.player-progress-seek[type=range]::-moz-focus-outer{border:0}.player.loading .player-progress-buffer{-webkit-animation:progress 1s linear infinite;animation:progress 1s linear infinite;background-size:40px 40px;background-repeat:repeat-x;background-color:rgba(86,93,100,.25);background-image:linear-gradient(-45deg,rgba(0,0,0,.15) 25%,transparent 25%,transparent 50%,rgba(0,0,0,.15) 50%,rgba(0,0,0,.15) 75%,transparent 75%,transparent);color:transparent}.player-controls [data-player=pause],.player.playing .player-controls [data-player=play]{display:none}.player.playing .player-controls [data-player=pause]{display:inline-block}.player-volume[type=range]{display:inline-block;vertical-align:middle;-webkit-appearance:none;-moz-appearance:none;width:100px;margin:0 10px 0 0;padding:0;cursor:pointer;background:0 0}.player-volume[type=range]::-webkit-slider-runnable-track{height:6px;background:#565d64;border:0;border-radius:3px}.player-volume[type=range]::-webkit-slider-thumb{-webkit-appearance:none;margin-top:-3px;height:12px;width:12px;background:#cbd0d3;border:0;border-radius:6px;transition:background .3s ease;cursor:ew-resize}.player-volume[type=range]::-moz-range-track{height:6px;background:#565d64;border:0;border-radius:3px}.player-volume[type=range]::-moz-range-thumb{height:12px;width:12px;background:#cbd0d3;border:0;border-radius:6px;transition:background .3s ease;cursor:ew-resize}.player-volume[type=range]::-ms-track{height:6px;background:0 0;border-color:transparent;border-width:3px 0;color:transparent}.player-volume[type=range]::-ms-fill-lower,.player-volume[type=range]::-ms-fill-upper{height:6px;background:#565d64;border:0;border-radius:3px}.player-volume[type=range]::-ms-thumb{height:12px;width:12px;background:#cbd0d3;border:0;border-radius:6px;transition:background .3s ease;cursor:ew-resize}.player-volume[type=range]:focus{outline:0}.player-volume[type=range]:focus::-webkit-slider-thumb{background:#3498db}.player-volume[type=range]:focus::-moz-range-thumb{background:#3498db}.player-volume[type=range]:focus::-ms-thumb{background:#3498db}.player-audio.ios .player-controls-right,.player.ios .player-volume,.player.ios [data-player=mute],.player.ios [data-player=mute]+label{display:none}.player-audio.ios .player-controls-left{float:none}.player-fullscreen,.player.fullscreen-active{position:fixed;top:0;left:0;right:0;bottom:0;height:100%;width:100%;z-index:10000000;background:#000}.player-fullscreen video,.player.fullscreen-active video{height:100%}.player-fullscreen .player-video-wrapper,.player.fullscreen-active .player-video-wrapper{height:100%;width:100%}.player-fullscreen .player-video-wrapper .player-captions,.player.fullscreen-active .player-video-wrapper .player-captions{top:auto;bottom:90px}@media (min-width:560px) and (max-width:767px){.player-fullscreen .player-video-wrapper .player-captions,.player.fullscreen-active .player-video-wrapper .player-captions{bottom:60px}}@media (min-width:768px){.player-fullscreen .player-video-wrapper .player-captions,.player.fullscreen-active .player-video-wrapper .player-captions{bottom:80px}}.player-fullscreen .player-controls,.player.fullscreen-active .player-controls{position:absolute;bottom:0;left:0;right:0}.player-fullscreen.fullscreen-hide-controls.playing .player-controls,.player.fullscreen-active.fullscreen-hide-controls.playing .player-controls{-webkit-transform:translateY(100%) translateY(5px);transform:translateY(100%) translateY(5px);transition:-webkit-transform .3s 1s ease;transition:transform .3s 1s ease}.player-fullscreen.fullscreen-hide-controls.playing .player-controls.hover,.player.fullscreen-active.fullscreen-hide-controls.playing .player-controls.hover{-webkit-transform:translateY(0);transform:translateY(0);transition-delay:0}.player.captions-active .player-controls .icon-captions-on,.player.fullscreen-active .icon-exit-fullscreen,.player.muted .player-controls .icon-muted{display:block}.player [data-player=captions],.player [data-player=captions]+label,.player [data-player=fullscreen],.player [data-player=fullscreen]+label,.player.captions-active .player-controls .icon-captions-on+svg,.player.fullscreen-active .icon-exit-fullscreen+svg,.player.muted .player-controls .icon-muted+svg{display:none}.player.captions-enabled [data-player=captions],.player.captions-enabled [data-player=captions]+label,.player.fullscreen-enabled [data-player=fullscreen],.player.fullscreen-enabled [data-player=fullscreen]+label{display:inline-block} \ No newline at end of file
+.sr-only{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0!important;border:0!important;height:1px!important;width:1px!important;overflow:hidden}@-webkit-keyframes progress{to{background-position:40px 0}}@keyframes progress{to{background-position:40px 0}}.player{position:relative;max-width:100%;min-width:290px}.player,.player *,.player ::after,.player ::before{box-sizing:border-box}.player-video-wrapper{position:relative}.player video{width:100%;height:auto;vertical-align:middle}.player-captions{display:none;position:absolute;bottom:0;left:0;width:100%;padding:20px;min-height:2.5em;color:#fff;font-size:16px;font-weight:600;text-shadow:-1px -1px 0 #565d64,1px -1px 0 #565d64,-1px 1px 0 #565d64,1px 1px 0 #565d64;text-align:center;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}@media (min-width:768px){.player-captions{font-size:24px}}.player.captions-active .player-captions{display:block}.player-controls{zoom:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;position:relative;padding:10px;background:#343f4a;line-height:1;text-align:center}.player-controls:after,.player-controls:before{content:"";display:table}.player-controls:after{clear:both}.player-controls-right{display:block;margin:10px auto 0}@media (min-width:560px){.player-controls-left{float:left}.player-controls-right{float:right;margin-top:0}}.player-controls button,.player-controls input+label{display:inline-block;vertical-align:middle;margin:0 2px;padding:5px 10px;transition:background .3s ease;border-radius:3px;cursor:pointer}.player-controls button svg,.player-controls input+label svg{width:18px;height:18px;display:block;fill:currentColor;transition:fill .3s ease}.player-controls .inverted:checked+label,.player-controls input+label{color:#565d64}.player-controls .inverted+label,.player-controls button,.player-controls input:checked+label{color:#cbd0d3}.player-controls button{border:0;background:0 0;overflow:hidden}.player-controls [type=checkbox]+label:hover,.player-controls [type=checkbox]:focus+label,.player-controls button:focus,.player-controls button:hover{background:#3498db;color:#fff}.player-controls button:focus,.player-controls input:focus+label{outline:0}.player-controls .icon-captions-on,.player-controls .icon-exit-fullscreen,.player-controls .icon-muted{display:none}.player-controls .player-time{display:inline-block;vertical-align:middle;margin-left:10px;color:#cbd0d3;font-weight:600;font-size:14px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.player-controls .player-time+.player-time{display:none}@media (min-width:560px){.player-controls .player-time+.player-time{display:inline-block}}.player-controls .player-time+.player-time::before{content:"\2044";margin-right:10px;color:#78858d}.player-tooltip{visibility:hidden;position:absolute;z-index:2;bottom:100%;margin-bottom:10px;padding:10px 15px;opacity:0;background:#343f4a;border-radius:3px;color:#fff;font-size:14px;line-height:1.5;font-weight:600;-webkit-transform:translate(-50%,30px);transform:translate(-50%,30px);transition:-webkit-transform .2s .2s ease,opacity .2s .2s ease;transition:transform .2s .2s ease,opacity .2s .2s ease}.player-tooltip::after{content:"";display:block;position:absolute;left:50%;bottom:-5px;margin-left:-5px;width:0;height:0;transition:inherit;border-style:solid;border-width:5px 5px 0;border-color:#343f4a transparent transparent}.player button:focus .player-tooltip,.player button:hover .player-tooltip,.player input:focus+label .player-tooltip,.player label:hover .player-tooltip{visibility:visible;opacity:1;-webkit-transform:translate(-50%,0);transform:translate(-50%,0)}.player button:hover .player-tooltip,.player label:hover .player-tooltip{z-index:3}.player-progress{position:absolute;bottom:100%;left:0;right:0;width:100%;height:10px;background:rgba(86,93,100,.2)}.player-progress-buffer[value],.player-progress-played[value],.player-progress-seek[type=range]{position:absolute;left:0;top:0;width:100%;height:10px;margin:0;padding:0;vertical-align:top;-webkit-appearance:none;-moz-appearance:none;border:none;background:0 0}.player-progress-buffer[value]::-webkit-progress-bar,.player-progress-played[value]::-webkit-progress-bar{background:0 0}.player-progress-buffer[value]::-webkit-progress-value,.player-progress-played[value]::-webkit-progress-value{background:currentColor}.player-progress-buffer[value]::-moz-progress-bar,.player-progress-played[value]::-moz-progress-bar{background:currentColor}.player-progress-played[value]{z-index:2;color:#3498db}.player-progress-buffer[value]{color:rgba(86,93,100,.25)}.player-progress-seek[type=range]{z-index:4;cursor:pointer;outline:0}.player-progress-seek[type=range]::-webkit-slider-runnable-track{background:0 0;border:0}.player-progress-seek[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:0 0;border:0;width:20px;height:10px}.player-progress-seek[type=range]::-moz-range-track{background:0 0;border:0}.player-progress-seek[type=range]::-moz-range-thumb{-moz-appearance:none;background:0 0;border:0;width:20px;height:10px}.player-progress-seek[type=range]::-ms-track{color:transparent;background:0 0;border:0}.player-progress-seek[type=range]::-ms-fill-lower,.player-progress-seek[type=range]::-ms-fill-upper{background:0 0;border:0}.player-progress-seek[type=range]::-ms-thumb{background:0 0;border:0;width:20px;height:10px}.player-progress-seek[type=range]:focus{outline:0}.player-progress-seek[type=range]::-moz-focus-outer{border:0}.player.loading .player-progress-buffer{-webkit-animation:progress 1s linear infinite;animation:progress 1s linear infinite;background-size:40px 40px;background-repeat:repeat-x;background-color:rgba(86,93,100,.25);background-image:linear-gradient(-45deg,rgba(0,0,0,.15) 25%,transparent 25%,transparent 50%,rgba(0,0,0,.15) 50%,rgba(0,0,0,.15) 75%,transparent 75%,transparent);color:transparent}.player-controls [data-player=pause],.player.playing .player-controls [data-player=play]{display:none}.player.playing .player-controls [data-player=pause]{display:inline-block}.player-volume[type=range]{display:inline-block;vertical-align:middle;-webkit-appearance:none;-moz-appearance:none;width:100px;margin:0 10px 0 0;padding:0;cursor:pointer;background:0 0}.player-volume[type=range]::-webkit-slider-runnable-track{height:6px;background:#565d64;border:0;border-radius:3px}.player-volume[type=range]::-webkit-slider-thumb{-webkit-appearance:none;margin-top:-3px;height:12px;width:12px;background:#cbd0d3;border:0;border-radius:6px;transition:background .3s ease;cursor:ew-resize}.player-volume[type=range]::-moz-range-track{height:6px;background:#565d64;border:0;border-radius:3px}.player-volume[type=range]::-moz-range-thumb{height:12px;width:12px;background:#cbd0d3;border:0;border-radius:6px;transition:background .3s ease;cursor:ew-resize}.player-volume[type=range]::-ms-track{height:6px;background:0 0;border-color:transparent;border-width:3px 0;color:transparent}.player-volume[type=range]::-ms-fill-lower,.player-volume[type=range]::-ms-fill-upper{height:6px;background:#565d64;border:0;border-radius:3px}.player-volume[type=range]::-ms-thumb{height:12px;width:12px;background:#cbd0d3;border:0;border-radius:6px;transition:background .3s ease;cursor:ew-resize}.player-volume[type=range]:focus{outline:0}.player-volume[type=range]:focus::-webkit-slider-thumb{background:#3498db}.player-volume[type=range]:focus::-moz-range-thumb{background:#3498db}.player-volume[type=range]:focus::-ms-thumb{background:#3498db}.player-audio.ios .player-controls-right,.player.ios .player-volume,.player.ios [data-player=mute],.player.ios [data-player=mute]+label{display:none}.player-audio.ios .player-controls-left{float:none}.player-audio .player-controls{padding-top:20px}.player-audio .player-progress{bottom:auto;top:0;background:#f9fafb}.player-fullscreen,.player.fullscreen-active{position:fixed;top:0;left:0;right:0;bottom:0;height:100%;width:100%;z-index:10000000;background:#000}.player-fullscreen video,.player.fullscreen-active video{height:100%}.player-fullscreen .player-video-wrapper,.player.fullscreen-active .player-video-wrapper{height:100%;width:100%}.player-fullscreen .player-video-wrapper .player-captions,.player.fullscreen-active .player-video-wrapper .player-captions{top:auto;bottom:90px}@media (min-width:560px) and (max-width:767px){.player-fullscreen .player-video-wrapper .player-captions,.player.fullscreen-active .player-video-wrapper .player-captions{bottom:60px}}@media (min-width:768px){.player-fullscreen .player-video-wrapper .player-captions,.player.fullscreen-active .player-video-wrapper .player-captions{bottom:80px}}.player-fullscreen .player-controls,.player.fullscreen-active .player-controls{position:absolute;bottom:0;left:0;right:0}.player-fullscreen.fullscreen-hide-controls.playing .player-controls,.player.fullscreen-active.fullscreen-hide-controls.playing .player-controls{-webkit-transform:translateY(100%) translateY(5px);transform:translateY(100%) translateY(5px);transition:-webkit-transform .3s 1s ease;transition:transform .3s 1s ease}.player-fullscreen.fullscreen-hide-controls.playing .player-controls.hover,.player.fullscreen-active.fullscreen-hide-controls.playing .player-controls.hover{-webkit-transform:translateY(0);transform:translateY(0);transition-delay:0}.player.captions-active .player-controls .icon-captions-on,.player.fullscreen-active .icon-exit-fullscreen,.player.muted .player-controls .icon-muted{display:block}.player [data-player=captions],.player [data-player=captions]+label,.player [data-player=fullscreen],.player [data-player=fullscreen]+label,.player.captions-active .player-controls .icon-captions-on+svg,.player.fullscreen-active .icon-exit-fullscreen+svg,.player.muted .player-controls .icon-muted+svg{display:none}.player.captions-enabled [data-player=captions],.player.captions-enabled [data-player=captions]+label,.player.fullscreen-enabled [data-player=fullscreen],.player.fullscreen-enabled [data-player=fullscreen]+label{display:inline-block} \ No newline at end of file
diff --git a/dist/plyr.js b/dist/plyr.js
index 45ffdad0..ffbafcbb 100644
--- a/dist/plyr.js
+++ b/dist/plyr.js
@@ -1 +1 @@
-!function(e){"use strict";function t(){var e=["<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'>"];return a(T.controls,"restart")&&e.push("<button type='button' data-player='restart'>","<svg><use xlink:href='#icon-restart'></use></svg>","<span class='sr-only'>Restart</span>","</button>"),a(T.controls,"rewind")&&e.push("<button type='button' data-player='rewind'>","<svg><use xlink:href='#icon-rewind'></use></svg>","<span class='sr-only'>Rewind {seektime} secs</span>","</button>"),a(T.controls,"play")&&e.push("<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>"),a(T.controls,"fast-forward")&&e.push("<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>"),a(T.controls,"current-time")&&e.push("<span class='player-time'>","<span class='sr-only'>Current time</span>","<span class='player-current-time'>00:00</span>","</span>"),a(T.controls,"duration")&&e.push("<span class='player-time'>","<span class='sr-only'>Duration</span>","<span class='player-duration'>00:00</span>","</span>"),e.push("</span>","<span class='player-controls-right'>"),a(T.controls,"mute")&&e.push("<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>"),a(T.controls,"volume")&&e.push("<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'>"),a(T.controls,"captions")&&e.push("<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>"),a(T.controls,"fullscreen")&&e.push("<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>"),e.push("</span>","</div>"),e.join("")}function n(e,t){T.debug&&window.console&&console[t?"error":"log"](e)}function r(){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 s(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 a(e,t){return Array.prototype.indexOf&&-1!=e.indexOf(t)}function o(e,t,n){return e.replace(new RegExp(t.replace(/([.*+?^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}function i(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 l(e){e.parentNode.removeChild(e)}function u(e,t){e.insertBefore(t,e.firstChild)}function c(e,t){for(var n in t)e.setAttribute(n,t[n])}function p(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 d(e,t,n,r){if(t=t.split(" "),e instanceof NodeList)for(var s=0;s<e.length;s++)e[s]instanceof Node&&d(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 f(e,t,n){e&&d(e,t,n,!0)}function m(e,t,n){e&&d(e,t,n,!1)}function y(e,t){var n=document.createEvent("MouseEvents");n.initEvent(t,!0,!0),e.dispatchEvent(n)}function v(e){return e.keyCode&&13!=e.keyCode?!0:(e.target.checked=!e.target.checked,y(e.target,"change"),void 0)}function g(e,t){return 0===e||0===t||isNaN(e)||isNaN(t)?0:(e/t*100).toFixed(2)}function b(e,t){for(var n in t)t[n]&&t[n].constructor&&t[n].constructor===Object?(e[n]=e[n]||{},b(e[n],t[n])):e[n]=t[n];return e}function h(){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(e){switch("undefined"==typeof e&&(e=document),this.prefix){case"":return document.fullscreenElement==e;default:return document[this.prefix+"FullscreenElement"]==e}},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 k(){var e={supported:function(){try{return"localStorage"in window&&null!==window.localStorage}catch(e){return!1}}()};return e}function x(a){function d(e){if(!rt.usingTextTracks&&"video"===rt.type&&rt.supported.full){for(rt.subcount=0,e="number"==typeof e?e:rt.media.currentTime;x(rt.captions[rt.subcount][0])<e.toFixed(1);)if(rt.subcount++,rt.subcount>rt.captions.length-1){rt.subcount=rt.captions.length-1;break}rt.media.currentTime.toFixed(1)>=b(rt.captions[rt.subcount][0])&&rt.media.currentTime.toFixed(1)<=x(rt.captions[rt.subcount][0])?(rt.currentCaption=rt.captions[rt.subcount][1],rt.captionsContainer.innerHTML=rt.currentCaption):rt.captionsContainer.innerHTML=""}}function y(){rt.buttons.captions&&(p(rt.container,T.classes.captions.enabled,!0),T.captions.defaultActive&&(p(rt.container,T.classes.captions.active,!0),rt.buttons.captions.checked=!0))}function b(e){var t=[];return t=e.split(" --> "),F(t[0])}function x(e){var t=[];return t=e.split(" --> "),F(t[1])}function F(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 S(e){return rt.container.querySelectorAll(e)}function C(e){return S(e)[0]}function E(){try{return window.self!==window.top}catch(e){return!0}}function A(){if(n("Injecting custom controls."),T.html||(T.html=t()),T.html=o(T.html,"{seektime}",T.seekTime),T.html=o(T.html,"{id}",rt.random),rt.container.insertAdjacentHTML("beforeend",T.html),T.tooltips)for(var e=S(T.selectors.labels),r=e.length-1;r>=0;r--){var s=e[r];p(s,T.classes.hidden,!1),p(s,T.classes.tooltip,!0)}}function N(){try{return rt.controls=C(T.selectors.controls),rt.buttons={},rt.buttons.seek=C(T.selectors.buttons.seek),rt.buttons.play=C(T.selectors.buttons.play),rt.buttons.pause=C(T.selectors.buttons.pause),rt.buttons.restart=C(T.selectors.buttons.restart),rt.buttons.rewind=C(T.selectors.buttons.rewind),rt.buttons.forward=C(T.selectors.buttons.forward),rt.buttons.fullscreen=C(T.selectors.buttons.fullscreen),rt.buttons.mute=C(T.selectors.buttons.mute),rt.buttons.captions=C(T.selectors.buttons.captions),rt.checkboxes=S("[type='checkbox']"),rt.progress={},rt.progress.container=C(T.selectors.progress.container),rt.progress.buffer={},rt.progress.buffer.bar=C(T.selectors.progress.buffer),rt.progress.buffer.text=rt.progress.buffer.bar&&rt.progress.buffer.bar.getElementsByTagName("span")[0],rt.progress.played={},rt.progress.played.bar=C(T.selectors.progress.played),rt.progress.played.text=rt.progress.played.bar&&rt.progress.played.bar.getElementsByTagName("span")[0],rt.volume=C(T.selectors.buttons.volume),rt.duration=C(T.selectors.duration),rt.currentTime=C(T.selectors.currentTime),rt.seekTime=S(T.selectors.seekTime),!0}catch(e){return n("It looks like there's a problem with your controls html. Bailing.",!0),rt.media.setAttribute("controls",""),!1}}function P(){if(rt.buttons.play){var e=rt.buttons.play.innerText||"Play";"undefined"!=typeof T.title&&T.title.length&&(e+=", "+T.title),rt.buttons.play.setAttribute("aria-label",e)}}function I(){if(!rt.media)return n("No audio or video element found!",!0),!1;if(rt.supported.full&&(rt.media.removeAttribute("controls"),p(rt.container,T.classes[rt.type],!0),p(rt.container,T.classes.stopped,null===rt.media.getAttribute("autoplay")),rt.browser.ios&&p(rt.container,"ios",!0),"video"===rt.type)){var e=document.createElement("div");e.setAttribute("class",T.classes.videoWrapper),i(rt.media,e),rt.videoContainer=e}null!==rt.media.getAttribute("autoplay")&&O()}function M(){if("video"===rt.type){rt.videoContainer.insertAdjacentHTML("afterbegin","<div class='"+T.selectors.captions.replace(".","")+"'></div>"),rt.captionsContainer=C(T.selectors.captions),rt.usingTextTracks=!1,rt.media.textTracks&&(rt.usingTextTracks=!0);for(var e,t="",r=rt.media.childNodes,s=0;s<r.length;s++)"track"===r[s].nodeName.toLowerCase()&&(e=r[s].getAttribute("kind"),"captions"===e&&(t=r[s].getAttribute("src")));if(rt.captionExists=!0,""===t?(rt.captionExists=!1,n("No caption track found.")):n("Caption track found; URI: "+t),rt.captionExists){for(var a=rt.media.textTracks,o=0;o<a.length;o++)a[o].mode="hidden";if(y(rt),("IE"===rt.browser.name&&10===rt.browser.version||"IE"===rt.browser.name&&11===rt.browser.version||"Firefox"===rt.browser.name&&rt.browser.version>=31||"Safari"===rt.browser.name&&rt.browser.version>=7)&&(n("Detected IE 10/11 or Firefox 31+ or Safari 7+."),rt.usingTextTracks=!1),rt.usingTextTracks){n("TextTracks supported.");for(var i=0;i<a.length;i++){var l=a[i];"captions"===l.kind&&f(l,"cuechange",function(){rt.captionsContainer.innerHTML="",this.activeCues[0]&&this.activeCues[0].hasOwnProperty("text")&&rt.captionsContainer.appendChild(this.activeCues[0].getCueAsHTML())})}}else if(n("TextTracks not supported so rendering captions manually."),rt.currentCaption="",rt.captions=[],""!==t){var u=new XMLHttpRequest;u.onreadystatechange=function(){if(4===u.readyState)if(200===u.status){var e,t=[],r=u.responseText;t=r.split("\n\n");for(var s=0;s<t.length;s++)e=t[s],rt.captions[s]=[],rt.captions[s]=e.split("\n");rt.captions.shift(),n("Successfully loaded the caption file via AJAX.")}else n("There was a problem loading the caption file via AJAX.",!0)},u.open("get",t,!0),u.send()}if("Safari"===rt.browser.name&&rt.browser.version>=7){n("Safari 7+ detected; removing track from DOM."),a=rt.media.getElementsByTagName("track");for(var c=0;c<a.length;c++)rt.media.removeChild(a[c])}}else p(rt.container,T.classes.captions.enabled)}}function L(){if("video"===rt.type&&T.fullscreen.enabled){var e=w.supportsFullScreen;e||T.fullscreen.fallback&&!E()?(n((e?"Native":"Fallback")+" fullscreen enabled."),p(rt.container,T.classes.fullscreen.enabled,!0)):n("Fullscreen not supported and fallback disabled."),T.fullscreen.hideControls&&p(rt.container,T.classes.fullscreen.hideControls,!0)}}function O(){rt.media.play()}function q(){rt.media.pause()}function H(e){"number"!=typeof e&&(e=T.seekTime),R(rt.media.currentTime-e)}function V(e){"number"!=typeof e&&(e=T.seekTime),R(rt.media.currentTime+e)}function R(e){var t=0;"number"==typeof e?t=e:"object"!=typeof e||"input"!==e.type&&"change"!==e.type||(t=e.target.value/e.target.max*rt.media.duration),0>t?t=0:t>rt.media.duration&&(t=rt.media.duration);try{rt.media.currentTime=t.toFixed(1)}catch(r){}n("Seeking to "+rt.media.currentTime+" seconds"),d(t)}function j(){p(rt.container,T.classes.playing,!rt.media.paused),p(rt.container,T.classes.stopped,rt.media.paused)}function B(e){var t=w.supportsFullScreen,n=rt.container;e&&e.type===w.fullScreenEventName?rt.isFullscreen=w.isFullScreen(n):t?(w.isFullScreen(n)?w.cancelFullScreen():w.requestFullScreen(n),rt.isFullscreen=w.isFullScreen(n)):(rt.isFullscreen=!rt.isFullscreen,rt.isFullscreen?(f(document,"keyup",D),document.body.style.overflow="hidden"):(m(document,"keyup",D),document.body.style.overflow="")),p(n,T.classes.fullscreen.active,rt.isFullscreen)}function D(e){27===(e.which||e.charCode||e.keyCode)&&rt.isFullscreen&&B()}function W(e){rt.volume&&("undefined"==typeof e&&(e=T.storage.enabled&&k().supported?window.localStorage[T.storage.key]||T.volume:T.volume),e>10&&(e=10),rt.supported.full&&(rt.volume.value=e),rt.media.volume=parseFloat(e/10),X(),T.storage.enabled&&k().supported&&(window.localStorage.plyr_volume=e))}function _(e){"undefined"==typeof e&&(e=!rt.media.muted),rt.supported.full&&(rt.buttons.mute.checked=e),rt.media.muted=e,X()}function U(e){rt.supported.full&&rt.buttons.captions&&("undefined"==typeof e&&(e=-1===rt.container.className.indexOf(T.classes.captions.active),rt.buttons.captions.checked=e),p(rt.container,T.classes.captions.active,e))}function X(){p(rt.container,T.classes.muted,0===rt.media.volume||rt.media.muted)}function J(e){var t="waiting"===e.type;clearTimeout(rt.loadingTimer),rt.loadingTimer=setTimeout(function(){p(rt.container,T.classes.loading,t)},t?250:0)}function $(e){var t=rt.progress.played.bar,n=rt.progress.played.text,r=0;if(e)switch(e.type){case"timeupdate":case"seeking":r=g(rt.media.currentTime,rt.media.duration),"timeupdate"==e.type&&rt.buttons.seek&&(rt.buttons.seek.value=r);break;case"change":case"input":r=e.target.value;break;case"playing":case"progress":t=rt.progress.buffer.bar,n=rt.progress.buffer.text,r=function(){var e=rt.media.buffered;return e.length?g(e.end(0),rt.media.duration):0}()}t&&(t.value=r),n&&(n.innerHTML=r)}function z(e,t){if(t){rt.secs=parseInt(e%60),rt.mins=parseInt(e/60%60),rt.hours=parseInt(e/60/60%60);var n=parseInt(rt.media.duration/60/60%60)>0;rt.secs=("0"+rt.secs).slice(-2),rt.mins=("0"+rt.mins).slice(-2),t.innerHTML=(n?rt.hours+":":"")+rt.mins+":"+rt.secs}}function K(){var e=rt.media.duration||0;!rt.duration&&T.displayDuration&&rt.media.paused&&z(e,rt.currentTime),rt.duration&&z(e,rt.duration)}function Y(e){z(rt.media.currentTime,rt.currentTime),$(e)}function G(){for(var e=rt.media.querySelectorAll("source"),t=e.length-1;t>=0;t--)l(e[t]);rt.media.removeAttribute("src")}function Q(e){if(e.src){var t=document.createElement("source");c(t,e),u(rt.media,t)}}function Z(e){if(q(),R(),G(),"string"==typeof e)rt.media.setAttribute("src",e);else if(e.constructor===Array)for(var t in e)Q(e[t]);rt.supported.full&&(Y(),j()),rt.media.load(),null!==rt.media.getAttribute("autoplay")&&O()}function et(e){"video"===rt.type&&rt.media.setAttribute("poster",e)}function tt(){var e="IE"==rt.browser.name?"change":"input";f(rt.buttons.play,"click",function(){O(),setTimeout(function(){rt.buttons.pause.focus()},100)}),f(rt.buttons.pause,"click",function(){q(),setTimeout(function(){rt.buttons.play.focus()},100)}),f(rt.buttons.restart,"click",R),f(rt.buttons.rewind,"click",H),f(rt.buttons.forward,"click",V),f(rt.buttons.seek,e,R),f(rt.volume,e,function(){W(this.value)}),f(rt.buttons.mute,"change",function(){_(this.checked)}),f(rt.buttons.fullscreen,"click",B),w.supportsFullScreen&&f(document,w.fullScreenEventName,B),f(rt.media,"timeupdate seeking",Y),f(rt.media,"timeupdate",d),f(rt.media,"loadedmetadata",K),f(rt.buttons.captions,"change",function(){U(this.checked)}),f(rt.media,"ended",function(){"video"===rt.type&&(rt.captionsContainer.innerHTML=""),j()}),f(rt.media,"progress",$),f(rt.media,"playing",$),f(rt.media,"volumechange",X),f(rt.media,"play pause",j),f(rt.media,"waiting canplay seeked",J),f(rt.checkboxes,"keyup",v),"video"===rt.type&&T.click&&f(rt.videoContainer,"click",function(){rt.media.paused?O():rt.media.ended?(R(),O()):q()}),T.fullscreen.hideControls&&f(rt.controls,"mouseenter mouseleave",function(e){p(rt.controls,T.classes.hover,"mouseenter"===e.type)})}function nt(){if(w=h(),rt.browser=r(),rt.media=rt.container.querySelectorAll("audio, video")[0],rt.type=rt.media.tagName.toLowerCase(),rt.supported=e.supported(rt.type),!rt.supported.basic)return!1;if(n(rt.browser.name+" "+rt.browser.version),I(),rt.random=Math.floor(1e4*Math.random()),rt.supported.full){if(A(),!N())return!1;T.displayDuration&&K(),P(),M(),W(),L(),tt()}return!0}var rt=this;return rt.container=a,nt()?{media:rt.media,play:O,pause:q,restart:R,rewind:H,forward:V,seek:R,source:Z,poster:et,setVolume:W,toggleMute:_,toggleCaptions:U,toggleFullscreen:B,isFullscreen:function(){return rt.isFullscreen||!1},support:function(e){return s(rt,e)}}:{}}var w,T,F={enabled:!0,debug:!1,seekTime:10,volume:5,click:!0,tooltips:!1,displayDuration:!0,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",currentTime:".player-current-time",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",hover:"hover",captions:{enabled:"captions-enabled",active:"captions-active"},fullscreen:{enabled:"fullscreen-enabled",active:"fullscreen-active",hideControls:"fullscreen-hide-controls"}},captions:{defaultActive:!1},fullscreen:{enabled:!0,fallback:!0,hideControls:!0},storage:{enabled:!0,key:"plyr_volume"},controls:["restart","rewind","play","fast-forward","current-time","duration","mute","volume","captions","fullscreen"],onSetup:function(){}};e.supported=function(e){var t,n,s=r(),a="IE"===s.name&&s.version<=9,o=/iPhone|iPod/i.test(navigator.userAgent),i=!!document.createElement("audio").canPlayType,l=!!document.createElement("video").canPlayType;switch(e){case"video":t=l,n=t&&!a&&!o;break;case"audio":t=i,n=t&&!a;break;default:t=i&&l,n=t&&!a}return{basic:t,full:n}},e.setup=function(t){if(T=b(F,t),!T.enabled||!e.supported().basic)return!1;for(var n=document.querySelectorAll(T.selectors.container),r=[],s=n.length-1;s>=0;s--){var a=n[s];if("undefined"==typeof a.plyr){var o=new x(a);a.plyr=Object.keys(o).length?o:!1,T.onSetup.apply(a.plyr)}r.push(a.plyr)}return r}}(this.plyr=this.plyr||{}); \ No newline at end of file
+!function(e){"use strict";function t(){var e=["<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'>"];return a(T.controls,"restart")&&e.push("<button type='button' data-player='restart'>","<svg><use xlink:href='#icon-restart'></use></svg>","<span class='sr-only'>Restart</span>","</button>"),a(T.controls,"rewind")&&e.push("<button type='button' data-player='rewind'>","<svg><use xlink:href='#icon-rewind'></use></svg>","<span class='sr-only'>Rewind {seektime} secs</span>","</button>"),a(T.controls,"play")&&e.push("<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>"),a(T.controls,"fast-forward")&&e.push("<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>"),a(T.controls,"current-time")&&e.push("<span class='player-time'>","<span class='sr-only'>Current time</span>","<span class='player-current-time'>00:00</span>","</span>"),a(T.controls,"duration")&&e.push("<span class='player-time'>","<span class='sr-only'>Duration</span>","<span class='player-duration'>00:00</span>","</span>"),e.push("</span>","<span class='player-controls-right'>"),a(T.controls,"mute")&&e.push("<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>"),a(T.controls,"volume")&&e.push("<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'>"),a(T.controls,"captions")&&e.push("<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>"),a(T.controls,"fullscreen")&&e.push("<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>"),e.push("</span>","</div>"),e.join("")}function n(e,t){T.debug&&window.console&&console[t?"error":"log"](e)}function r(){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 s(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 a(e,t){return Array.prototype.indexOf&&-1!=e.indexOf(t)}function o(e,t,n){return e.replace(new RegExp(t.replace(/([.*+?^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}function i(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 l(e){e.parentNode.removeChild(e)}function u(e,t){e.insertBefore(t,e.firstChild)}function c(e,t){for(var n in t)e.setAttribute(n,t[n])}function p(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 d(e,t,n,r){if(t=t.split(" "),e instanceof NodeList)for(var s=0;s<e.length;s++)e[s]instanceof Node&&d(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 f(e,t,n){e&&d(e,t,n,!0)}function m(e,t,n){e&&d(e,t,n,!1)}function y(e,t){var n=document.createEvent("MouseEvents");n.initEvent(t,!0,!0),e.dispatchEvent(n)}function v(e){return e.keyCode&&13!=e.keyCode?!0:(e.target.checked=!e.target.checked,y(e.target,"change"),void 0)}function g(e,t){return 0===e||0===t||isNaN(e)||isNaN(t)?0:(e/t*100).toFixed(2)}function b(e,t){for(var n in t)t[n]&&t[n].constructor&&t[n].constructor===Object?(e[n]=e[n]||{},b(e[n],t[n])):e[n]=t[n];return e}function h(){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(e){switch("undefined"==typeof e&&(e=document),this.prefix){case"":return document.fullscreenElement==e;default:return document[this.prefix+"FullscreenElement"]==e}},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 k(){var e={supported:function(){try{return"localStorage"in window&&null!==window.localStorage}catch(e){return!1}}()};return e}function x(a){function d(e){if(!rt.usingTextTracks&&"video"===rt.type&&rt.supported.full){for(rt.subcount=0,e="number"==typeof e?e:rt.media.currentTime;x(rt.captions[rt.subcount][0])<e.toFixed(1);)if(rt.subcount++,rt.subcount>rt.captions.length-1){rt.subcount=rt.captions.length-1;break}rt.media.currentTime.toFixed(1)>=b(rt.captions[rt.subcount][0])&&rt.media.currentTime.toFixed(1)<=x(rt.captions[rt.subcount][0])?(rt.currentCaption=rt.captions[rt.subcount][1],rt.captionsContainer.innerHTML=rt.currentCaption):rt.captionsContainer.innerHTML=""}}function y(){rt.buttons.captions&&(p(rt.container,T.classes.captions.enabled,!0),T.captions.defaultActive&&(p(rt.container,T.classes.captions.active,!0),rt.buttons.captions.checked=!0))}function b(e){var t=[];return t=e.split(" --> "),F(t[0])}function x(e){var t=[];return t=e.split(" --> "),F(t[1])}function F(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 S(e){return rt.container.querySelectorAll(e)}function C(e){return S(e)[0]}function E(){try{return window.self!==window.top}catch(e){return!0}}function A(){var e=T.html;if(n("Injecting custom controls."),e||(e=t()),e=o(e,"{seektime}",T.seekTime),e=o(e,"{id}",Math.floor(1e4*Math.random())),rt.container.insertAdjacentHTML("beforeend",e),T.tooltips)for(var r=S(T.selectors.labels),s=r.length-1;s>=0;s--){var a=r[s];p(a,T.classes.hidden,!1),p(a,T.classes.tooltip,!0)}}function N(){try{return rt.controls=C(T.selectors.controls),rt.buttons={},rt.buttons.seek=C(T.selectors.buttons.seek),rt.buttons.play=C(T.selectors.buttons.play),rt.buttons.pause=C(T.selectors.buttons.pause),rt.buttons.restart=C(T.selectors.buttons.restart),rt.buttons.rewind=C(T.selectors.buttons.rewind),rt.buttons.forward=C(T.selectors.buttons.forward),rt.buttons.fullscreen=C(T.selectors.buttons.fullscreen),rt.buttons.mute=C(T.selectors.buttons.mute),rt.buttons.captions=C(T.selectors.buttons.captions),rt.checkboxes=S("[type='checkbox']"),rt.progress={},rt.progress.container=C(T.selectors.progress.container),rt.progress.buffer={},rt.progress.buffer.bar=C(T.selectors.progress.buffer),rt.progress.buffer.text=rt.progress.buffer.bar&&rt.progress.buffer.bar.getElementsByTagName("span")[0],rt.progress.played={},rt.progress.played.bar=C(T.selectors.progress.played),rt.progress.played.text=rt.progress.played.bar&&rt.progress.played.bar.getElementsByTagName("span")[0],rt.volume=C(T.selectors.buttons.volume),rt.duration=C(T.selectors.duration),rt.currentTime=C(T.selectors.currentTime),rt.seekTime=S(T.selectors.seekTime),!0}catch(e){return n("It looks like there's a problem with your controls html. Bailing.",!0),rt.media.setAttribute("controls",""),!1}}function P(){if(rt.buttons.play){var e=rt.buttons.play.innerText||"Play";"undefined"!=typeof T.title&&T.title.length&&(e+=", "+T.title),rt.buttons.play.setAttribute("aria-label",e)}}function I(){if(!rt.media)return n("No audio or video element found!",!0),!1;if(rt.supported.full&&(rt.media.removeAttribute("controls"),p(rt.container,T.classes[rt.type],!0),p(rt.container,T.classes.stopped,null===rt.media.getAttribute("autoplay")),rt.browser.ios&&p(rt.container,"ios",!0),"video"===rt.type)){var e=document.createElement("div");e.setAttribute("class",T.classes.videoWrapper),i(rt.media,e),rt.videoContainer=e}null!==rt.media.getAttribute("autoplay")&&O()}function M(){if("video"===rt.type){rt.videoContainer.insertAdjacentHTML("afterbegin","<div class='"+T.selectors.captions.replace(".","")+"'></div>"),rt.captionsContainer=C(T.selectors.captions),rt.usingTextTracks=!1,rt.media.textTracks&&(rt.usingTextTracks=!0);for(var e,t="",r=rt.media.childNodes,s=0;s<r.length;s++)"track"===r[s].nodeName.toLowerCase()&&(e=r[s].getAttribute("kind"),"captions"===e&&(t=r[s].getAttribute("src")));if(rt.captionExists=!0,""===t?(rt.captionExists=!1,n("No caption track found.")):n("Caption track found; URI: "+t),rt.captionExists){for(var a=rt.media.textTracks,o=0;o<a.length;o++)a[o].mode="hidden";if(y(rt),("IE"===rt.browser.name&&10===rt.browser.version||"IE"===rt.browser.name&&11===rt.browser.version||"Firefox"===rt.browser.name&&rt.browser.version>=31||"Safari"===rt.browser.name&&rt.browser.version>=7)&&(n("Detected IE 10/11 or Firefox 31+ or Safari 7+."),rt.usingTextTracks=!1),rt.usingTextTracks){n("TextTracks supported.");for(var i=0;i<a.length;i++){var l=a[i];"captions"===l.kind&&f(l,"cuechange",function(){rt.captionsContainer.innerHTML="",this.activeCues[0]&&this.activeCues[0].hasOwnProperty("text")&&rt.captionsContainer.appendChild(this.activeCues[0].getCueAsHTML())})}}else if(n("TextTracks not supported so rendering captions manually."),rt.currentCaption="",rt.captions=[],""!==t){var u=new XMLHttpRequest;u.onreadystatechange=function(){if(4===u.readyState)if(200===u.status){var e,t=[],r=u.responseText;t=r.split("\n\n");for(var s=0;s<t.length;s++)e=t[s],rt.captions[s]=[],rt.captions[s]=e.split("\n");rt.captions.shift(),n("Successfully loaded the caption file via AJAX.")}else n("There was a problem loading the caption file via AJAX.",!0)},u.open("get",t,!0),u.send()}if("Safari"===rt.browser.name&&rt.browser.version>=7){n("Safari 7+ detected; removing track from DOM."),a=rt.media.getElementsByTagName("track");for(var c=0;c<a.length;c++)rt.media.removeChild(a[c])}}else p(rt.container,T.classes.captions.enabled)}}function L(){if("video"===rt.type&&T.fullscreen.enabled){var e=w.supportsFullScreen;e||T.fullscreen.fallback&&!E()?(n((e?"Native":"Fallback")+" fullscreen enabled."),p(rt.container,T.classes.fullscreen.enabled,!0)):n("Fullscreen not supported and fallback disabled."),T.fullscreen.hideControls&&p(rt.container,T.classes.fullscreen.hideControls,!0)}}function O(){rt.media.play()}function q(){rt.media.pause()}function H(e){"number"!=typeof e&&(e=T.seekTime),R(rt.media.currentTime-e)}function V(e){"number"!=typeof e&&(e=T.seekTime),R(rt.media.currentTime+e)}function R(e){var t=0;"number"==typeof e?t=e:"object"!=typeof e||"input"!==e.type&&"change"!==e.type||(t=e.target.value/e.target.max*rt.media.duration),0>t?t=0:t>rt.media.duration&&(t=rt.media.duration);try{rt.media.currentTime=t.toFixed(1)}catch(r){}n("Seeking to "+rt.media.currentTime+" seconds"),d(t)}function j(){p(rt.container,T.classes.playing,!rt.media.paused),p(rt.container,T.classes.stopped,rt.media.paused)}function B(e){var t=w.supportsFullScreen;e&&e.type===w.fullScreenEventName?rt.isFullscreen=w.isFullScreen(rt.container):t?(w.isFullScreen(rt.container)?w.cancelFullScreen():w.requestFullScreen(rt.container),rt.isFullscreen=w.isFullScreen(rt.container)):(rt.isFullscreen=!rt.isFullscreen,rt.isFullscreen?(f(document,"keyup",D),document.body.style.overflow="hidden"):(m(document,"keyup",D),document.body.style.overflow="")),p(rt.container,T.classes.fullscreen.active,rt.isFullscreen)}function D(e){27===(e.which||e.charCode||e.keyCode)&&rt.isFullscreen&&B()}function W(e){rt.volume&&("undefined"==typeof e&&(e=T.storage.enabled&&k().supported?window.localStorage[T.storage.key]||T.volume:T.volume),e>10&&(e=10),rt.supported.full&&(rt.volume.value=e),rt.media.volume=parseFloat(e/10),_(),T.storage.enabled&&k().supported&&window.localStorage.setItem(T.storage.key,e))}function U(e){"undefined"==typeof e&&(e=!rt.media.muted),rt.supported.full&&(rt.buttons.mute.checked=e),rt.media.muted=e,_()}function X(e){rt.supported.full&&rt.buttons.captions&&("undefined"==typeof e&&(e=-1===rt.container.className.indexOf(T.classes.captions.active),rt.buttons.captions.checked=e),p(rt.container,T.classes.captions.active,e))}function _(){p(rt.container,T.classes.muted,0===rt.media.volume||rt.media.muted)}function J(e){var t="waiting"===e.type;clearTimeout(rt.loadingTimer),rt.loadingTimer=setTimeout(function(){p(rt.container,T.classes.loading,t)},t?250:0)}function $(e){var t=rt.progress.played.bar,n=rt.progress.played.text,r=0;if(e)switch(e.type){case"timeupdate":case"seeking":r=g(rt.media.currentTime,rt.media.duration),"timeupdate"==e.type&&rt.buttons.seek&&(rt.buttons.seek.value=r);break;case"change":case"input":r=e.target.value;break;case"playing":case"progress":t=rt.progress.buffer.bar,n=rt.progress.buffer.text,r=function(){var e=rt.media.buffered;return e.length?g(e.end(0),rt.media.duration):0}()}t&&(t.value=r),n&&(n.innerHTML=r)}function z(e,t){if(t){rt.secs=parseInt(e%60),rt.mins=parseInt(e/60%60),rt.hours=parseInt(e/60/60%60);var n=parseInt(rt.media.duration/60/60%60)>0;rt.secs=("0"+rt.secs).slice(-2),rt.mins=("0"+rt.mins).slice(-2),t.innerHTML=(n?rt.hours+":":"")+rt.mins+":"+rt.secs}}function K(){var e=rt.media.duration||0;!rt.duration&&T.displayDuration&&rt.media.paused&&z(e,rt.currentTime),rt.duration&&z(e,rt.duration)}function Y(e){z(rt.media.currentTime,rt.currentTime),$(e)}function G(){for(var e=rt.media.querySelectorAll("source"),t=e.length-1;t>=0;t--)l(e[t]);rt.media.removeAttribute("src")}function Q(e){if(e.src){var t=document.createElement("source");c(t,e),u(rt.media,t)}}function Z(e){if(q(),R(),G(),"string"==typeof e)rt.media.setAttribute("src",e);else if(e.constructor===Array)for(var t in e)Q(e[t]);rt.supported.full&&(Y(),j()),rt.media.load(),null!==rt.media.getAttribute("autoplay")&&O()}function et(e){"video"===rt.type&&rt.media.setAttribute("poster",e)}function tt(){var e="IE"==rt.browser.name?"change":"input";f(rt.buttons.play,"click",function(){O(),setTimeout(function(){rt.buttons.pause.focus()},100)}),f(rt.buttons.pause,"click",function(){q(),setTimeout(function(){rt.buttons.play.focus()},100)}),f(rt.buttons.restart,"click",R),f(rt.buttons.rewind,"click",H),f(rt.buttons.forward,"click",V),f(rt.buttons.seek,e,R),f(rt.volume,e,function(){W(this.value)}),f(rt.buttons.mute,"change",function(){U(this.checked)}),f(rt.buttons.fullscreen,"click",B),w.supportsFullScreen&&f(document,w.fullScreenEventName,B),f(rt.media,"timeupdate seeking",Y),f(rt.media,"timeupdate",d),f(rt.media,"loadedmetadata",K),f(rt.buttons.captions,"change",function(){X(this.checked)}),f(rt.media,"ended",function(){"video"===rt.type&&(rt.captionsContainer.innerHTML=""),j()}),f(rt.media,"progress",$),f(rt.media,"playing",$),f(rt.media,"volumechange",_),f(rt.media,"play pause",j),f(rt.media,"waiting canplay seeked",J),f(rt.checkboxes,"keyup",v),"video"===rt.type&&T.click&&f(rt.videoContainer,"click",function(){rt.media.paused?O():rt.media.ended?(R(),O()):q()}),T.fullscreen.hideControls&&f(rt.controls,"mouseenter mouseleave",function(e){p(rt.controls,T.classes.hover,"mouseenter"===e.type)})}function nt(){if(w=h(),rt.browser=r(),rt.media=rt.container.querySelectorAll("audio, video")[0],rt.type=rt.media.tagName.toLowerCase(),rt.supported=e.supported(rt.type),!rt.supported.basic)return!1;if(n(rt.browser.name+" "+rt.browser.version),I(),rt.supported.full){if(A(),!N())return!1;T.displayDuration&&K(),P(),M(),W(),L(),tt()}return!0}var rt=this;return rt.container=a,nt()?{media:rt.media,play:O,pause:q,restart:R,rewind:H,forward:V,seek:R,source:Z,poster:et,setVolume:W,toggleMute:U,toggleCaptions:X,toggleFullscreen:B,isFullscreen:function(){return rt.isFullscreen||!1},support:function(e){return s(rt,e)}}:{}}var w,T,F={enabled:!0,debug:!1,seekTime:10,volume:5,click:!0,tooltips:!1,displayDuration:!0,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",currentTime:".player-current-time",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",hover:"hover",captions:{enabled:"captions-enabled",active:"captions-active"},fullscreen:{enabled:"fullscreen-enabled",active:"fullscreen-active",hideControls:"fullscreen-hide-controls"}},captions:{defaultActive:!1},fullscreen:{enabled:!0,fallback:!0,hideControls:!0},storage:{enabled:!0,key:"plyr_volume"},controls:["restart","rewind","play","fast-forward","current-time","duration","mute","volume","captions","fullscreen"],onSetup:function(){}};e.supported=function(e){var t,n,s=r(),a="IE"===s.name&&s.version<=9,o=/iPhone|iPod/i.test(navigator.userAgent),i=!!document.createElement("audio").canPlayType,l=!!document.createElement("video").canPlayType;switch(e){case"video":t=l,n=t&&!a&&!o;break;case"audio":t=i,n=t&&!a;break;default:t=i&&l,n=t&&!a}return{basic:t,full:n}},e.setup=function(t){if(T=b(F,t),!T.enabled||!e.supported().basic)return!1;for(var n=document.querySelectorAll(T.selectors.container),r=[],s=n.length-1;s>=0;s--){var a=n[s];if("undefined"==typeof a.plyr){var o=new x(a);a.plyr=Object.keys(o).length?o:!1,T.onSetup.apply(a.plyr)}r.push(a.plyr)}return r}}(this.plyr=this.plyr||{}); \ No newline at end of file
diff --git a/docs/error.html b/docs/error.html
index 1d004f98..5feecea7 100644
--- a/docs/error.html
+++ b/docs/error.html
@@ -6,7 +6,7 @@
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- Docs styles -->
- <link rel="stylesheet" href="//cdn.plyr.io/1.1.2/docs.css">
+ <link rel="stylesheet" href="//cdn.plyr.io/1.1.3/docs.css">
</head>
<body>
<main>
diff --git a/docs/index.html b/docs/index.html
index b12191b4..91b27543 100644
--- a/docs/index.html
+++ b/docs/index.html
@@ -8,10 +8,10 @@
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- Styles -->
- <link rel="stylesheet" href="//cdn.plyr.io/1.1.2/plyr.css">
+ <link rel="stylesheet" href="//cdn.plyr.io/1.1.3/plyr.css">
<!-- Docs styles -->
- <link rel="stylesheet" href="//cdn.plyr.io/1.1.2/docs.css">
+ <link rel="stylesheet" href="//cdn.plyr.io/1.1.3/docs.css">
</head>
<body>
<header>
@@ -83,13 +83,13 @@
b.insertBefore(c, b.childNodes[0]);
}
}
- })(document, "https://cdn.plyr.io/1.1.2/sprite.svg");
+ })(document, "https://cdn.plyr.io/1.1.3/sprite.svg");
</script>
<!-- Plyr core script -->
- <script src="//cdn.plyr.io/1.1.2/plyr.js"></script>
+ <script src="//cdn.plyr.io/1.1.3/plyr.js"></script>
<!-- Docs script -->
- <script src="//cdn.plyr.io/1.1.2/docs.js"></script>
+ <script src="//cdn.plyr.io/1.1.3/docs.js"></script>
</body>
</html> \ No newline at end of file
diff --git a/package.json b/package.json
index 79edf364..eed31485 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "plyr",
- "version": "1.1.2",
+ "version": "1.1.3",
"description": "A simple HTML5 media player using custom controls",
"homepage": "http://plyr.io",
"main": "gulpfile.js",
diff --git a/readme.md b/readme.md
index 43da2b63..fc18d7ca 100644
--- a/readme.md
+++ b/readme.md
@@ -38,7 +38,7 @@ If you have any cool ideas or features, please let me know by [creating an issue
Check `docs/index.html` and `docs/dist/docs.js` for an example setup.
-**Heads up**, the example `index.html` file needs to be served from a webserver (such as Apache, Nginx, IIS or similar) unless you change the file sources to include http or https. e.g. change `//cdn.plyr.io/1.1.2/plyr.js` to `https://cdn.plyr.io/1.1.2/plyr.js`
+**Heads up**, the example `index.html` file needs to be served from a webserver (such as Apache, Nginx, IIS or similar) unless you change the file sources to include http or https. e.g. change `//cdn.plyr.io/1.1.3/plyr.js` to `https://cdn.plyr.io/1.1.3/plyr.js`
### Bower
If bower is your thang, you can grab Plyr using:
@@ -58,11 +58,11 @@ More info is on [npm](https://www.npmjs.com/package/ember-cli-plyr) and [GitHub]
If you want to use our CDN, you can use the following. HTTPS (SSL) is supported.
```html
-<link rel="stylesheet" href="//cdn.plyr.io/1.1.2/plyr.css">
-<script src="//cdn.plyr.io/1.1.2/plyr.js"></script>
+<link rel="stylesheet" href="//cdn.plyr.io/1.1.3/plyr.css">
+<script src="//cdn.plyr.io/1.1.3/plyr.js"></script>
```
-You can also access the `sprite.svg` file at `//cdn.plyr.io/1.1.2/sprite.svg`.
+You can also access the `sprite.svg` file at `//cdn.plyr.io/1.1.3/sprite.svg`.
### CSS
If you want to use the default css, add the `plyr.css` file from /dist into your head, or even better use `plyr.less` or `plyr.sass` file included in `/src` in your build to save a request.
diff --git a/src/js/plyr.js b/src/js/plyr.js
index 49f9d5c2..83ba3282 100644
--- a/src/js/plyr.js
+++ b/src/js/plyr.js
@@ -680,22 +680,25 @@
// Insert controls
function _injectControls() {
+ // Make a copy of the html
+ var html = config.html;
+
// Insert custom video controls
_log("Injecting custom controls.");
// If no controls are specified, create default
- if(!config.html) {
- config.html = _buildControls();
+ if(!html) {
+ html = _buildControls();
}
// Replace seek time instances
- config.html = _replaceAll(config.html, "{seektime}", config.seekTime);
+ html = _replaceAll(html, "{seektime}", config.seekTime);
- // Replace all id references
- config.html = _replaceAll(config.html, "{id}", player.random);
+ // Replace all id references with random numbers
+ html = _replaceAll(html, "{id}", Math.floor(Math.random() * (10000)));
// Inject into the container
- player.container.insertAdjacentHTML("beforeend", config.html);
+ player.container.insertAdjacentHTML("beforeend", html);
// Setup tooltips
if(config.tooltips) {
@@ -1071,18 +1074,17 @@
// Toggle fullscreen
function _toggleFullscreen(event) {
// Check for native support
- var nativeSupport = fullscreen.supportsFullScreen,
- container = player.container;
+ var nativeSupport = fullscreen.supportsFullScreen;
// If it's a fullscreen change event, it's probably a native close
if(event && event.type === fullscreen.fullScreenEventName) {
- player.isFullscreen = fullscreen.isFullScreen(container);
+ player.isFullscreen = fullscreen.isFullScreen(player.container);
}
// If there's native support, use it
else if(nativeSupport) {
// Request fullscreen
- if(!fullscreen.isFullScreen(container)) {
- fullscreen.requestFullScreen(container);
+ if(!fullscreen.isFullScreen(player.container)) {
+ fullscreen.requestFullScreen(player.container);
}
// Bail from fullscreen
else {
@@ -1090,7 +1092,7 @@
}
// Check if we're actually full screen (it could fail)
- player.isFullscreen = fullscreen.isFullScreen(container);
+ player.isFullscreen = fullscreen.isFullScreen(player.container);
}
else {
// Otherwise, it's a simple toggle
@@ -1108,7 +1110,7 @@
}
// Set class hook
- _toggleClass(container, config.classes.fullscreen.active, player.isFullscreen);
+ _toggleClass(player.container, config.classes.fullscreen.active, player.isFullscreen);
}
// Bail from faux-fullscreen
@@ -1530,9 +1532,6 @@
// Setup media
_setupMedia();
- // Generate random number for id/for attribute values for controls
- player.random = Math.floor(Math.random() * (10000));
-
// If there's full support
if(player.supported.full) {
// Inject custom controls
diff --git a/src/less/plyr.less b/src/less/plyr.less
index ba9d7130..e0402e92 100644
--- a/src/less/plyr.less
+++ b/src/less/plyr.less
@@ -9,6 +9,7 @@
@gray-dark: #343f4a;
@gray: #565d64;
@gray-light: #cbd0d3;
+@off-white: #f9fafb;
// Font sizes
@font-size-small: 14px;
@@ -527,6 +528,17 @@
float: none;
}
+ // Audio specific styles
+ // Position the progress within the container
+ &-audio .player-controls {
+ padding-top: (@control-spacing * 2);
+ }
+ &-audio .player-progress {
+ bottom: auto;
+ top: 0;
+ background: @off-white;
+ }
+
// Full screen mode
&-fullscreen,
&.fullscreen-active {
diff --git a/src/sass/plyr.scss b/src/sass/plyr.scss
index 3453dd50..e1fb4960 100644
--- a/src/sass/plyr.scss
+++ b/src/sass/plyr.scss
@@ -9,6 +9,7 @@ $blue: #3498DB;
$gray-dark: #343f4a;
$gray: #565d64;
$gray-light: #cbd0d3;
+$off-white: #f9fafb;
// Font sizes
$font-size-small: 14px;
@@ -535,6 +536,17 @@ $bp-captions-large: 768px; // When captions jump to the larger font size
float: none;
}
+ // Audio specific styles
+ // Position the progress within the container
+ &-audio .player-controls {
+ padding-top: ($control-spacing * 2);
+ }
+ &-audio .player-progress {
+ bottom: auto;
+ top: 0;
+ background: $off-white;
+ }
+
// Full screen mode
&-fullscreen,
&.fullscreen-active {