From 9fbbb474db34ca949b755fbe38684aa034a3e478 Mon Sep 17 00:00:00 2001 From: Sam Potts Date: Thu, 14 Jan 2016 23:50:00 +1100 Subject: [PATCH] Clean up --- changelog.md | 2 +- dist/plyr.css | 2 +- dist/plyr.js | 2 +- docs/dist/docs.css | 2 +- docs/index.html | 6 +- docs/src/less/components/buttons.less | 31 +- docs/src/less/components/examples.less | 2 + docs/src/less/components/icons.less | 4 + docs/src/less/components/type.less | 8 +- docs/src/less/variables.less | 5 + src/js/plyr.js | 458 +++++++++++++------------ src/less/plyr.less | 2 +- 12 files changed, 270 insertions(+), 254 deletions(-) diff --git a/changelog.md b/changelog.md index 1b27cc5d..45de7747 100644 --- a/changelog.md +++ b/changelog.md @@ -1,7 +1,7 @@ # Changelog # v1.5.0 -- *Beta* Vimeo support (please report bugs) (fixes #8) +- Vimeo support (fixes #8) - New options for initialization (you can now pass a selector, HTMLElement or NodeList) (fixes #118) - Switched to BEM methodology (you will need to change CSS and probably HTML) - Decoupled CSS and JS hooks (fixes #129) diff --git a/dist/plyr.css b/dist/plyr.css index 9196495d..d3a1f20b 100644 --- a/dist/plyr.css +++ b/dist/plyr.css @@ -1 +1 @@ -.plyr__captions,.plyr__controls{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;text-align:center}@-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}.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;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: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 button:focus{outline:0}.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 input[type=range].tab-focus:focus{outline:rgba(52,63,74,.8) dotted 1px;outline-offset:3px}.plyr__progress--seek[type=range]:focus,.plyr__volume[type=range]:focus{outline:0}.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;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;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;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 +.plyr__captions,.plyr__controls{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;text-align:center}@-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}.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;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: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 button:focus{outline:0}.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 input[type=range].tab-focus:focus{outline:rgba(52,63,74,.8) dotted 1px;outline-offset:3px}.plyr__progress--seek[type=range]:focus,.plyr__volume[type=range]:focus{outline:0}.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;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;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;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 e6b3a145..23537091 100644 --- a/dist/plyr.js +++ b/dist/plyr.js @@ -1 +1 @@ -!function(e,t){"use strict";"function"==typeof define&&define.amd?define(null,function(){t(e,document)}):"object"==typeof module?module.exports=t(e,document):e.plyr=t(e,document)}(this,function(e,t){"use strict";function n(){var e=['
','
','','','',"0% "+I.i18n.played,"",'',"0% "+I.i18n.buffered,"","
",''];return i(I.controls,"restart")&&e.push('"),i(I.controls,"rewind")&&e.push('"),i(I.controls,"play")&&e.push('",'"),i(I.controls,"fast-forward")&&e.push('"),i(I.controls,"current-time")&&e.push('',''+I.i18n.currentTime+"",'00:00',""),i(I.controls,"duration")&&e.push('',''+I.i18n.duration+"",'00:00',""),e.push("",''),i(I.controls,"mute")&&e.push('"),i(I.controls,"volume")&&e.push('",''),i(I.controls,"captions")&&e.push('"),i(I.controls,"fullscreen")&&e.push('"),e.push("","
"),e.join("")}function r(t,n){I.debug&&e.console&&console[n?"error":"log"](t)}function a(){var e,n,r,a=navigator.userAgent,s=navigator.appName,o=""+parseFloat(navigator.appVersion),i=parseInt(navigator.appVersion,10);return-1!==navigator.appVersion.indexOf("Windows NT")&&-1!==navigator.appVersion.indexOf("rv:11")?(s="IE",o="11;"):-1!==(n=a.indexOf("MSIE"))?(s="IE",o=a.substring(n+5)):-1!==(n=a.indexOf("Chrome"))?(s="Chrome",o=a.substring(n+7)):-1!==(n=a.indexOf("Safari"))?(s="Safari",o=a.substring(n+7),-1!==(n=a.indexOf("Version"))&&(o=a.substring(n+8))):-1!==(n=a.indexOf("Firefox"))?(s="Firefox",o=a.substring(n+8)):(e=a.lastIndexOf(" ")+1)<(n=a.lastIndexOf("/"))&&(s=a.substring(e,n),o=a.substring(n+1),s.toLowerCase()==s.toUpperCase()&&(s=navigator.appName)),-1!==(r=o.indexOf(";"))&&(o=o.substring(0,r)),-1!==(r=o.indexOf(" "))&&(o=o.substring(0,r)),i=parseInt(""+o,10),isNaN(i)&&(o=""+parseFloat(navigator.appVersion),i=parseInt(navigator.appVersion,10)),{name:s,version:i,ios:/(iPad|iPhone|iPod)/g.test(navigator.platform),touch:"ontouchstart"in t.documentElement}}function s(e,t){var n=e.media;if("video"==e.type)switch(t){case"video/webm":return!(!n.canPlayType||!n.canPlayType('video/webm; codecs="vp8, vorbis"').replace(/no/,""));case"video/mp4":return!(!n.canPlayType||!n.canPlayType('video/mp4; codecs="avc1.42E01E, mp4a.40.2"').replace(/no/,""));case"video/ogg":return!(!n.canPlayType||!n.canPlayType('video/ogg; codecs="theora"').replace(/no/,""))}else if("audio"==e.type)switch(t){case"audio/mpeg":return!(!n.canPlayType||!n.canPlayType("audio/mpeg;").replace(/no/,""));case"audio/ogg":return!(!n.canPlayType||!n.canPlayType('audio/ogg; codecs="vorbis"').replace(/no/,""));case"audio/wav":return!(!n.canPlayType||!n.canPlayType('audio/wav; codecs="1"').replace(/no/,""))}return!1}function o(e){if(!t.querySelectorAll('script[src="'+e+'"]').length){var n=t.createElement("script");n.src=e;var r=t.getElementsByTagName("script")[0];r.parentNode.insertBefore(n,r)}}function i(e,t){return Array.prototype.indexOf&&-1!=e.indexOf(t)}function l(e,t,n){return e.replace(new RegExp(t.replace(/([.*+?\^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}function u(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],s=a.parentNode,o=a.nextSibling;r.appendChild(a),o?s.insertBefore(r,o):s.appendChild(r)}}function c(e){for(var t=e.parentNode;e.firstChild;)t.insertBefore(e.firstChild,e);t.removeChild(e)}function p(e){e.parentNode.removeChild(e)}function d(e,t){e.insertBefore(t,e.firstChild)}function f(e,t){for(var n in t)e.setAttribute(n,"boolean"==typeof t[n]&&t[n]?"":t[n])}function m(e,n,r){var a=t.createElement(e);f(a,r),d(n,a)}function y(e){return e.replace(".","")}function b(e,t,n){e&&e.classList[n?"add":"remove"](t)}function v(e,t){return e?e.classList.contains(t):!1}function g(e,t,n){e&&T(e,t,n,!0)}function h(e,t,n){e&&T(e,t,n,!1)}function k(e,t,n,r){g(e,t,function(t){n&&n.apply(e,[t]),r.apply(e,[t])})}function T(e,t,n,r){var a=t.split(" ");if(e instanceof NodeList)for(var s=0;sr;r++){if(e.prefix=n[r],"undefined"!=typeof t[e.prefix+"CancelFullScreen"]){e.supportsFullScreen=!0;break}if("undefined"!=typeof t.msExitFullscreen&&t.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=t.body),this.prefix){case"":return t.fullscreenElement==e;case"moz":return t.mozFullScreenElement==e;default:return t[this.prefix+"FullscreenElement"]==e}},e.requestFullScreen=function(e){return"undefined"==typeof e&&(e=t.body),""===this.prefix?e.requestFullScreen():e[this.prefix+("ms"==this.prefix?"RequestFullscreen":"RequestFullScreen")]()},e.cancelFullScreen=function(){return""===this.prefix?t.cancelFullScreen():t[this.prefix+("ms"==this.prefix?"ExitFullscreen":"CancelFullScreen")]()},e.element=function(){return""===this.prefix?t.fullscreenElement:t[this.prefix+"FullscreenElement"]}),e}function S(){var t={supported:function(){if(!("localStorage"in e))return!1;try{e.localStorage.setItem("___test","OK");var t=e.localStorage.getItem("___test");return e.localStorage.removeItem("___test"),"OK"===t}catch(n){return!1}return!1}()};return t}function E(F){function E(e){if(!_e.usingTextTracks&&"video"===_e.type&&_e.supported.full&&(_e.subcount=0,e="number"==typeof e?e:_e.media.currentTime,_e.captions[_e.subcount])){for(;O(_e.captions[_e.subcount][0])_e.captions.length-1){_e.subcount=_e.captions.length-1;break}if(_e.media.currentTime.toFixed(1)>=L(_e.captions[_e.subcount][0])&&_e.media.currentTime.toFixed(1)<=O(_e.captions[_e.subcount][0])){_e.currentCaption=_e.captions[_e.subcount][1];var t=_e.currentCaption.trim();_e.captionsContainer.innerHTML!=t&&(_e.captionsContainer.innerHTML="",_e.captionsContainer.innerHTML=t)}else _e.captionsContainer.innerHTML=""}}function M(){_e.buttons.captions&&(b(_e.container,I.classes.captions.enabled,!0),I.captions.defaultActive&&(b(_e.container,I.classes.captions.active,!0),x(_e.buttons.captions,!0)))}function L(e){var t=[];return t=e.split(" --> "),V(t[0])}function O(e){var t=[];return t=e.split(" --> "),V(t[1])}function V(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 q(e){return _e.container.querySelectorAll(e)}function H(e){return q(e)[0]}function R(){try{return e.self!==e.top}catch(t){return!0}}function D(){function e(e){9===e.which&&_e.isFullscreen&&(e.target!==r||e.shiftKey?e.target===n&&e.shiftKey&&(e.preventDefault(),r.focus()):(e.preventDefault(),n.focus()))}var t=q("input:not([disabled]), button:not([disabled])"),n=t[0],r=t[t.length-1];g(_e.container,"keydown",e)}function j(e,t){if("string"==typeof t)m(e,_e.media,{src:t});else if(t.constructor===Array)for(var n=t.length-1;n>=0;n--)m(e,_e.media,t[n])}function B(){var e=I.html;r("Injecting custom controls."),e||(e=n()),e=l(e,"{seektime}",I.seekTime),e=l(e,"{id}",Math.floor(1e4*Math.random()));var a;if(null!==I.selectors.controls.container&&(a=I.selectors.controls.container,"string"==typeof selector&&(a=t.querySelector(a))),a instanceof HTMLElement||(a=_e.container),a.insertAdjacentHTML("beforeend",e),I.tooltips)for(var s=q(I.selectors.labels),o=s.length-1;o>=0;o--){var i=s[o];b(i,I.classes.hidden,!1),b(i,I.classes.tooltip,!0)}}function Y(){try{return _e.controls=H(I.selectors.controls.wrapper),_e.buttons={},_e.buttons.seek=H(I.selectors.buttons.seek),_e.buttons.play=H(I.selectors.buttons.play),_e.buttons.pause=H(I.selectors.buttons.pause),_e.buttons.restart=H(I.selectors.buttons.restart),_e.buttons.rewind=H(I.selectors.buttons.rewind),_e.buttons.forward=H(I.selectors.buttons.forward),_e.buttons.fullscreen=H(I.selectors.buttons.fullscreen),_e.buttons.volume=H(I.selectors.buttons.volume),_e.buttons.mute=H(I.selectors.buttons.mute),_e.buttons.captions=H(I.selectors.buttons.captions),_e.checkboxes=q('[type="checkbox"]'),_e.progress={},_e.progress.container=H(I.selectors.progress.container),_e.progress.buffer={},_e.progress.buffer.bar=H(I.selectors.progress.buffer),_e.progress.buffer.text=_e.progress.buffer.bar&&_e.progress.buffer.bar.getElementsByTagName("span")[0],_e.progress.played={},_e.progress.played.bar=H(I.selectors.progress.played),_e.progress.played.text=_e.progress.played.bar&&_e.progress.played.bar.getElementsByTagName("span")[0],_e.volume=H(I.selectors.buttons.volume),_e.duration=H(I.selectors.duration),_e.currentTime=H(I.selectors.currentTime),_e.seekTime=q(I.selectors.seekTime),!0}catch(e){return r("It looks like there's a problem with your controls html. Bailing.",!0),_e.media.setAttribute("controls",""),!1}}function W(e){var t=I.i18n.play;"undefined"!=typeof I.title&&I.title.length&&(t+=", "+I.title),_e.buttons.play&&_e.buttons.play.setAttribute("aria-label",t),e instanceof HTMLElement&&e.setAttribute("title",I.i18n.frameTitle.replace("{title}",I.title))}function U(){if(!_e.media)return r("No audio or video element found!",!0),!1;if(_e.supported.full&&(_e.media.removeAttribute("controls"),b(_e.container,I.classes.type.replace("{0}",_e.type),!0),b(_e.container,I.classes.stopped,I.autoplay),b(_e.container,I.classes.isIos,_e.browser.ios),b(_e.container,I.classes.isTouch,_e.browser.touch),"video"===_e.type)){var e=t.createElement("div");e.setAttribute("class",I.classes.videoWrapper),u(_e.media,e),_e.videoContainer=e}i(I.types.embed,_e.type)?($(),_e.embedId=null):I.autoplay&&Q()}function $(){for(var n=t.createElement("div"),r=_e.embedId,a=_e.type+"-"+Math.floor(1e4*Math.random()),s=q('[id^="'+_e.type+'-"]'),i=s.length-1;i>=0;i--)p(s[i]);if(b(_e.media,I.classes.videoWrapper,!0),b(_e.media,I.classes.embedWrapper,!0),"youtube"===_e.type)_e.media.appendChild(n),n.setAttribute("id",a),"object"==typeof YT?K(r,n):(o(I.urls.youtube.api),e.onYouTubeReadyCallbacks=e.onYouTubeReadyCallbacks||[],e.onYouTubeReadyCallbacks.push(function(){K(r,n)}),e.onYouTubeIframeAPIReady=function(){e.onYouTubeReadyCallbacks.forEach(function(e){e()})});else if("vimeo"===_e.type){var l=t.createElement("iframe");l.loaded=!1,g(l,"load",function(){l.loaded=!0}),f(l,{src:"https://player.vimeo.com/video/"+r+"?player_id="+a+"&api=1&badge=0&byline=0&portrait=0&title=0",id:a,webkitallowfullscreen:"",mozallowfullscreen:"",allowfullscreen:"",frameborder:0}),n.appendChild(l),_e.media.appendChild(n),"$f"in e||o(I.urls.vimeo.api);var u=e.setInterval(function(){"$f"in e&&l.loaded&&(e.clearInterval(u),X.call(l))},50)}}function z(){_e.supported.full&&(_e.container.querySelectorAll(I.selectors.controls.wrapper).length||we()),W(H("iframe")),le(),ue()}function K(t,n){"timer"in _e||(_e.timer={}),_e.embed=new YT.Player(n.id,{videoId:t,playerVars:{autoplay:I.autoplay?1:0,controls:_e.supported.full?0:1,rel:0,showinfo:0,iv_load_policy:3,cc_load_policy:I.captions.defaultActive?1:0,cc_lang_pref:"en",wmode:"transparent",modestbranding:1,disablekb:1,origin:"*"},events:{onReady:function(t){var n=t.target;_e.media.play=function(){n.playVideo(),_e.media.paused=!1},_e.media.pause=function(){n.pauseVideo(),_e.media.paused=!0},_e.media.stop=function(){n.stopVideo(),_e.media.paused=!0},_e.media.duration=n.getDuration(),_e.media.paused=!I.autoplay,_e.media.currentTime=n.getCurrentTime(),_e.media.muted=n.isMuted(),w(_e.media,"timeupdate"),e.clearInterval(_e.timer.buffering),_e.timer.buffering=e.setInterval(function(){_e.media.buffered=n.getVideoLoadedFraction(),w(_e.media,"progress"),1===_e.media.buffered&&e.clearInterval(_e.timer.buffering)},200),z(),I.displayDuration&&me()},onStateChange:function(t){var n=t.target;switch(e.clearInterval(_e.timer.playing),t.data){case 0:_e.media.paused=!0,w(_e.media,"ended");break;case 1:_e.media.paused=!1,w(_e.media,"play"),_e.timer.playing=e.setInterval(function(){_e.media.currentTime=n.getCurrentTime(),w(_e.media,"timeupdate")},200);break;case 2:_e.media.paused=!0,w(_e.media,"pause")}}}})}function X(){_e.embed=$f(this),_e.embed.addEvent("ready",function(){_e.media.play=function(){_e.embed.api("play"),_e.media.paused=!1},_e.media.pause=function(){_e.embed.api("pause"),_e.media.paused=!0},_e.media.stop=function(){_e.embed.api("stop"),_e.media.paused=!0},_e.media.paused=!I.autoplay,_e.media.currentTime=0,z(),_e.embed.api("getCurrentTime",function(e){_e.media.currentTime=e,w(_e.media,"timeupdate")}),_e.embed.api("getDuration",function(e){_e.media.duration=e,_e.supported.full&&I.displayDuration&&me()}),_e.embed.addEvent("play",function(){_e.media.paused=!1,w(_e.media,"play")}),_e.embed.addEvent("pause",function(){_e.media.paused=!0,w(_e.media,"pause")}),_e.embed.addEvent("playProgress",function(e){_e.media.currentTime=e.seconds,w(_e.media,"timeupdate")}),_e.embed.addEvent("loadProgress",function(e){_e.media.buffered=e.percent,w(_e.media,"progress")}),_e.embed.addEvent("finish",function(){_e.media.paused=!0,w(_e.media,"ended")})})}function J(){if("video"===_e.type){H(I.selectors.captions)||_e.videoContainer.insertAdjacentHTML("afterbegin",'
'),_e.captionsContainer=H(I.selectors.captions).querySelector("span"),_e.usingTextTracks=!1,_e.media.textTracks&&(_e.usingTextTracks=!0);for(var e,t="",n=_e.media.childNodes,a=0;a=10||"Firefox"===_e.browser.name&&_e.browser.version>=31||"Chrome"===_e.browser.name&&_e.browser.version>=43||"Safari"===_e.browser.name&&_e.browser.version>=7)&&(r("Detected unsupported browser for HTML5 captions. Using fallback."),_e.usingTextTracks=!1),_e.usingTextTracks){r("TextTracks supported.");for(var i=0;i=7){r("Safari 7+ detected; removing track from DOM."),s=_e.media.getElementsByTagName("track");for(var c=0;ct?t=0:t>_e.media.duration&&(t=_e.media.duration);try{_e.media.currentTime=t.toFixed(1)}catch(a){}"embed"in _e&&("youtube"===_e.type&&_e.embed.seekTo(t),"vimeo"===_e.type&&_e.embed.api("seekTo",t),w(_e.media,"timeupdate"),n&&Z()),r("Seeking to "+_e.media.currentTime+" seconds"),E(t)}function ae(){b(_e.container,I.classes.playing,!_e.media.paused),b(_e.container,I.classes.stopped,_e.media.paused)}function se(n){function r(){b(_e.container,I.classes.hover,!0),e.clearTimeout(o),i||(o=e.setTimeout(function(){b(_e.container,I.classes.hover,!1)},2e3))}function a(e){i="mouseenter"===e.type}var s=A.supportsFullScreen;n&&n.type===A.fullScreenEventName?_e.isFullscreen=A.isFullScreen(_e.container):s?(A.isFullScreen(_e.container)?A.cancelFullScreen():A.requestFullScreen(_e.container),_e.isFullscreen=A.isFullScreen(_e.container)):(_e.isFullscreen=!_e.isFullscreen,_e.isFullscreen?(g(t,"keyup",oe),t.body.style.overflow="hidden"):(h(t,"keyup",oe),t.body.style.overflow="")),b(_e.container,I.classes.fullscreen.active,_e.isFullscreen),_e.isFullscreen?_e.container.setAttribute("tabindex","-1"):_e.container.removeAttribute("tabindex"),D(_e.isFullscreen),x(_e.buttons.fullscreen,_e.isFullscreen);var o,i=!1;I.fullscreen.hideControls&&(b(_e.controls,I.classes.hover,!1),T(_e.controls,"mouseenter mouseleave",a,_e.isFullscreen),T(_e.container,"mousemove",r,_e.isFullscreen))}function oe(e){27===(e.which||e.charCode||e.keyCode)&&_e.isFullscreen&&se()}function ie(e){"boolean"!=typeof e&&(e=!_e.media.muted),x(_e.buttons.mute,e),_e.media.muted=e,"youtube"===_e.type&&(_e.embed[_e.media.muted?"mute":"unMute"](),w(_e.media,"volumechange")),"vimeo"===_e.type&&(_e.media.muted?_e.embed.api("setVolume",0):_e.embed.api("setVolume",parseFloat(I.volume/10)),w(_e.media,"volumechange"))}function le(t){"undefined"==typeof t&&(t=I.storage.enabled&&S().supported?e.localStorage[I.storage.key]||I.volume:I.volume),t>10&&(t=10),0>t&&(t=0),_e.media.volume=parseFloat(t/10),I.volume=t,"youtube"===_e.type&&_e.embed.setVolume(100*_e.media.volume),"vimeo"===_e.type&&_e.embed.api("setVolume",_e.media.volume),"embed"in _e&&w(_e.media,"volumechange"),_e.media.muted&&t>0&&ie()}function ue(){var t=_e.media.muted?0:10*_e.media.volume;_e.supported.full&&_e.volume&&(_e.volume.value=t),I.storage.enabled&&S().supported&&e.localStorage.setItem(I.storage.key,t),b(_e.container,I.classes.muted,0===t),_e.supported.full&&_e.buttons.mute&&x(_e.buttons.mute,0===t)}function ce(e){_e.supported.full&&_e.buttons.captions&&("boolean"!=typeof e&&(e=-1===_e.container.className.indexOf(I.classes.captions.active)),_e.captionsEnabled=e,x(_e.buttons.captions,_e.captionsEnabled),b(_e.container,I.classes.captions.active,_e.captionsEnabled))}function pe(e){var t="waiting"===e.type;clearTimeout(_e.loadingTimer),_e.loadingTimer=setTimeout(function(){b(_e.container,I.classes.loading,t)},t?250:0)}function de(e){var t=_e.progress.played.bar,n=_e.progress.played.text,r=0;if(e)switch(e.type){case"timeupdate":case"seeking":r=_(_e.media.currentTime,_e.media.duration),"timeupdate"==e.type&&_e.buttons.seek&&(_e.buttons.seek.value=r);break;case"change":case"input":r=e.target.value;break;case"playing":case"progress":t=_e.progress.buffer.bar,n=_e.progress.buffer.text,r=function(){var e=_e.media.buffered;return e&&e.length?_(e.end(0),_e.media.duration):"number"==typeof e?100*e:0}()}t&&(t.value=r),n&&(n.innerHTML=r)}function fe(e,t){if(t){isNaN(e)&&(e=0),_e.secs=parseInt(e%60),_e.mins=parseInt(e/60%60),_e.hours=parseInt(e/60/60%60);var n=parseInt(_e.media.duration/60/60%60)>0;_e.secs=("0"+_e.secs).slice(-2),_e.mins=("0"+_e.mins).slice(-2),t.innerHTML=(n?_e.hours+":":"")+_e.mins+":"+_e.secs}}function me(){var e=_e.media.duration||0;!_e.duration&&I.displayDuration&&_e.media.paused&&fe(e,_e.currentTime),_e.duration&&fe(e,_e.duration)}function ye(e){fe(_e.media.currentTime,_e.currentTime),de(e)}function be(e){if("undefined"!=typeof e)return void ve(e);var t;switch(_e.type){case"youtube":t=_e.embed.getVideoUrl();break;case"vimeo":_e.embed.api("getVideoUrl",function(e){t=e});break;default:t=_e.media.currentSrc}return t||""}function ve(n){if(!("undefined"!=typeof n&&"sources"in n&&n.sources.length))return void r("Invalid source format",!0);if(Z(),"youtube"===_e.type?(_e.embed.destroy(),e.clearInterval(_e.timer.buffering),e.clearInterval(_e.timer.playing)):"video"===_e.type&&p(_e.videoContainer),p(_e.media),"type"in n&&(_e.type=n.type,"video"===_e.type)){var a=n.sources[0];"type"in a&&i(I.types.embed,a.type)&&(_e.type=a.type)}switch(_e.type){case"video":_e.media=t.createElement("video");break;case"audio":_e.media=t.createElement("audio");break;case"youtube":case"vimeo":_e.media=t.createElement("div"),_e.embedId=n.sources[0].src}d(_e.container,_e.media),i(I.types.html5,_e.type)&&(I.crossorigin&&_e.media.setAttribute("crossorigin",""),I.autoplay&&_e.media.setAttribute("autoplay",""),"poster"in n&&_e.media.setAttribute("poster",n.poster),I.loop&&_e.media.setAttribute("loop","")),_e.container.className=_e.originalClassName,b(_e.container,I.classes.fullscreen.active,_e.isFullscreen),b(_e.container,I.classes.captions.active,_e.captionsEnabled),I.autoplay=n.autoplay||I.autoplay,i(I.types.html5,_e.type)&&j("source",n.sources),U(),xe(),i(I.types.html5,_e.type)&&(le(),ue(),_e.supported.full&&(ye(),ae()),"tracks"in n&&(j("track",n.tracks),J()),_e.media.load(),I.autoplay&&Q()),"title"in n&&(I.title=n.title,W())}function ge(e){"video"===_e.type&&_e.media.setAttribute("poster",e)}function he(){function n(e){e?Q():Z();var t=_e.buttons[e?"play":"pause"],n=_e.buttons[e?"pause":"play"];if(n){var r=v(t,I.classes.tabFocus);setTimeout(function(){n.focus(),r&&(b(t,I.classes.tabFocus,!1),b(n,I.classes.tabFocus,!0))},100)}}function r(){var e=t.activeElement;e&&e!=t.body?t.querySelector&&(e=t.querySelector(":focus")):e=null;for(var n in _e.buttons){var r=_e.buttons[n];b(r,I.classes.tabFocus,r===e)}}var a="IE"==_e.browser.name?"change":"input";g(e,"keyup",function(e){var t=e.keyCode?e.keyCode:e.which;9==t&&r()}),g(t.body,"click",function(){b(H("."+I.classes.tabFocus),I.classes.tabFocus,!1)});for(var s in _e.buttons){var o=_e.buttons[s];g(o,"blur",function(){b(o,"tab-focus",!1)})}k(_e.buttons.play,"click",I.handlers.play,function(){n(!0)}),k(_e.buttons.pause,"click",I.handlers.pause,function(){n()}),k(_e.buttons.restart,"click",I.handlers.restart,re),k(_e.buttons.rewind,"click",I.handlers.rewind,te),k(_e.buttons.forward,"click",I.handlers.forward,ne),k(_e.buttons.seek,a,I.handlers.seek,re),k(_e.volume,a,I.handlers.volume,function(){le(_e.volume.value)}),k(_e.buttons.mute,"click",I.handlers.mute,ie),k(_e.buttons.fullscreen,"click",I.handlers.fullscreen,se),A.supportsFullScreen&&g(t,A.fullScreenEventName,se),g(_e.media,"timeupdate seeking",ye),g(_e.media,"timeupdate",E),g(_e.media,"loadedmetadata",me),g(_e.buttons.captions,"click",ce),g(_e.media,"ended",function(){"video"===_e.type&&(_e.captionsContainer.innerHTML=""),ae()}),g(_e.media,"progress playing",de),g(_e.media,"volumechange",ue),g(_e.media,"play pause",ae),g(_e.media,"waiting canplay seeked",pe),"video"===_e.type&&I.click&&g(_e.videoContainer,"click",function(){_e.media.paused?Q():_e.media.ended?(re(),Q()):Z()})}function ke(){if(!_e.init)return null;if(_e.container.setAttribute("class",y(I.selectors.container)),_e.init=!1,p(H(I.selectors.controls.wrapper)),"youtube"===_e.type)return void _e.embed.destroy();"video"===_e.type&&(p(H(I.selectors.captions)),c(_e.videoContainer)),_e.media.setAttribute("controls","");var e=_e.media.cloneNode(!0);_e.media.parentNode.replaceChild(e,_e.media)}function Te(){if(_e.init)return null;A=C(),_e.browser=a(),_e.media=_e.container.querySelectorAll("audio, video, div")[0],b(_e.container,P.selectors.container.replace(".",""),!0),_e.originalClassName=_e.container.className;var e=_e.media.tagName.toLowerCase();if("div"===e?(_e.type=_e.media.getAttribute("data-type"),_e.embedId=_e.media.getAttribute("data-video-id"),_e.media.removeAttribute("data-type"),_e.media.removeAttribute("data-video-id")):(_e.type=e,I.crossorigin=null!==_e.media.getAttribute("crossorigin"),I.autoplay=I.autoplay||null!==_e.media.getAttribute("autoplay"),I.loop=I.loop||null!==_e.media.getAttribute("loop")),_e.supported=N.supported(_e.type),!_e.supported.basic)return!1;if(r(_e.browser.name+" "+_e.browser.version),U(),"video"==_e.type||"audio"==_e.type){if(!_e.supported.full)return void(_e.init=!0);we(),I.displayDuration&&me(),W()}_e.init=!0}function we(){return B(),Y()?(J(),xe(),le(),void ue()):!1}function xe(){G(),he()}var _e=this;return _e.container=F,Te(),_e.init?{media:_e.media,play:Q,pause:Z,restart:re,rewind:te,forward:ne,seek:re,source:be,poster:ge,setVolume:le,togglePlay:ee,toggleMute:ie,toggleCaptions:ce,toggleFullscreen:se,isFullscreen:function(){return _e.isFullscreen||!1},support:function(e){return s(_e,e)},destroy:ke,restore:Te}:{}}var A,I,N={},P={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"},tabFocus:"tab-focus"},handlers:{seek:null,play:null,pause:null,restart:null,rewind:null,forward:null,mute:null,volume:null,captions:null,fullscreen:null},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 N.supported=function(e){var n,r,s=a(),o="IE"===s.name&&s.version<=9,i=/iPhone|iPod/i.test(navigator.userAgent),l=!!t.createElement("audio").canPlayType,u=!!t.createElement("video").canPlayType;switch(e){case"video":n=u,r=n&&!o&&!i;break;case"audio":n=l,r=n&&!o;break;case"vimeo":case"youtube":n=!0,r=!o&&!i;break;default:n=l&&u,r=n&&!o}return{basic:n,full:r}},N.setup=function(e,n){var r=[];if("string"==typeof e?e=t.querySelectorAll(e):e instanceof HTMLElement?e=[e]:e instanceof NodeList||"string"==typeof e||("undefined"==typeof n&&"object"==typeof e&&(n=e),e=t.querySelectorAll(P.selectors.container)),I=F(P,n),!I.enabled||!N.supported().basic||!e.length)return!1;for(var a=e.length-1;a>=0;a--){var s=e[a];if("undefined"==typeof s.plyr){var o=new E(s);s.plyr=Object.keys(o).length?o:!1,"function"==typeof I.onSetup&&I.onSetup.apply(s.plyr)}r.push(s.plyr)}return r},N}); \ No newline at end of file +!function(e,t){"use strict";"function"==typeof define&&define.amd?define(null,function(){t(e,document)}):"object"==typeof module?module.exports=t(e,document):e.plyr=t(e,document)}(this,function(e,t){"use strict";function n(){var e=['
','
','','','',"0% "+I.i18n.played,"",'',"0% "+I.i18n.buffered,"","
",''];return i(I.controls,"restart")&&e.push('"),i(I.controls,"rewind")&&e.push('"),i(I.controls,"play")&&e.push('",'"),i(I.controls,"fast-forward")&&e.push('"),i(I.controls,"current-time")&&e.push('',''+I.i18n.currentTime+"",'00:00',""),i(I.controls,"duration")&&e.push('',''+I.i18n.duration+"",'00:00',""),e.push("",''),i(I.controls,"mute")&&e.push('"),i(I.controls,"volume")&&e.push('",''),i(I.controls,"captions")&&e.push('"),i(I.controls,"fullscreen")&&e.push('"),e.push("","
"),e.join("")}function r(t,n){I.debug&&e.console&&console[n?"error":"log"](t)}function a(){var e,n,r,a=navigator.userAgent,s=navigator.appName,o=""+parseFloat(navigator.appVersion),i=parseInt(navigator.appVersion,10);return-1!==navigator.appVersion.indexOf("Windows NT")&&-1!==navigator.appVersion.indexOf("rv:11")?(s="IE",o="11;"):-1!==(n=a.indexOf("MSIE"))?(s="IE",o=a.substring(n+5)):-1!==(n=a.indexOf("Chrome"))?(s="Chrome",o=a.substring(n+7)):-1!==(n=a.indexOf("Safari"))?(s="Safari",o=a.substring(n+7),-1!==(n=a.indexOf("Version"))&&(o=a.substring(n+8))):-1!==(n=a.indexOf("Firefox"))?(s="Firefox",o=a.substring(n+8)):(e=a.lastIndexOf(" ")+1)<(n=a.lastIndexOf("/"))&&(s=a.substring(e,n),o=a.substring(n+1),s.toLowerCase()==s.toUpperCase()&&(s=navigator.appName)),-1!==(r=o.indexOf(";"))&&(o=o.substring(0,r)),-1!==(r=o.indexOf(" "))&&(o=o.substring(0,r)),i=parseInt(""+o,10),isNaN(i)&&(o=""+parseFloat(navigator.appVersion),i=parseInt(navigator.appVersion,10)),{name:s,version:i,ios:/(iPad|iPhone|iPod)/g.test(navigator.platform),touch:"ontouchstart"in t.documentElement}}function s(e,t){var n=e.media;if("video"==e.type)switch(t){case"video/webm":return!(!n.canPlayType||!n.canPlayType('video/webm; codecs="vp8, vorbis"').replace(/no/,""));case"video/mp4":return!(!n.canPlayType||!n.canPlayType('video/mp4; codecs="avc1.42E01E, mp4a.40.2"').replace(/no/,""));case"video/ogg":return!(!n.canPlayType||!n.canPlayType('video/ogg; codecs="theora"').replace(/no/,""))}else if("audio"==e.type)switch(t){case"audio/mpeg":return!(!n.canPlayType||!n.canPlayType("audio/mpeg;").replace(/no/,""));case"audio/ogg":return!(!n.canPlayType||!n.canPlayType('audio/ogg; codecs="vorbis"').replace(/no/,""));case"audio/wav":return!(!n.canPlayType||!n.canPlayType('audio/wav; codecs="1"').replace(/no/,""))}return!1}function o(e){if(!t.querySelectorAll('script[src="'+e+'"]').length){var n=t.createElement("script");n.src=e;var r=t.getElementsByTagName("script")[0];r.parentNode.insertBefore(n,r)}}function i(e,t){return Array.prototype.indexOf&&-1!=e.indexOf(t)}function l(e,t,n){return e.replace(new RegExp(t.replace(/([.*+?\^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}function u(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],s=a.parentNode,o=a.nextSibling;r.appendChild(a),o?s.insertBefore(r,o):s.appendChild(r)}}function c(e){for(var t=e.parentNode;e.firstChild;)t.insertBefore(e.firstChild,e);t.removeChild(e)}function p(e){e.parentNode.removeChild(e)}function d(e,t){e.insertBefore(t,e.firstChild)}function f(e,t){for(var n in t)e.setAttribute(n,"boolean"==typeof t[n]&&t[n]?"":t[n])}function m(e,n,r){var a=t.createElement(e);f(a,r),d(n,a)}function y(e){return e.replace(".","")}function b(e,t,n){e&&e.classList[n?"add":"remove"](t)}function v(e,t){return e?e.classList.contains(t):!1}function g(e,t,n){e&&T(e,t,n,!0)}function h(e,t,n){e&&T(e,t,n,!1)}function k(e,t,n,r){g(e,t,function(t){n&&n.apply(e,[t]),r.apply(e,[t])})}function T(e,t,n,r){var a=t.split(" ");if(e instanceof NodeList)for(var s=0;sr;r++){if(e.prefix=n[r],"undefined"!=typeof t[e.prefix+"CancelFullScreen"]){e.supportsFullScreen=!0;break}if("undefined"!=typeof t.msExitFullscreen&&t.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=t.body),this.prefix){case"":return t.fullscreenElement==e;case"moz":return t.mozFullScreenElement==e;default:return t[this.prefix+"FullscreenElement"]==e}},e.requestFullScreen=function(e){return"undefined"==typeof e&&(e=t.body),""===this.prefix?e.requestFullScreen():e[this.prefix+("ms"==this.prefix?"RequestFullscreen":"RequestFullScreen")]()},e.cancelFullScreen=function(){return""===this.prefix?t.cancelFullScreen():t[this.prefix+("ms"==this.prefix?"ExitFullscreen":"CancelFullScreen")]()},e.element=function(){return""===this.prefix?t.fullscreenElement:t[this.prefix+"FullscreenElement"]}),e}function S(){var t={supported:function(){if(!("localStorage"in e))return!1;try{e.localStorage.setItem("___test","OK");var t=e.localStorage.getItem("___test");return e.localStorage.removeItem("___test"),"OK"===t}catch(n){return!1}return!1}()};return t}function E(F){function E(e){if(!_e.usingTextTracks&&"video"===_e.type&&_e.supported.full&&(_e.subcount=0,e="number"==typeof e?e:_e.media.currentTime,_e.captions[_e.subcount])){for(;O(_e.captions[_e.subcount][0])_e.captions.length-1){_e.subcount=_e.captions.length-1;break}if(_e.media.currentTime.toFixed(1)>=L(_e.captions[_e.subcount][0])&&_e.media.currentTime.toFixed(1)<=O(_e.captions[_e.subcount][0])){_e.currentCaption=_e.captions[_e.subcount][1];var t=_e.currentCaption.trim();_e.captionsContainer.innerHTML!=t&&(_e.captionsContainer.innerHTML="",_e.captionsContainer.innerHTML=t)}else _e.captionsContainer.innerHTML=""}}function M(){_e.buttons.captions&&(b(_e.container,I.classes.captions.enabled,!0),I.captions.defaultActive&&(b(_e.container,I.classes.captions.active,!0),x(_e.buttons.captions,!0)))}function L(e){var t=[];return t=e.split(" --> "),V(t[0])}function O(e){var t=[];return t=e.split(" --> "),V(t[1])}function V(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 q(e){return _e.container.querySelectorAll(e)}function H(e){return q(e)[0]}function R(){try{return e.self!==e.top}catch(t){return!0}}function j(){function e(e){9===e.which&&_e.isFullscreen&&(e.target!==r||e.shiftKey?e.target===n&&e.shiftKey&&(e.preventDefault(),r.focus()):(e.preventDefault(),n.focus()))}var t=q("input:not([disabled]), button:not([disabled])"),n=t[0],r=t[t.length-1];g(_e.container,"keydown",e)}function B(e,t){if("string"==typeof t)m(e,_e.media,{src:t});else if(t.constructor===Array)for(var n=t.length-1;n>=0;n--)m(e,_e.media,t[n])}function D(){var e=I.html;r("Injecting custom controls."),e||(e=n()),e=l(e,"{seektime}",I.seekTime),e=l(e,"{id}",Math.floor(1e4*Math.random()));var a;if(null!==I.selectors.controls.container&&(a=I.selectors.controls.container,"string"==typeof selector&&(a=t.querySelector(a))),a instanceof HTMLElement||(a=_e.container),a.insertAdjacentHTML("beforeend",e),I.tooltips)for(var s=q(I.selectors.labels),o=s.length-1;o>=0;o--){var i=s[o];b(i,I.classes.hidden,!1),b(i,I.classes.tooltip,!0)}}function Y(){try{return _e.controls=H(I.selectors.controls.wrapper),_e.buttons={},_e.buttons.seek=H(I.selectors.buttons.seek),_e.buttons.play=H(I.selectors.buttons.play),_e.buttons.pause=H(I.selectors.buttons.pause),_e.buttons.restart=H(I.selectors.buttons.restart),_e.buttons.rewind=H(I.selectors.buttons.rewind),_e.buttons.forward=H(I.selectors.buttons.forward),_e.buttons.fullscreen=H(I.selectors.buttons.fullscreen),_e.buttons.volume=H(I.selectors.buttons.volume),_e.buttons.mute=H(I.selectors.buttons.mute),_e.buttons.captions=H(I.selectors.buttons.captions),_e.checkboxes=q('[type="checkbox"]'),_e.progress={},_e.progress.container=H(I.selectors.progress.container),_e.progress.buffer={},_e.progress.buffer.bar=H(I.selectors.progress.buffer),_e.progress.buffer.text=_e.progress.buffer.bar&&_e.progress.buffer.bar.getElementsByTagName("span")[0],_e.progress.played={},_e.progress.played.bar=H(I.selectors.progress.played),_e.progress.played.text=_e.progress.played.bar&&_e.progress.played.bar.getElementsByTagName("span")[0],_e.volume=H(I.selectors.buttons.volume),_e.duration=H(I.selectors.duration),_e.currentTime=H(I.selectors.currentTime),_e.seekTime=q(I.selectors.seekTime),!0}catch(e){return r("It looks like there's a problem with your controls html. Bailing.",!0),_e.media.setAttribute("controls",""),!1}}function W(){b(_e.container,P.selectors.container.replace(".",""),_e.supported.full)}function U(e){var t=I.i18n.play;"undefined"!=typeof I.title&&I.title.length&&(t+=", "+I.title),_e.buttons.play&&_e.buttons.play.setAttribute("aria-label",t),e instanceof HTMLElement&&e.setAttribute("title",I.i18n.frameTitle.replace("{title}",I.title))}function $(){if(!_e.media)return r("No audio or video element found!",!0),!1;if(_e.supported.full&&(_e.media.removeAttribute("controls"),b(_e.container,I.classes.type.replace("{0}",_e.type),!0),b(_e.container,I.classes.stopped,I.autoplay),b(_e.container,I.classes.isIos,_e.browser.ios),b(_e.container,I.classes.isTouch,_e.browser.touch),"video"===_e.type)){var e=t.createElement("div");e.setAttribute("class",I.classes.videoWrapper),u(_e.media,e),_e.videoContainer=e}i(I.types.embed,_e.type)?(z(),_e.embedId=null):I.autoplay&&Z()}function z(){for(var n=t.createElement("div"),r=_e.embedId,a=_e.type+"-"+Math.floor(1e4*Math.random()),s=q('[id^="'+_e.type+'-"]'),i=s.length-1;i>=0;i--)p(s[i]);if(b(_e.media,I.classes.videoWrapper,!0),b(_e.media,I.classes.embedWrapper,!0),"youtube"===_e.type)_e.media.appendChild(n),n.setAttribute("id",a),"object"==typeof YT?X(r,n):(o(I.urls.youtube.api),e.onYouTubeReadyCallbacks=e.onYouTubeReadyCallbacks||[],e.onYouTubeReadyCallbacks.push(function(){X(r,n)}),e.onYouTubeIframeAPIReady=function(){e.onYouTubeReadyCallbacks.forEach(function(e){e()})});else if("vimeo"===_e.type){var l=t.createElement("iframe");l.loaded=!1,g(l,"load",function(){l.loaded=!0}),f(l,{src:"https://player.vimeo.com/video/"+r+"?player_id="+a+"&api=1&badge=0&byline=0&portrait=0&title=0",id:a,webkitallowfullscreen:"",mozallowfullscreen:"",allowfullscreen:"",frameborder:0}),n.appendChild(l),_e.media.appendChild(n),"$f"in e||o(I.urls.vimeo.api);var u=e.setInterval(function(){"$f"in e&&l.loaded&&(e.clearInterval(u),J.call(l))},50)}}function K(){xe(),U(H("iframe"))}function X(t,n){"timer"in _e||(_e.timer={}),_e.embed=new YT.Player(n.id,{videoId:t,playerVars:{autoplay:0,controls:_e.supported.full?0:1,rel:0,showinfo:0,iv_load_policy:3,cc_load_policy:I.captions.defaultActive?1:0,cc_lang_pref:"en",wmode:"transparent",modestbranding:1,disablekb:1,origin:"*"},events:{onReady:function(t){var n=t.target;_e.media.play=function(){n.playVideo(),_e.media.paused=!1},_e.media.pause=function(){n.pauseVideo(),_e.media.paused=!0},_e.media.stop=function(){n.stopVideo(),_e.media.paused=!0},_e.media.duration=n.getDuration(),_e.media.paused=!0,_e.media.currentTime=n.getCurrentTime(),_e.media.muted=n.isMuted(),w(_e.media,"timeupdate"),e.clearInterval(_e.timer.buffering),_e.timer.buffering=e.setInterval(function(){_e.media.buffered=n.getVideoLoadedFraction(),w(_e.media,"progress"),1===_e.media.buffered&&e.clearInterval(_e.timer.buffering)},200),K(),ye()},onStateChange:function(t){var n=t.target;switch(e.clearInterval(_e.timer.playing),t.data){case 0:_e.media.paused=!0,w(_e.media,"ended");break;case 1:_e.media.paused=!1,_e.media.seeking=!1,w(_e.media,"play"),_e.timer.playing=e.setInterval(function(){_e.media.currentTime=n.getCurrentTime(),w(_e.media,"timeupdate")},100);break;case 2:_e.media.paused=!0,w(_e.media,"pause")}}}})}function J(){_e.embed=$f(this),_e.embed.addEvent("ready",function(){_e.media.play=function(){_e.embed.api("play"),_e.media.paused=!1},_e.media.pause=function(){_e.embed.api("pause"),_e.media.paused=!0},_e.media.stop=function(){_e.embed.api("stop"),_e.media.paused=!0},_e.media.paused=!0,_e.media.currentTime=0,K(),_e.embed.api("getCurrentTime",function(e){_e.media.currentTime=e,w(_e.media,"timeupdate")}),_e.embed.api("getDuration",function(e){_e.media.duration=e,ye()}),_e.embed.addEvent("play",function(){_e.media.paused=!1,w(_e.media,"play")}),_e.embed.addEvent("pause",function(){_e.media.paused=!0,w(_e.media,"pause")}),_e.embed.addEvent("playProgress",function(e){_e.media.seeking=!1,_e.media.currentTime=e.seconds,w(_e.media,"timeupdate")}),_e.embed.addEvent("loadProgress",function(e){_e.media.buffered=e.percent,w(_e.media,"progress")}),_e.embed.addEvent("finish",function(){_e.media.paused=!0,w(_e.media,"ended")})})}function G(){if("video"===_e.type){H(I.selectors.captions)||_e.videoContainer.insertAdjacentHTML("afterbegin",'
'),_e.captionsContainer=H(I.selectors.captions).querySelector("span"),_e.usingTextTracks=!1,_e.media.textTracks&&(_e.usingTextTracks=!0);for(var e,t="",n=_e.media.childNodes,a=0;a=10||"Firefox"===_e.browser.name&&_e.browser.version>=31||"Chrome"===_e.browser.name&&_e.browser.version>=43||"Safari"===_e.browser.name&&_e.browser.version>=7)&&(r("Detected unsupported browser for HTML5 captions. Using fallback."),_e.usingTextTracks=!1),_e.usingTextTracks){r("TextTracks supported.");for(var i=0;i=7){r("Safari 7+ detected; removing track from DOM."),s=_e.media.getElementsByTagName("track");for(var c=0;ct?t=0:t>_e.media.duration&&(t=_e.media.duration);try{_e.media.currentTime=t.toFixed(1)}catch(a){}if(i(I.types.embed,_e.type)){switch(_e.type){case"youtube":_e.embed.seekTo(t);break;case"vimeo":_e.embed.api("seekTo",t)}n&&ee(),w(_e.media,"timeupdate"),_e.media.seeking=!0}r("Seeking to "+_e.media.currentTime+" seconds"),E(t)}function se(){b(_e.container,I.classes.playing,!_e.media.paused),b(_e.container,I.classes.stopped,_e.media.paused)}function oe(n){function r(){b(_e.container,I.classes.hover,!0),e.clearTimeout(o),i||(o=e.setTimeout(function(){b(_e.container,I.classes.hover,!1)},2e3))}function a(e){i="mouseenter"===e.type}var s=A.supportsFullScreen;n&&n.type===A.fullScreenEventName?_e.isFullscreen=A.isFullScreen(_e.container):s?(A.isFullScreen(_e.container)?A.cancelFullScreen():A.requestFullScreen(_e.container),_e.isFullscreen=A.isFullScreen(_e.container)):(_e.isFullscreen=!_e.isFullscreen,_e.isFullscreen?(g(t,"keyup",ie),t.body.style.overflow="hidden"):(h(t,"keyup",ie),t.body.style.overflow="")),b(_e.container,I.classes.fullscreen.active,_e.isFullscreen),_e.isFullscreen?_e.container.setAttribute("tabindex","-1"):_e.container.removeAttribute("tabindex"),j(_e.isFullscreen),x(_e.buttons.fullscreen,_e.isFullscreen);var o,i=!1;I.fullscreen.hideControls&&(b(_e.controls,I.classes.hover,!1),T(_e.controls,"mouseenter mouseleave",a,_e.isFullscreen),T(_e.container,"mousemove",r,_e.isFullscreen))}function ie(e){27===(e.which||e.charCode||e.keyCode)&&_e.isFullscreen&&oe()}function le(e){if("boolean"!=typeof e&&(e=!_e.media.muted),x(_e.buttons.mute,e),_e.media.muted=e,i(I.types.embed,_e.type)){switch(_e.type){case"youtube":_e.embed[_e.media.muted?"mute":"unMute"]();break;case"vimeo":_e.embed.api("setVolume",_e.media.muted?0:parseFloat(I.volume/10))}w(_e.media,"volumechange")}}function ue(t){if("undefined"==typeof t&&(t=I.storage.enabled&&S().supported?e.localStorage[I.storage.key]||I.volume:I.volume),t>10&&(t=10),0>t&&(t=0),_e.media.volume=parseFloat(t/10),I.volume=t,i(I.types.embed,_e.type)){switch(_e.type){case"youtube":_e.embed.setVolume(100*_e.media.volume);break;case"vimeo":_e.embed.api("setVolume",_e.media.volume)}w(_e.media,"volumechange")}_e.media.muted&&t>0&&le()}function ce(){var t=_e.media.muted?0:10*_e.media.volume;_e.supported.full&&_e.volume&&(_e.volume.value=t),I.storage.enabled&&S().supported&&e.localStorage.setItem(I.storage.key,t),b(_e.container,I.classes.muted,0===t),_e.supported.full&&_e.buttons.mute&&x(_e.buttons.mute,0===t)}function pe(e){_e.supported.full&&_e.buttons.captions&&("boolean"!=typeof e&&(e=-1===_e.container.className.indexOf(I.classes.captions.active)),_e.captionsEnabled=e,x(_e.buttons.captions,_e.captionsEnabled),b(_e.container,I.classes.captions.active,_e.captionsEnabled))}function de(e){var t="waiting"===e.type;clearTimeout(_e.loadingTimer),_e.loadingTimer=setTimeout(function(){b(_e.container,I.classes.loading,t)},t?250:0)}function fe(e){var t=_e.progress.played.bar,n=_e.progress.played.text,r=0;if(e)switch(e.type){case"timeupdate":case"seeking":r=_(_e.media.currentTime,_e.media.duration),"timeupdate"==e.type&&_e.buttons.seek&&(_e.buttons.seek.value=r);break;case"change":case"input":r=e.target.value;break;case"playing":case"progress":t=_e.progress.buffer.bar,n=_e.progress.buffer.text,r=function(){var e=_e.media.buffered;return e&&e.length?_(e.end(0),_e.media.duration):"number"==typeof e?100*e:0}()}t&&(t.value=r),n&&(n.innerHTML=r)}function me(e,t){if(t){isNaN(e)&&(e=0),_e.secs=parseInt(e%60),_e.mins=parseInt(e/60%60),_e.hours=parseInt(e/60/60%60);var n=parseInt(_e.media.duration/60/60%60)>0;_e.secs=("0"+_e.secs).slice(-2),_e.mins=("0"+_e.mins).slice(-2),t.innerHTML=(n?_e.hours+":":"")+_e.mins+":"+_e.secs}}function ye(){if(_e.supported.full){var e=_e.media.duration||0;!_e.duration&&I.displayDuration&&_e.media.paused&&me(e,_e.currentTime),_e.duration&&me(e,_e.duration)}}function be(e){me(_e.media.currentTime,_e.currentTime),e&&"timeupdate"==e.type&&_e.media.seeking||fe(e)}function ve(e){if("undefined"!=typeof e)return void ge(e);var t;switch(_e.type){case"youtube":t=_e.embed.getVideoUrl();break;case"vimeo":_e.embed.api("getVideoUrl",function(e){t=e});break;default:t=_e.media.currentSrc}return t||""}function ge(n){if(!("undefined"!=typeof n&&"sources"in n&&n.sources.length))return void r("Invalid source format",!0);if(ee(),"youtube"===_e.type?(_e.embed.destroy(),e.clearInterval(_e.timer.buffering),e.clearInterval(_e.timer.playing)):"video"===_e.type&&_e.videoContainer&&p(_e.videoContainer),p(_e.media),"type"in n&&(_e.type=n.type,"video"===_e.type)){var a=n.sources[0];"type"in a&&i(I.types.embed,a.type)&&(_e.type=a.type)}switch(_e.type){case"video":_e.media=t.createElement("video");break;case"audio":_e.media=t.createElement("audio");break;case"youtube":case"vimeo":_e.media=t.createElement("div"),_e.embedId=n.sources[0].src}d(_e.container,_e.media),i(I.types.html5,_e.type)&&(I.crossorigin&&_e.media.setAttribute("crossorigin",""),I.autoplay&&_e.media.setAttribute("autoplay",""),"poster"in n&&_e.media.setAttribute("poster",n.poster),I.loop&&_e.media.setAttribute("loop","")),_e.container.className=_e.originalClassName,b(_e.container,I.classes.fullscreen.active,_e.isFullscreen),b(_e.container,I.classes.captions.active,_e.captionsEnabled),W(),I.autoplay=n.autoplay||I.autoplay,i(I.types.html5,_e.type)&&B("source",n.sources),$(),i(I.types.html5,_e.type)&&("tracks"in n&&B("track",n.tracks),_e.media.load(),ye(),xe()),I.autoplay&&Z(),"title"in n&&(I.title=n.title,U())}function he(e){"video"===_e.type&&_e.media.setAttribute("poster",e)}function ke(){function n(e){e?Z():ee();var t=_e.buttons[e?"play":"pause"],n=_e.buttons[e?"pause":"play"];if(n){var r=v(t,I.classes.tabFocus);setTimeout(function(){n.focus(),r&&(b(t,I.classes.tabFocus,!1),b(n,I.classes.tabFocus,!0))},100)}}function r(){var e=t.activeElement;e&&e!=t.body?t.querySelector&&(e=t.querySelector(":focus")):e=null;for(var n in _e.buttons){var r=_e.buttons[n];b(r,I.classes.tabFocus,r===e)}}var a="IE"==_e.browser.name?"change":"input";g(e,"keyup",function(e){var t=e.keyCode?e.keyCode:e.which;9==t&&r()}),g(t.body,"click",function(){b(H("."+I.classes.tabFocus),I.classes.tabFocus,!1)});for(var s in _e.buttons){var o=_e.buttons[s];g(o,"blur",function(){b(o,"tab-focus",!1)})}k(_e.buttons.play,"click",I.handlers.play,function(){n(!0)}),k(_e.buttons.pause,"click",I.handlers.pause,function(){n()}),k(_e.buttons.restart,"click",I.handlers.restart,ae),k(_e.buttons.rewind,"click",I.handlers.rewind,ne),k(_e.buttons.forward,"click",I.handlers.forward,re),k(_e.buttons.seek,a,I.handlers.seek,ae),k(_e.volume,a,I.handlers.volume,function(){ue(_e.volume.value)}),k(_e.buttons.mute,"click",I.handlers.mute,le),k(_e.buttons.fullscreen,"click",I.handlers.fullscreen,oe),A.supportsFullScreen&&g(t,A.fullScreenEventName,oe),g(_e.media,"timeupdate seeking",be),g(_e.media,"timeupdate",E),g(_e.media,"loadedmetadata",ye),g(_e.buttons.captions,"click",pe),g(_e.media,"ended",function(){"video"===_e.type&&(_e.captionsContainer.innerHTML=""),se()}),g(_e.media,"progress playing",fe),g(_e.media,"volumechange",ce),g(_e.media,"play pause",se),g(_e.media,"waiting canplay seeked",de),"video"===_e.type&&I.click&&g(_e.videoContainer,"click",function(){_e.media.paused?Z():_e.media.ended?(ae(),Z()):ee()})}function Te(){if(!_e.init)return null;if(_e.container.setAttribute("class",y(I.selectors.container)),_e.init=!1,p(H(I.selectors.controls.wrapper)),"youtube"===_e.type)return void _e.embed.destroy();"video"===_e.type&&(p(H(I.selectors.captions)),c(_e.videoContainer)),_e.media.setAttribute("controls","");var e=_e.media.cloneNode(!0);_e.media.parentNode.replaceChild(e,_e.media)}function we(){if(_e.init)return null;A=C(),_e.browser=a(),_e.media=_e.container.querySelectorAll("audio, video, div")[0],_e.originalClassName=_e.container.className;var e=_e.media.tagName.toLowerCase();if("div"===e?(_e.type=_e.media.getAttribute("data-type"),_e.embedId=_e.media.getAttribute("data-video-id"),_e.media.removeAttribute("data-type"),_e.media.removeAttribute("data-video-id")):(_e.type=e,I.crossorigin=null!==_e.media.getAttribute("crossorigin"),I.autoplay=I.autoplay||null!==_e.media.getAttribute("autoplay"),I.loop=I.loop||null!==_e.media.getAttribute("loop")),_e.supported=N.supported(_e.type),W(),!_e.supported.basic)return!1;if(r(_e.browser.name+" "+_e.browser.version),$(),i(I.types.html5,_e.type)){if(!_e.supported.full)return void(_e.init=!0);xe(),U()}_e.init=!0}function xe(){_e.supported.full&&(_e.container.querySelectorAll(I.selectors.controls.wrapper).length||D(),Y()&&(Q(),ke(),G(),ue(),ce(),be(),se()))}var _e=this;return _e.container=F,we(),_e.init?{media:_e.media,play:Z,pause:ee,restart:ae,rewind:ne,forward:re,seek:ae,source:ve,poster:he,setVolume:ue,togglePlay:te,toggleMute:le,toggleCaptions:pe,toggleFullscreen:oe,isFullscreen:function(){return _e.isFullscreen||!1},support:function(e){return s(_e,e)},destroy:Te,restore:we}:{}}var A,I,N={},P={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"},tabFocus:"tab-focus"},handlers:{seek:null,play:null,pause:null,restart:null,rewind:null,forward:null,mute:null,volume:null,captions:null,fullscreen:null},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 N.supported=function(e){var n,r,s=a(),o="IE"===s.name&&s.version<=9,i=/iPhone|iPod/i.test(navigator.userAgent),l=!!t.createElement("audio").canPlayType,u=!!t.createElement("video").canPlayType;switch(e){case"video":n=u,r=n&&!o&&!i;break;case"audio":n=l,r=n&&!o;break;case"vimeo":case"youtube":n=!0,r=!o&&!i;break;default:n=l&&u,r=n&&!o}return{basic:n,full:r}},N.setup=function(e,n){var r=[];if("string"==typeof e?e=t.querySelectorAll(e):e instanceof HTMLElement?e=[e]:e instanceof NodeList||"string"==typeof e||("undefined"==typeof n&&"object"==typeof e&&(n=e),e=t.querySelectorAll(P.selectors.container)),I=F(P,n),!I.enabled||!N.supported().basic||!e.length)return!1;for(var a=e.length-1;a>=0;a--){var s=e[a];if("undefined"==typeof s.plyr){var o=new E(s);s.plyr=Object.keys(o).length?o:!1,"function"==typeof I.onSetup&&I.onSetup.apply(s.plyr)}r.push(s.plyr)}return r},N}); \ No newline at end of file diff --git a/docs/dist/docs.css b/docs/dist/docs.css index 5bcbe5fa..d4a79f04 100644 --- a/docs/dist/docs.css +++ b/docs/dist/docs.css @@ -1 +1 @@ -/*! normalize.css v2.1.3 | MIT License | git.io/normalize */a.logo,img,legend{border:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,small,summary{display:block}[hidden],template{display:none}body,figure,li,ul{margin:0}body,h1,h2{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}body,small{padding:0 10px}li,nav ul,ul{list-style:none;padding:0}legend,li,nav ul,ul{padding:0}.btn__bar,sub,sup{position:relative}.btn__bar,.plyr{max-width:1200px}audio,canvas,video{display:inline-block}audio:not([controls]){display:none;height:0}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}a{background:0 0;text-decoration:none;color:#3498db;border-bottom:1px dotted currentColor;transition:background .3s ease,color .3s ease,border .3s ease}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}hr{box-sizing:content-box;height:0}mark{background:#ff0;color:#000}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em}pre{white-space:pre-wrap}.btn__bar,nav li{white-space:nowrap}q{quotes:"\201C" "\201D" "\2018" "\2019"}sub,sup{font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}svg:not(:root){overflow:hidden}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}button,input,select,textarea{font-family:inherit;font-size:100%;margin:0}button,input{line-height:normal}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}textarea{overflow:auto;vertical-align:top}table{border-collapse:collapse;border-spacing:0}@-webkit-keyframes fade-in{0%{opacity:0}100%{opacity:1}}@keyframes fade-in{0%{opacity:0}100%{opacity:1}}@font-face{font-family:Avenir;src:url(//cdn.plyr.io/fonts/avenir-medium.woff2) format("woff2"),url(//cdn.plyr.io/fonts/avenir-medium.woff) format("woff");font-style:normal;font-weight:400}@font-face{font-family:Avenir;src:url(//cdn.plyr.io/fonts/avenir-bold.woff2) format("woff2"),url(//cdn.plyr.io/fonts/avenir-bold.woff) format("woff");font-style:normal;font-weight:600}h1,h2{letter-spacing:-.025em;color:#2E3C44;margin:0 0 10px;line-height:1.2}h1{font-size:64px;font-size:4rem;color:#3498DB}p,small{margin:0 0 20px}small{font-size:14px;font-size:.875rem}sup{top:-.5em;vertical-align:2px;font-size:9px;font-size:.563rem}.btn__bar::before,.btn__count::before{content:"";top:50%}a:focus,a:hover{color:#343f4a;border-bottom-color:transparent}a:focus{outline:#343f4a dotted thin;outline-offset:1px}.color--vimeo{color:#19b7ed}.color--youtube{color:#cc181e}*,::after,::before{box-sizing:border-box}.btn__bar ul,nav li{display:inline-block}html{height:100%;font-size:100%;background:linear-gradient(#fff,#f2f5f7) fixed}body{font-family:Avenir,"Helvetica Neue",Helvetica,Arial,sans-serif;line-height:1.5;text-align:center;color:#55646b}header{padding:20px;margin-bottom:20px}header p{font-size:18px;font-size:1.125rem}section{padding-bottom:20px}@media (min-width:480px){header{padding-top:60px;padding-bottom:60px}section{padding-bottom:40px}}.icon{fill:currentColor;width:18px;height:18px;vertical-align:-3px}a svg,button svg,label svg{pointer-events:none}.btn .icon,a .icon{margin-right:10px}nav ul{margin:0;font-size:0}nav li{margin-top:10px;font-size:16px;font-size:1rem}nav li+li{margin-left:20px}.btn__bar{margin:0 auto 20px}.btn__bar::before{position:absolute;left:0;right:0;height:1px;background:#dbe3e8}.btn__bar ul{position:relative;z-index:1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn__bar li{margin:0}.btn__bar li:first-child .btn{border-radius:4px 0 0 4px}.btn__bar li:last-child .btn{border-radius:0 4px 4px 0}.btn__bar li+li .btn{margin-left:-1px}.btn__bar li.active .btn{position:relative;z-index:1}.btn__bar li.active .btn .icon{color:inherit}.btn__bar li.active+li .btn:hover{z-index:0}.btn__bar .btn{position:relative;display:block;border-radius:0}.btn__bar .btn:focus,.btn__bar .btn:hover{z-index:1}@media (min-width:560px){.btn__bar{margin-bottom:40px}}.btn,.btn__count{display:inline-block;vertical-align:middle;border-radius:4px;font-weight:600;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn{padding:10px 20px;background:linear-gradient(#f8fafb,#e9eef1);border:1px solid #cbd0d3;box-shadow:0 1px 1px rgba(0,0,0,.05);text-shadow:0 1px 1px #fff;color:#55646b;transition:background .1s ease,color .1s ease}.btn:focus,.btn:hover{border-color:#b5bcc0;color:#55646b;outline:0}.btn--youtube .icon{color:#cc181e}.btn--vimeo .icon{color:#19b7ed}.btn--twitter .icon{color:#4BAAF4}.btn--primary,.btn__bar li.active .btn{background-image:linear-gradient(#3498db,#258cd1);background-color:#3498db;border-color:#217dbb;box-shadow:0 1px 1px rgba(0,0,0,.15);text-shadow:0 1px 1px rgba(0,0,0,.1);color:#fff}.btn--primary:focus,.btn--primary:hover{color:#fff;border-color:#196090}.btn--small{padding-top:7px;padding-bottom:7px}.btn__count{position:relative;margin-left:10px;padding:10px 15px;background:#fff;border:1px solid #cbd0d3}.btn__count::before{position:absolute;display:block;width:8px;height:8px;left:1px;margin-top:-4px;background:inherit;border:inherit;border-width:1px 0 0 1px;-webkit-transform:rotate(-45deg) translate(-50%,-50%);transform:rotate(-45deg) translate(-50%,-50%)}.error body,html.error{height:100%}.error body{width:100%;display:table;table-layout:fixed}.error main{display:table-cell;width:100%;vertical-align:middle}.plyr__video-embed,video{border-radius:4px}.plyr__video-embed{-webkit-mask-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAA5JREFUeNpiYGBgAAgwAAAEAAGbA+oJAAAAAElFTkSuQmCC)}.plyr{margin:0 auto 20px}.plyr__controls{border-radius:0 0 4px 4px}.plyr .plyr__video-embed,.plyr video{border-radius:4px 4px 0 0}.plyr--fullscreen,.plyr--fullscreen-active{max-width:none}.plyr--fullscreen .plyr-controls,.plyr--fullscreen iframe,.plyr--fullscreen video,.plyr--fullscreen-active .plyr-controls,.plyr--fullscreen-active iframe,.plyr--fullscreen-active video{border-radius:0}.plyr--fullscreen iframe,.plyr--fullscreen-active iframe{-webkit-mask-image:none}.plyr--audio{max-width:520px}.plyr--audio .plyr__controls{border-radius:4px}.plyr--audio .plyr__progress{border-radius:4px 4px 0 0;overflow:hidden}.plyr__cite{display:none}.plyr__cite .icon{margin-right:5px}.plyr--audio~ul .plyr__cite--audio,.plyr--video~ul .plyr__cite--video,.plyr--vimeo~ul .plyr__cite--vimeo,.plyr--youtube~ul .plyr__cite--youtube{display:block} \ No newline at end of file +/*! normalize.css v2.1.3 | MIT License | git.io/normalize */a.logo,img,legend{border:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,small,summary{display:block}[hidden],template{display:none}body,figure,li,ul{margin:0}body,h1,h2{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}body,small{padding:0 10px}li,nav ul,ul{list-style:none;padding:0}legend,li,nav ul,ul{padding:0}.btn__bar,sub,sup{position:relative}audio,canvas,video{display:inline-block}audio:not([controls]){display:none;height:0}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}a{background:0 0;text-decoration:none;color:#3498db;border-bottom:1px dotted currentColor;transition:background .3s ease,color .3s ease,border .3s ease}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}hr{box-sizing:content-box;height:0}mark{background:#ff0;color:#000}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em}pre{white-space:pre-wrap}.btn__bar,nav li{white-space:nowrap}q{quotes:"\201C" "\201D" "\2018" "\2019"}sub,sup{font-size:75%;line-height:0;vertical-align:baseline}sup{top:-.5em}.btn__bar::before,.btn__count::before{content:"";top:50%}sub{bottom:-.25em}svg:not(:root){overflow:hidden}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}button,input,select,textarea{font-family:inherit;font-size:100%;margin:0}button,input{line-height:normal}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}textarea{overflow:auto;vertical-align:top}table{border-collapse:collapse;border-spacing:0}@-webkit-keyframes fade-in{0%{opacity:0}100%{opacity:1}}@keyframes fade-in{0%{opacity:0}100%{opacity:1}}@font-face{font-family:Avenir;src:url(//cdn.plyr.io/fonts/avenir-medium.woff2) format("woff2"),url(//cdn.plyr.io/fonts/avenir-medium.woff) format("woff");font-style:normal;font-weight:400}@font-face{font-family:Avenir;src:url(//cdn.plyr.io/fonts/avenir-bold.woff2) format("woff2"),url(//cdn.plyr.io/fonts/avenir-bold.woff) format("woff");font-style:normal;font-weight:600}h1,h2{letter-spacing:-.025em;color:#2E3C44;margin:0 0 10px;line-height:1.2}h1{font-size:64px;font-size:4rem;color:#3498DB}p,small{margin:0 0 20px}small{font-size:14px;font-size:.875rem}a:focus,a:hover{color:#343f4a;border-bottom-color:transparent}a:focus{outline:#343f4a dotted thin;outline-offset:1px}.color--vimeo{color:#19b7ed}.color--youtube{color:#cc181e}*,::after,::before{box-sizing:border-box}.btn__bar ul,nav li{display:inline-block}html{height:100%;font-size:100%;background:linear-gradient(#fff,#f2f5f7) fixed}body{font-family:Avenir,"Helvetica Neue",Helvetica,Arial,sans-serif;line-height:1.5;text-align:center;color:#55646b}header{padding:20px;margin-bottom:20px}header p{font-size:18px;font-size:1.125rem}section{padding-bottom:20px}@media (min-width:480px){header{padding-top:60px;padding-bottom:60px}section{padding-bottom:40px}}.icon{fill:currentColor;width:18px;height:18px;vertical-align:-3px}a svg,button svg,label svg{pointer-events:none}.btn .icon,a .icon{margin-right:10px}.btn:not(.btn-large) .icon{width:16px;height:16px}nav ul{margin:0;font-size:0}nav li{margin-top:10px;font-size:16px;font-size:1rem}nav li+li{margin-left:20px}.btn__bar{margin:0 auto 20px;max-width:1200px}.btn__bar::before{position:absolute;left:0;right:0;height:1px;background:#dbe3e8}.btn__bar ul{position:relative;z-index:1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn__bar li{margin:0}.btn__bar li:first-child .btn{border-radius:4px 0 0 4px}.btn__bar li:last-child .btn{border-radius:0 4px 4px 0}.btn__bar li+li .btn{margin-left:-1px}.btn__bar li.active .btn{position:relative;z-index:1}.btn__bar li.active .btn .icon{color:inherit}.btn__bar li.active+li .btn:hover{z-index:0}.btn__bar .btn{position:relative;display:block;border-radius:0}.btn__bar .btn:focus,.btn__bar .btn:hover{z-index:1}@media (min-width:560px){.btn__bar{margin-bottom:40px}}.btn,.btn__count{display:inline-block;vertical-align:middle;border-radius:4px;font-weight:600;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn{padding:10px 12px;background:linear-gradient(#f8fafb,#e9eef1);border:1px solid #cbd0d3;box-shadow:0 1px 1px rgba(0,0,0,.05);text-shadow:0 1px 1px #fff;color:#55646b;transition:background .1s ease,color .1s ease;font-size:14px;font-size:.875rem}.btn:focus,.btn:hover{border-color:#b5bcc0;color:#55646b;outline:0}.btn--large{padding:10px 20px;font-size:16px;font-size:1rem}.btn--primary,.btn__bar li.active .btn{background-image:linear-gradient(#3498db,#258cd1);background-color:#3498db;border-color:#217dbb;box-shadow:0 1px 1px rgba(0,0,0,.15);text-shadow:0 1px 1px rgba(0,0,0,.1);color:#fff}.btn--primary:focus,.btn--primary:hover{color:#fff;border-color:#196090}.btn--youtube .icon{color:#cc181e}.btn--vimeo .icon{color:#19b7ed}.btn--twitter .icon{color:#4BAAF4}.btn__count{position:relative;margin-left:10px;padding:10px 15px;background:#fff;border:1px solid #cbd0d3}.btn__count::before{position:absolute;display:block;width:8px;height:8px;left:1px;margin-top:-4px;background:inherit;border:inherit;border-width:1px 0 0 1px;-webkit-transform:rotate(-45deg) translate(-50%,-50%);transform:rotate(-45deg) translate(-50%,-50%)}.error body,html.error{height:100%}.error body{width:100%;display:table;table-layout:fixed}.error main{display:table-cell;width:100%;vertical-align:middle}.plyr__video-embed,video{border-radius:4px;max-width:100%;vertical-align:middle}.plyr__video-embed{-webkit-mask-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAA5JREFUeNpiYGBgAAgwAAAEAAGbA+oJAAAAAElFTkSuQmCC)}.plyr{margin:0 auto 20px;max-width:1200px}.plyr__controls{border-radius:0 0 4px 4px}.plyr .plyr__video-embed,.plyr video{border-radius:4px 4px 0 0}.plyr--fullscreen,.plyr--fullscreen-active{max-width:none}.plyr--fullscreen .plyr-controls,.plyr--fullscreen iframe,.plyr--fullscreen video,.plyr--fullscreen-active .plyr-controls,.plyr--fullscreen-active iframe,.plyr--fullscreen-active video{border-radius:0}.plyr--fullscreen iframe,.plyr--fullscreen-active iframe{-webkit-mask-image:none}.plyr--audio{max-width:520px}.plyr--audio .plyr__controls{border-radius:4px}.plyr--audio .plyr__progress{border-radius:4px 4px 0 0;overflow:hidden}.plyr__cite{display:none}.plyr__cite .icon{margin-right:5px}.plyr--audio~ul .plyr__cite--audio,.plyr--video~ul .plyr__cite--video,.plyr--vimeo~ul .plyr__cite--vimeo,.plyr--youtube~ul .plyr__cite--youtube{display:block} \ No newline at end of file diff --git a/docs/index.html b/docs/index.html index 8c4026bb..ad3d9d01 100644 --- a/docs/index.html +++ b/docs/index.html @@ -20,12 +20,12 @@ diff --git a/docs/src/less/components/buttons.less b/docs/src/less/components/buttons.less index fef9af68..26c9fcd2 100644 --- a/docs/src/less/components/buttons.less +++ b/docs/src/less/components/buttons.less @@ -98,13 +98,14 @@ nav { // Buttons .btn { - padding: (@padding-base / 2) @padding-base; + padding: (@padding-base / 2) ((@padding-base / 2) + 2); background: linear-gradient(lighten(@body-background, 2%), darken(@body-background, 3%)); border: 1px solid @gray-light; box-shadow: 0 1px 1px rgba(0,0,0, .05); text-shadow: 0 1px 1px #fff; color: @gray; transition: background .1s ease, color .1s ease; + .font-size(@font-size-small); &:hover, &:focus { @@ -112,16 +113,15 @@ nav { color: @gray; outline: 0; } - &--youtube .icon { - color: @color-youtube; - } - &--vimeo .icon { - color: @color-vimeo; - } - &--twitter .icon { - color: @color-twitter; - } } + +// Sizes +.btn--large { + padding: (@padding-base / 2) @padding-base; + .font-size(); +} + +// Styles .btn--primary { background-image: linear-gradient(@link-color, darken(@link-color, 5%)); background-color: @link-color; @@ -136,9 +136,14 @@ nav { border-color: darken(@link-color, 20%); } } -.btn--small { - padding-top: ceil(@padding-base / 3); - padding-bottom: ceil(@padding-base / 3); +.btn--youtube .icon { + color: @color-youtube; +} +.btn--vimeo .icon { + color: @color-vimeo; +} +.btn--twitter .icon { + color: @color-twitter; } // Count bubble diff --git a/docs/src/less/components/examples.less b/docs/src/less/components/examples.less index 6dde9690..97d272d0 100644 --- a/docs/src/less/components/examples.less +++ b/docs/src/less/components/examples.less @@ -5,6 +5,8 @@ video, .plyr__video-embed { border-radius: @border-radius-base; + max-width: 100%; + vertical-align: middle; } .plyr__video-embed { -webkit-mask-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAA5JREFUeNpiYGBgAAgwAAAEAAGbA+oJAAAAAElFTkSuQmCC); diff --git a/docs/src/less/components/icons.less b/docs/src/less/components/icons.less index 7bcc792e..9530b601 100644 --- a/docs/src/less/components/icons.less +++ b/docs/src/less/components/icons.less @@ -20,3 +20,7 @@ a .icon, .btn .icon { margin-right: (@padding-base / 2); } +.btn:not(.btn-large) .icon { + width: (@icon-size - 2); + height: (@icon-size - 2); +} diff --git a/docs/src/less/components/type.less b/docs/src/less/components/type.less index 854da12d..a040a022 100644 --- a/docs/src/less/components/type.less +++ b/docs/src/less/components/type.less @@ -12,7 +12,7 @@ h2 { .font-smoothing(); } h1 { - .font-size(64); + .font-size(@font-size-h1); color: #3498DB; } @@ -24,11 +24,7 @@ small { small { display: block; padding: 0 (@padding-base / 2); - .font-size(14); -} -sup { - vertical-align: 2px; - .font-size(9); + .font-size(@font-size-small); } // Lists diff --git a/docs/src/less/variables.less b/docs/src/less/variables.less index 097aa1f2..78c812d3 100644 --- a/docs/src/less/variables.less +++ b/docs/src/less/variables.less @@ -18,6 +18,11 @@ // Base @body-background: @off-white; +// Type +@font-size-base: 16; +@font-size-small: 14; +@font-size-h1: 64; + // Elements @link-color: @blue; @padding-base: 20px; diff --git a/src/js/plyr.js b/src/js/plyr.js index 1953f864..4d5fa3fe 100644 --- a/src/js/plyr.js +++ b/src/js/plyr.js @@ -980,6 +980,11 @@ } } + // Toggle style hook + function _toggleStyleHook() { + _toggleClass(plyr.container, defaults.selectors.container.replace('.', ''), plyr.supported.full); + } + // Setup aria attribute for play and iframe title function _setTitle(iframe) { // Find the current text @@ -1136,20 +1141,11 @@ // When embeds are ready function _embedReady() { - // Inject and update UI - if (plyr.supported.full) { - // Only setup controls once - if (!plyr.container.querySelectorAll(config.selectors.controls.wrapper).length) { - _setupInterface(); - } - } + // Setup the UI + _setupInterface(); // Set title _setTitle(_getElement('iframe')); - - // Set the volume - _setVolume(); - _updateVolume(); } // Handle YouTube API ready @@ -1165,7 +1161,7 @@ plyr.embed = new YT.Player(container.id, { videoId: videoId, playerVars: { - autoplay: (config.autoplay ? 1 : 0), + autoplay: 0, controls: (plyr.supported.full ? 0 : 1), rel: 0, showinfo: 0, @@ -1196,7 +1192,7 @@ plyr.media.paused = true; }; plyr.media.duration = instance.getDuration(); - plyr.media.paused = !config.autoplay; + plyr.media.paused = true; plyr.media.currentTime = instance.getCurrentTime(); plyr.media.muted = instance.isMuted(); @@ -1224,9 +1220,7 @@ _embedReady(); // Display duration if available - if (config.displayDuration) { - _displayDuration(); - } + _displayDuration(); }, 'onStateChange': function(event) { // Get the instance @@ -1250,6 +1244,7 @@ case 1: plyr.media.paused = false; + plyr.media.seeking = false; _triggerEvent(plyr.media, 'play'); // Poll to get playback progress @@ -1259,7 +1254,7 @@ // Trigger timeupdate _triggerEvent(plyr.media, 'timeupdate'); - }, 200); + }, 100); break; @@ -1293,7 +1288,7 @@ plyr.embed.api('stop'); plyr.media.paused = true; }; - plyr.media.paused = !config.autoplay; + plyr.media.paused = true; plyr.media.currentTime = 0; // Update UI @@ -1310,9 +1305,7 @@ plyr.media.duration = value; // Display duration if available - if (plyr.supported.full && config.displayDuration) { - _displayDuration(); - } + _displayDuration(); }); plyr.embed.addEvent('play', function() { @@ -1326,6 +1319,7 @@ }); plyr.embed.addEvent('playProgress', function(data) { + plyr.media.seeking = false; plyr.media.currentTime = data.seconds; _triggerEvent(plyr.media, 'timeupdate'); }); @@ -1352,149 +1346,151 @@ // Setup captions function _setupCaptions() { - if (plyr.type === 'video') { - // Inject the container - if (!_getElement(config.selectors.captions)) { - plyr.videoContainer.insertAdjacentHTML('afterbegin', '
'); - } + if (plyr.type !== 'video') { + return; + } - // Cache selector - plyr.captionsContainer = _getElement(config.selectors.captions).querySelector('span'); + // Inject the container + if (!_getElement(config.selectors.captions)) { + plyr.videoContainer.insertAdjacentHTML('afterbegin', '
'); + } - // Determine if HTML5 textTracks is supported - plyr.usingTextTracks = false; - if (plyr.media.textTracks) { - plyr.usingTextTracks = true; - } + // Cache selector + plyr.captionsContainer = _getElement(config.selectors.captions).querySelector('span'); - // Get URL of caption file if exists - var captionSrc = '', - kind, - children = plyr.media.childNodes; + // Determine if HTML5 textTracks is supported + plyr.usingTextTracks = false; + if (plyr.media.textTracks) { + plyr.usingTextTracks = true; + } - for (var i = 0; i < children.length; i++) { - if (children[i].nodeName.toLowerCase() === 'track') { - kind = children[i].kind; - if (kind === 'captions' || kind === 'subtitles') { - captionSrc = children[i].getAttribute('src'); - } + // Get URL of caption file if exists + var captionSrc = '', + kind, + children = plyr.media.childNodes; + + for (var i = 0; i < children.length; i++) { + if (children[i].nodeName.toLowerCase() === 'track') { + kind = children[i].kind; + if (kind === 'captions' || kind === 'subtitles') { + captionSrc = children[i].getAttribute('src'); } } + } - // Record if caption file exists or not - plyr.captionExists = true; - if (captionSrc === '') { - plyr.captionExists = false; - _log('No caption track found.'); - } - else { - _log('Caption track found; URI: ' + captionSrc); + // Record if caption file exists or not + plyr.captionExists = true; + if (captionSrc === '') { + plyr.captionExists = false; + _log('No caption track found.'); + } + else { + _log('Caption track found; URI: ' + captionSrc); + } + + // If no caption file exists, hide container for caption text + if (!plyr.captionExists) { + _toggleClass(plyr.container, config.classes.captions.enabled); + } + // If caption file exists, process captions + else { + // Turn off native caption rendering to avoid double captions + // This doesn't seem to work in Safari 7+, so the elements are removed from the dom below + var tracks = plyr.media.textTracks; + for (var x = 0; x < tracks.length; x++) { + tracks[x].mode = 'hidden'; } - // If no caption file exists, hide container for caption text - if (!plyr.captionExists) { - _toggleClass(plyr.container, config.classes.captions.enabled); + // Enable UI + _showCaptions(plyr); + + // Disable unsupported browsers than report false positive + if ((plyr.browser.name === 'IE' && plyr.browser.version >= 10) || + (plyr.browser.name === 'Firefox' && plyr.browser.version >= 31) || + (plyr.browser.name === 'Chrome' && plyr.browser.version >= 43) || + (plyr.browser.name === 'Safari' && plyr.browser.version >= 7)) { + // Debugging + _log('Detected unsupported browser for HTML5 captions. Using fallback.'); + + // Set to false so skips to 'manual' captioning + plyr.usingTextTracks = false; } - // If caption file exists, process captions - else { - // Turn off native caption rendering to avoid double captions - // This doesn't seem to work in Safari 7+, so the elements are removed from the dom below - var tracks = plyr.media.textTracks; - for (var x = 0; x < tracks.length; x++) { - tracks[x].mode = 'hidden'; - } - // Enable UI - _showCaptions(plyr); + // Rendering caption tracks + // Native support required - http://caniuse.com/webvtt + if (plyr.usingTextTracks) { + _log('TextTracks supported.'); - // Disable unsupported browsers than report false positive - if ((plyr.browser.name === 'IE' && plyr.browser.version >= 10) || - (plyr.browser.name === 'Firefox' && plyr.browser.version >= 31) || - (plyr.browser.name === 'Chrome' && plyr.browser.version >= 43) || - (plyr.browser.name === 'Safari' && plyr.browser.version >= 7)) { - // Debugging - _log('Detected unsupported browser for HTML5 captions. Using fallback.'); + for (var y = 0; y < tracks.length; y++) { + var track = tracks[y]; - // Set to false so skips to 'manual' captioning - plyr.usingTextTracks = false; - } + if (track.kind === 'captions' || track.kind === 'subtitles') { + _on(track, 'cuechange', function() { + // Clear container + plyr.captionsContainer.innerHTML = ''; - // Rendering caption tracks - // Native support required - http://caniuse.com/webvtt - if (plyr.usingTextTracks) { - _log('TextTracks supported.'); - - for (var y = 0; y < tracks.length; y++) { - var track = tracks[y]; - - if (track.kind === 'captions' || track.kind === 'subtitles') { - _on(track, 'cuechange', function() { - // Clear container - plyr.captionsContainer.innerHTML = ''; - - // Display a cue, if there is one - if (this.activeCues[0] && this.activeCues[0].hasOwnProperty('text')) { - plyr.captionsContainer.appendChild(this.activeCues[0].getCueAsHTML().trim()); - } - }); - } - } - } - // Caption tracks not natively supported - else { - _log('TextTracks not supported so rendering captions manually.'); - - // Render captions from array at appropriate time - plyr.currentCaption = ''; - plyr.captions = []; - - if (captionSrc !== '') { - // Create XMLHttpRequest Object - var xhr = new XMLHttpRequest(); - - xhr.onreadystatechange = function() { - if (xhr.readyState === 4) { - if (xhr.status === 200) { - var records = [], - record, - req = xhr.responseText; - - records = req.split('\n\n'); - - for (var r = 0; r < records.length; r++) { - record = records[r]; - plyr.captions[r] = []; - plyr.captions[r] = record.split('\n'); - } - - // Remove first element ('VTT') - plyr.captions.shift(); - - _log('Successfully loaded the caption file via AJAX.'); - } - else { - _log('There was a problem loading the caption file via AJAX.', true); - } + // Display a cue, if there is one + if (this.activeCues[0] && this.activeCues[0].hasOwnProperty('text')) { + plyr.captionsContainer.appendChild(this.activeCues[0].getCueAsHTML().trim()); } - }; - - xhr.open('get', captionSrc, true); - - xhr.send(); + }); } } + } + // Caption tracks not natively supported + else { + _log('TextTracks not supported so rendering captions manually.'); - // If Safari 7+, removing track from DOM [see 'turn off native caption rendering' above] - if (plyr.browser.name === 'Safari' && plyr.browser.version >= 7) { - _log('Safari 7+ detected; removing track from DOM.'); + // Render captions from array at appropriate time + plyr.currentCaption = ''; + plyr.captions = []; - // Find all elements - tracks = plyr.media.getElementsByTagName('track'); + if (captionSrc !== '') { + // Create XMLHttpRequest Object + var xhr = new XMLHttpRequest(); - // Loop through and remove one by one - for (var t = 0; t < tracks.length; t++) { - plyr.media.removeChild(tracks[t]); - } + xhr.onreadystatechange = function() { + if (xhr.readyState === 4) { + if (xhr.status === 200) { + var records = [], + record, + req = xhr.responseText; + + records = req.split('\n\n'); + + for (var r = 0; r < records.length; r++) { + record = records[r]; + plyr.captions[r] = []; + plyr.captions[r] = record.split('\n'); + } + + // Remove first element ('VTT') + plyr.captions.shift(); + + _log('Successfully loaded the caption file via AJAX.'); + } + else { + _log('There was a problem loading the caption file via AJAX.', true); + } + } + }; + + xhr.open('get', captionSrc, true); + + xhr.send(); + } + } + + // If Safari 7+, removing track from DOM [see 'turn off native caption rendering' above] + if (plyr.browser.name === 'Safari' && plyr.browser.version >= 7) { + _log('Safari 7+ detected; removing track from DOM.'); + + // Find all elements + tracks = plyr.media.getElementsByTagName('track'); + + // Loop through and remove one by one + for (var t = 0; t < tracks.length; t++) { + plyr.media.removeChild(tracks[t]); } } } @@ -1502,6 +1498,10 @@ // Setup fullscreen function _setupFullscreen() { + if (!plyr.supported.full) { + return; + } + if ((plyr.type != 'audio' || config.fullscreen.allowAudio) && config.fullscreen.enabled) { // Check for native support var nativeSupport = fullscreen.supportsFullScreen; @@ -1609,24 +1609,28 @@ } catch(e) {} - // Trigger timeupdate for embed and restore pause state - if ('embed' in plyr) { + // Embeds + if(_inArray(config.types.embed, plyr.type)) { // YouTube - if (plyr.type === 'youtube') { - plyr.embed.seekTo(targetTime); - } + switch(plyr.type) { + case 'youtube': + plyr.embed.seekTo(targetTime); + break; - // Vimeo - if (plyr.type === 'vimeo') { - plyr.embed.api('seekTo', targetTime); + case 'vimeo': + plyr.embed.api('seekTo', targetTime); + break; } - // Trigger timeupdate - _triggerEvent(plyr.media, 'timeupdate'); - if (paused) { _pause(); } + + // Trigger timeupdate for embeds + _triggerEvent(plyr.media, 'timeupdate'); + + // Set seeking flag + plyr.media.seeking = true; } // Logging @@ -1754,24 +1758,20 @@ // Set mute on the player plyr.media.muted = muted; - // YouTube - if (plyr.type === 'youtube') { - plyr.embed[plyr.media.muted ? 'mute' : 'unMute'](); + // Embeds + if(_inArray(config.types.embed, plyr.type)) { + // YouTube + switch(plyr.type) { + case 'youtube': + plyr.embed[plyr.media.muted ? 'mute' : 'unMute'](); + break; - // Trigger timeupdate - _triggerEvent(plyr.media, 'volumechange'); - } - - // Vimeo - if (plyr.type === 'vimeo') { - if (plyr.media.muted) { - plyr.embed.api('setVolume', 0); - } - else { - plyr.embed.api('setVolume', parseFloat(config.volume / 10)); + case 'vimeo': + plyr.embed.api('setVolume', plyr.media.muted ? 0 : parseFloat(config.volume / 10)); + break; } - // Trigger timeupdate + // Trigger volumechange for embeds _triggerEvent(plyr.media, 'volumechange'); } } @@ -1803,18 +1803,20 @@ // Store in config config.volume = volume; - // YouTube - if (plyr.type === 'youtube') { - plyr.embed.setVolume(plyr.media.volume * 100); - } + // Embeds + if(_inArray(config.types.embed, plyr.type)) { + // YouTube + switch(plyr.type) { + case 'youtube': + plyr.embed.setVolume(plyr.media.volume * 100); + break; - // Vimeo - if (plyr.type === 'vimeo') { - plyr.embed.api('setVolume', plyr.media.volume); - } + case 'vimeo': + plyr.embed.api('setVolume', plyr.media.volume); + break; + } - // Trigger volumechange for embeds - if ('embed' in plyr) { + // Trigger volumechange for embeds _triggerEvent(plyr.media, 'volumechange'); } @@ -1970,6 +1972,10 @@ // Show the duration on metadataloaded function _displayDuration() { + if (!plyr.supported.full) { + return; + } + var duration = plyr.media.duration || 0; // If there's only one time display, display duration there @@ -1988,6 +1994,11 @@ // Duration _updateTimeDisplay(plyr.media.currentTime, plyr.currentTime); + // Ignore updates while seeking + if(event && event.type == 'timeupdate' && plyr.media.seeking) { + return; + } + // Playing progress _updateProgress(event); } @@ -2041,7 +2052,7 @@ window.clearInterval(plyr.timer.buffering); window.clearInterval(plyr.timer.playing); } - else if (plyr.type === 'video') { + else if (plyr.type === 'video' && plyr.videoContainer) { // Remove video wrapper _remove(plyr.videoContainer); } @@ -2105,6 +2116,7 @@ // Restore class hooks _toggleClass(plyr.container, config.classes.fullscreen.active, plyr.isFullscreen); _toggleClass(plyr.container, config.classes.captions.active, plyr.captionsEnabled); + _toggleStyleHook(); // Autoplay the new source? config.autoplay = (source.autoplay || config.autoplay); @@ -2117,41 +2129,29 @@ // Set up from scratch _setupMedia(); - // Trigger media updated - _mediaUpdated(); - // HTML5 stuff if (_inArray(config.types.html5, plyr.type)) { - // Set volume - _setVolume(); - _updateVolume(); - - // UI updates - if (plyr.supported.full) { - // Reset time display - _timeUpdate(); - - // Update the UI - _checkPlaying(); - } - // Setup captions if ('tracks' in source) { _insertChildElements('track', source.tracks); - - // Captions - _setupCaptions(); } // Load HTML5 sources plyr.media.load(); - // Play if autoplay attribute is present - if (config.autoplay) { - _play(); - } + // Display duration if available + _displayDuration(); + + // Setup interface + _setupInterface(); } + // Play if autoplay attribute is present + if (config.autoplay) { + _play(); + } + + // Set aria title and iframe title if ('title' in source) { config.title = source.title; _setTitle(); @@ -2376,9 +2376,6 @@ // Get the media element plyr.media = plyr.container.querySelectorAll('audio, video, div')[0]; - // Add style hook - _toggleClass(plyr.container, defaults.selectors.container.replace('.', ''), true); - // Get original classname plyr.originalClassName = plyr.container.className; @@ -2403,6 +2400,9 @@ // Check for full support plyr.supported = api.supported(plyr.type); + // Add style hook + _toggleStyleHook(); + // If no native support, bail if (!plyr.supported.basic) { return false; @@ -2415,7 +2415,7 @@ _setupMedia(); // Setup interface - if (plyr.type == 'video' || plyr.type == 'audio') { + if (_inArray(config.types.html5, plyr.type)) { // Bail if no support if (!plyr.supported.full) { // Successful setup @@ -2428,11 +2428,6 @@ // Setup UI _setupInterface(); - // Display duration if available - if (config.displayDuration) { - _displayDuration(); - } - // Set title on button and frame _setTitle(); } @@ -2442,31 +2437,40 @@ } function _setupInterface() { + // Don't setup interface if no support + if (!plyr.supported.full) { + return; + } + // Inject custom controls - _injectControls(); + if (!plyr.container.querySelectorAll(config.selectors.controls.wrapper).length) { + // Inject custom controls + _injectControls(); + } // Find the elements if (!_findElements()) { - return false; + return; } - // Captions - _setupCaptions(); - - // Media updated - _mediaUpdated(); - - // Set volume - _setVolume(); - _updateVolume(); - } - - function _mediaUpdated() { // Setup fullscreen _setupFullscreen(); // Listeners _listeners(); + + // Captions + _setupCaptions(); + + // Set volume + _setVolume(); + _updateVolume(); + + // Reset time display + _timeUpdate(); + + // Update the UI + _checkPlaying(); } // Initialize instance diff --git a/src/less/plyr.less b/src/less/plyr.less index 891b6f9d..fde725d7 100644 --- a/src/less/plyr.less +++ b/src/less/plyr.less @@ -583,7 +583,7 @@ // Hide sound controls on iOS // It's not supported to change volume using JavaScript: // https://developer.apple.com/library/safari/documentation/AudioVideo/Conceptual/Using_HTML5_Audio_Video/Device-SpecificConsiderations/Device-SpecificConsiderations.html - &--is-ios &-volume, + &--is-ios &__volume, &--is-ios [data-plyr='mute'], &--is-ios.plyr--audio &__controls--right { display: none;