aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSam Potts <me@sampotts.me>2016-01-14 00:23:57 +1100
committerSam Potts <me@sampotts.me>2016-01-14 00:23:57 +1100
commitca8fd08e81e79875505f432b304e8140a3978ed4 (patch)
tree0e98da7ed199580380ee6596cd28636f787b1562
parentbc67d969cbba42b5a93866c42c8b49facf532a49 (diff)
downloadplyr-ca8fd08e81e79875505f432b304e8140a3978ed4.tar.lz
plyr-ca8fd08e81e79875505f432b304e8140a3978ed4.tar.xz
plyr-ca8fd08e81e79875505f432b304e8140a3978ed4.zip
Use only one index.html for testing locally, fixes for limited controls, larger seek handle
-rw-r--r--changelog.md3
-rw-r--r--dist/plyr.css2
-rw-r--r--dist/plyr.js2
-rw-r--r--docs/error.html4
-rw-r--r--docs/index.html12
-rw-r--r--docs/index.master.html130
-rw-r--r--gulpfile.js11
-rw-r--r--readme.md2
-rw-r--r--src/js/plyr.js53
-rw-r--r--src/less/plyr.less17
10 files changed, 57 insertions, 179 deletions
diff --git a/changelog.md b/changelog.md
index f43b3692..9eb7b009 100644
--- a/changelog.md
+++ b/changelog.md
@@ -9,6 +9,9 @@
- Fix for private/incognito mode local storage bug (fixes #131)
- UMD module setup (fixes #121)
- Specify iframe title for Vimeo and YouTube (fixes #124)
+- Better handling of mission controls (fixes #132)
+- Retain classname on source change (fixes #120)
+- Increased thumb size on seek (partially fixes #130)
## v1.3.5
- Fixed bug with API use on basic supported browsers
diff --git a/dist/plyr.css b/dist/plyr.css
index 660e85a2..be0e6532 100644
--- a/dist/plyr.css
+++ b/dist/plyr.css
@@ -1 +1 @@
-.plyr__captions,.plyr__controls,.plyr__controls .plyr__time{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.plyr__controls button:focus,.plyr__progress--seek[type=range]:focus,.plyr__volume[type=range]:focus{outline:0}@-webkit-keyframes progress{to{background-position:40px 0}}@keyframes progress{to{background-position:40px 0}}.plyr{position:relative;max-width:100%;min-width:290px}.plyr,.plyr *,.plyr ::after,.plyr ::before{box-sizing:border-box}.plyr a,.plyr button,.plyr input,.plyr label{-ms-touch-action:manipulation;touch-action:manipulation}.plyr__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}.plyr__video-wrapper{position:relative}.plyr audio,.plyr video{width:100%;height:auto;vertical-align:middle}.plyr__video-embed{padding-bottom:56.25%;height:0;overflow:hidden;background:#000}.plyr__video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.plyr__video-embed>div{position:relative;padding-bottom:200%;-webkit-transform:translateY(-35.95%);transform:translateY(-35.95%)}.plyr__captions{display:none;position:absolute;bottom:0;left:0;width:100%;padding:20px 20px 30px;color:#fff;font-size:20px;text-align:center}.plyr__captions span{border-radius:2px;padding:3px 10px;background:rgba(0,0,0,.9)}.plyr__captions span:empty{display:none}@media (min-width:768px){.plyr__captions{font-size:24px}}.plyr--captions-active .plyr__captions{display:block}.plyr--fullscreen-active .plyr__captions{font-size:32px}.plyr__controls{zoom:1;position:relative;padding:10px;background:#fff;line-height:1;text-align:center;box-shadow:0 1px 1px rgba(52,63,74,.2)}.plyr__controls:after,.plyr__controls:before{content:"";display:table}.plyr__controls:after{clear:both}.plyr__controls--right{display:block;margin:10px auto 0}@media (min-width:560px){.plyr__controls--left{float:left}.plyr__controls--right{float:right;margin-top:0}}.plyr__controls button{display:inline-block;vertical-align:middle;margin:0 2px;padding:5px 10px;overflow:hidden;border:0;background:0 0;border-radius:3px;cursor:pointer;color:#6B7D86;transition:background .3s ease,color .3s ease,opacity .3s ease}.plyr__controls button svg{width:18px;height:18px;display:block;fill:currentColor;transition:fill .3s ease}.plyr__controls button.tab-focus,.plyr__controls button:hover{background:#3498DB;color:#fff}.plyr__controls .plyr__time,.plyr__tooltip{color:#6B7D86;font-size:14px;font-weight:600}.plyr__controls .icon--captions-on,.plyr__controls .icon--exit-fullscreen,.plyr__controls .icon--muted{display:none}.plyr__controls .plyr__time{display:inline-block;vertical-align:middle;margin-left:10px}.plyr__controls .plyr__time+.plyr__time{display:none}@media (min-width:560px){.plyr__controls .plyr__time+.plyr__time{display:inline-block}}.plyr__controls .plyr__time+.plyr__time::before{content:'\2044';margin-right:10px}.plyr__tooltip{position:absolute;z-index:2;bottom:100%;margin-bottom:10px;padding:10px 15px;opacity:0;background:#fff;box-shadow:0 0 5px rgba(52,63,74,.1),0 0 0 1px rgba(52,63,74,.1);border-radius:3px;line-height:1.5;-webkit-transform:translate(-50%,30px) scale(.8);transform:translate(-50%,30px) scale(.8);-webkit-transform-origin:50% 100%;transform-origin:50% 100%;transition:opacity .2s .1s ease,-webkit-transform .2s .1s ease;transition:transform .2s .1s ease,opacity .2s .1s ease;transition:transform .2s .1s ease,opacity .2s .1s ease,-webkit-transform .2s .1s ease}.plyr__tooltip::after,.plyr__tooltip::before{content:'';position:absolute;width:0;height:0;top:100%;left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.plyr__tooltip::after{bottom:-8px;border-right:7px solid transparent;border-top:7px solid rgba(52,63,74,.1);border-left:7px solid transparent;z-index:1}.plyr__tooltip::before{bottom:-6px;border-right:6px solid transparent;border-top:6px solid #fff;border-left:6px solid transparent;z-index:2}.plyr button.tab-focus:focus .plyr__tooltip,.plyr button:hover .plyr__tooltip{opacity:1;-webkit-transform:translate(-50%,0) scale(1);transform:translate(-50%,0) scale(1)}.plyr button:hover .plyr__tooltip{z-index:3}.plyr__progress{position:absolute;bottom:100%;left:0;right:0;width:100%;height:10px;background:rgba(86,93,100,.2)}.plyr__progress--buffer[value],.plyr__progress--played[value],.plyr__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}.plyr__progress--buffer[value]::-webkit-progress-bar,.plyr__progress--played[value]::-webkit-progress-bar{background:0 0}.plyr__progress--buffer[value]::-webkit-progress-value,.plyr__progress--played[value]::-webkit-progress-value{background:currentColor}.plyr__progress--buffer[value]::-moz-progress-bar,.plyr__progress--played[value]::-moz-progress-bar{background:currentColor}.plyr__progress--played[value]{z-index:2;color:#3498DB}.plyr__progress--buffer[value]{color:rgba(86,93,100,.25)}.plyr__progress--seek[type=range]{z-index:4;cursor:pointer;outline:0}.plyr__progress--seek[type=range]::-webkit-slider-runnable-track{background:0 0;border:0}.plyr__progress--seek[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:0 0;border:0;width:20px;height:10px}.plyr__progress--seek[type=range]::-moz-range-track{background:0 0;border:0}.plyr__progress--seek[type=range]::-moz-range-thumb{-moz-appearance:none;background:0 0;border:0;width:20px;height:10px}.plyr__progress--seek[type=range]::-ms-track{color:transparent;background:0 0;border:0}.plyr__progress--seek[type=range]::-ms-fill-lower,.plyr__progress--seek[type=range]::-ms-fill-upper{background:0 0;border:0}.plyr__progress--seek[type=range]::-ms-thumb{background:0 0;border:0;width:20px;height:10px}.plyr__progress--seek[type=range]::-moz-focus-outer{border:0}.plyr--loading .plyr__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}.plyr--playing .plyr__controls [data-plyr=play],.plyr__controls [data-plyr=pause]{display:none}.plyr--playing .plyr__controls [data-plyr=pause]{display:inline-block}.plyr__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;border:none}.plyr__volume[type=range]::-webkit-slider-runnable-track{height:6px;background:#e6e6e6;border:0;border-radius:3px}.plyr__volume[type=range]::-webkit-slider-thumb{-webkit-appearance:none;margin-top:-3px;height:12px;width:12px;background:#6B7D86;border:0;border-radius:100%;transition:background .3s ease,-webkit-transform .2s ease;transition:background .3s ease,transform .2s ease;transition:background .3s ease,transform .2s ease,-webkit-transform .2s ease;cursor:ew-resize}.plyr__volume[type=range]::-webkit-slider-thumb:hover{-webkit-transform:scale(110%);transform:scale(110%)}.plyr__volume[type=range]::-webkit-slider-thumb:active{height:15px;width:15px;border:2px solid #3498DB;background:#fff!important;margin-top:-4px}.plyr__volume[type=range]::-moz-range-track{height:6px;background:#e6e6e6;border:0;border-radius:3px}.plyr__volume[type=range]::-moz-range-thumb{height:12px;width:12px;background:#6B7D86;border:0;border-radius:100%;transition:background .3s ease,-webkit-transform .2s ease;transition:background .3s ease,transform .2s ease;transition:background .3s ease,transform .2s ease,-webkit-transform .2s ease;cursor:ew-resize}.plyr__volume[type=range]::-moz-range-thumb:hover{transform:scale(110%)}.plyr__volume[type=range]::-moz-range-thumb:active{height:15px;width:15px;border:2px solid #3498DB;background:#fff!important}.plyr__volume[type=range]::-ms-track{height:6px;background:0 0;border-color:transparent;border-width:3px 0;color:transparent}.plyr__volume[type=range]::-ms-fill-lower,.plyr__volume[type=range]::-ms-fill-upper{height:6px;background:#e6e6e6;border:0;border-radius:3px}.plyr__volume[type=range]::-ms-thumb{height:12px;width:12px;background:#6B7D86;border:0;border-radius:100%;transition:background .3s ease,-webkit-transform .2s ease;transition:background .3s ease,transform .2s ease;transition:background .3s ease,transform .2s ease,-webkit-transform .2s ease;cursor:ew-resize}.plyr__volume[type=range]::-ms-thumb:hover{transform:scale(110%)}.plyr__volume[type=range]::-ms-thumb:active{height:15px;width:15px;border:2px solid #3498DB;background:#fff!important}.plyr__volume[type=range]:focus::-webkit-slider-thumb{background:#3498DB}.plyr__volume[type=range]:focus::-moz-range-thumb{background:#3498DB}.plyr__volume[type=range]:focus::-ms-thumb{background:#3498DB}.plyr--is-ios .plyr-volume,.plyr--is-ios [data-plyr=mute],.plyr--is-ios.plyr--audio .plyr__controls--right{display:none}.plyr--is-ios.plyr--audio .plyr__controls--left{float:none}.plyr--audio .plyr__controls{padding-top:20px}.plyr--audio .plyr__progress{bottom:auto;top:0;background:#D6DADD}.plyr--fullscreen,.plyr--fullscreen-active{position:fixed;top:0;left:0;right:0;bottom:0;height:100%;width:100%;z-index:10000000;background:#000}.plyr--fullscreen video,.plyr--fullscreen-active video{height:100%}.plyr--fullscreen .plyr__video-wrapper,.plyr--fullscreen-active .plyr__video-wrapper{height:100%;width:100%}.plyr--fullscreen .plyr__controls,.plyr--fullscreen-active .plyr__controls{position:absolute;bottom:0;left:0;right:0}.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing .plyr__controls{-webkit-transform:translateY(100%) translateY(5px);transform:translateY(100%) translateY(5px);transition:-webkit-transform .3s .2s ease;transition:transform .3s .2s ease;transition:transform .3s .2s ease,-webkit-transform .3s .2s ease}.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing.plyr--hover .plyr__controls{-webkit-transform:translateY(0);transform:translateY(0)}.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing .plyr__captions{bottom:5px;transition:bottom .3s .2s ease}.plyr--fullscreen .plyr__captions,.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing.plyr--hover .plyr__captions,.plyr--fullscreen-active .plyr__captions{top:auto;bottom:90px}@media (min-width:560px){.plyr--fullscreen .plyr__captions,.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing.plyr--hover .plyr__captions,.plyr--fullscreen-active .plyr__captions{bottom:60px}}.plyr--captions-active .plyr__controls .icon--captions-on,.plyr--fullscreen-active .icon--exit-fullscreen,.plyr--muted .plyr__controls .icon--muted{display:block}.plyr [data-plyr=captions],.plyr [data-plyr=fullscreen],.plyr--captions-active .plyr__controls .icon--captions-on+svg,.plyr--fullscreen-active .icon--exit-fullscreen+svg,.plyr--muted .plyr__controls .icon--muted+svg{display:none}.plyr--captions-enabled [data-plyr=captions],.plyr--fullscreen-enabled [data-plyr=fullscreen]{display:inline-block} \ No newline at end of file
+.plyr__captions,.plyr__controls,.plyr__controls .plyr__time{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.plyr__controls button:focus,.plyr__progress--seek[type=range]:focus,.plyr__volume[type=range]:focus{outline:0}@-webkit-keyframes progress{to{background-position:40px 0}}@keyframes progress{to{background-position:40px 0}}.plyr{position:relative;max-width:100%;min-width:290px}.plyr,.plyr *,.plyr ::after,.plyr ::before{box-sizing:border-box}.plyr a,.plyr button,.plyr input,.plyr label{-ms-touch-action:manipulation;touch-action:manipulation}.plyr__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}.plyr__video-wrapper{position:relative}.plyr audio,.plyr video{width:100%;height:auto;vertical-align:middle}.plyr__video-embed{padding-bottom:56.25%;height:0;overflow:hidden;background:#000}.plyr__video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.plyr__video-embed>div{position:relative;padding-bottom:200%;-webkit-transform:translateY(-35.95%);transform:translateY(-35.95%)}.plyr__captions{display:none;position:absolute;bottom:0;left:0;width:100%;padding:20px 20px 30px;color:#fff;font-size:20px;text-align:center}.plyr__captions span{border-radius:2px;padding:3px 10px;background:rgba(0,0,0,.9)}.plyr__captions span:empty{display:none}@media (min-width:768px){.plyr__captions{font-size:24px}}.plyr--captions-active .plyr__captions{display:block}.plyr--fullscreen-active .plyr__captions{font-size:32px}.plyr__controls{zoom:1;position:relative;padding:10px;background:#fff;line-height:1;text-align:center;box-shadow:0 1px 1px rgba(52,63,74,.2)}.plyr__controls:after,.plyr__controls:before{content:"";display:table}.plyr__controls:after{clear:both}.plyr__controls--right{display:block;margin:10px auto 0}@media (min-width:560px){.plyr__controls--left{float:left}.plyr__controls--right{float:right;margin-top:0}}.plyr__controls button{display:inline-block;vertical-align:middle;margin:0 2px;padding:5px 10px;overflow:hidden;border:0;background:0 0;border-radius:3px;cursor:pointer;color:#6B7D86;transition:background .3s ease,color .3s ease,opacity .3s ease}.plyr__controls button svg{width:18px;height:18px;display:block;fill:currentColor;transition:fill .3s ease}.plyr__controls button.tab-focus,.plyr__controls button:hover{background:#3498DB;color:#fff}.plyr__controls .plyr__time,.plyr__tooltip{color:#6B7D86;font-size:14px;font-weight:600}.plyr__controls .icon--captions-on,.plyr__controls .icon--exit-fullscreen,.plyr__controls .icon--muted{display:none}.plyr__controls .plyr__time{display:inline-block;vertical-align:middle;margin-left:10px}.plyr__controls .plyr__time+.plyr__time{display:none}@media (min-width:560px){.plyr__controls .plyr__time+.plyr__time{display:inline-block}}.plyr__controls .plyr__time+.plyr__time::before{content:'\2044';margin-right:10px}.plyr__tooltip{position:absolute;z-index:2;bottom:100%;margin-bottom:10px;padding:10px 15px;opacity:0;background:#fff;box-shadow:0 0 5px rgba(52,63,74,.1),0 0 0 1px rgba(52,63,74,.1);border-radius:3px;line-height:1.5;-webkit-transform:translate(-50%,30px) scale(.8);transform:translate(-50%,30px) scale(.8);-webkit-transform-origin:50% 100%;transform-origin:50% 100%;transition:opacity .2s .1s ease,-webkit-transform .2s .1s ease;transition:transform .2s .1s ease,opacity .2s .1s ease;transition:transform .2s .1s ease,opacity .2s .1s ease,-webkit-transform .2s .1s ease}.plyr__tooltip::after,.plyr__tooltip::before{content:'';position:absolute;width:0;height:0;top:100%;left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.plyr__tooltip::after{bottom:-8px;border-right:7px solid transparent;border-top:7px solid rgba(52,63,74,.1);border-left:7px solid transparent;z-index:1}.plyr__tooltip::before{bottom:-6px;border-right:6px solid transparent;border-top:6px solid #fff;border-left:6px solid transparent;z-index:2}.plyr button.tab-focus:focus .plyr__tooltip,.plyr button:hover .plyr__tooltip{opacity:1;-webkit-transform:translate(-50%,0) scale(1);transform:translate(-50%,0) scale(1)}.plyr button:hover .plyr__tooltip{z-index:3}.plyr__progress{position:absolute;bottom:100%;left:0;right:0;width:100%;height:10px;background:rgba(86,93,100,.2)}.plyr__progress--buffer[value],.plyr__progress--played[value],.plyr__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}.plyr__progress--buffer[value]::-webkit-progress-bar,.plyr__progress--played[value]::-webkit-progress-bar{background:0 0}.plyr__progress--buffer[value]::-webkit-progress-value,.plyr__progress--played[value]::-webkit-progress-value{background:currentColor}.plyr__progress--buffer[value]::-moz-progress-bar,.plyr__progress--played[value]::-moz-progress-bar{background:currentColor}.plyr__progress--played[value]{z-index:2;color:#3498DB}.plyr__progress--buffer[value]{color:rgba(86,93,100,.25)}.plyr__progress--seek[type=range]{z-index:4;cursor:pointer;outline:0}.plyr__progress--seek[type=range]::-webkit-slider-runnable-track{background:0 0;border:0}.plyr__progress--seek[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:0 0;border:0;width:40px;height:10px;-webkit-transform:translateX(-50%);transform:translateX(-50%)}.plyr__progress--seek[type=range]::-moz-range-track{background:0 0;border:0}.plyr__progress--seek[type=range]::-moz-range-thumb{-moz-appearance:none;background:0 0;border:0;width:40px;height:10px;transform:translateX(-50%)}.plyr__progress--seek[type=range]::-ms-track{color:transparent;background:0 0;border:0}.plyr__progress--seek[type=range]::-ms-fill-lower,.plyr__progress--seek[type=range]::-ms-fill-upper{background:0 0;border:0}.plyr__progress--seek[type=range]::-ms-thumb{background:0 0;border:0;width:40px;height:10px;transform:translateX(-50%)}.plyr__progress--seek[type=range]::-moz-focus-outer{border:0}.plyr--loading .plyr__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}.plyr--playing .plyr__controls [data-plyr=play],.plyr__controls [data-plyr=pause]{display:none}.plyr--playing .plyr__controls [data-plyr=pause]{display:inline-block}.plyr__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;border:none}.plyr__volume[type=range]::-webkit-slider-runnable-track{height:6px;background:#e6e6e6;border:0;border-radius:3px}.plyr__volume[type=range]::-webkit-slider-thumb{-webkit-appearance:none;margin-top:-3px;height:12px;width:12px;background:#6B7D86;border:0;border-radius:100%;transition:background .3s ease,-webkit-transform .2s ease;transition:background .3s ease,transform .2s ease;transition:background .3s ease,transform .2s ease,-webkit-transform .2s ease;cursor:ew-resize}.plyr__volume[type=range]::-moz-range-track{height:6px;background:#e6e6e6;border:0;border-radius:3px}.plyr__volume[type=range]::-moz-range-thumb{height:12px;width:12px;background:#6B7D86;border:0;border-radius:100%;transition:background .3s ease,-webkit-transform .2s ease;transition:background .3s ease,transform .2s ease;transition:background .3s ease,transform .2s ease,-webkit-transform .2s ease;cursor:ew-resize}.plyr__volume[type=range]::-ms-track{height:6px;background:0 0;border-color:transparent;border-width:3px 0;color:transparent}.plyr__volume[type=range]::-ms-fill-lower,.plyr__volume[type=range]::-ms-fill-upper{height:6px;background:#e6e6e6;border:0;border-radius:3px}.plyr__volume[type=range]::-ms-thumb{height:12px;width:12px;background:#6B7D86;border:0;border-radius:100%;transition:background .3s ease,-webkit-transform .2s ease;transition:background .3s ease,transform .2s ease;transition:background .3s ease,transform .2s ease,-webkit-transform .2s ease;cursor:ew-resize}.plyr__volume[type=range]:focus::-webkit-slider-thumb{background:#3498DB}.plyr__volume[type=range]:focus::-moz-range-thumb{background:#3498DB}.plyr__volume[type=range]:focus::-ms-thumb{background:#3498DB}.plyr--is-ios .plyr-volume,.plyr--is-ios [data-plyr=mute],.plyr--is-ios.plyr--audio .plyr__controls--right{display:none}.plyr--is-ios.plyr--audio .plyr__controls--left{float:none}.plyr--audio .plyr__controls{padding-top:20px}.plyr--audio .plyr__progress{bottom:auto;top:0;background:#D6DADD}.plyr--fullscreen,.plyr--fullscreen-active{position:fixed;top:0;left:0;right:0;bottom:0;height:100%;width:100%;z-index:10000000;background:#000}.plyr--fullscreen video,.plyr--fullscreen-active video{height:100%}.plyr--fullscreen .plyr__video-wrapper,.plyr--fullscreen-active .plyr__video-wrapper{height:100%;width:100%}.plyr--fullscreen .plyr__controls,.plyr--fullscreen-active .plyr__controls{position:absolute;bottom:0;left:0;right:0}.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing .plyr__controls{-webkit-transform:translateY(100%) translateY(5px);transform:translateY(100%) translateY(5px);transition:-webkit-transform .3s .2s ease;transition:transform .3s .2s ease;transition:transform .3s .2s ease,-webkit-transform .3s .2s ease}.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing.plyr--hover .plyr__controls{-webkit-transform:translateY(0);transform:translateY(0)}.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing .plyr__captions{bottom:5px;transition:bottom .3s .2s ease}.plyr--fullscreen .plyr__captions,.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing.plyr--hover .plyr__captions,.plyr--fullscreen-active .plyr__captions{top:auto;bottom:90px}@media (min-width:560px){.plyr--fullscreen .plyr__captions,.plyr--fullscreen--hide-controls.plyr--fullscreen-active.plyr--playing.plyr--hover .plyr__captions,.plyr--fullscreen-active .plyr__captions{bottom:60px}}.plyr--captions-active .plyr__controls .icon--captions-on,.plyr--fullscreen-active .icon--exit-fullscreen,.plyr--muted .plyr__controls .icon--muted{display:block}.plyr [data-plyr=captions],.plyr [data-plyr=fullscreen],.plyr--captions-active .plyr__controls .icon--captions-on+svg,.plyr--fullscreen-active .icon--exit-fullscreen+svg,.plyr--muted .plyr__controls .icon--muted+svg{display:none}.plyr--captions-enabled [data-plyr=captions],.plyr--fullscreen-enabled [data-plyr=fullscreen]{display:inline-block} \ No newline at end of file
diff --git a/dist/plyr.js b/dist/plyr.js
index 630a993f..3f29d647 100644
--- a/dist/plyr.js
+++ b/dist/plyr.js
@@ -1 +1 @@
-!function(e,t){"use strict";"function"==typeof define&&define.amd?define(null,t):"object"==typeof module?module.exports=t():e.plyr=t()}(this,function(){"use strict";function e(){var e=['<div class="plyr__controls">','<div class="plyr__progress">','<label for="seek{id}" class="plyr__sr-only">Seek</label>','<input id="seek{id}" class="plyr__progress--seek" type="range" min="0" max="100" step="0.5" value="0" data-plyr="seek">','<progress class="plyr__progress--played" max="100" value="0">',"<span>0</span>% "+F.i18n.played,"</progress>",'<progress class="plyr__progress--buffer" max="100" value="0">',"<span>0</span>% "+F.i18n.buffered,"</progress>","</div>",'<span class="plyr__controls--left">'];return o(F.controls,"restart")&&e.push('<button type="button" data-plyr="restart">','<svg><use xlink:href="#'+F.iconPrefix+'-restart" /></svg>','<span class="plyr__sr-only">'+F.i18n.restart+"</span>","</button>"),o(F.controls,"rewind")&&e.push('<button type="button" data-plyr="rewind">','<svg><use xlink:href="#'+F.iconPrefix+'-rewind" /></svg>','<span class="plyr__sr-only">'+F.i18n.rewind+"</span>","</button>"),o(F.controls,"play")&&e.push('<button type="button" data-plyr="play">','<svg><use xlink:href="#'+F.iconPrefix+'-play" /></svg>','<span class="plyr__sr-only">'+F.i18n.play+"</span>","</button>",'<button type="button" data-plyr="pause">','<svg><use xlink:href="#'+F.iconPrefix+'-pause" /></svg>','<span class="plyr__sr-only">'+F.i18n.pause+"</span>","</button>"),o(F.controls,"fast-forward")&&e.push('<button type="button" data-plyr="fast-forward">','<svg><use xlink:href="#'+F.iconPrefix+'-fast-forward" /></svg>','<span class="plyr__sr-only">'+F.i18n.forward+"</span>","</button>"),o(F.controls,"current-time")&&e.push('<span class="plyr__time">','<span class="plyr__sr-only">'+F.i18n.currentTime+"</span>",'<span class="plyr__time--current">00:00</span>',"</span>"),o(F.controls,"duration")&&e.push('<span class="plyr__time">','<span class="plyr__sr-only">'+F.i18n.duration+"</span>",'<span class="plyr__time--duration">00:00</span>',"</span>"),e.push("</span>",'<span class="plyr__controls--right">'),o(F.controls,"mute")&&e.push('<button type="button" data-plyr="mute">','<svg class="icon--muted"><use xlink:href="#'+F.iconPrefix+'-muted" /></svg>','<svg><use xlink:href="#'+F.iconPrefix+'-volume" /></svg>','<span class="plyr__sr-only">'+F.i18n.toggleMute+"</span>","</button>"),o(F.controls,"volume")&&e.push('<label for="volume{id}" class="plyr__sr-only">'+F.i18n.volume+"</label>",'<input id="volume{id}" class="plyr__volume" type="range" min="0" max="10" value="5" data-plyr="volume">'),o(F.controls,"captions")&&e.push('<button type="button" data-plyr="captions">','<svg class="icon--captions-on"><use xlink:href="#'+F.iconPrefix+'-captions-on" /></svg>','<svg><use xlink:href="#'+F.iconPrefix+'-captions-off" /></svg>','<span class="plyr__sr-only">'+F.i18n.toggleCaptions+"</span>","</button>"),o(F.controls,"fullscreen")&&e.push('<button type="button" data-plyr="fullscreen">','<svg class="icon--exit-fullscreen"><use xlink:href="#'+F.iconPrefix+'-exit-fullscreen" /></svg>','<svg><use xlink:href="#'+F.iconPrefix+'-enter-fullscreen" /></svg>','<span class="plyr__sr-only">'+F.i18n.toggleFullscreen+"</span>","</button>"),e.push("</span>","</div>"),e.join("")}function t(e,t){F.debug&&window.console&&console[t?"error":"log"](e)}function n(){var e,t,n,r=navigator.userAgent,a=navigator.appName,o=""+parseFloat(navigator.appVersion),i=parseInt(navigator.appVersion,10);return-1!==navigator.appVersion.indexOf("Windows NT")&&-1!==navigator.appVersion.indexOf("rv:11")?(a="IE",o="11;"):-1!==(t=r.indexOf("MSIE"))?(a="IE",o=r.substring(t+5)):-1!==(t=r.indexOf("Chrome"))?(a="Chrome",o=r.substring(t+7)):-1!==(t=r.indexOf("Safari"))?(a="Safari",o=r.substring(t+7),-1!==(t=r.indexOf("Version"))&&(o=r.substring(t+8))):-1!==(t=r.indexOf("Firefox"))?(a="Firefox",o=r.substring(t+8)):(e=r.lastIndexOf(" ")+1)<(t=r.lastIndexOf("/"))&&(a=r.substring(e,t),o=r.substring(t+1),a.toLowerCase()==a.toUpperCase()&&(a=navigator.appName)),-1!==(n=o.indexOf(";"))&&(o=o.substring(0,n)),-1!==(n=o.indexOf(" "))&&(o=o.substring(0,n)),i=parseInt(""+o,10),isNaN(i)&&(o=""+parseFloat(navigator.appVersion),i=parseInt(navigator.appVersion,10)),{name:a,version:i,ios:/(iPad|iPhone|iPod)/g.test(navigator.platform),touch:"ontouchstart"in document.documentElement}}function r(e,t){var n=e.media;if("video"==e.type)switch(t){case"video/webm":return!(!n.canPlayType||!n.canPlayType('video/webm; codecs="vp8, vorbis"').replace(/no/,""));case"video/mp4":return!(!n.canPlayType||!n.canPlayType('video/mp4; codecs="avc1.42E01E, mp4a.40.2"').replace(/no/,""));case"video/ogg":return!(!n.canPlayType||!n.canPlayType('video/ogg; codecs="theora"').replace(/no/,""))}else if("audio"==e.type)switch(t){case"audio/mpeg":return!(!n.canPlayType||!n.canPlayType("audio/mpeg;").replace(/no/,""));case"audio/ogg":return!(!n.canPlayType||!n.canPlayType('audio/ogg; codecs="vorbis"').replace(/no/,""));case"audio/wav":return!(!n.canPlayType||!n.canPlayType('audio/wav; codecs="1"').replace(/no/,""))}return!1}function a(e){if(!document.querySelectorAll('script[src="'+e+'"]').length){var t=document.createElement("script");t.src=e;var n=document.getElementsByTagName("script")[0];n.parentNode.insertBefore(t,n)}}function o(e,t){return Array.prototype.indexOf&&-1!=e.indexOf(t)}function i(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,a=e[n],o=a.parentNode,i=a.nextSibling;r.appendChild(a),i?o.insertBefore(r,i):o.appendChild(r)}}function l(e){for(var t=e.parentNode;e.firstChild;)t.insertBefore(e.firstChild,e);t.removeChild(e)}function u(e){e.parentNode.removeChild(e)}function c(e,t){e.insertBefore(t,e.firstChild)}function p(e,t){for(var n in t)e.setAttribute(n,"boolean"==typeof t[n]&&t[n]?"":t[n])}function d(e,t,n){var r=document.createElement(e);p(r,n),c(t,r)}function m(e){return e.replace(".","")}function f(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 y(e,t,n,r){var a=t.split(" ");if(e instanceof NodeList)for(var o=0;o<e.length;o++)e[o]instanceof Node&&y(e[o],arguments[1],arguments[2],arguments[3]);else for(var i=0;i<a.length;i++)e[r?"addEventListener":"removeEventListener"](a[i],n,!1)}function b(e,t,n){e&&y(e,t,n,!0)}function v(e,t,n){e&&y(e,t,n,!1)}function g(e,t){var n=document.createEvent("MouseEvents");n.initEvent(t,!0,!0),e.dispatchEvent(n)}function h(e,t){return t="boolean"==typeof t?t:!e.getAttribute("aria-pressed"),e.setAttribute("aria-pressed",t),t}function w(e,t){return 0===e||0===t||isNaN(e)||isNaN(t)?0:(e/t*100).toFixed(2)}function k(e,t){for(var n in t)t[n]&&t[n].constructor&&t[n].constructor===Object?(e[n]=e[n]||{},k(e[n],t[n])):e[n]=t[n];return e}function T(){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 e.supportsFullScreen&&(e.fullScreenEventName="ms"==e.prefix?"MSFullscreenChange":e.prefix+"fullscreenchange",e.isFullScreen=function(e){switch("undefined"==typeof e&&(e=document.body),this.prefix){case"":return document.fullscreenElement==e;case"moz":return document.mozFullScreenElement==e;default:return document[this.prefix+"FullscreenElement"]==e}},e.requestFullScreen=function(e){return"undefined"==typeof e&&(e=document.body),""===this.prefix?e.requestFullScreen():e[this.prefix+("ms"==this.prefix?"RequestFullscreen":"RequestFullScreen")]()},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 x(){var e={supported:function(){if(!("localStorage"in window))return!1;try{window.localStorage.setItem("___test","OK");var e=window.localStorage.getItem("___test");return window.localStorage.removeItem("___test"),"OK"===e}catch(t){return!1}return!1}()};return e}function _(k){function _(e){if(!ge.usingTextTracks&&"video"===ge.type&&ge.supported.full&&(ge.subcount=0,e="number"==typeof e?e:ge.media.currentTime,ge.captions[ge.subcount])){for(;I(ge.captions[ge.subcount][0])<e.toFixed(1);)if(ge.subcount++,ge.subcount>ge.captions.length-1){ge.subcount=ge.captions.length-1;break}if(ge.media.currentTime.toFixed(1)>=N(ge.captions[ge.subcount][0])&&ge.media.currentTime.toFixed(1)<=I(ge.captions[ge.subcount][0])){ge.currentCaption=ge.captions[ge.subcount][1];var t=ge.currentCaption.trim();ge.captionsContainer.innerHTML!=t&&(ge.captionsContainer.innerHTML="",ge.captionsContainer.innerHTML=t)}else ge.captionsContainer.innerHTML=""}}function A(){ge.buttons.captions&&(f(ge.container,F.classes.captions.enabled,!0),F.captions.defaultActive&&(f(ge.container,F.classes.captions.active,!0),h(ge.buttons.captions,!0)))}function N(e){var t=[];return t=e.split(" --> "),P(t[0])}function I(e){var t=[];return t=e.split(" --> "),P(t[1])}function P(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 M(e){return ge.container.querySelectorAll(e)}function L(e){return M(e)[0]}function O(){try{return window.self!==window.top}catch(e){return!0}}function V(){var n=F.html;t("Injecting custom controls."),n||(n=e()),n=i(n,"{seektime}",F.seekTime),n=i(n,"{id}",Math.floor(1e4*Math.random()));var r;if(null!==F.selectors.controls.container&&(r=F.selectors.controls.container,"string"==typeof selector&&(r=document.querySelector(r))),r instanceof HTMLElement||(r=ge.container),r.insertAdjacentHTML("beforeend",n),F.tooltips)for(var a=M(F.selectors.labels),o=a.length-1;o>=0;o--){var s=a[o];f(s,F.classes.hidden,!1),f(s,F.classes.tooltip,!0)}}function q(){try{return ge.controls=L(F.selectors.controls.wrapper),ge.buttons={},ge.buttons.seek=L(F.selectors.buttons.seek),ge.buttons.play=L(F.selectors.buttons.play),ge.buttons.pause=L(F.selectors.buttons.pause),ge.buttons.restart=L(F.selectors.buttons.restart),ge.buttons.rewind=L(F.selectors.buttons.rewind),ge.buttons.forward=L(F.selectors.buttons.forward),ge.buttons.fullscreen=L(F.selectors.buttons.fullscreen),ge.buttons.mute=L(F.selectors.buttons.mute),ge.buttons.captions=L(F.selectors.buttons.captions),ge.checkboxes=M('[type="checkbox"]'),ge.progress={},ge.progress.container=L(F.selectors.progress.container),ge.progress.buffer={},ge.progress.buffer.bar=L(F.selectors.progress.buffer),ge.progress.buffer.text=ge.progress.buffer.bar&&ge.progress.buffer.bar.getElementsByTagName("span")[0],ge.progress.played={},ge.progress.played.bar=L(F.selectors.progress.played),ge.progress.played.text=ge.progress.played.bar&&ge.progress.played.bar.getElementsByTagName("span")[0],ge.volume=L(F.selectors.buttons.volume),ge.duration=L(F.selectors.duration),ge.currentTime=L(F.selectors.currentTime),ge.seekTime=M(F.selectors.seekTime),!0}catch(e){return t("It looks like there's a problem with your controls html. Bailing.",!0),ge.media.setAttribute("controls",""),!1}}function H(e){var t=ge.buttons.play.innerText||F.i18n.play;"undefined"!=typeof F.title&&F.title.length&&(t+=", "+F.title),ge.buttons.play&&ge.buttons.play.setAttribute("aria-label",t),e instanceof HTMLElement&&e.setAttribute("title",F.i18n.frameTitle.replace("{title}",F.title))}function R(){if(!ge.media)return t("No audio or video element found!",!0),!1;if(ge.supported.full&&(ge.media.removeAttribute("controls"),f(ge.container,F.classes.type.replace("{0}",ge.type),!0),f(ge.container,F.classes.stopped,F.autoplay),f(ge.container,F.classes.isIos,ge.browser.ios),f(ge.container,F.classes.isTouch,ge.browser.touch),"video"===ge.type)){var e=document.createElement("div");e.setAttribute("class",F.classes.videoWrapper),s(ge.media,e),ge.videoContainer=e}o(F.types.embed,ge.type)?(j(),ge.embedId=null):F.autoplay&&z()}function j(){for(var e=document.createElement("div"),t=ge.embedId,n=ge.type+"-"+Math.floor(1e4*Math.random()),r=M('[id^="'+ge.type+'-"]'),o=r.length-1;o>=0;o--)u(r[o]);if(f(ge.media,F.classes.videoWrapper,!0),f(ge.media,F.classes.embedWrapper,!0),"youtube"===ge.type)ge.media.appendChild(e),e.setAttribute("id",n),"object"==typeof YT?B(t,e):(a(F.urls.youtube.api),window.onYouTubeReadyCallbacks=window.onYouTubeReadyCallbacks||[],window.onYouTubeReadyCallbacks.push(function(){B(t,e)}),window.onYouTubeIframeAPIReady=function(){window.onYouTubeReadyCallbacks.forEach(function(e){e()})});else if("vimeo"===ge.type){var i=document.createElement("iframe");i.loaded=!1,b(i,"load",function(){i.loaded=!0}),p(i,{src:"https://player.vimeo.com/video/"+t+"?player_id="+n+"&api=1&badge=0&byline=0&portrait=0&title=0",id:n,webkitallowfullscreen:"",mozallowfullscreen:"",allowfullscreen:"",frameborder:0}),e.appendChild(i),ge.media.appendChild(e),"$f"in window||a(F.urls.vimeo.api);var s=window.setInterval(function(){"$f"in window&&i.loaded&&(window.clearInterval(s),Y.call(i))},50)}}function D(){ge.supported.full&&(ge.container.querySelectorAll(F.selectors.controls.wrapper).length||be()),H(L("iframe")),ne(),re()}function B(e,t){"timer"in ge||(ge.timer={}),ge.embed=new YT.Player(t.id,{videoId:e,playerVars:{autoplay:F.autoplay?1:0,controls:ge.supported.full?0:1,rel:0,showinfo:0,iv_load_policy:3,cc_load_policy:F.captions.defaultActive?1:0,cc_lang_pref:"en",wmode:"transparent",modestbranding:1,disablekb:1,origin:"*"},events:{onReady:function(e){var t=e.target;ge.media.play=function(){t.playVideo(),ge.media.paused=!1},ge.media.pause=function(){t.pauseVideo(),ge.media.paused=!0},ge.media.stop=function(){t.stopVideo(),ge.media.paused=!0},ge.media.duration=t.getDuration(),ge.media.paused=!F.autoplay,ge.media.currentTime=t.getCurrentTime(),ge.media.muted=t.isMuted(),g(ge.media,"timeupdate"),window.clearInterval(ge.timer.buffering),ge.timer.buffering=window.setInterval(function(){ge.media.buffered=t.getVideoLoadedFraction(),g(ge.media,"progress"),1===ge.media.buffered&&window.clearInterval(ge.timer.buffering)},200),D(),F.displayDuration&&le()},onStateChange:function(e){var t=e.target;switch(window.clearInterval(ge.timer.playing),e.data){case 0:ge.media.paused=!0,g(ge.media,"ended");break;case 1:ge.media.paused=!1,g(ge.media,"play"),ge.timer.playing=window.setInterval(function(){ge.media.currentTime=t.getCurrentTime(),g(ge.media,"timeupdate")},200);break;case 2:ge.media.paused=!0,g(ge.media,"pause")}}}})}function Y(){ge.embed=$f(this),ge.embed.addEvent("ready",function(){ge.media.play=function(){ge.embed.api("play"),ge.media.paused=!1},ge.media.pause=function(){ge.embed.api("pause"),ge.media.paused=!0},ge.media.stop=function(){ge.embed.api("stop"),ge.media.paused=!0},ge.media.paused=!F.autoplay,ge.media.currentTime=0,D(),ge.embed.api("getCurrentTime",function(e){ge.media.currentTime=e,g(ge.media,"timeupdate")}),ge.embed.api("getDuration",function(e){ge.media.duration=e,ge.supported.full&&F.displayDuration&&le()}),ge.embed.addEvent("play",function(){ge.media.paused=!1,g(ge.media,"play")}),ge.embed.addEvent("pause",function(){ge.media.paused=!0,g(ge.media,"pause")}),ge.embed.addEvent("playProgress",function(e){ge.media.currentTime=e.seconds,g(ge.media,"timeupdate")}),ge.embed.addEvent("loadProgress",function(e){ge.media.buffered=e.percent,g(ge.media,"progress")}),ge.embed.addEvent("finish",function(){ge.media.paused=!0,g(ge.media,"ended")})})}function W(){if("video"===ge.type){L(F.selectors.captions)||ge.videoContainer.insertAdjacentHTML("afterbegin",'<div class="'+m(F.selectors.captions)+'"><span></span></div>'),ge.captionsContainer=L(F.selectors.captions).querySelector("span"),ge.usingTextTracks=!1,ge.media.textTracks&&(ge.usingTextTracks=!0);for(var e,n="",r=ge.media.childNodes,a=0;a<r.length;a++)"track"===r[a].nodeName.toLowerCase()&&(e=r[a].kind,("captions"===e||"subtitles"===e)&&(n=r[a].getAttribute("src")));if(ge.captionExists=!0,""===n?(ge.captionExists=!1,t("No caption track found.")):t("Caption track found; URI: "+n),ge.captionExists){for(var o=ge.media.textTracks,i=0;i<o.length;i++)o[i].mode="hidden";if(A(ge),("IE"===ge.browser.name&&ge.browser.version>=10||"Firefox"===ge.browser.name&&ge.browser.version>=31||"Chrome"===ge.browser.name&&ge.browser.version>=43||"Safari"===ge.browser.name&&ge.browser.version>=7)&&(t("Detected unsupported browser for HTML5 captions. Using fallback."),ge.usingTextTracks=!1),ge.usingTextTracks){t("TextTracks supported.");for(var s=0;s<o.length;s++){var l=o[s];("captions"===l.kind||"subtitles"===l.kind)&&b(l,"cuechange",function(){ge.captionsContainer.innerHTML="",this.activeCues[0]&&this.activeCues[0].hasOwnProperty("text")&&ge.captionsContainer.appendChild(this.activeCues[0].getCueAsHTML().trim())})}}else if(t("TextTracks not supported so rendering captions manually."),ge.currentCaption="",ge.captions=[],""!==n){var u=new XMLHttpRequest;u.onreadystatechange=function(){if(4===u.readyState)if(200===u.status){var e,n=[],r=u.responseText;n=r.split("\n\n");for(var a=0;a<n.length;a++)e=n[a],ge.captions[a]=[],ge.captions[a]=e.split("\n");ge.captions.shift(),t("Successfully loaded the caption file via AJAX.")}else t("There was a problem loading the caption file via AJAX.",!0)},u.open("get",n,!0),u.send()}if("Safari"===ge.browser.name&&ge.browser.version>=7){t("Safari 7+ detected; removing track from DOM."),o=ge.media.getElementsByTagName("track");for(var c=0;c<o.length;c++)ge.media.removeChild(o[c])}}else f(ge.container,F.classes.captions.enabled)}}function $(){if(("audio"!=ge.type||F.fullscreen.allowAudio)&&F.fullscreen.enabled){var e=C.supportsFullScreen;e||F.fullscreen.fallback&&!O()?(t((e?"Native":"Fallback")+" fullscreen enabled."),f(ge.container,F.classes.fullscreen.enabled,!0)):t("Fullscreen not supported and fallback disabled."),h(ge.buttons.fullscreen,!1),F.fullscreen.hideControls&&f(ge.container,F.classes.fullscreen.hideControls,!0)}}function z(){"play"in ge.media&&ge.media.play()}function U(){"pause"in ge.media&&ge.media.pause()}function X(e){e===!0?z():e===!1?U():ge.media[ge.media.paused?"play":"pause"]()}function J(e){"number"!=typeof e&&(e=F.seekTime),G(ge.media.currentTime-e)}function K(e){"number"!=typeof e&&(e=F.seekTime),G(ge.media.currentTime+e)}function G(e){var n=0,r=ge.media.paused;"number"==typeof e?n=e:"object"!=typeof e||"input"!==e.type&&"change"!==e.type||(n=e.target.value/e.target.max*ge.media.duration),0>n?n=0:n>ge.media.duration&&(n=ge.media.duration);try{ge.media.currentTime=n.toFixed(1)}catch(a){}"embed"in ge&&("youtube"===ge.type&&ge.embed.seekTo(n),"vimeo"===ge.type&&ge.embed.api("seekTo",n),g(ge.media,"timeupdate"),r&&U()),t("Seeking to "+ge.media.currentTime+" seconds"),_(n)}function Q(){f(ge.container,F.classes.playing,!ge.media.paused),f(ge.container,F.classes.stopped,ge.media.paused)}function Z(e){function t(){f(ge.container,F.classes.hover,!0),window.clearTimeout(a),o||(a=window.setTimeout(function(){f(ge.container,F.classes.hover,!1)},2e3))}function n(e){o="mouseenter"===e.type}var r=C.supportsFullScreen;e&&e.type===C.fullScreenEventName?ge.isFullscreen=C.isFullScreen(ge.container):r?(C.isFullScreen(ge.container)?C.cancelFullScreen():C.requestFullScreen(ge.container),ge.isFullscreen=C.isFullScreen(ge.container)):(ge.isFullscreen=!ge.isFullscreen,ge.isFullscreen?(b(document,"keyup",ee),document.body.style.overflow="hidden"):(v(document,"keyup",ee),document.body.style.overflow="")),f(ge.container,F.classes.fullscreen.active,ge.isFullscreen),h(ge.buttons.fullscreen,ge.isFullscreen);var a,o=!1;F.fullscreen.hideControls&&(f(ge.controls,F.classes.hover,!1),y(ge.controls,"mouseenter mouseleave",n,ge.isFullscreen),y(ge.container,"mousemove",t,ge.isFullscreen))}function ee(e){27===(e.which||e.charCode||e.keyCode)&&ge.isFullscreen&&Z()}function te(e){"boolean"!=typeof e&&(e=!ge.media.muted),h(ge.buttons.mute,e),ge.media.muted=e,"youtube"===ge.type&&(ge.embed[ge.media.muted?"mute":"unMute"](),g(ge.media,"volumechange")),"vimeo"===ge.type&&(ge.media.muted?ge.embed.api("setVolume",0):ge.embed.api("setVolume",parseFloat(F.volume/10)),g(ge.media,"volumechange"))}function ne(e){"undefined"==typeof e&&(e=F.storage.enabled&&x().supported?window.localStorage[F.storage.key]||F.volume:F.volume),e>10&&(e=10),0>e&&(e=0),ge.media.volume=parseFloat(e/10),F.volume=e,"youtube"===ge.type&&ge.embed.setVolume(100*ge.media.volume),"vimeo"===ge.type&&ge.embed.api("setVolume",ge.media.volume),"embed"in ge&&g(ge.media,"volumechange"),ge.media.muted&&e>0&&te()}function re(){var e=ge.media.muted?0:10*ge.media.volume;ge.supported.full&&ge.volume&&(ge.volume.value=e),F.storage.enabled&&x().supported&&window.localStorage.setItem(F.storage.key,e),f(ge.container,F.classes.muted,0===e),ge.supported.full&&ge.buttons.mute&&h(ge.buttons.mute,0===e)}function ae(e){ge.supported.full&&ge.buttons.captions&&("boolean"!=typeof e&&(e=-1===ge.container.className.indexOf(F.classes.captions.active)),ge.captionsEnabled=e,h(ge.buttons.captions,ge.captionsEnabled),f(ge.container,F.classes.captions.active,ge.captionsEnabled))}function oe(e){var t="waiting"===e.type;clearTimeout(ge.loadingTimer),ge.loadingTimer=setTimeout(function(){f(ge.container,F.classes.loading,t)},t?250:0)}function ie(e){var t=ge.progress.played.bar,n=ge.progress.played.text,r=0;if(e)switch(e.type){case"timeupdate":case"seeking":r=w(ge.media.currentTime,ge.media.duration),"timeupdate"==e.type&&ge.buttons.seek&&(ge.buttons.seek.value=r);break;case"change":case"input":r=e.target.value;break;case"playing":case"progress":t=ge.progress.buffer.bar,n=ge.progress.buffer.text,r=function(){var e=ge.media.buffered;return e&&e.length?w(e.end(0),ge.media.duration):"number"==typeof e?100*e:0}()}t&&(t.value=r),n&&(n.innerHTML=r)}function se(e,t){if(t){isNaN(e)&&(e=0),ge.secs=parseInt(e%60),ge.mins=parseInt(e/60%60),ge.hours=parseInt(e/60/60%60);var n=parseInt(ge.media.duration/60/60%60)>0;ge.secs=("0"+ge.secs).slice(-2),ge.mins=("0"+ge.mins).slice(-2),t.innerHTML=(n?ge.hours+":":"")+ge.mins+":"+ge.secs}}function le(){var e=ge.media.duration||0;!ge.duration&&F.displayDuration&&ge.media.paused&&se(e,ge.currentTime),ge.duration&&se(e,ge.duration)}function ue(e){se(ge.media.currentTime,ge.currentTime),ie(e)}function ce(e,t){if("string"==typeof t)d(e,ge.media,{src:t});else if(t.constructor===Array)for(var n=t.length-1;n>=0;n--)d(e,ge.media,t[n])}function pe(e){if(!("undefined"!=typeof e&&"sources"in e&&e.sources.length))return void t("Invalid source format",!0);if(U(),"youtube"===ge.type?(ge.embed.destroy(),window.clearInterval(ge.timer.buffering),window.clearInterval(ge.timer.playing)):"video"===ge.type&&u(ge.videoContainer),u(ge.media),"type"in e&&(ge.type=e.type,"video"===ge.type)){var n=e.sources[0];"type"in n&&o(F.types.embed,n.type)&&(ge.type=n.type)}switch(ge.type){case"video":ge.media=document.createElement("video");break;case"audio":ge.media=document.createElement("audio");break;case"youtube":case"vimeo":ge.media=document.createElement("div"),ge.embedId=e.sources[0].src}c(ge.container,ge.media),o(F.types.html5,ge.type)&&(F.crossorigin&&ge.media.setAttribute("crossorigin",""),F.autoplay&&ge.media.setAttribute("autoplay",""),"poster"in e&&ge.media.setAttribute("poster",e.poster),F.loop&&ge.media.setAttribute("loop","")),ge.container.className=ge.originalClassName,f(ge.container,F.classes.fullscreen.active,ge.isFullscreen),f(ge.container,F.classes.captions.active,ge.captionsEnabled),F.autoplay=e.autoplay||F.autoplay,o(F.types.html5,ge.type)&&ce("source",e.sources),R(),ve(),o(F.types.html5,ge.type)&&(ne(),re(),ge.supported.full&&(ue(),Q()),"tracks"in e&&(ce("track",e.tracks),W()),ge.media.load(),F.autoplay&&z()),"title"in e&&(F.title=e.title,H())}function de(e){"video"===ge.type&&ge.media.setAttribute("poster",e)}function me(){function e(){var e=document.activeElement;e&&e!=document.body?document.querySelector&&(e=document.querySelector(":focus")):e=null;for(var t in ge.buttons){var n=ge.buttons[t];f(n,"tab-focus",n===e)}}var t="IE"==ge.browser.name?"change":"input";b(window,"keyup",function(t){var n=t.keyCode?t.keyCode:t.which;9==n&&e()});for(var n in ge.buttons){var r=ge.buttons[n];b(r,"blur",function(){f(r,"tab-focus",!1)})}b(ge.buttons.play,"click",function(){z(),setTimeout(function(){ge.buttons.pause.focus()},100)}),b(ge.buttons.pause,"click",function(){U(),setTimeout(function(){ge.buttons.play.focus()},100)}),b(ge.buttons.restart,"click",G),b(ge.buttons.rewind,"click",J),b(ge.buttons.forward,"click",K),b(ge.buttons.seek,t,G),b(ge.volume,t,function(){ne(this.value)}),b(ge.buttons.mute,"click",te),b(ge.buttons.fullscreen,"click",Z),C.supportsFullScreen&&b(document,C.fullScreenEventName,Z),b(ge.media,"timeupdate seeking",ue),b(ge.media,"timeupdate",_),b(ge.media,"loadedmetadata",le),b(ge.buttons.captions,"click",ae),b(ge.media,"ended",function(){"video"===ge.type&&(ge.captionsContainer.innerHTML=""),Q()}),b(ge.media,"progress playing",ie),b(ge.media,"volumechange",re),b(ge.media,"play pause",Q),b(ge.media,"waiting canplay seeked",oe),"video"===ge.type&&F.click&&b(ge.videoContainer,"click",function(){ge.media.paused?g(ge.buttons.play,"click"):ge.media.ended?(G(),g(ge.buttons.play,"click")):g(ge.buttons.pause,"click")})}function fe(){if(!ge.init)return null;if(ge.container.setAttribute("class",m(F.selectors.container)),ge.init=!1,u(L(F.selectors.controls.wrapper)),"youtube"===ge.type)return void ge.embed.destroy();"video"===ge.type&&(u(L(F.selectors.captions)),l(ge.videoContainer)),ge.media.setAttribute("controls","");var e=ge.media.cloneNode(!0);ge.media.parentNode.replaceChild(e,ge.media)}function ye(){if(ge.init)return null;C=T(),ge.browser=n(),ge.media=ge.container.querySelectorAll("audio, video, div")[0],f(ge.container,E.selectors.container.replace(".",""),!0),ge.originalClassName=ge.container.className;var e=ge.media.tagName.toLowerCase();if("div"===e?(ge.type=ge.media.getAttribute("data-type"),ge.embedId=ge.media.getAttribute("data-video-id"),ge.media.removeAttribute("data-type"),ge.media.removeAttribute("data-video-id")):(ge.type=e,F.crossorigin=null!==ge.media.getAttribute("crossorigin"),F.autoplay=F.autoplay||null!==ge.media.getAttribute("autoplay"),F.loop=F.loop||null!==ge.media.getAttribute("loop")),ge.supported=S.supported(ge.type),!ge.supported.basic)return!1;if(t(ge.browser.name+" "+ge.browser.version),R(),"video"==ge.type||"audio"==ge.type){if(!ge.supported.full)return void(ge.init=!0);be(),F.displayDuration&&le(),H()}ge.init=!0}function be(){return V(),q()?(W(),ve(),ne(),void re()):!1}function ve(){$(),me()}var ge=this;return ge.container=k,ye(),ge.init?{media:ge.media,play:z,pause:U,restart:G,rewind:J,forward:K,seek:G,source:pe,poster:de,setVolume:ne,togglePlay:X,toggleMute:te,toggleCaptions:ae,toggleFullscreen:Z,isFullscreen:function(){return ge.isFullscreen||!1},support:function(e){return r(ge,e)},destroy:fe,restore:ye}:{}}var C,F,S={},E={enabled:!0,debug:!1,autoplay:!1,loop:!1,seekTime:10,volume:5,click:!0,tooltips:!1,displayDuration:!0,iconPrefix:"icon",selectors:{container:".plyr",controls:{container:null,wrapper:".plyr__controls"},labels:"[data-plyr] .sr-only, label .sr-only",buttons:{seek:'[data-plyr="seek"]',play:'[data-plyr="play"]',pause:'[data-plyr="pause"]',restart:'[data-plyr="restart"]',rewind:'[data-plyr="rewind"]',forward:'[data-plyr="fast-forward"]',mute:'[data-plyr="mute"]',volume:'[data-plyr="volume"]',captions:'[data-plyr="captions"]',fullscreen:'[data-plyr="fullscreen"]'},progress:{container:".plyr__progress",buffer:".plyr__progress--buffer",played:".plyr__progress--played"},captions:".plyr__captions",currentTime:".plyr__time--current",duration:".plyr__time--duration"},classes:{videoWrapper:"plyr__video-wrapper",embedWrapper:"plyr__video-embed",type:"plyr--{0}",stopped:"plyr--stopped",playing:"plyr--playing",muted:"plyr--muted",loading:"plyr--loading",hover:"plyr--hover",tooltip:"plyr__tooltip",hidden:"plyr__sr-only",isIos:"plyr--is-ios",isTouch:"plyr--is-touch",captions:{enabled:"plyr--captions-enabled",active:"plyr--captions-active"},fullscreen:{enabled:"plyr--fullscreen-enabled",active:"plyr--fullscreen-active",hideControls:"plyr--fullscreen--hide-controls"}},captions:{defaultActive:!1},fullscreen:{enabled:!0,fallback:!0,hideControls:!0,allowAudio:!1},storage:{enabled:!0,key:"plyr_volume"},controls:["restart","rewind","play","fast-forward","current-time","duration","mute","volume","captions","fullscreen"],i18n:{restart:"Restart",rewind:"Rewind {seektime} secs",play:"Play",pause:"Pause",forward:"Forward {seektime} secs",played:"played",buffered:"buffered",currentTime:"Current time",duration:"Duration",volume:"Volume",toggleMute:"Toggle Mute",toggleCaptions:"Toggle Captions",toggleFullscreen:"Toggle Fullscreen",frameTitle:"Player for {title}"},types:{embed:["youtube","vimeo"],html5:["video","audio"]},urls:{vimeo:{api:"http://cdn.plyr.io/froogaloop/1.0.0/plyr.froogaloop.js"},youtube:{api:"https://www.youtube.com/iframe_api"}}};return S.supported=function(e){var t,r,a=n(),o="IE"===a.name&&a.version<=9,i=/iPhone|iPod/i.test(navigator.userAgent),s=!!document.createElement("audio").canPlayType,l=!!document.createElement("video").canPlayType;switch(e){case"video":t=l,r=t&&!o&&!i;break;case"audio":t=s,r=t&&!o;break;case"vimeo":case"youtube":t=!0,r=!o&&!i;break;default:t=s&&l,r=t&&!o}return{basic:t,full:r}},S.setup=function(e,t){var n=[];if("string"==typeof e?e=document.querySelectorAll(e):e instanceof HTMLElement?e=[e]:e instanceof NodeList||"string"==typeof e||("undefined"==typeof t&&"object"==typeof e&&(t=e),e=document.querySelectorAll(E.selectors.container)),F=k(E,t),!F.enabled||!S.supported().basic||!e.length)return!1;for(var r=e.length-1;r>=0;r--){var a=e[r];if("undefined"==typeof a.plyr){var o=new _(a);a.plyr=Object.keys(o).length?o:!1,"function"==typeof F.onSetup&&F.onSetup.apply(a.plyr)}n.push(a.plyr)}return n},S}); \ No newline at end of file
+!function(e,t){"use strict";"function"==typeof define&&define.amd?define(null,t):"object"==typeof module?module.exports=t():e.plyr=t()}(this,function(){"use strict";function e(){var e=['<div class="plyr__controls">','<div class="plyr__progress">','<label for="seek{id}" class="plyr__sr-only">Seek</label>','<input id="seek{id}" class="plyr__progress--seek" type="range" min="0" max="100" step="0.5" value="0" data-plyr="seek">','<progress class="plyr__progress--played" max="100" value="0">',"<span>0</span>% "+F.i18n.played,"</progress>",'<progress class="plyr__progress--buffer" max="100" value="0">',"<span>0</span>% "+F.i18n.buffered,"</progress>","</div>",'<span class="plyr__controls--left">'];return o(F.controls,"restart")&&e.push('<button type="button" data-plyr="restart">','<svg><use xlink:href="#'+F.iconPrefix+'-restart" /></svg>','<span class="plyr__sr-only">'+F.i18n.restart+"</span>","</button>"),o(F.controls,"rewind")&&e.push('<button type="button" data-plyr="rewind">','<svg><use xlink:href="#'+F.iconPrefix+'-rewind" /></svg>','<span class="plyr__sr-only">'+F.i18n.rewind+"</span>","</button>"),o(F.controls,"play")&&e.push('<button type="button" data-plyr="play">','<svg><use xlink:href="#'+F.iconPrefix+'-play" /></svg>','<span class="plyr__sr-only">'+F.i18n.play+"</span>","</button>",'<button type="button" data-plyr="pause">','<svg><use xlink:href="#'+F.iconPrefix+'-pause" /></svg>','<span class="plyr__sr-only">'+F.i18n.pause+"</span>","</button>"),o(F.controls,"fast-forward")&&e.push('<button type="button" data-plyr="fast-forward">','<svg><use xlink:href="#'+F.iconPrefix+'-fast-forward" /></svg>','<span class="plyr__sr-only">'+F.i18n.forward+"</span>","</button>"),o(F.controls,"current-time")&&e.push('<span class="plyr__time">','<span class="plyr__sr-only">'+F.i18n.currentTime+"</span>",'<span class="plyr__time--current">00:00</span>',"</span>"),o(F.controls,"duration")&&e.push('<span class="plyr__time">','<span class="plyr__sr-only">'+F.i18n.duration+"</span>",'<span class="plyr__time--duration">00:00</span>',"</span>"),e.push("</span>",'<span class="plyr__controls--right">'),o(F.controls,"mute")&&e.push('<button type="button" data-plyr="mute">','<svg class="icon--muted"><use xlink:href="#'+F.iconPrefix+'-muted" /></svg>','<svg><use xlink:href="#'+F.iconPrefix+'-volume" /></svg>','<span class="plyr__sr-only">'+F.i18n.toggleMute+"</span>","</button>"),o(F.controls,"volume")&&e.push('<label for="volume{id}" class="plyr__sr-only">'+F.i18n.volume+"</label>",'<input id="volume{id}" class="plyr__volume" type="range" min="0" max="10" value="5" data-plyr="volume">'),o(F.controls,"captions")&&e.push('<button type="button" data-plyr="captions">','<svg class="icon--captions-on"><use xlink:href="#'+F.iconPrefix+'-captions-on" /></svg>','<svg><use xlink:href="#'+F.iconPrefix+'-captions-off" /></svg>','<span class="plyr__sr-only">'+F.i18n.toggleCaptions+"</span>","</button>"),o(F.controls,"fullscreen")&&e.push('<button type="button" data-plyr="fullscreen">','<svg class="icon--exit-fullscreen"><use xlink:href="#'+F.iconPrefix+'-exit-fullscreen" /></svg>','<svg><use xlink:href="#'+F.iconPrefix+'-enter-fullscreen" /></svg>','<span class="plyr__sr-only">'+F.i18n.toggleFullscreen+"</span>","</button>"),e.push("</span>","</div>"),e.join("")}function t(e,t){F.debug&&window.console&&console[t?"error":"log"](e)}function n(){var e,t,n,r=navigator.userAgent,a=navigator.appName,o=""+parseFloat(navigator.appVersion),i=parseInt(navigator.appVersion,10);return-1!==navigator.appVersion.indexOf("Windows NT")&&-1!==navigator.appVersion.indexOf("rv:11")?(a="IE",o="11;"):-1!==(t=r.indexOf("MSIE"))?(a="IE",o=r.substring(t+5)):-1!==(t=r.indexOf("Chrome"))?(a="Chrome",o=r.substring(t+7)):-1!==(t=r.indexOf("Safari"))?(a="Safari",o=r.substring(t+7),-1!==(t=r.indexOf("Version"))&&(o=r.substring(t+8))):-1!==(t=r.indexOf("Firefox"))?(a="Firefox",o=r.substring(t+8)):(e=r.lastIndexOf(" ")+1)<(t=r.lastIndexOf("/"))&&(a=r.substring(e,t),o=r.substring(t+1),a.toLowerCase()==a.toUpperCase()&&(a=navigator.appName)),-1!==(n=o.indexOf(";"))&&(o=o.substring(0,n)),-1!==(n=o.indexOf(" "))&&(o=o.substring(0,n)),i=parseInt(""+o,10),isNaN(i)&&(o=""+parseFloat(navigator.appVersion),i=parseInt(navigator.appVersion,10)),{name:a,version:i,ios:/(iPad|iPhone|iPod)/g.test(navigator.platform),touch:"ontouchstart"in document.documentElement}}function r(e,t){var n=e.media;if("video"==e.type)switch(t){case"video/webm":return!(!n.canPlayType||!n.canPlayType('video/webm; codecs="vp8, vorbis"').replace(/no/,""));case"video/mp4":return!(!n.canPlayType||!n.canPlayType('video/mp4; codecs="avc1.42E01E, mp4a.40.2"').replace(/no/,""));case"video/ogg":return!(!n.canPlayType||!n.canPlayType('video/ogg; codecs="theora"').replace(/no/,""))}else if("audio"==e.type)switch(t){case"audio/mpeg":return!(!n.canPlayType||!n.canPlayType("audio/mpeg;").replace(/no/,""));case"audio/ogg":return!(!n.canPlayType||!n.canPlayType('audio/ogg; codecs="vorbis"').replace(/no/,""));case"audio/wav":return!(!n.canPlayType||!n.canPlayType('audio/wav; codecs="1"').replace(/no/,""))}return!1}function a(e){if(!document.querySelectorAll('script[src="'+e+'"]').length){var t=document.createElement("script");t.src=e;var n=document.getElementsByTagName("script")[0];n.parentNode.insertBefore(t,n)}}function o(e,t){return Array.prototype.indexOf&&-1!=e.indexOf(t)}function i(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,a=e[n],o=a.parentNode,i=a.nextSibling;r.appendChild(a),i?o.insertBefore(r,i):o.appendChild(r)}}function l(e){for(var t=e.parentNode;e.firstChild;)t.insertBefore(e.firstChild,e);t.removeChild(e)}function u(e){e.parentNode.removeChild(e)}function c(e,t){e.insertBefore(t,e.firstChild)}function p(e,t){for(var n in t)e.setAttribute(n,"boolean"==typeof t[n]&&t[n]?"":t[n])}function d(e,t,n){var r=document.createElement(e);p(r,n),c(t,r)}function m(e){return e.replace(".","")}function f(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 y(e,t,n,r){var a=t.split(" ");if(e instanceof NodeList)for(var o=0;o<e.length;o++)e[o]instanceof Node&&y(e[o],arguments[1],arguments[2],arguments[3]);else for(var i=0;i<a.length;i++)e[r?"addEventListener":"removeEventListener"](a[i],n,!1)}function b(e,t,n){e&&y(e,t,n,!0)}function v(e,t,n){e&&y(e,t,n,!1)}function g(e,t){if(e&&t){var n=document.createEvent("MouseEvents");n.initEvent(t,!0,!0),e.dispatchEvent(n)}}function h(e,t){return e?(t="boolean"==typeof t?t:!e.getAttribute("aria-pressed"),e.setAttribute("aria-pressed",t),t):void 0}function w(e,t){return 0===e||0===t||isNaN(e)||isNaN(t)?0:(e/t*100).toFixed(2)}function k(e,t){for(var n in t)t[n]&&t[n].constructor&&t[n].constructor===Object?(e[n]=e[n]||{},k(e[n],t[n])):e[n]=t[n];return e}function T(){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 e.supportsFullScreen&&(e.fullScreenEventName="ms"==e.prefix?"MSFullscreenChange":e.prefix+"fullscreenchange",e.isFullScreen=function(e){switch("undefined"==typeof e&&(e=document.body),this.prefix){case"":return document.fullscreenElement==e;case"moz":return document.mozFullScreenElement==e;default:return document[this.prefix+"FullscreenElement"]==e}},e.requestFullScreen=function(e){return"undefined"==typeof e&&(e=document.body),""===this.prefix?e.requestFullScreen():e[this.prefix+("ms"==this.prefix?"RequestFullscreen":"RequestFullScreen")]()},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 x(){var e={supported:function(){if(!("localStorage"in window))return!1;try{window.localStorage.setItem("___test","OK");var e=window.localStorage.getItem("___test");return window.localStorage.removeItem("___test"),"OK"===e}catch(t){return!1}return!1}()};return e}function _(k){function _(e){if(!ge.usingTextTracks&&"video"===ge.type&&ge.supported.full&&(ge.subcount=0,e="number"==typeof e?e:ge.media.currentTime,ge.captions[ge.subcount])){for(;I(ge.captions[ge.subcount][0])<e.toFixed(1);)if(ge.subcount++,ge.subcount>ge.captions.length-1){ge.subcount=ge.captions.length-1;break}if(ge.media.currentTime.toFixed(1)>=N(ge.captions[ge.subcount][0])&&ge.media.currentTime.toFixed(1)<=I(ge.captions[ge.subcount][0])){ge.currentCaption=ge.captions[ge.subcount][1];var t=ge.currentCaption.trim();ge.captionsContainer.innerHTML!=t&&(ge.captionsContainer.innerHTML="",ge.captionsContainer.innerHTML=t)}else ge.captionsContainer.innerHTML=""}}function A(){ge.buttons.captions&&(f(ge.container,F.classes.captions.enabled,!0),F.captions.defaultActive&&(f(ge.container,F.classes.captions.active,!0),h(ge.buttons.captions,!0)))}function N(e){var t=[];return t=e.split(" --> "),P(t[0])}function I(e){var t=[];return t=e.split(" --> "),P(t[1])}function P(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 M(e){return ge.container.querySelectorAll(e)}function L(e){return M(e)[0]}function O(){try{return window.self!==window.top}catch(e){return!0}}function V(){var n=F.html;t("Injecting custom controls."),n||(n=e()),n=i(n,"{seektime}",F.seekTime),n=i(n,"{id}",Math.floor(1e4*Math.random()));var r;if(null!==F.selectors.controls.container&&(r=F.selectors.controls.container,"string"==typeof selector&&(r=document.querySelector(r))),r instanceof HTMLElement||(r=ge.container),r.insertAdjacentHTML("beforeend",n),F.tooltips)for(var a=M(F.selectors.labels),o=a.length-1;o>=0;o--){var s=a[o];f(s,F.classes.hidden,!1),f(s,F.classes.tooltip,!0)}}function q(){try{return ge.controls=L(F.selectors.controls.wrapper),ge.buttons={},ge.buttons.seek=L(F.selectors.buttons.seek),ge.buttons.play=L(F.selectors.buttons.play),ge.buttons.pause=L(F.selectors.buttons.pause),ge.buttons.restart=L(F.selectors.buttons.restart),ge.buttons.rewind=L(F.selectors.buttons.rewind),ge.buttons.forward=L(F.selectors.buttons.forward),ge.buttons.fullscreen=L(F.selectors.buttons.fullscreen),ge.buttons.mute=L(F.selectors.buttons.mute),ge.buttons.captions=L(F.selectors.buttons.captions),ge.checkboxes=M('[type="checkbox"]'),ge.progress={},ge.progress.container=L(F.selectors.progress.container),ge.progress.buffer={},ge.progress.buffer.bar=L(F.selectors.progress.buffer),ge.progress.buffer.text=ge.progress.buffer.bar&&ge.progress.buffer.bar.getElementsByTagName("span")[0],ge.progress.played={},ge.progress.played.bar=L(F.selectors.progress.played),ge.progress.played.text=ge.progress.played.bar&&ge.progress.played.bar.getElementsByTagName("span")[0],ge.volume=L(F.selectors.buttons.volume),ge.duration=L(F.selectors.duration),ge.currentTime=L(F.selectors.currentTime),ge.seekTime=M(F.selectors.seekTime),!0}catch(e){return t("It looks like there's a problem with your controls html. Bailing.",!0),ge.media.setAttribute("controls",""),!1}}function H(e){var t=F.i18n.play;"undefined"!=typeof F.title&&F.title.length&&(t+=", "+F.title),ge.buttons.play&&ge.buttons.play.setAttribute("aria-label",t),e instanceof HTMLElement&&e.setAttribute("title",F.i18n.frameTitle.replace("{title}",F.title))}function R(){if(!ge.media)return t("No audio or video element found!",!0),!1;if(ge.supported.full&&(ge.media.removeAttribute("controls"),f(ge.container,F.classes.type.replace("{0}",ge.type),!0),f(ge.container,F.classes.stopped,F.autoplay),f(ge.container,F.classes.isIos,ge.browser.ios),f(ge.container,F.classes.isTouch,ge.browser.touch),"video"===ge.type)){var e=document.createElement("div");e.setAttribute("class",F.classes.videoWrapper),s(ge.media,e),ge.videoContainer=e}o(F.types.embed,ge.type)?(j(),ge.embedId=null):F.autoplay&&z()}function j(){for(var e=document.createElement("div"),t=ge.embedId,n=ge.type+"-"+Math.floor(1e4*Math.random()),r=M('[id^="'+ge.type+'-"]'),o=r.length-1;o>=0;o--)u(r[o]);if(f(ge.media,F.classes.videoWrapper,!0),f(ge.media,F.classes.embedWrapper,!0),"youtube"===ge.type)ge.media.appendChild(e),e.setAttribute("id",n),"object"==typeof YT?B(t,e):(a(F.urls.youtube.api),window.onYouTubeReadyCallbacks=window.onYouTubeReadyCallbacks||[],window.onYouTubeReadyCallbacks.push(function(){B(t,e)}),window.onYouTubeIframeAPIReady=function(){window.onYouTubeReadyCallbacks.forEach(function(e){e()})});else if("vimeo"===ge.type){var i=document.createElement("iframe");i.loaded=!1,b(i,"load",function(){i.loaded=!0}),p(i,{src:"https://player.vimeo.com/video/"+t+"?player_id="+n+"&api=1&badge=0&byline=0&portrait=0&title=0",id:n,webkitallowfullscreen:"",mozallowfullscreen:"",allowfullscreen:"",frameborder:0}),e.appendChild(i),ge.media.appendChild(e),"$f"in window||a(F.urls.vimeo.api);var s=window.setInterval(function(){"$f"in window&&i.loaded&&(window.clearInterval(s),Y.call(i))},50)}}function D(){ge.supported.full&&(ge.container.querySelectorAll(F.selectors.controls.wrapper).length||be()),H(L("iframe")),ne(),re()}function B(e,t){"timer"in ge||(ge.timer={}),ge.embed=new YT.Player(t.id,{videoId:e,playerVars:{autoplay:F.autoplay?1:0,controls:ge.supported.full?0:1,rel:0,showinfo:0,iv_load_policy:3,cc_load_policy:F.captions.defaultActive?1:0,cc_lang_pref:"en",wmode:"transparent",modestbranding:1,disablekb:1,origin:"*"},events:{onReady:function(e){var t=e.target;ge.media.play=function(){t.playVideo(),ge.media.paused=!1},ge.media.pause=function(){t.pauseVideo(),ge.media.paused=!0},ge.media.stop=function(){t.stopVideo(),ge.media.paused=!0},ge.media.duration=t.getDuration(),ge.media.paused=!F.autoplay,ge.media.currentTime=t.getCurrentTime(),ge.media.muted=t.isMuted(),g(ge.media,"timeupdate"),window.clearInterval(ge.timer.buffering),ge.timer.buffering=window.setInterval(function(){ge.media.buffered=t.getVideoLoadedFraction(),g(ge.media,"progress"),1===ge.media.buffered&&window.clearInterval(ge.timer.buffering)},200),D(),F.displayDuration&&le()},onStateChange:function(e){var t=e.target;switch(window.clearInterval(ge.timer.playing),e.data){case 0:ge.media.paused=!0,g(ge.media,"ended");break;case 1:ge.media.paused=!1,g(ge.media,"play"),ge.timer.playing=window.setInterval(function(){ge.media.currentTime=t.getCurrentTime(),g(ge.media,"timeupdate")},200);break;case 2:ge.media.paused=!0,g(ge.media,"pause")}}}})}function Y(){ge.embed=$f(this),ge.embed.addEvent("ready",function(){ge.media.play=function(){ge.embed.api("play"),ge.media.paused=!1},ge.media.pause=function(){ge.embed.api("pause"),ge.media.paused=!0},ge.media.stop=function(){ge.embed.api("stop"),ge.media.paused=!0},ge.media.paused=!F.autoplay,ge.media.currentTime=0,D(),ge.embed.api("getCurrentTime",function(e){ge.media.currentTime=e,g(ge.media,"timeupdate")}),ge.embed.api("getDuration",function(e){ge.media.duration=e,ge.supported.full&&F.displayDuration&&le()}),ge.embed.addEvent("play",function(){ge.media.paused=!1,g(ge.media,"play")}),ge.embed.addEvent("pause",function(){ge.media.paused=!0,g(ge.media,"pause")}),ge.embed.addEvent("playProgress",function(e){ge.media.currentTime=e.seconds,g(ge.media,"timeupdate")}),ge.embed.addEvent("loadProgress",function(e){ge.media.buffered=e.percent,g(ge.media,"progress")}),ge.embed.addEvent("finish",function(){ge.media.paused=!0,g(ge.media,"ended")})})}function W(){if("video"===ge.type){L(F.selectors.captions)||ge.videoContainer.insertAdjacentHTML("afterbegin",'<div class="'+m(F.selectors.captions)+'"><span></span></div>'),ge.captionsContainer=L(F.selectors.captions).querySelector("span"),ge.usingTextTracks=!1,ge.media.textTracks&&(ge.usingTextTracks=!0);for(var e,n="",r=ge.media.childNodes,a=0;a<r.length;a++)"track"===r[a].nodeName.toLowerCase()&&(e=r[a].kind,("captions"===e||"subtitles"===e)&&(n=r[a].getAttribute("src")));if(ge.captionExists=!0,""===n?(ge.captionExists=!1,t("No caption track found.")):t("Caption track found; URI: "+n),ge.captionExists){for(var o=ge.media.textTracks,i=0;i<o.length;i++)o[i].mode="hidden";if(A(ge),("IE"===ge.browser.name&&ge.browser.version>=10||"Firefox"===ge.browser.name&&ge.browser.version>=31||"Chrome"===ge.browser.name&&ge.browser.version>=43||"Safari"===ge.browser.name&&ge.browser.version>=7)&&(t("Detected unsupported browser for HTML5 captions. Using fallback."),ge.usingTextTracks=!1),ge.usingTextTracks){t("TextTracks supported.");for(var s=0;s<o.length;s++){var l=o[s];("captions"===l.kind||"subtitles"===l.kind)&&b(l,"cuechange",function(){ge.captionsContainer.innerHTML="",this.activeCues[0]&&this.activeCues[0].hasOwnProperty("text")&&ge.captionsContainer.appendChild(this.activeCues[0].getCueAsHTML().trim())})}}else if(t("TextTracks not supported so rendering captions manually."),ge.currentCaption="",ge.captions=[],""!==n){var u=new XMLHttpRequest;u.onreadystatechange=function(){if(4===u.readyState)if(200===u.status){var e,n=[],r=u.responseText;n=r.split("\n\n");for(var a=0;a<n.length;a++)e=n[a],ge.captions[a]=[],ge.captions[a]=e.split("\n");ge.captions.shift(),t("Successfully loaded the caption file via AJAX.")}else t("There was a problem loading the caption file via AJAX.",!0)},u.open("get",n,!0),u.send()}if("Safari"===ge.browser.name&&ge.browser.version>=7){t("Safari 7+ detected; removing track from DOM."),o=ge.media.getElementsByTagName("track");for(var c=0;c<o.length;c++)ge.media.removeChild(o[c])}}else f(ge.container,F.classes.captions.enabled)}}function $(){if(("audio"!=ge.type||F.fullscreen.allowAudio)&&F.fullscreen.enabled){var e=C.supportsFullScreen;e||F.fullscreen.fallback&&!O()?(t((e?"Native":"Fallback")+" fullscreen enabled."),f(ge.container,F.classes.fullscreen.enabled,!0)):t("Fullscreen not supported and fallback disabled."),h(ge.buttons.fullscreen,!1),F.fullscreen.hideControls&&f(ge.container,F.classes.fullscreen.hideControls,!0)}}function z(){"play"in ge.media&&ge.media.play()}function U(){"pause"in ge.media&&ge.media.pause()}function X(e){e===!0?z():e===!1?U():ge.media[ge.media.paused?"play":"pause"]()}function J(e){"number"!=typeof e&&(e=F.seekTime),G(ge.media.currentTime-e)}function K(e){"number"!=typeof e&&(e=F.seekTime),G(ge.media.currentTime+e)}function G(e){var n=0,r=ge.media.paused;"number"==typeof e?n=e:"object"!=typeof e||"input"!==e.type&&"change"!==e.type||(n=e.target.value/e.target.max*ge.media.duration),0>n?n=0:n>ge.media.duration&&(n=ge.media.duration);try{ge.media.currentTime=n.toFixed(1)}catch(a){}"embed"in ge&&("youtube"===ge.type&&ge.embed.seekTo(n),"vimeo"===ge.type&&ge.embed.api("seekTo",n),g(ge.media,"timeupdate"),r&&U()),t("Seeking to "+ge.media.currentTime+" seconds"),_(n)}function Q(){f(ge.container,F.classes.playing,!ge.media.paused),f(ge.container,F.classes.stopped,ge.media.paused)}function Z(e){function t(){f(ge.container,F.classes.hover,!0),window.clearTimeout(a),o||(a=window.setTimeout(function(){f(ge.container,F.classes.hover,!1)},2e3))}function n(e){o="mouseenter"===e.type}var r=C.supportsFullScreen;e&&e.type===C.fullScreenEventName?ge.isFullscreen=C.isFullScreen(ge.container):r?(C.isFullScreen(ge.container)?C.cancelFullScreen():C.requestFullScreen(ge.container),ge.isFullscreen=C.isFullScreen(ge.container)):(ge.isFullscreen=!ge.isFullscreen,ge.isFullscreen?(b(document,"keyup",ee),document.body.style.overflow="hidden"):(v(document,"keyup",ee),document.body.style.overflow="")),f(ge.container,F.classes.fullscreen.active,ge.isFullscreen),h(ge.buttons.fullscreen,ge.isFullscreen);var a,o=!1;F.fullscreen.hideControls&&(f(ge.controls,F.classes.hover,!1),y(ge.controls,"mouseenter mouseleave",n,ge.isFullscreen),y(ge.container,"mousemove",t,ge.isFullscreen))}function ee(e){27===(e.which||e.charCode||e.keyCode)&&ge.isFullscreen&&Z()}function te(e){"boolean"!=typeof e&&(e=!ge.media.muted),h(ge.buttons.mute,e),ge.media.muted=e,"youtube"===ge.type&&(ge.embed[ge.media.muted?"mute":"unMute"](),g(ge.media,"volumechange")),"vimeo"===ge.type&&(ge.media.muted?ge.embed.api("setVolume",0):ge.embed.api("setVolume",parseFloat(F.volume/10)),g(ge.media,"volumechange"))}function ne(e){"undefined"==typeof e&&(e=F.storage.enabled&&x().supported?window.localStorage[F.storage.key]||F.volume:F.volume),e>10&&(e=10),0>e&&(e=0),ge.media.volume=parseFloat(e/10),F.volume=e,"youtube"===ge.type&&ge.embed.setVolume(100*ge.media.volume),"vimeo"===ge.type&&ge.embed.api("setVolume",ge.media.volume),"embed"in ge&&g(ge.media,"volumechange"),ge.media.muted&&e>0&&te()}function re(){var e=ge.media.muted?0:10*ge.media.volume;ge.supported.full&&ge.volume&&(ge.volume.value=e),F.storage.enabled&&x().supported&&window.localStorage.setItem(F.storage.key,e),f(ge.container,F.classes.muted,0===e),ge.supported.full&&ge.buttons.mute&&h(ge.buttons.mute,0===e)}function ae(e){ge.supported.full&&ge.buttons.captions&&("boolean"!=typeof e&&(e=-1===ge.container.className.indexOf(F.classes.captions.active)),ge.captionsEnabled=e,h(ge.buttons.captions,ge.captionsEnabled),f(ge.container,F.classes.captions.active,ge.captionsEnabled))}function oe(e){var t="waiting"===e.type;clearTimeout(ge.loadingTimer),ge.loadingTimer=setTimeout(function(){f(ge.container,F.classes.loading,t)},t?250:0)}function ie(e){var t=ge.progress.played.bar,n=ge.progress.played.text,r=0;if(e)switch(e.type){case"timeupdate":case"seeking":r=w(ge.media.currentTime,ge.media.duration),"timeupdate"==e.type&&ge.buttons.seek&&(ge.buttons.seek.value=r);break;case"change":case"input":r=e.target.value;break;case"playing":case"progress":t=ge.progress.buffer.bar,n=ge.progress.buffer.text,r=function(){var e=ge.media.buffered;return e&&e.length?w(e.end(0),ge.media.duration):"number"==typeof e?100*e:0}()}t&&(t.value=r),n&&(n.innerHTML=r)}function se(e,t){if(t){isNaN(e)&&(e=0),ge.secs=parseInt(e%60),ge.mins=parseInt(e/60%60),ge.hours=parseInt(e/60/60%60);var n=parseInt(ge.media.duration/60/60%60)>0;ge.secs=("0"+ge.secs).slice(-2),ge.mins=("0"+ge.mins).slice(-2),t.innerHTML=(n?ge.hours+":":"")+ge.mins+":"+ge.secs}}function le(){var e=ge.media.duration||0;!ge.duration&&F.displayDuration&&ge.media.paused&&se(e,ge.currentTime),ge.duration&&se(e,ge.duration)}function ue(e){se(ge.media.currentTime,ge.currentTime),ie(e)}function ce(e,t){if("string"==typeof t)d(e,ge.media,{src:t});else if(t.constructor===Array)for(var n=t.length-1;n>=0;n--)d(e,ge.media,t[n])}function pe(e){if(!("undefined"!=typeof e&&"sources"in e&&e.sources.length))return void t("Invalid source format",!0);if(U(),"youtube"===ge.type?(ge.embed.destroy(),window.clearInterval(ge.timer.buffering),window.clearInterval(ge.timer.playing)):"video"===ge.type&&u(ge.videoContainer),u(ge.media),"type"in e&&(ge.type=e.type,"video"===ge.type)){var n=e.sources[0];"type"in n&&o(F.types.embed,n.type)&&(ge.type=n.type)}switch(ge.type){case"video":ge.media=document.createElement("video");break;case"audio":ge.media=document.createElement("audio");break;case"youtube":case"vimeo":ge.media=document.createElement("div"),ge.embedId=e.sources[0].src}c(ge.container,ge.media),o(F.types.html5,ge.type)&&(F.crossorigin&&ge.media.setAttribute("crossorigin",""),F.autoplay&&ge.media.setAttribute("autoplay",""),"poster"in e&&ge.media.setAttribute("poster",e.poster),F.loop&&ge.media.setAttribute("loop","")),ge.container.className=ge.originalClassName,f(ge.container,F.classes.fullscreen.active,ge.isFullscreen),f(ge.container,F.classes.captions.active,ge.captionsEnabled),F.autoplay=e.autoplay||F.autoplay,o(F.types.html5,ge.type)&&ce("source",e.sources),R(),ve(),o(F.types.html5,ge.type)&&(ne(),re(),ge.supported.full&&(ue(),Q()),"tracks"in e&&(ce("track",e.tracks),W()),ge.media.load(),F.autoplay&&z()),"title"in e&&(F.title=e.title,H())}function de(e){"video"===ge.type&&ge.media.setAttribute("poster",e)}function me(){function e(){z(),setTimeout(function(){ge.buttons.pause&&ge.buttons.pause.focus()},100)}function t(){U(),setTimeout(function(){ge.buttons.play&&ge.buttons.play.focus()},100)}function n(){var e=document.activeElement;e&&e!=document.body?document.querySelector&&(e=document.querySelector(":focus")):e=null;for(var t in ge.buttons){var n=ge.buttons[t];f(n,"tab-focus",n===e)}}var r="IE"==ge.browser.name?"change":"input";b(window,"keyup",function(e){var t=e.keyCode?e.keyCode:e.which;9==t&&n()});for(var a in ge.buttons){var o=ge.buttons[a];b(o,"blur",function(){f(o,"tab-focus",!1)})}b(ge.buttons.play,"click",e),b(ge.buttons.pause,"click",t),b(ge.buttons.restart,"click",G),b(ge.buttons.rewind,"click",J),b(ge.buttons.forward,"click",K),b(ge.buttons.seek,r,G),b(ge.volume,r,function(){ne(this.value)}),b(ge.buttons.mute,"click",te),b(ge.buttons.fullscreen,"click",Z),C.supportsFullScreen&&b(document,C.fullScreenEventName,Z),b(ge.media,"timeupdate seeking",ue),b(ge.media,"timeupdate",_),b(ge.media,"loadedmetadata",le),b(ge.buttons.captions,"click",ae),b(ge.media,"ended",function(){"video"===ge.type&&(ge.captionsContainer.innerHTML=""),Q()}),b(ge.media,"progress playing",ie),b(ge.media,"volumechange",re),b(ge.media,"play pause",Q),b(ge.media,"waiting canplay seeked",oe),"video"===ge.type&&F.click&&b(ge.videoContainer,"click",function(){ge.media.paused?e():ge.media.ended?(G(),e()):t()})}function fe(){if(!ge.init)return null;if(ge.container.setAttribute("class",m(F.selectors.container)),ge.init=!1,u(L(F.selectors.controls.wrapper)),"youtube"===ge.type)return void ge.embed.destroy();"video"===ge.type&&(u(L(F.selectors.captions)),l(ge.videoContainer)),ge.media.setAttribute("controls","");var e=ge.media.cloneNode(!0);ge.media.parentNode.replaceChild(e,ge.media)}function ye(){if(ge.init)return null;C=T(),ge.browser=n(),ge.media=ge.container.querySelectorAll("audio, video, div")[0],f(ge.container,E.selectors.container.replace(".",""),!0),ge.originalClassName=ge.container.className;var e=ge.media.tagName.toLowerCase();if("div"===e?(ge.type=ge.media.getAttribute("data-type"),ge.embedId=ge.media.getAttribute("data-video-id"),ge.media.removeAttribute("data-type"),ge.media.removeAttribute("data-video-id")):(ge.type=e,F.crossorigin=null!==ge.media.getAttribute("crossorigin"),F.autoplay=F.autoplay||null!==ge.media.getAttribute("autoplay"),F.loop=F.loop||null!==ge.media.getAttribute("loop")),ge.supported=S.supported(ge.type),!ge.supported.basic)return!1;if(t(ge.browser.name+" "+ge.browser.version),R(),"video"==ge.type||"audio"==ge.type){if(!ge.supported.full)return void(ge.init=!0);be(),F.displayDuration&&le(),H()}ge.init=!0}function be(){return V(),q()?(W(),ve(),ne(),void re()):!1}function ve(){$(),me()}var ge=this;return ge.container=k,ye(),ge.init?{media:ge.media,play:z,pause:U,restart:G,rewind:J,forward:K,seek:G,source:pe,poster:de,setVolume:ne,togglePlay:X,toggleMute:te,toggleCaptions:ae,toggleFullscreen:Z,isFullscreen:function(){return ge.isFullscreen||!1},support:function(e){return r(ge,e)},destroy:fe,restore:ye}:{}}var C,F,S={},E={enabled:!0,debug:!1,autoplay:!1,loop:!1,seekTime:10,volume:5,click:!0,tooltips:!1,displayDuration:!0,iconPrefix:"icon",selectors:{container:".plyr",controls:{container:null,wrapper:".plyr__controls"},labels:"[data-plyr] .sr-only, label .sr-only",buttons:{seek:'[data-plyr="seek"]',play:'[data-plyr="play"]',pause:'[data-plyr="pause"]',restart:'[data-plyr="restart"]',rewind:'[data-plyr="rewind"]',forward:'[data-plyr="fast-forward"]',mute:'[data-plyr="mute"]',volume:'[data-plyr="volume"]',captions:'[data-plyr="captions"]',fullscreen:'[data-plyr="fullscreen"]'},progress:{container:".plyr__progress",buffer:".plyr__progress--buffer",played:".plyr__progress--played"},captions:".plyr__captions",currentTime:".plyr__time--current",duration:".plyr__time--duration"},classes:{videoWrapper:"plyr__video-wrapper",embedWrapper:"plyr__video-embed",type:"plyr--{0}",stopped:"plyr--stopped",playing:"plyr--playing",muted:"plyr--muted",loading:"plyr--loading",hover:"plyr--hover",tooltip:"plyr__tooltip",hidden:"plyr__sr-only",isIos:"plyr--is-ios",isTouch:"plyr--is-touch",captions:{enabled:"plyr--captions-enabled",active:"plyr--captions-active"},fullscreen:{enabled:"plyr--fullscreen-enabled",active:"plyr--fullscreen-active",hideControls:"plyr--fullscreen--hide-controls"}},captions:{defaultActive:!1},fullscreen:{enabled:!0,fallback:!0,hideControls:!0,allowAudio:!1},storage:{enabled:!0,key:"plyr_volume"},controls:["restart","rewind","play","fast-forward","current-time","duration","mute","volume","captions","fullscreen"],i18n:{restart:"Restart",rewind:"Rewind {seektime} secs",play:"Play",pause:"Pause",forward:"Forward {seektime} secs",played:"played",buffered:"buffered",currentTime:"Current time",duration:"Duration",volume:"Volume",toggleMute:"Toggle Mute",toggleCaptions:"Toggle Captions",toggleFullscreen:"Toggle Fullscreen",frameTitle:"Player for {title}"},types:{embed:["youtube","vimeo"],html5:["video","audio"]},urls:{vimeo:{api:"http://cdn.plyr.io/froogaloop/1.0.0/plyr.froogaloop.js"},youtube:{api:"https://www.youtube.com/iframe_api"}}};return S.supported=function(e){var t,r,a=n(),o="IE"===a.name&&a.version<=9,i=/iPhone|iPod/i.test(navigator.userAgent),s=!!document.createElement("audio").canPlayType,l=!!document.createElement("video").canPlayType;switch(e){case"video":t=l,r=t&&!o&&!i;break;case"audio":t=s,r=t&&!o;break;case"vimeo":case"youtube":t=!0,r=!o&&!i;break;default:t=s&&l,r=t&&!o}return{basic:t,full:r}},S.setup=function(e,t){var n=[];if("string"==typeof e?e=document.querySelectorAll(e):e instanceof HTMLElement?e=[e]:e instanceof NodeList||"string"==typeof e||("undefined"==typeof t&&"object"==typeof e&&(t=e),e=document.querySelectorAll(E.selectors.container)),F=k(E,t),!F.enabled||!S.supported().basic||!e.length)return!1;for(var r=e.length-1;r>=0;r--){var a=e[r];if("undefined"==typeof a.plyr){var o=new _(a);a.plyr=Object.keys(o).length?o:!1,"function"==typeof F.onSetup&&F.onSetup.apply(a.plyr)}n.push(a.plyr)}return n},S}); \ No newline at end of file
diff --git a/docs/error.html b/docs/error.html
index 8f5086ef..7c7bc14a 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.3.7/docs.css">
+ <link rel="stylesheet" href="dist/docs.css">
</head>
<body>
<main>
@@ -15,4 +15,4 @@
<a href="http://plyr.io" class="btn">Back to plyr.io</a>
</main>
</body>
-</html> \ No newline at end of file
+</html>
diff --git a/docs/index.html b/docs/index.html
index 53d2c73e..8c4026bb 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="https://cdn.plyr.io/1.3.7/plyr.css">
+ <link rel="stylesheet" href="../dist/plyr.css">
<!-- Docs styles -->
- <link rel="stylesheet" href="https://cdn.plyr.io/1.3.7/docs.css">
+ <link rel="stylesheet" href="dist/docs.css">
</head>
<body>
<header>
@@ -79,8 +79,8 @@
<script>
(function() {
[
- 'https://cdn.plyr.io/1.3.7/sprite.svg',
- 'https://cdn.plyr.io/1.3.7/docs.svg'
+ '../dist/sprite.svg',
+ 'dist/docs.svg'
]
.forEach(function(u) {
var x = new XMLHttpRequest(), b = document.body;
@@ -99,12 +99,12 @@
</script>
<!-- Plyr core script -->
- <script src="https://cdn.plyr.io/1.3.7/plyr.js"></script>
+ <script src="../dist/plyr.js"></script>
<!-- Shr core script -->
<script src="https://cdn.shr.one/0.1.9/shr.js"></script>
<!-- Docs script -->
- <script src="https://cdn.plyr.io/1.3.7/docs.js"></script>
+ <script src="dist/docs.js"></script>
</body>
</html>
diff --git a/docs/index.master.html b/docs/index.master.html
deleted file mode 100644
index c6972ae6..00000000
--- a/docs/index.master.html
+++ /dev/null
@@ -1,130 +0,0 @@
-<!doctype html>
-<html lang="en">
- <head>
- <meta charset="utf-8" />
- <title>Plyr - A simple HTML5 media player</title>
- <meta name="description" content="A simple HTML5 media player with custom controls and WebVTT captions.">
- <meta name="author" content="Sam Potts">
- <meta name="viewport" content="width=device-width, initial-scale=1">
-
- <!-- Styles -->
- <link rel="stylesheet" href="../dist/plyr.css">
-
- <!-- Docs styles -->
- <link rel="stylesheet" href="dist/docs.css">
- </head>
- <body>
- <header>
- <h1>Plyr</h1>
- <p>A simple HTML5 media player with custom controls and WebVTT captions by <a href="https://twitter.com/sam_potts" target="_blank">@sam_potts</a> from <a href="https://twitter.com/selz" target="_blank">@selz</a></p>
- <nav>
- <ul>
- <li>
- <a href="https://github.com/selz/plyr" target="_blank" class="btn btn-primary" data-shr-network="github">
- <svg class="icon"><use xlink:href="#shr-github"/></svg>Download on GitHub
- </a>
- </li>
- <li>
- <a href="https://twitter.com/intent/tweet?text=A+simple+HTML5+media+player+with+custom+controls+and+WebVTT+captions.&url=http%3A%2F%2Fplyr.io&via=Sam_Potts" target="_blank" class="btn btn-twitter" data-shr-network="twitter">
- <svg class="icon"><use xlink:href="#shr-twitter"/></svg>Tweet
- </a>
- </li>
- </ul>
- </nav>
- </header>
-
- <main role="main" id="main">
- <nav class="btn-bar nav-panel">
- <ul>
- <li><a href="#video" class="btn active btn-small">Video</a></li>
- <li><a href="#youtube" class="btn btn-small">YouTube</a></li>
- <li><a href="#audio" class="btn btn-small">Audio</a></li>
- </ul>
- </nav>
- <div class="panels">
- <section class="panel example-video active" id="video">
- <div class="player">
- <video poster="poster.jpg" controls crossorigin>
- <!-- Video files -->
- <source src="https://cdn.selz.com/plyr/1.0/movie.mp4" type="video/mp4">
- <source src="https://cdn.selz.com/plyr/1.0/movie.webm" type="video/webm">
-
- <!-- Text track file -->
- <track kind="captions" label="English" srclang="en" src="https://cdn.selz.com/plyr/1.0/example_captions_en.vtt" default>
-
- <!-- Fallback for browsers that don't support the <video> element -->
- <a href="https://cdn.selz.com/plyr/1.0/movie.mp4">Download</a>
- </video>
- </div>
- <small>Big Buck Bunny. More info can be found at <a href="https://peach.blender.org" target="_blank">peach.blender.org</a>.</small>
- </section>
- <section class="panel example-video" id="youtube">
- <div class="player">
- <div data-video-id="Au87oAJ2jeE" data-type="youtube"></div>
- </div>
- <small>Envato's "Made By" interview of <a href="https://www.youtube.com/watch?v=Au87oAJ2jeE" target="_blank">Dan Cederholm</a> from <a href="https://dribbble.com" target="_blank">Dribbble</a>.</small>
- </section>
- <section class="panel example-audio" id="audio">
- <div class="player">
- <audio controls>
- <!-- Audio files -->
- <source src="//cdn.selz.com/plyr/1.0/logistics-96-sample.mp3" type="audio/mp3">
- <source src="//cdn.selz.com/plyr/1.0/logistics-96-sample.ogg" type="audio/ogg">
-
- <!-- Fallback for browsers that don't support the <audio> element -->
- <a href="//cdn.selz.com/plyr/1.0/logistics-96-sample.mp3">Download</a>
- </audio>
- </div>
- <small>"96" by Logistics, which can be purchased from <a href="https://www.hospitalrecords.com/shop/artist/logistics" target="_blank">Hospital Records</a>.</small>
- </section>
- </div>
- </main>
-
- <!-- Load SVG defs -->
- <!-- You should bundle all SVG/Icons into one file using a build tool such as gulp and svg store -->
- <script>
- (function() {
- [
- "https://cdn.shr.one/0.1.9/sprite.svg",
- "../dist/sprite.svg"
- ]
- .forEach(function(u) {
- var x = new XMLHttpRequest(),
- b = document.body;
-
- // Check for CORS support
- // If you're loading from same domain, you can remove the if statement
- // XHR for Chrome/Firefox/Opera/Safari
- if ("withCredentials" in x) {
- x.open("GET", u, true);
- }
- // XDomainRequest for older IE
- else if (typeof XDomainRequest != "undefined") {
- x = new XDomainRequest();
- x.open("GET", u);
- }
- else {
- return;
- }
-
- x.send();
- x.onload = function() {
- var c = document.createElement("div");
- c.setAttribute("hidden", "");
- c.innerHTML = x.responseText;
- b.insertBefore(c, b.childNodes[0]);
- }
- });
- })();
- </script>
-
- <!-- Plyr core script -->
- <script src="../src/js/plyr.js"></script>
-
- <!-- Shr core script -->
- <script src="https://cdn.shr.one/0.1.9/shr.js"></script>
-
- <!-- Docs script -->
- <script src="dist/docs.js"></script>
- </body>
-</html>
diff --git a/gulpfile.js b/gulpfile.js
index e3bd6f43..ca7c0de5 100644
--- a/gulpfile.js
+++ b/gulpfile.js
@@ -214,7 +214,8 @@ options = {
// If aws is setup
if("cdn" in aws) {
- var cdnpath = new RegExp(aws.cdn.bucket + "\/(\\d+\\.)?(\\d+\\.)?(\\*|\\d+)","gi");
+ var cdnpath = new RegExp(aws.cdn.bucket + "\/(\\d+\\.)?(\\d+\\.)?(\\*|\\d+)","gi"),
+ localpath = new RegExp("(\.\.\/)?dist", "gi");
}
// Publish version to CDN bucket
@@ -243,14 +244,14 @@ gulp.task("docs", function () {
.pipe(replace(cdnpath, aws.cdn.bucket + "/" + version))
.pipe(gulp.dest(root));
- // Replace versioned files in *.html
+ // Replace local file paths with remote paths in docs
+ // e.g. "../dist/plyr.js" to "https://cdn.plyr.io/x.x.x/plyr.js"
gulp.src([paths.docs.root + "*.html"])
- .pipe(replace(cdnpath, aws.cdn.bucket + "/" + version))
- .pipe(gulp.dest(paths.docs.root))
+ .pipe(replace(localpath, "https://" + aws.cdn.bucket + "/" + version))
.pipe(gzip())
.pipe(s3(aws.docs, options.docs));
- // Upload error.html to cdn using docs options
+ // Upload error.html to cdn (as well as docs site)
gulp.src([paths.docs.root + "error.html"])
.pipe(gzip())
.pipe(s3(aws.cdn, options.docs));
diff --git a/readme.md b/readme.md
index ff6b17fc..01397e66 100644
--- a/readme.md
+++ b/readme.md
@@ -541,7 +541,7 @@ Vimeo example
```javascript
player.source({
- type: 'vimeo',
+ type: 'video',
title: 'Example title',
sources: [{
src: '143418951',
diff --git a/src/js/plyr.js b/src/js/plyr.js
index 1f4e70c4..79597b99 100644
--- a/src/js/plyr.js
+++ b/src/js/plyr.js
@@ -533,6 +533,11 @@
// Trigger event
function _triggerEvent(element, event) {
+ // Bail if no element
+ if(!element || !event) {
+ return;
+ }
+
// Create faux event
var fauxEvent = document.createEvent('MouseEvents');
@@ -545,6 +550,11 @@
// Toggle aria-pressed state on a toggle button
function _toggleState(target, state) {
+ // Bail if no target
+ if(!target) {
+ return;
+ }
+
// Get state
state = (typeof state === 'boolean' ? state : !target.getAttribute('aria-pressed'));
@@ -909,14 +919,14 @@
// Setup aria attribute for play and iframe title
function _setTitle(iframe) {
// Find the current text
- var label = plyr.buttons.play.innerText || config.i18n.play;
+ var label = config.i18n.play;
// If there's a media title set, use that for the label
if (typeof(config.title) !== 'undefined' && config.title.length) {
label += ', ' + config.title;
}
- // If there's no play button, bail
+ // If there's a play button, set label
if (plyr.buttons.play) {
plyr.buttons.play.setAttribute('aria-label', label);
}
@@ -2065,6 +2075,24 @@
// IE doesn't support input event, so we fallback to change
var inputEvent = (plyr.browser.name == 'IE' ? 'change' : 'input');
+ // Click play/pause helpers
+ function _onPlay() {
+ _play();
+ setTimeout(function() {
+ if(plyr.buttons.pause) {
+ plyr.buttons.pause.focus();
+ }
+ }, 100);
+ }
+ function _onPause() {
+ _pause();
+ setTimeout(function() {
+ if(plyr.buttons.play) {
+ plyr.buttons.play.focus();
+ }
+ }, 100);
+ }
+
// Detect tab focus
function checkFocus() {
var focused = document.activeElement;
@@ -2095,22 +2123,11 @@
});
}
- // Messages
- /*_on(window, 'message', function(event) {
- _log(event);
- });*/
-
// Play
- _on(plyr.buttons.play, 'click', function() {
- _play();
- setTimeout(function() { plyr.buttons.pause.focus(); }, 100);
- });
+ _on(plyr.buttons.play, 'click', _onPlay);
// Pause
- _on(plyr.buttons.pause, 'click', function() {
- _pause();
- setTimeout(function() { plyr.buttons.play.focus(); }, 100);
- });
+ _on(plyr.buttons.pause, 'click', _onPause);
// Restart
_on(plyr.buttons.restart, 'click', _seek);
@@ -2179,14 +2196,14 @@
if (plyr.type === 'video' && config.click) {
_on(plyr.videoContainer, 'click', function() {
if (plyr.media.paused) {
- _triggerEvent(plyr.buttons.play, 'click');
+ _onPlay();
}
else if (plyr.media.ended) {
_seek();
- _triggerEvent(plyr.buttons.play, 'click');
+ _onPlay();
}
else {
- _triggerEvent(plyr.buttons.pause, 'click');
+ _onPause();
}
});
}
diff --git a/src/less/plyr.less b/src/less/plyr.less
index e7b4ca01..97304845 100644
--- a/src/less/plyr.less
+++ b/src/less/plyr.less
@@ -113,16 +113,6 @@
border-radius: 100%;
transition: background .3s ease, transform .2s ease;
cursor: ew-resize;
-
- &:hover {
- transform: scale(110%);
- }
- &:active {
- height: @volume-thumb-height + 3;
- width: @volume-thumb-width + 3;
- border: 2px solid @control-bg-hover;
- background: #fff !important;
- }
}
.volume-track() {
height: @volume-track-height;
@@ -133,8 +123,9 @@
.seek-thumb() {
background: transparent;
border: 0;
- width: (@control-spacing * 2);
+ width: (@control-spacing * 4);
height: @control-spacing;
+ transform: translateX(-50%);
}
.seek-track() {
background: none;
@@ -544,10 +535,6 @@
-webkit-appearance: none;
margin-top: -((@volume-thumb-height - @volume-track-height) / 2);
.volume-thumb();
-
- &:active {
- margin-top: -(((@volume-thumb-height - @volume-track-height) / 2) + 1);
- }
}
// Mozilla