;(function () { var _excluded = ['premium', 'referrerPolicy'] function _objectWithoutProperties(source, excluded) { if (source == null) return {} var target = _objectWithoutPropertiesLoose(source, excluded) var key, i if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source) for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i] if (excluded.indexOf(key) >= 0) continue if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue target[key] = source[key] } } return target } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {} var target = {} var sourceKeys = Object.keys(source) var key, i for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i] if (excluded.indexOf(key) >= 0) continue target[key] = source[key] } return target } function _toConsumableArray(arr) { return ( _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread() ) } function _nonIterableSpread() { throw new TypeError( 'Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.' ) } function _iterableToArray(iter) { if ( (typeof Symbol !== 'undefined' && iter[Symbol.iterator] != null) || iter['@@iterator'] != null ) return Array.from(iter) } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr) } function _classCallCheck2(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function') } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i] descriptor.enumerable = descriptor.enumerable || false descriptor.configurable = true if ('value' in descriptor) descriptor.writable = true Object.defineProperty(target, descriptor.key, descriptor) } } function _createClass2(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps) if (staticProps) _defineProperties(Constructor, staticProps) Object.defineProperty(Constructor, 'prototype', { writable: false }) return Constructor } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object) if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object) enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable })), keys.push.apply(keys, symbols) } return keys } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {} i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty2(target, key, source[key]) }) : Object.getOwnPropertyDescriptors ? Object.defineProperties( target, Object.getOwnPropertyDescriptors(source) ) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty( target, key, Object.getOwnPropertyDescriptor(source, key) ) }) } return target } function _slicedToArray(arr, i) { return ( _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest() ) } function _nonIterableRest() { throw new TypeError( 'Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.' ) } function _unsupportedIterableToArray(o, minLen) { if (!o) return if (typeof o === 'string') return _arrayLikeToArray(o, minLen) var n = Object.prototype.toString.call(o).slice(8, -1) if (n === 'Object' && o.constructor) n = o.constructor.name if (n === 'Map' || n === 'Set') return Array.from(o) if (n === 'Arguments' || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen) } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i] } return arr2 } function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : (typeof Symbol !== 'undefined' && arr[Symbol.iterator]) || arr['@@iterator'] if (_i == null) return var _arr = [] var _n = true var _d = false var _s, _e try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value) if (i && _arr.length === i) break } } catch (err) { _d = true _e = err } finally { try { if (!_n && _i['return'] != null) _i['return']() } finally { if (_d) throw _e } } return _arr } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr } function _defineProperty2(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }) } else { obj[key] = value } return obj } function _typeof(obj) { '@babel/helpers - typeof' return ( (_typeof = 'function' == typeof Symbol && 'symbol' == typeof Symbol.iterator ? function (obj) { return typeof obj } : function (obj) { return obj && 'function' == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj }), _typeof(obj) ) } var __vite_style__ = document.createElement('style') __vite_style__.innerHTML = '@charset "UTF-8";._video-container_1vz16_1{position:relative;width:100%;--plyr-color-main: #01c1b5}._video-container_1vz16_1 video{width:100%}._video-container_1vz16_1 .video-back{position:absolute;left:.53333rem;top:.53333rem;color:#fff;z-index:99;font-size:.64rem;width:.8rem;height:.8rem;background-color:rgba(0,0,0,.5);border-radius:50%;padding:.10667rem .13333rem .10667rem .08rem}._video-container_1vz16_1 .plyr__poster{background-size:cover}._video-container_1vz16_1 .plyr__control--overlaid{border:.02667rem solid #fff;background-color:transparent!important}._video-container_1vz16_1 .plyr--video .plyr__control:hover{background-color:transparent!important}._video-container_1vz16_1 ._video_1vz16_1{position:relative}._loadingVideo_1vz16_35{position:absolute;top:0;left:0;bottom:0;right:0;background:rgba(0,0,0,.9);z-index:10}._playOver_1vz16_44{background:rgba(0,0,0,.5);color:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column}._playOver_1vz16_44 ._tips_1vz16_52{font-size:.4rem;color:#fff}._playOver_1vz16_44 ._btn_1vz16_56{margin:.26667rem 0}._freeTxt_1vz16_59{font-size:.4rem;color:#fff;line-height:.56rem;padding-top:.26667rem}._freeRate_1vz16_65{color:#32ffd8}@keyframes plyr-progress{to{background-position:.66667rem 0;background-position:var(--plyr-progress-loading-size,25px) 0}}@keyframes plyr-popup{0%{opacity:.5;transform:translateY(.26667rem)}to{opacity:1;transform:translateY(0)}}@keyframes plyr-fade-in{0%{opacity:0}to{opacity:1}}.plyr{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;align-items:center;direction:ltr;display:flex;flex-direction:column;font-family:inherit;font-family:var(--plyr-font-family,inherit);font-variant-numeric:tabular-nums;font-weight:400;font-weight:var(--plyr-font-weight-regular,400);line-height:1.7;line-height:var(--plyr-line-height,1.7);max-width:100%;min-width:5.33333rem;position:relative;text-shadow:none;transition:box-shadow .3s ease;z-index:0}.plyr audio,.plyr iframe,.plyr video{display:block;height:100%;width:100%}.plyr button{font:inherit;line-height:inherit;width:auto}.plyr:focus{outline:0}.plyr--full-ui{box-sizing:border-box}.plyr--full-ui *,.plyr--full-ui :after,.plyr--full-ui :before{box-sizing:inherit}.plyr--full-ui a,.plyr--full-ui button,.plyr--full-ui input,.plyr--full-ui label{touch-action:manipulation}.plyr__badge{background:#4a5464;background:var(--plyr-badge-background,#4a5464);border-radius:.05333rem;border-radius:var(--plyr-badge-border-radius,2px);color:#fff;color:var(--plyr-badge-text-color,#fff);font-size:.24rem;font-size:var(--plyr-font-size-badge,9px);line-height:1;padding:.08rem .10667rem}.plyr--full-ui ::-webkit-media-text-track-container{display:none}.plyr__captions{animation:plyr-fade-in .3s ease;bottom:0;display:none;font-size:.34667rem;font-size:var(--plyr-font-size-small,13px);left:0;padding:.26667rem;padding:var(--plyr-control-spacing,10px);position:absolute;text-align:center;transition:transform .4s ease-in-out;width:100%}.plyr__captions span:empty{display:none}@media (min-width:480px){.plyr__captions{font-size:.4rem;font-size:var(--plyr-font-size-base,15px);padding:.53333rem;padding:calc(var(--plyr-control-spacing, 10px)*2)}}@media (min-width:768px){.plyr__captions{font-size:.48rem;font-size:var(--plyr-font-size-large,18px)}}.plyr--captions-active .plyr__captions{display:block}.plyr:not(.plyr--hide-controls) .plyr__controls:not(:empty)~.plyr__captions{transform:translateY(-1.06667rem);transform:translateY(calc(var(--plyr-control-spacing, 10px)*-4))}.plyr__caption{background:rgba(0,0,0,.8);background:var(--plyr-captions-background,rgba(0,0,0,.8));border-radius:.05333rem;-webkit-box-decoration-break:clone;box-decoration-break:clone;color:#fff;color:var(--plyr-captions-text-color,#fff);line-height:185%;padding:.2em .5em;white-space:pre-wrap}.plyr__caption div{display:inline}.plyr__control{background:transparent;border:0;border-radius:.08rem;border-radius:var(--plyr-control-radius,3px);color:inherit;cursor:pointer;flex-shrink:0;overflow:visible;padding:.18667rem;padding:calc(var(--plyr-control-spacing, 10px)*.7);position:relative;transition:all .3s ease}.plyr__control svg{fill:currentColor;display:block;height:.48rem;height:var(--plyr-control-icon-size,18px);pointer-events:none;width:.48rem;width:var(--plyr-control-icon-size,18px)}.plyr__control:focus{outline:0}.plyr__control.plyr__tab-focus{outline:.08rem dotted #00b2ff;outline:var(--plyr-tab-focus-color,var(--plyr-color-main,var(--plyr-color-main,#00b2ff))) dotted .08rem;outline-offset:.05333rem}a.plyr__control{text-decoration:none}.plyr__control.plyr__control--pressed .icon--not-pressed,.plyr__control.plyr__control--pressed .label--not-pressed,.plyr__control:not(.plyr__control--pressed) .icon--pressed,.plyr__control:not(.plyr__control--pressed) .label--pressed,a.plyr__control:after,a.plyr__control:before{display:none}.plyr--full-ui ::-webkit-media-controls{display:none}.plyr__controls{align-items:center;display:flex;justify-content:flex-end;text-align:center}.plyr__controls .plyr__progress__container{flex:1;min-width:0}.plyr__controls .plyr__controls__item{margin-left:.06667rem;margin-left:calc(var(--plyr-control-spacing, 10px)/4)}.plyr__controls .plyr__controls__item:first-child{margin-left:0;margin-right:auto}.plyr__controls .plyr__controls__item.plyr__progress__container{padding-left:.06667rem;padding-left:calc(var(--plyr-control-spacing, 10px)/4)}.plyr__controls .plyr__controls__item.plyr__time{padding:0 .13333rem;padding:0 calc(var(--plyr-control-spacing, 10px)/2)}.plyr__controls .plyr__controls__item.plyr__progress__container:first-child,.plyr__controls .plyr__controls__item.plyr__time+.plyr__time,.plyr__controls .plyr__controls__item.plyr__time:first-child{padding-left:0}.plyr [data-plyr=airplay],.plyr [data-plyr=captions],.plyr [data-plyr=fullscreen],.plyr [data-plyr=pip],.plyr__controls:empty{display:none}.plyr--airplay-supported [data-plyr=airplay],.plyr--captions-enabled [data-plyr=captions],.plyr--fullscreen-enabled [data-plyr=fullscreen],.plyr--pip-supported [data-plyr=pip]{display:inline-block}.plyr__menu{display:flex;position:relative}.plyr__menu .plyr__control svg{transition:transform .3s ease}.plyr__menu .plyr__control[aria-expanded=true] svg{transform:rotate(90deg)}.plyr__menu .plyr__control[aria-expanded=true] .plyr__tooltip{display:none}.plyr__menu__container{animation:plyr-popup .2s ease;background:hsla(0,0%,100%,.9);background:var(--plyr-menu-background,hsla(0,0%,100%,.9));border-radius:.10667rem;bottom:100%;box-shadow:0 .02667rem .05333rem rgba(0,0,0,.15);box-shadow:var(--plyr-menu-shadow,0 1px 2px rgba(0,0,0,.15));color:#4a5464;color:var(--plyr-menu-color,#4a5464);font-size:.4rem;font-size:var(--plyr-font-size-base,15px);margin-bottom:.26667rem;position:absolute;right:-.08rem;text-align:left;white-space:nowrap;z-index:3}.plyr__menu__container>div{overflow:hidden;transition:height .35s cubic-bezier(.4,0,.2,1),width .35s cubic-bezier(.4,0,.2,1)}.plyr__menu__container:after{border:.10667rem solid transparent;border-top-color:rgba(255,255,255,.9);border:var(--plyr-menu-arrow-size,4px) solid transparent;border-top-color:var(--plyr-menu-background,hsla(0,0%,100%,.9));content:"";height:0;position:absolute;right:.37333rem;right:calc(var(--plyr-control-icon-size, 18px)/2 + var(--plyr-control-spacing, 10px)*.7 - var(--plyr-menu-arrow-size, 4px)/2);top:100%;width:0}.plyr__menu__container [role=menu]{padding:.18667rem;padding:calc(var(--plyr-control-spacing, 10px)*.7)}.plyr__menu__container [role=menuitem],.plyr__menu__container [role=menuitemradio]{margin-top:.05333rem}.plyr__menu__container [role=menuitem]:first-child,.plyr__menu__container [role=menuitemradio]:first-child{margin-top:0}.plyr__menu__container .plyr__control{align-items:center;color:#4a5464;color:var(--plyr-menu-color,#4a5464);display:flex;font-size:.34667rem;font-size:var(--plyr-font-size-menu,var(--plyr-font-size-small,13px));padding:.12444rem .28rem;padding:calc(var(--plyr-control-spacing, 10px)*.7/1.5) calc(var(--plyr-control-spacing, 10px)*.7*1.5);-webkit-user-select:none;user-select:none;width:100%}.plyr__menu__container .plyr__control>span{align-items:inherit;display:flex;width:100%}.plyr__menu__container .plyr__control:after{border:.10667rem solid transparent;border:var(--plyr-menu-item-arrow-size,4px) solid transparent;content:"";position:absolute;top:50%;transform:translateY(-50%)}.plyr__menu__container .plyr__control--forward{padding-right:.74667rem;padding-right:calc(var(--plyr-control-spacing, 10px)*.7*4)}.plyr__menu__container .plyr__control--forward:after{border-left-color:#728197;border-left-color:var(--plyr-menu-arrow-color,#728197);right:.17333rem;right:calc(var(--plyr-control-spacing, 10px)*.7*1.5 - var(--plyr-menu-item-arrow-size, 4px))}.plyr__menu__container .plyr__control--forward.plyr__tab-focus:after,.plyr__menu__container .plyr__control--forward:hover:after{border-left-color:currentColor}.plyr__menu__container .plyr__control--back{font-weight:400;font-weight:var(--plyr-font-weight-regular,400);margin:.18667rem;margin:calc(var(--plyr-control-spacing, 10px)*.7);margin-bottom:.09333rem;margin-bottom:calc(var(--plyr-control-spacing, 10px)*.7/2);padding-left:.74667rem;padding-left:calc(var(--plyr-control-spacing, 10px)*.7*4);position:relative;width:calc(100% - 0.37333rem);width:calc(100% - var(--plyr-control-spacing, 10px)*.7*2)}.plyr__menu__container .plyr__control--back:after{border-right-color:#728197;border-right-color:var(--plyr-menu-arrow-color,#728197);left:.17333rem;left:calc(var(--plyr-control-spacing, 10px)*.7*1.5 - var(--plyr-menu-item-arrow-size, 4px))}.plyr__menu__container .plyr__control--back:before{background:#dcdfe5;background:var(--plyr-menu-back-border-color,#dcdfe5);box-shadow:0 .02667rem #fff;box-shadow:0 .02667rem 0 var(--plyr-menu-back-border-shadow-color,#fff);content:"";height:.02667rem;left:0;margin-top:.09333rem;margin-top:calc(var(--plyr-control-spacing, 10px)*.7/2);overflow:hidden;position:absolute;right:0;top:100%}.plyr__menu__container .plyr__control--back.plyr__tab-focus:after,.plyr__menu__container .plyr__control--back:hover:after{border-right-color:currentColor}.plyr__menu__container .plyr__control[role=menuitemradio]{padding-left:.18667rem;padding-left:calc(var(--plyr-control-spacing, 10px)*.7)}.plyr__menu__container .plyr__control[role=menuitemradio]:after,.plyr__menu__container .plyr__control[role=menuitemradio]:before{border-radius:100%}.plyr__menu__container .plyr__control[role=menuitemradio]:before{background:rgba(0,0,0,.1);content:"";display:block;flex-shrink:0;height:.42667rem;margin-right:.26667rem;margin-right:var(--plyr-control-spacing,10px);transition:all .3s ease;width:.42667rem}.plyr__menu__container .plyr__control[role=menuitemradio]:after{background:#fff;border:0;height:.16rem;left:.32rem;opacity:0;top:50%;transform:translateY(-50%) scale(0);transition:transform .3s ease,opacity .3s ease;width:.16rem}.plyr__menu__container .plyr__control[role=menuitemradio][aria-checked=true]:before{background:#00b2ff;background:var(--plyr-control-toggle-checked-background,var(--plyr-color-main,var(--plyr-color-main,#00b2ff)))}.plyr__menu__container .plyr__control[role=menuitemradio][aria-checked=true]:after{opacity:1;transform:translateY(-50%) scale(1)}.plyr__menu__container .plyr__control[role=menuitemradio].plyr__tab-focus:before,.plyr__menu__container .plyr__control[role=menuitemradio]:hover:before{background:rgba(35,40,47,.1)}.plyr__menu__container .plyr__menu__value{align-items:center;display:flex;margin-left:auto;margin-right:calc(-0.18667rem + 2);margin-right:calc(var(--plyr-control-spacing, 10px)*.7*-1 - -2);overflow:hidden;padding-left:.65333rem;padding-left:calc(var(--plyr-control-spacing, 10px)*.7*3.5);pointer-events:none}.plyr--full-ui input[type=range]{-webkit-appearance:none;appearance:none;background:transparent;border:0;border-radius:.69333rem;border-radius:calc(var(--plyr-range-thumb-height, 13px)*2);color:#00b2ff;color:var(--plyr-range-fill-background,var(--plyr-color-main,var(--plyr-color-main,#00b2ff)));display:block;height:.50667rem;height:calc(var(--plyr-range-thumb-active-shadow-width, 3px)*2 + var(--plyr-range-thumb-height, 13px));margin:0;min-width:0;padding:0;transition:box-shadow .3s ease;width:100%}.plyr--full-ui input[type=range]::-webkit-slider-runnable-track{background:transparent;background-image:linear-gradient(90deg,currentColor 0,transparent 0);background-image:linear-gradient(to right,currentColor var(--value,0),transparent var(--value,0));border:0;border-radius:.06667rem;border-radius:calc(var(--plyr-range-track-height, 5px)/2);height:.13333rem;height:var(--plyr-range-track-height,5px);-webkit-transition:box-shadow .3s ease;transition:box-shadow .3s ease;-webkit-user-select:none;user-select:none}.plyr--full-ui input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#fff;background:var(--plyr-range-thumb-background,#fff);border:0;border-radius:100%;box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2));height:.34667rem;height:var(--plyr-range-thumb-height,13px);margin-top:-.10667rem;margin-top:calc((var(--plyr-range-thumb-height, 13px) - var(--plyr-range-track-height, 5px))/2*-1);position:relative;-webkit-transition:all .2s ease;transition:all .2s ease;width:.34667rem;width:var(--plyr-range-thumb-height,13px)}.plyr--full-ui input[type=range]::-moz-range-track{background:transparent;border:0;border-radius:.06667rem;border-radius:calc(var(--plyr-range-track-height, 5px)/2);height:.13333rem;height:var(--plyr-range-track-height,5px);-moz-transition:box-shadow .3s ease;transition:box-shadow .3s ease;user-select:none}.plyr--full-ui input[type=range]::-moz-range-thumb{background:#fff;background:var(--plyr-range-thumb-background,#fff);border:0;border-radius:100%;box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2));height:.34667rem;height:var(--plyr-range-thumb-height,13px);position:relative;-moz-transition:all .2s ease;transition:all .2s ease;width:.34667rem;width:var(--plyr-range-thumb-height,13px)}.plyr--full-ui input[type=range]::-moz-range-progress{background:currentColor;border-radius:.06667rem;border-radius:calc(var(--plyr-range-track-height, 5px)/2);height:.13333rem;height:var(--plyr-range-track-height,5px)}.plyr--full-ui input[type=range]::-ms-track{color:transparent}.plyr--full-ui input[type=range]::-ms-fill-upper,.plyr--full-ui input[type=range]::-ms-track{background:transparent;border:0;border-radius:.06667rem;border-radius:calc(var(--plyr-range-track-height, 5px)/2);height:.13333rem;height:var(--plyr-range-track-height,5px);-ms-transition:box-shadow .3s ease;transition:box-shadow .3s ease;user-select:none}.plyr--full-ui input[type=range]::-ms-fill-lower{background:transparent;background:currentColor;border:0;border-radius:.06667rem;border-radius:calc(var(--plyr-range-track-height, 5px)/2);height:.13333rem;height:var(--plyr-range-track-height,5px);-ms-transition:box-shadow .3s ease;transition:box-shadow .3s ease;user-select:none}.plyr--full-ui input[type=range]::-ms-thumb{background:#fff;background:var(--plyr-range-thumb-background,#fff);border:0;border-radius:100%;box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2));height:.34667rem;height:var(--plyr-range-thumb-height,13px);margin-top:0;position:relative;-ms-transition:all .2s ease;transition:all .2s ease;width:.34667rem;width:var(--plyr-range-thumb-height,13px)}.plyr--full-ui input[type=range]::-ms-tooltip{display:none}.plyr--full-ui input[type=range]::-moz-focus-outer{border:0}.plyr--full-ui input[type=range]:focus{outline:0}.plyr--full-ui input[type=range].plyr__tab-focus::-webkit-slider-runnable-track{outline:.08rem dotted #00b2ff;outline:var(--plyr-tab-focus-color,var(--plyr-color-main,var(--plyr-color-main,#00b2ff))) dotted .08rem;outline-offset:.05333rem}.plyr--full-ui input[type=range].plyr__tab-focus::-moz-range-track{outline:.08rem dotted #00b2ff;outline:var(--plyr-tab-focus-color,var(--plyr-color-main,var(--plyr-color-main,#00b2ff))) dotted .08rem;outline-offset:.05333rem}.plyr--full-ui input[type=range].plyr__tab-focus::-ms-track{outline:.08rem dotted #00b2ff;outline:var(--plyr-tab-focus-color,var(--plyr-color-main,var(--plyr-color-main,#00b2ff))) dotted .08rem;outline-offset:.05333rem}.plyr__poster{background-color:#000;background-color:var(--plyr-video-background,var(--plyr-video-background,#000));background-position:50% 50%;background-repeat:no-repeat;background-size:contain;height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .2s ease;width:100%;z-index:1}.plyr--stopped.plyr__poster-enabled .plyr__poster{opacity:1}.plyr--youtube.plyr--paused.plyr__poster-enabled:not(.plyr--stopped) .plyr__poster{display:none}.plyr__time{font-size:.34667rem;font-size:var(--plyr-font-size-time,var(--plyr-font-size-small,13px))}.plyr__time+.plyr__time:before{content:"\\2044";margin-right:.26667rem;margin-right:var(--plyr-control-spacing,10px)}@media (max-width:767px){.plyr__time+.plyr__time{display:none}}.plyr__tooltip{background:hsla(0,0%,100%,.9);background:var(--plyr-tooltip-background,hsla(0,0%,100%,.9));border-radius:.13333rem;border-radius:var(--plyr-tooltip-radius,5px);bottom:100%;box-shadow:0 .02667rem .05333rem rgba(0,0,0,.15);box-shadow:var(--plyr-tooltip-shadow,0 1px 2px rgba(0,0,0,.15));color:#4a5464;color:var(--plyr-tooltip-color,#4a5464);font-size:.34667rem;font-size:var(--plyr-font-size-small,13px);font-weight:400;font-weight:var(--plyr-font-weight-regular,400);left:50%;line-height:1.3;margin-bottom:.26667rem;margin-bottom:calc(var(--plyr-control-spacing, 10px)/2*2);opacity:0;padding:.13333rem .2rem;padding:calc(var(--plyr-control-spacing, 10px)/2) calc(var(--plyr-control-spacing, 10px)/2*1.5);pointer-events:none;position:absolute;transform:translate(-50%,.26667rem) scale(.8);transform-origin:50% 100%;transition:transform .2s ease .1s,opacity .2s ease .1s;white-space:nowrap;z-index:2}.plyr__tooltip:before{border-left:.10667rem solid transparent;border-left:var(--plyr-tooltip-arrow-size,4px) solid transparent;border-right:.10667rem solid transparent;border-right:var(--plyr-tooltip-arrow-size,4px) solid transparent;border-top:.10667rem solid hsla(0,0%,100%,.9);border-top:var(--plyr-tooltip-arrow-size,4px) solid var(--plyr-tooltip-background,hsla(0,0%,100%,.9));bottom:-.10667rem;bottom:calc(var(--plyr-tooltip-arrow-size, 4px)*-1);content:"";height:0;left:50%;position:absolute;transform:translate(-50%);width:0;z-index:2}.plyr .plyr__control.plyr__tab-focus .plyr__tooltip,.plyr .plyr__control:hover .plyr__tooltip,.plyr__tooltip--visible{opacity:1;transform:translate(-50%) scale(1)}.plyr .plyr__control:hover .plyr__tooltip{z-index:3}.plyr__controls>.plyr__control:first-child .plyr__tooltip,.plyr__controls>.plyr__control:first-child+.plyr__control .plyr__tooltip{left:0;transform:translateY(.26667rem) scale(.8);transform-origin:0 100%}.plyr__controls>.plyr__control:first-child .plyr__tooltip:before,.plyr__controls>.plyr__control:first-child+.plyr__control .plyr__tooltip:before{left:.42667rem;left:calc(var(--plyr-control-icon-size, 18px)/2 + var(--plyr-control-spacing, 10px)*.7)}.plyr__controls>.plyr__control:last-child .plyr__tooltip{left:auto;right:0;transform:translateY(.26667rem) scale(.8);transform-origin:100% 100%}.plyr__controls>.plyr__control:last-child .plyr__tooltip:before{left:auto;right:.42667rem;right:calc(var(--plyr-control-icon-size, 18px)/2 + var(--plyr-control-spacing, 10px)*.7);transform:translate(50%)}.plyr__controls>.plyr__control:first-child .plyr__tooltip--visible,.plyr__controls>.plyr__control:first-child+.plyr__control .plyr__tooltip--visible,.plyr__controls>.plyr__control:first-child+.plyr__control.plyr__tab-focus .plyr__tooltip,.plyr__controls>.plyr__control:first-child+.plyr__control:hover .plyr__tooltip,.plyr__controls>.plyr__control:first-child.plyr__tab-focus .plyr__tooltip,.plyr__controls>.plyr__control:first-child:hover .plyr__tooltip,.plyr__controls>.plyr__control:last-child .plyr__tooltip--visible,.plyr__controls>.plyr__control:last-child.plyr__tab-focus .plyr__tooltip,.plyr__controls>.plyr__control:last-child:hover .plyr__tooltip{transform:translate(0) scale(1)}.plyr__progress{left:.17333rem;left:calc(var(--plyr-range-thumb-height, 13px)*.5);margin-right:.34667rem;margin-right:var(--plyr-range-thumb-height,13px);position:relative}.plyr__progress input[type=range],.plyr__progress__buffer{margin-left:-.17333rem;margin-left:calc(var(--plyr-range-thumb-height, 13px)*-.5);margin-right:-.17333rem;margin-right:calc(var(--plyr-range-thumb-height, 13px)*-.5);width:calc(100% + 0.34667rem);width:calc(100% + var(--plyr-range-thumb-height, 13px))}.plyr__progress input[type=range]{position:relative;z-index:2}.plyr__progress .plyr__tooltip{left:0;max-width:3.2rem;overflow-wrap:break-word;white-space:normal}.plyr__progress__buffer{-webkit-appearance:none;background:transparent;border:0;border-radius:2.66667rem;height:.13333rem;height:var(--plyr-range-track-height,5px);left:0;margin-top:-.06667rem;margin-top:calc((var(--plyr-range-track-height, 5px)/2)*-1);padding:0;position:absolute;top:50%}.plyr__progress__buffer::-webkit-progress-bar{background:transparent}.plyr__progress__buffer::-webkit-progress-value{background:currentColor;border-radius:2.66667rem;min-width:.13333rem;min-width:var(--plyr-range-track-height,5px);-webkit-transition:width .2s ease;transition:width .2s ease}.plyr__progress__buffer::-moz-progress-bar{background:currentColor;border-radius:2.66667rem;min-width:.13333rem;min-width:var(--plyr-range-track-height,5px);-moz-transition:width .2s ease;transition:width .2s ease}.plyr__progress__buffer::-ms-fill{border-radius:2.66667rem;-ms-transition:width .2s ease;transition:width .2s ease}.plyr--loading .plyr__progress__buffer{animation:plyr-progress 1s linear infinite;background-image:linear-gradient(-45deg,rgba(35,40,47,.6) 25%,transparent 0,transparent 50%,rgba(35,40,47,.6) 0,rgba(35,40,47,.6) 75%,transparent 0,transparent);background-image:linear-gradient(-45deg,var(--plyr-progress-loading-background,rgba(35,40,47,.6)) 25%,transparent 25%,transparent 50%,var(--plyr-progress-loading-background,rgba(35,40,47,.6)) 50%,var(--plyr-progress-loading-background,rgba(35,40,47,.6)) 75%,transparent 75%,transparent);background-repeat:repeat-x;background-size:.66667rem .66667rem;background-size:var(--plyr-progress-loading-size,25px) var(--plyr-progress-loading-size,25px);color:transparent}.plyr--video.plyr--loading .plyr__progress__buffer{background-color:rgba(255,255,255,.25);background-color:var(--plyr-video-progress-buffered-background,hsla(0,0%,100%,.25))}.plyr--audio.plyr--loading .plyr__progress__buffer{background-color:rgba(193,200,209,.6);background-color:var(--plyr-audio-progress-buffered-background,rgba(193,200,209,.6))}.plyr__progress__marker{background-color:#fff;background-color:var(--plyr-progress-marker-background,#fff);border-radius:.02667rem;height:.13333rem;height:var(--plyr-range-track-height,5px);position:absolute;top:50%;transform:translate(-50%,-50%);width:.08rem;width:var(--plyr-progress-marker-width,3px);z-index:3}.plyr__volume{align-items:center;display:flex;max-width:2.93333rem;min-width:2.13333rem;position:relative;width:20%}.plyr__volume input[type=range]{margin-left:.13333rem;margin-left:calc(var(--plyr-control-spacing, 10px)/2);margin-right:.13333rem;margin-right:calc(var(--plyr-control-spacing, 10px)/2);position:relative;z-index:2}.plyr--is-ios .plyr__volume{min-width:0;width:auto}.plyr--audio{display:block}.plyr--audio .plyr__controls{background:#fff;background:var(--plyr-audio-controls-background,#fff);border-radius:inherit;color:#4a5464;color:var(--plyr-audio-control-color,#4a5464);padding:.26667rem;padding:var(--plyr-control-spacing,10px)}.plyr--audio .plyr__control.plyr__tab-focus,.plyr--audio .plyr__control:hover,.plyr--audio .plyr__control[aria-expanded=true]{background:#00b2ff;background:var(--plyr-audio-control-background-hover,var(--plyr-color-main,var(--plyr-color-main,#00b2ff)));color:#fff;color:var(--plyr-audio-control-color-hover,#fff)}.plyr--full-ui.plyr--audio input[type=range]::-webkit-slider-runnable-track{background-color:rgba(193,200,209,.6);background-color:var(--plyr-audio-range-track-background,var(--plyr-audio-progress-buffered-background,rgba(193,200,209,.6)))}.plyr--full-ui.plyr--audio input[type=range]::-moz-range-track{background-color:rgba(193,200,209,.6);background-color:var(--plyr-audio-range-track-background,var(--plyr-audio-progress-buffered-background,rgba(193,200,209,.6)))}.plyr--full-ui.plyr--audio input[type=range]::-ms-track{background-color:rgba(193,200,209,.6);background-color:var(--plyr-audio-range-track-background,var(--plyr-audio-progress-buffered-background,rgba(193,200,209,.6)))}.plyr--full-ui.plyr--audio input[type=range]:active::-webkit-slider-thumb{box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2),0 0 0 .08rem rgba(35,40,47,.1);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2)),0 0 0 var(--plyr-range-thumb-active-shadow-width,3px) var(--plyr-audio-range-thumb-active-shadow-color,rgba(35,40,47,.1))}.plyr--full-ui.plyr--audio input[type=range]:active::-moz-range-thumb{box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2),0 0 0 .08rem rgba(35,40,47,.1);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2)),0 0 0 var(--plyr-range-thumb-active-shadow-width,3px) var(--plyr-audio-range-thumb-active-shadow-color,rgba(35,40,47,.1))}.plyr--full-ui.plyr--audio input[type=range]:active::-ms-thumb{box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2),0 0 0 .08rem rgba(35,40,47,.1);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2)),0 0 0 var(--plyr-range-thumb-active-shadow-width,3px) var(--plyr-audio-range-thumb-active-shadow-color,rgba(35,40,47,.1))}.plyr--audio .plyr__progress__buffer{color:rgba(193,200,209,.6);color:var(--plyr-audio-progress-buffered-background,rgba(193,200,209,.6))}.plyr--video{background:#000;background:var(--plyr-video-background,var(--plyr-video-background,#000));overflow:hidden}.plyr--video.plyr--menu-open{overflow:visible}.plyr__video-wrapper{background:#000;background:var(--plyr-video-background,var(--plyr-video-background,#000));height:100%;margin:auto;overflow:hidden;position:relative;width:100%}.plyr__video-embed,.plyr__video-wrapper--fixed-ratio{aspect-ratio:16/9}@supports not (aspect-ratio:16/9){.plyr__video-embed,.plyr__video-wrapper--fixed-ratio{height:0;padding-bottom:56.25%;position:relative}}.plyr__video-embed iframe,.plyr__video-wrapper--fixed-ratio video{border:0;height:100%;left:0;position:absolute;top:0;width:100%}.plyr--full-ui .plyr__video-embed>.plyr__video-embed__container{padding-bottom:240%;position:relative;transform:translateY(-38.28125%)}.plyr--video .plyr__controls{background:linear-gradient(transparent,rgba(0,0,0,.75));background:var(--plyr-video-controls-background,linear-gradient(transparent,rgba(0,0,0,.75)));border-bottom-left-radius:inherit;border-bottom-right-radius:inherit;bottom:0;color:#fff;color:var(--plyr-video-control-color,#fff);left:0;padding:.13333rem;padding:calc(var(--plyr-control-spacing, 10px)/2);padding-top:.53333rem;padding-top:calc(var(--plyr-control-spacing, 10px)*2);position:absolute;right:0;transition:opacity .4s ease-in-out,transform .4s ease-in-out;z-index:3}@media (min-width:480px){.plyr--video .plyr__controls{padding:.26667rem;padding:var(--plyr-control-spacing,10px);padding-top:.93333rem;padding-top:calc(var(--plyr-control-spacing, 10px)*3.5)}}.plyr--video.plyr--hide-controls .plyr__controls{opacity:0;pointer-events:none;transform:translateY(100%)}.plyr--video .plyr__control.plyr__tab-focus,.plyr--video .plyr__control:hover,.plyr--video .plyr__control[aria-expanded=true]{background:#00b2ff;background:var(--plyr-video-control-background-hover,var(--plyr-color-main,var(--plyr-color-main,#00b2ff)));color:#fff;color:var(--plyr-video-control-color-hover,#fff)}.plyr__control--overlaid{background:#00b2ff;background:var(--plyr-video-control-background-hover,var(--plyr-color-main,var(--plyr-color-main,#00b2ff)));border:0;border-radius:100%;color:#fff;color:var(--plyr-video-control-color,#fff);display:none;left:50%;opacity:.9;padding:.4rem;padding:calc(var(--plyr-control-spacing, 10px)*1.5);position:absolute;top:50%;transform:translate(-50%,-50%);transition:.3s;z-index:2}.plyr__control--overlaid svg{left:.05333rem;position:relative}.plyr__control--overlaid:focus,.plyr__control--overlaid:hover{opacity:1}.plyr--playing .plyr__control--overlaid{opacity:0;visibility:hidden}.plyr--full-ui.plyr--video .plyr__control--overlaid{display:block}.plyr--full-ui.plyr--video input[type=range]::-webkit-slider-runnable-track{background-color:rgba(255,255,255,.25);background-color:var(--plyr-video-range-track-background,var(--plyr-video-progress-buffered-background,hsla(0,0%,100%,.25)))}.plyr--full-ui.plyr--video input[type=range]::-moz-range-track{background-color:rgba(255,255,255,.25);background-color:var(--plyr-video-range-track-background,var(--plyr-video-progress-buffered-background,hsla(0,0%,100%,.25)))}.plyr--full-ui.plyr--video input[type=range]::-ms-track{background-color:rgba(255,255,255,.25);background-color:var(--plyr-video-range-track-background,var(--plyr-video-progress-buffered-background,hsla(0,0%,100%,.25)))}.plyr--full-ui.plyr--video input[type=range]:active::-webkit-slider-thumb{box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2),0 0 0 .08rem rgba(255,255,255,.5);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2)),0 0 0 var(--plyr-range-thumb-active-shadow-width,3px) var(--plyr-audio-range-thumb-active-shadow-color,hsla(0,0%,100%,.5))}.plyr--full-ui.plyr--video input[type=range]:active::-moz-range-thumb{box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2),0 0 0 .08rem rgba(255,255,255,.5);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2)),0 0 0 var(--plyr-range-thumb-active-shadow-width,3px) var(--plyr-audio-range-thumb-active-shadow-color,hsla(0,0%,100%,.5))}.plyr--full-ui.plyr--video input[type=range]:active::-ms-thumb{box-shadow:0 .02667rem .02667rem rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2),0 0 0 .08rem rgba(255,255,255,.5);box-shadow:var(--plyr-range-thumb-shadow,0 1px 1px rgba(35,40,47,.15),0 0 0 .02667rem rgba(35,40,47,.2)),0 0 0 var(--plyr-range-thumb-active-shadow-width,3px) var(--plyr-audio-range-thumb-active-shadow-color,hsla(0,0%,100%,.5))}.plyr--video .plyr__progress__buffer{color:rgba(255,255,255,.25);color:var(--plyr-video-progress-buffered-background,hsla(0,0%,100%,.25))}.plyr:-webkit-full-screen{background:#000;border-radius:0!important;height:100%;margin:0;width:100%}.plyr:fullscreen{background:#000;border-radius:0!important;height:100%;margin:0;width:100%}.plyr:-webkit-full-screen video{height:100%}.plyr:fullscreen video{height:100%}.plyr:-webkit-full-screen .plyr__control .icon--exit-fullscreen{display:block}.plyr:fullscreen .plyr__control .icon--exit-fullscreen{display:block}.plyr:-webkit-full-screen .plyr__control .icon--exit-fullscreen+svg{display:none}.plyr:fullscreen .plyr__control .icon--exit-fullscreen+svg{display:none}.plyr:-webkit-full-screen.plyr--hide-controls{cursor:none}.plyr:fullscreen.plyr--hide-controls{cursor:none}@media (min-width:1024px){.plyr:-webkit-full-screen .plyr__captions{font-size:.56rem;font-size:var(--plyr-font-size-xlarge,21px)}.plyr:fullscreen .plyr__captions{font-size:.56rem;font-size:var(--plyr-font-size-xlarge,21px)}}.plyr--fullscreen-fallback{background:#000;border-radius:0!important;bottom:0;display:block;height:100%;left:0;margin:0;position:fixed;right:0;top:0;width:100%;z-index:10000000}.plyr--fullscreen-fallback video{height:100%}.plyr--fullscreen-fallback .plyr__control .icon--exit-fullscreen{display:block}.plyr--fullscreen-fallback .plyr__control .icon--exit-fullscreen+svg{display:none}.plyr--fullscreen-fallback.plyr--hide-controls{cursor:none}@media (min-width:1024px){.plyr--fullscreen-fallback .plyr__captions{font-size:.56rem;font-size:var(--plyr-font-size-xlarge,21px)}}.plyr__ads{border-radius:inherit;bottom:0;cursor:pointer;left:0;overflow:hidden;position:absolute;right:0;top:0;z-index:-1}.plyr__ads>div,.plyr__ads>div iframe{height:100%;position:absolute;width:100%}.plyr__ads:after{background:#23282f;border-radius:.05333rem;bottom:.26667rem;bottom:var(--plyr-control-spacing,10px);color:#fff;content:attr(data-badge-text);font-size:.29333rem;padding:.05333rem .16rem;pointer-events:none;position:absolute;right:.26667rem;right:var(--plyr-control-spacing,10px);z-index:3}.plyr__ads:empty:after{display:none}.plyr__cues{background:currentColor;display:block;height:.13333rem;height:var(--plyr-range-track-height,5px);left:0;opacity:.8;position:absolute;top:50%;transform:translateY(-50%);width:.08rem;z-index:3}.plyr__preview-thumb{background-color:rgba(255,255,255,.9);background-color:var(--plyr-tooltip-background,hsla(0,0%,100%,.9));border-radius:.13333rem;border-radius:var(--plyr-tooltip-radius,5px);bottom:100%;box-shadow:0 .02667rem .05333rem rgba(0,0,0,.15);box-shadow:var(--plyr-tooltip-shadow,0 1px 2px rgba(0,0,0,.15));margin-bottom:.26667rem;margin-bottom:calc(var(--plyr-control-spacing, 10px)/2*2);opacity:0;padding:.08rem;pointer-events:none;position:absolute;transform:translateY(.26667rem) scale(.8);transform-origin:50% 100%;transition:transform .2s ease .1s,opacity .2s ease .1s;z-index:2}.plyr__preview-thumb--is-shown{opacity:1;transform:translate(0) scale(1)}.plyr__preview-thumb:before{border-left:.10667rem solid transparent;border-left:var(--plyr-tooltip-arrow-size,4px) solid transparent;border-right:.10667rem solid transparent;border-right:var(--plyr-tooltip-arrow-size,4px) solid transparent;border-top:.10667rem solid hsla(0,0%,100%,.9);border-top:var(--plyr-tooltip-arrow-size,4px) solid var(--plyr-tooltip-background,hsla(0,0%,100%,.9));bottom:-.10667rem;bottom:calc(var(--plyr-tooltip-arrow-size, 4px)*-1);content:"";height:0;left:calc(50% + var(--preview-arrow-offset));position:absolute;transform:translate(-50%);width:0;z-index:2}.plyr__preview-thumb__image-container{background:#c1c8d1;border-radius:.10667rem;border-radius:calc(var(--plyr-tooltip-radius, 5px) - .02667rem);overflow:hidden;position:relative;z-index:0}.plyr__preview-thumb__image-container img,.plyr__preview-thumb__image-container:after{height:100%;left:0;position:absolute;top:0;width:100%}.plyr__preview-thumb__image-container:after{border-radius:inherit;box-shadow:inset 0 0 0 .02667rem rgba(0,0,0,.15);content:"";pointer-events:none}.plyr__preview-thumb__image-container img{max-height:none;max-width:none}.plyr__preview-thumb__time-container{background:linear-gradient(transparent,rgba(0,0,0,.75));background:var(--plyr-video-controls-background,linear-gradient(transparent,rgba(0,0,0,.75)));border-bottom-left-radius:.10667rem;border-bottom-left-radius:calc(var(--plyr-tooltip-radius, 5px) - .02667rem);border-bottom-right-radius:.10667rem;border-bottom-right-radius:calc(var(--plyr-tooltip-radius, 5px) - .02667rem);bottom:0;left:0;line-height:1.1;padding:.53333rem .16rem .16rem;position:absolute;right:0;z-index:3}.plyr__preview-thumb__time-container span{color:#fff;font-size:.34667rem;font-size:var(--plyr-font-size-time,var(--plyr-font-size-small,13px))}.plyr__preview-scrubbing{bottom:0;filter:blur(.02667rem);height:100%;left:0;margin:auto;opacity:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s ease;width:100%;z-index:1}.plyr__preview-scrubbing--is-shown{opacity:1}.plyr__preview-scrubbing img{height:100%;left:0;max-height:none;max-width:none;object-fit:contain;position:absolute;top:0;width:100%}.plyr--no-transition{transition:none!important}.plyr__sr-only{clip:rect(.02667rem,.02667rem,.02667rem,.02667rem);border:0!important;height:.02667rem!important;overflow:hidden;padding:0!important;position:absolute!important;width:.02667rem!important}.plyr [hidden]{display:none!important}\n' document.head.appendChild(__vite_style__) System.register( ['./vendor-legacy.09f20d09.js', './index-legacy.595c24c3.js'], function (exports) { 'use strict' var defineComponent, createVNode, Loading, createTextVNode, Fragment, Icon, Button, Toast, listenerMessage, browser$1, postMessage, state return { setters: [ function (module) { defineComponent = module.d createVNode = module.a Loading = module.L createTextVNode = module.j Fragment = module.F Icon = module.K Button = module.B Toast = module.T }, function (module) { listenerMessage = module.l browser$1 = module.b postMessage = module.p state = module.s } ], execute: function execute() { var video = '_video_1vz16_1' var loadingVideo = '_loadingVideo_1vz16_35' var playOver = '_playOver_1vz16_44' var tips = '_tips_1vz16_52' var btn = '_btn_1vz16_56' var freeTxt = '_freeTxt_1vz16_59' var freeRate = '_freeRate_1vz16_65' var styles = { 'video-container': '_video-container_1vz16_1', video: video, loadingVideo: loadingVideo, playOver: playOver, tips: tips, btn: btn, freeTxt: freeTxt, freeRate: freeRate } function _defineProperty$1(e, t, i) { return ( t in e ? Object.defineProperty(e, t, { value: i, enumerable: !0, configurable: !0, writable: !0 }) : (e[t] = i), e ) } function _classCallCheck(e, t) { if (!(e instanceof t)) throw new TypeError('Cannot call a class as a function') } function _defineProperties(e, t) { for (var i = 0; i < t.length; i++) { var s = t[i] ;(s.enumerable = s.enumerable || !1), (s.configurable = !0), 'value' in s && (s.writable = !0), Object.defineProperty(e, s.key, s) } } function _createClass(e, t, i) { return ( t && _defineProperties(e.prototype, t), i && _defineProperties(e, i), e ) } function _defineProperty(e, t, i) { return ( t in e ? Object.defineProperty(e, t, { value: i, enumerable: !0, configurable: !0, writable: !0 }) : (e[t] = i), e ) } function ownKeys(e, t) { var i = Object.keys(e) if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e) t && (s = s.filter(function (t) { return Object.getOwnPropertyDescriptor(e, t).enumerable })), i.push.apply(i, s) } return i } function _objectSpread2(e) { for (var t = 1; t < arguments.length; t++) { var i = null != arguments[t] ? arguments[t] : {} t % 2 ? ownKeys(Object(i), !0).forEach(function (t) { _defineProperty(e, t, i[t]) }) : Object.getOwnPropertyDescriptors ? Object.defineProperties( e, Object.getOwnPropertyDescriptors(i) ) : ownKeys(Object(i)).forEach(function (t) { Object.defineProperty( e, t, Object.getOwnPropertyDescriptor(i, t) ) }) } return e } var defaults$1 = { addCSS: !0, thumbWidth: 15, watch: !0 } function matches$1(e, t) { return function () { return Array.from(document.querySelectorAll(t)).includes(this) }.call(e, t) } function trigger(e, t) { if (e && t) { var i = new Event(t, { bubbles: !0 }) e.dispatchEvent(i) } } var getConstructor$1 = function getConstructor$1(e) { return null != e ? e.constructor : null }, instanceOf$1 = function instanceOf$1(e, t) { return !!(e && t && e instanceof t) }, isNullOrUndefined$1 = function isNullOrUndefined$1(e) { return null == e }, isObject$1 = function isObject$1(e) { return getConstructor$1(e) === Object }, isNumber$1 = function isNumber$1(e) { return getConstructor$1(e) === Number && !Number.isNaN(e) }, isString$1 = function isString$1(e) { return getConstructor$1(e) === String }, isBoolean$1 = function isBoolean$1(e) { return getConstructor$1(e) === Boolean }, isFunction$1 = function isFunction$1(e) { return getConstructor$1(e) === Function }, isArray$1 = function isArray$1(e) { return Array.isArray(e) }, isNodeList$1 = function isNodeList$1(e) { return instanceOf$1(e, NodeList) }, isElement$1 = function isElement$1(e) { return instanceOf$1(e, Element) }, isEvent$1 = function isEvent$1(e) { return instanceOf$1(e, Event) }, isEmpty$1 = function isEmpty$1(e) { return ( isNullOrUndefined$1(e) || ((isString$1(e) || isArray$1(e) || isNodeList$1(e)) && !e.length) || (isObject$1(e) && !Object.keys(e).length) ) }, is$1 = { nullOrUndefined: isNullOrUndefined$1, object: isObject$1, number: isNumber$1, string: isString$1, boolean: isBoolean$1, function: isFunction$1, array: isArray$1, nodeList: isNodeList$1, element: isElement$1, event: isEvent$1, empty: isEmpty$1 } function getDecimalPlaces(e) { var t = ''.concat(e).match(/(?:\.(\d+))?(?:[eE]([+-]?\d+))?$/) return t ? Math.max(0, (t[1] ? t[1].length : 0) - (t[2] ? +t[2] : 0)) : 0 } function round(e, t) { if (1 > t) { var i = getDecimalPlaces(t) return parseFloat(e.toFixed(i)) } return Math.round(e / t) * t } var RangeTouch = (function () { function e(t, i) { _classCallCheck(this, e), is$1.element(t) ? (this.element = t) : is$1.string(t) && (this.element = document.querySelector(t)), is$1.element(this.element) && is$1.empty(this.element.rangeTouch) && ((this.config = _objectSpread2({}, defaults$1, {}, i)), this.init()) } return ( _createClass( e, [ { key: 'init', value: function value() { e.enabled && (this.config.addCSS && ((this.element.style.userSelect = 'none'), (this.element.style.webKitUserSelect = 'none'), (this.element.style.touchAction = 'manipulation')), this.listeners(!0), (this.element.rangeTouch = this)) } }, { key: 'destroy', value: function value() { e.enabled && (this.config.addCSS && ((this.element.style.userSelect = ''), (this.element.style.webKitUserSelect = ''), (this.element.style.touchAction = '')), this.listeners(!1), (this.element.rangeTouch = null)) } }, { key: 'listeners', value: function value(e) { var t = this, i = e ? 'addEventListener' : 'removeEventListener' ;['touchstart', 'touchmove', 'touchend'].forEach( function (e) { t.element[i]( e, function (e) { return t.set(e) }, !1 ) } ) } }, { key: 'get', value: function value(t) { if (!e.enabled || !is$1.event(t)) return null var i, s = t.target, n = t.changedTouches[0], r = parseFloat(s.getAttribute('min')) || 0, a = parseFloat(s.getAttribute('max')) || 100, o = parseFloat(s.getAttribute('step')) || 1, l = s.getBoundingClientRect(), c = ((100 / l.width) * (this.config.thumbWidth / 2)) / 100 return ( 0 > (i = (100 / l.width) * (n.clientX - l.left)) ? (i = 0) : 100 < i && (i = 100), 50 > i ? (i -= (100 - 2 * i) * c) : 50 < i && (i += 2 * (i - 50) * c), r + round((i / 100) * (a - r), o) ) } }, { key: 'set', value: function value(t) { e.enabled && is$1.event(t) && !t.target.disabled && (t.preventDefault(), (t.target.value = this.get(t)), trigger( t.target, 'touchend' === t.type ? 'change' : 'input' )) } } ], [ { key: 'setup', value: function value(t) { var i = 1 < arguments.length && void 0 !== arguments[1] ? arguments[1] : {}, s = null if ( (is$1.empty(t) || is$1.string(t) ? (s = Array.from( document.querySelectorAll( is$1.string(t) ? t : 'input[type="range"]' ) )) : is$1.element(t) ? (s = [t]) : is$1.nodeList(t) ? (s = Array.from(t)) : is$1.array(t) && (s = t.filter(is$1.element)), is$1.empty(s)) ) return null var n = _objectSpread2({}, defaults$1, {}, i) if (is$1.string(t) && n.watch) { var r = new MutationObserver(function (i) { Array.from(i).forEach(function (i) { Array.from(i.addedNodes).forEach(function (i) { is$1.element(i) && matches$1(i, t) && new e(i, n) }) }) }) r.observe(document.body, { childList: !0, subtree: !0 }) } return s.map(function (t) { return new e(t, i) }) } }, { key: 'enabled', get: function get() { return 'ontouchstart' in document.documentElement } } ] ), e ) })() var getConstructor = function getConstructor(e) { return null != e ? e.constructor : null }, instanceOf = function instanceOf(e, t) { return Boolean(e && t && e instanceof t) }, isNullOrUndefined = function isNullOrUndefined(e) { return null == e }, isObject = function isObject(e) { return getConstructor(e) === Object }, isNumber = function isNumber(e) { return getConstructor(e) === Number && !Number.isNaN(e) }, isString = function isString(e) { return getConstructor(e) === String }, isBoolean = function isBoolean(e) { return getConstructor(e) === Boolean }, isFunction = function isFunction(e) { return getConstructor(e) === Function }, isArray = function isArray(e) { return Array.isArray(e) }, isWeakMap = function isWeakMap(e) { return instanceOf(e, WeakMap) }, isNodeList = function isNodeList(e) { return instanceOf(e, NodeList) }, isTextNode = function isTextNode(e) { return getConstructor(e) === Text }, isEvent = function isEvent(e) { return instanceOf(e, Event) }, isKeyboardEvent = function isKeyboardEvent(e) { return instanceOf(e, KeyboardEvent) }, isCue = function isCue(e) { return ( instanceOf(e, window.TextTrackCue) || instanceOf(e, window.VTTCue) ) }, isTrack = function isTrack(e) { return ( instanceOf(e, TextTrack) || (!isNullOrUndefined(e) && isString(e.kind)) ) }, isPromise = function isPromise(e) { return instanceOf(e, Promise) && isFunction(e.then) }, isElement = function isElement(e) { return ( null !== e && 'object' == _typeof(e) && 1 === e.nodeType && 'object' == _typeof(e.style) && 'object' == _typeof(e.ownerDocument) ) }, isEmpty = function isEmpty(e) { return ( isNullOrUndefined(e) || ((isString(e) || isArray(e) || isNodeList(e)) && !e.length) || (isObject(e) && !Object.keys(e).length) ) }, isUrl = function isUrl(e) { if (instanceOf(e, window.URL)) return !0 if (!isString(e)) return !1 var t = e ;(e.startsWith('http://') && e.startsWith('https://')) || (t = 'http://'.concat(e)) try { return !isEmpty(new URL(t).hostname) } catch (e) { return !1 } } var is = { nullOrUndefined: isNullOrUndefined, object: isObject, number: isNumber, string: isString, boolean: isBoolean, function: isFunction, array: isArray, weakMap: isWeakMap, nodeList: isNodeList, element: isElement, textNode: isTextNode, event: isEvent, keyboardEvent: isKeyboardEvent, cue: isCue, track: isTrack, promise: isPromise, url: isUrl, empty: isEmpty } var transitionEndEvent = (function () { var e = document.createElement('span'), t = { WebkitTransition: 'webkitTransitionEnd', MozTransition: 'transitionend', OTransition: 'oTransitionEnd otransitionend', transition: 'transitionend' }, i = Object.keys(t).find(function (t) { return void 0 !== e.style[t] }) return !!is.string(i) && t[i] })() function repaint(e, t) { setTimeout(function () { try { ;(e.hidden = !0), e.offsetHeight, (e.hidden = !1) } catch (e) {} }, t) } var browser = { isIE: Boolean(window.document.documentMode), isEdge: window.navigator.userAgent.includes('Edge'), isWebkit: 'WebkitAppearance' in document.documentElement.style && !/Edge/.test(navigator.userAgent), isIPhone: /(iPhone|iPod)/gi.test(navigator.platform), isIos: ('MacIntel' === navigator.platform && navigator.maxTouchPoints > 1) || /(iPad|iPhone|iPod)/gi.test(navigator.platform) } function cloneDeep(e) { return JSON.parse(JSON.stringify(e)) } function getDeep(e, t) { return t.split('.').reduce(function (e, t) { return e && e[t] }, e) } function extend() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {} for ( var _len = arguments.length, t = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++ ) { t[_key - 1] = arguments[_key] } if (!t.length) return e var i = t.shift() return is.object(i) ? (Object.keys(i).forEach(function (t) { is.object(i[t]) ? (Object.keys(e).includes(t) || Object.assign(e, _defineProperty2({}, t, {})), extend(e[t], i[t])) : Object.assign(e, _defineProperty2({}, t, i[t])) }), extend.apply(void 0, [e].concat(t))) : e } function wrap(e, t) { var i = e.length ? e : [e] Array.from(i) .reverse() .forEach(function (e, i) { var s = i > 0 ? t.cloneNode(!0) : t, n = e.parentNode, r = e.nextSibling s.appendChild(e), r ? n.insertBefore(s, r) : n.appendChild(s) }) } function setAttributes(e, t) { is.element(e) && !is.empty(t) && Object.entries(t) .filter(function (_ref) { var _ref2 = _slicedToArray(_ref, 2), e = _ref2[1] return !is.nullOrUndefined(e) }) .forEach(function (_ref3) { var _ref4 = _slicedToArray(_ref3, 2), t = _ref4[0], i = _ref4[1] return e.setAttribute(t, i) }) } function createElement(e, t, i) { var s = document.createElement(e) return ( is.object(t) && setAttributes(s, t), is.string(i) && (s.innerText = i), s ) } function insertAfter(e, t) { is.element(e) && is.element(t) && t.parentNode.insertBefore(e, t.nextSibling) } function insertElement(e, t, i, s) { is.element(t) && t.appendChild(createElement(e, i, s)) } function removeElement(e) { is.nodeList(e) || is.array(e) ? Array.from(e).forEach(removeElement) : is.element(e) && is.element(e.parentNode) && e.parentNode.removeChild(e) } function emptyElement(e) { if (!is.element(e)) return var t = e.childNodes.length for (; t > 0; ) { e.removeChild(e.lastChild), (t -= 1) } } function replaceElement(e, t) { return is.element(t) && is.element(t.parentNode) && is.element(e) ? (t.parentNode.replaceChild(e, t), e) : null } function getAttributesFromSelector(e, t) { if (!is.string(e) || is.empty(e)) return {} var i = {}, s = extend({}, t) return ( e.split(',').forEach(function (e) { var t = e.trim(), n = t.replace('.', ''), r = t.replace(/[[\]]/g, '').split('='), _r = _slicedToArray(r, 1), a = _r[0], o = r.length > 1 ? r[1].replace(/["']/g, '') : '' switch (t.charAt(0)) { case '.': is.string(s.class) ? (i.class = ''.concat(s.class, ' ').concat(n)) : (i.class = n) break case '#': i.id = t.replace('#', '') break case '[': i[a] = o } }), extend(s, i) ) } function toggleHidden(e, t) { if (!is.element(e)) return var i = t is.boolean(i) || (i = !e.hidden), (e.hidden = i) } function toggleClass(e, t, i) { if (is.nodeList(e)) return Array.from(e).map(function (e) { return toggleClass(e, t, i) }) if (is.element(e)) { var s = 'toggle' return ( void 0 !== i && (s = i ? 'add' : 'remove'), e.classList[s](t), e.classList.contains(t) ) } return !1 } function hasClass(e, t) { return is.element(e) && e.classList.contains(t) } function matches(e, t) { var _Element = Element, i = _Element.prototype return ( i.matches || i.webkitMatchesSelector || i.mozMatchesSelector || i.msMatchesSelector || function () { return Array.from(document.querySelectorAll(t)).includes(this) } ).call(e, t) } function closest$1(e, t) { var _Element2 = Element, i = _Element2.prototype return ( i.closest || function () { var e = this do { if (matches.matches(e, t)) return e e = e.parentElement || e.parentNode } while (null !== e && 1 === e.nodeType) return null } ).call(e, t) } function getElements(e) { return this.elements.container.querySelectorAll(e) } function getElement(e) { return this.elements.container.querySelector(e) } function setFocus() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1 is.element(e) && (e.focus({ preventScroll: !0 }), t && toggleClass(e, this.config.classNames.tabFocus)) } var defaultCodecs = { 'audio/ogg': 'vorbis', 'audio/wav': '1', 'video/webm': 'vp8, vorbis', 'video/mp4': 'avc1.42E01E, mp4a.40.2', 'video/ogg': 'theora' }, support = { audio: 'canPlayType' in document.createElement('audio'), video: 'canPlayType' in document.createElement('video'), check: function check(e, t, i) { var s = browser.isIPhone && i && support.playsinline, n = support[e] || 'html5' !== t return { api: n, ui: n && support.rangeInput && ('video' !== e || !browser.isIPhone || s) } }, pip: !( browser.isIPhone || (!is.function( createElement('video').webkitSetPresentationMode ) && (!document.pictureInPictureEnabled || createElement('video').disablePictureInPicture)) ), airplay: is.function( window.WebKitPlaybackTargetAvailabilityEvent ), playsinline: 'playsInline' in document.createElement('video'), mime: function mime(e) { if (is.empty(e)) return !1 var _e$split = e.split('/'), _e$split2 = _slicedToArray(_e$split, 1), t = _e$split2[0] var i = e if (!this.isHTML5 || t !== this.type) return !1 Object.keys(defaultCodecs).includes(i) && (i += '; codecs="'.concat(defaultCodecs[e], '"')) try { return Boolean( i && this.media.canPlayType(i).replace(/no/, '') ) } catch (e) { return !1 } }, textTracks: 'textTracks' in document.createElement('video'), rangeInput: (function () { var e = document.createElement('input') return (e.type = 'range'), 'range' === e.type })(), touch: 'ontouchstart' in document.documentElement, transitions: !1 !== transitionEndEvent, reducedMotion: 'matchMedia' in window && window.matchMedia('(prefers-reduced-motion)').matches }, supportsPassiveListeners = (function () { var e = !1 try { var t = Object.defineProperty({}, 'passive', { get: function get() { return (e = !0), null } }) window.addEventListener('test', null, t), window.removeEventListener('test', null, t) } catch (e) {} return e })() function toggleListener(e, t, i) { var _this2 = this var s = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : !1 var n = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : !0 var r = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : !1 if ( !e || !('addEventListener' in e) || is.empty(t) || !is.function(i) ) return var a = t.split(' ') var o = r supportsPassiveListeners && (o = { passive: n, capture: r }), a.forEach(function (t) { _this2 && _this2.eventListeners && s && _this2.eventListeners.push({ element: e, type: t, callback: i, options: o }), e[s ? 'addEventListener' : 'removeEventListener'](t, i, o) }) } function on(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '' var i = arguments.length > 2 ? arguments[2] : undefined var s = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : !0 var n = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : !1 toggleListener.call(this, e, t, i, !0, s, n) } function off(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '' var i = arguments.length > 2 ? arguments[2] : undefined var s = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : !0 var n = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : !1 toggleListener.call(this, e, t, i, !1, s, n) } function once(e) { var _this3 = this var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '' var i = arguments.length > 2 ? arguments[2] : undefined var s = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : !0 var n = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : !1 var r = function r() { for ( var _len2 = arguments.length, a = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++ ) { a[_key2] = arguments[_key2] } off(e, t, r, s, n), i.apply(_this3, a) } toggleListener.call(this, e, t, r, !0, s, n) } function triggerEvent(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '' var i = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : !1 var s = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {} if (!is.element(e) || is.empty(t)) return var n = new CustomEvent(t, { bubbles: i, detail: _objectSpread(_objectSpread({}, s), {}, { plyr: this }) }) e.dispatchEvent(n) } function unbindListeners() { this && this.eventListeners && (this.eventListeners.forEach(function (e) { var t = e.element, i = e.type, s = e.callback, n = e.options t.removeEventListener(i, s, n) }), (this.eventListeners = [])) } function ready() { var _this4 = this return new Promise(function (e) { return _this4.ready ? setTimeout(e, 0) : on.call(_this4, _this4.elements.container, 'ready', e) }).then(function () {}) } function silencePromise(e) { is.promise(e) && e.then(null, function () {}) } function dedupe(e) { return is.array(e) ? e.filter(function (t, i) { return e.indexOf(t) === i }) : e } function closest(e, t) { return is.array(e) && e.length ? e.reduce(function (e, i) { return Math.abs(i - t) < Math.abs(e - t) ? i : e }) : null } function supportsCSS(e) { return !(!window || !window.CSS) && window.CSS.supports(e) } var standardRatios = [ [1, 1], [4, 3], [3, 4], [5, 4], [4, 5], [3, 2], [2, 3], [16, 10], [10, 16], [16, 9], [9, 16], [21, 9], [9, 21], [32, 9], [9, 32] ].reduce(function (e, _ref5) { var _ref6 = _slicedToArray(_ref5, 2), t = _ref6[0], i = _ref6[1] return _objectSpread( _objectSpread({}, e), {}, _defineProperty2({}, t / i, [t, i]) ) }, {}) function validateAspectRatio(e) { if (!(is.array(e) || (is.string(e) && e.includes(':')))) return !1 return (is.array(e) ? e : e.split(':')).map(Number).every(is.number) } function reduceAspectRatio(e) { if (!is.array(e) || !e.every(is.number)) return null var _e2 = _slicedToArray(e, 2), t = _e2[0], i = _e2[1], s = function s(e, t) { return 0 === t ? e : s(t, e % t) }, n = s(t, i) return [t / n, i / n] } function getAspectRatio(e) { var _this$embed var t = function t(e) { return validateAspectRatio(e) ? e.split(':').map(Number) : null } var i = t(e) if ( (null === i && (i = t(this.config.ratio)), null === i && !is.empty(this.embed) && is.array(this.embed.ratio) && ((_this$embed = this.embed), (i = _this$embed.ratio), _this$embed), null === i && this.isHTML5) ) { var _this$media = this.media, _e3 = _this$media.videoWidth, _t = _this$media.videoHeight i = [_e3, _t] } return reduceAspectRatio(i) } function setAspectRatio(e) { if (!this.isVideo) return {} var t = this.elements.wrapper, i = getAspectRatio.call(this, e) if (!is.array(i)) return {} var _reduceAspectRatio = reduceAspectRatio(i), _reduceAspectRatio2 = _slicedToArray(_reduceAspectRatio, 2), s = _reduceAspectRatio2[0], n = _reduceAspectRatio2[1], r = (100 / s) * n if ( (supportsCSS('aspect-ratio: '.concat(s, '/').concat(n)) ? (t.style.aspectRatio = ''.concat(s, '/').concat(n)) : (t.style.paddingBottom = ''.concat(r, '%')), this.isVimeo && !this.config.vimeo.premium && this.supported.ui) ) { var _e4 = (100 / this.media.offsetWidth) * parseInt( window.getComputedStyle(this.media).paddingBottom, 10 ), _i2 = (_e4 - r) / (_e4 / 50) this.fullscreen.active ? (t.style.paddingBottom = null) : (this.media.style.transform = 'translateY(-'.concat( _i2, '%)' )) } else this.isHTML5 && t.classList.add(this.config.classNames.videoFixedRatio) return { padding: r, ratio: i } } function roundAspectRatio(e, t) { var i = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0.05 var s = e / t, n = closest(Object.keys(standardRatios), s) return Math.abs(n - s) <= i ? standardRatios[n] : [e, t] } function getViewportSize() { return [ Math.max( document.documentElement.clientWidth || 0, window.innerWidth || 0 ), Math.max( document.documentElement.clientHeight || 0, window.innerHeight || 0 ) ] } var html5 = { getSources: function getSources() { var _this5 = this if (!this.isHTML5) return [] return Array.from(this.media.querySelectorAll('source')).filter( function (e) { var t = e.getAttribute('type') return !!is.empty(t) || support.mime.call(_this5, t) } ) }, getQualityOptions: function getQualityOptions() { return this.config.quality.forced ? this.config.quality.options : html5.getSources .call(this) .map(function (e) { return Number(e.getAttribute('size')) }) .filter(Boolean) }, setup: function setup() { if (!this.isHTML5) return var e = this ;(e.options.speed = e.config.speed.options), is.empty(this.config.ratio) || setAspectRatio.call(e), Object.defineProperty(e.media, 'quality', { get: function get() { var t = html5.getSources.call(e).find(function (t) { return t.getAttribute('src') === e.source }) return t && Number(t.getAttribute('size')) }, set: function set(t) { if (e.quality !== t) { if ( e.config.quality.forced && is.function(e.config.quality.onChange) ) e.config.quality.onChange(t) else { var i = html5.getSources.call(e).find(function (e) { return Number(e.getAttribute('size')) === t }) if (!i) return var _e$media = e.media, s = _e$media.currentTime, n = _e$media.paused, r = _e$media.preload, a = _e$media.readyState, o = _e$media.playbackRate ;(e.media.src = i.getAttribute('src')), ('none' !== r || a) && (e.once('loadedmetadata', function () { ;(e.speed = o), (e.currentTime = s), n || silencePromise(e.play()) }), e.media.load()) } triggerEvent.call(e, e.media, 'qualitychange', !1, { quality: t }) } } }) }, cancelRequests: function cancelRequests() { this.isHTML5 && (removeElement(html5.getSources.call(this)), this.media.setAttribute('src', this.config.blankVideo), this.media.load(), this.debug.log('Cancelled network requests')) } } function generateId(e) { return ''.concat(e, '-').concat(Math.floor(1e4 * Math.random())) } function format(e) { for ( var _len3 = arguments.length, t = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++ ) { t[_key3 - 1] = arguments[_key3] } return is.empty(e) ? e : e.toString().replace(/{(\d+)}/g, function (e, i) { return t[i].toString() }) } function getPercentage(e, t) { return 0 === e || 0 === t || Number.isNaN(e) || Number.isNaN(t) ? 0 : ((e / t) * 100).toFixed(2) } var replaceAll = function replaceAll() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '' var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '' var i = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '' return e.replace( new RegExp( t.toString().replace(/([.*+?^=!:${}()|[\]/\\])/g, '\\$1'), 'g' ), i.toString() ) }, toTitleCase = function toTitleCase() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '' return e.toString().replace(/\w\S*/g, function (e) { return e.charAt(0).toUpperCase() + e.slice(1).toLowerCase() }) } function toPascalCase() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '' var t = e.toString() return ( (t = replaceAll(t, '-', ' ')), (t = replaceAll(t, '_', ' ')), (t = toTitleCase(t)), replaceAll(t, ' ', '') ) } function toCamelCase() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '' var t = e.toString() return (t = toPascalCase(t)), t.charAt(0).toLowerCase() + t.slice(1) } function stripHTML(e) { var t = document.createDocumentFragment(), i = document.createElement('div') return t.appendChild(i), (i.innerHTML = e), t.firstChild.innerText } function getHTML(e) { var t = document.createElement('div') return t.appendChild(e), t.innerHTML } var resources = { pip: 'PIP', airplay: 'AirPlay', html5: 'HTML5', vimeo: 'Vimeo', youtube: 'YouTube' }, i18n = { get: function get() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '' var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {} if (is.empty(e) || is.empty(t)) return '' var i = getDeep(t.i18n, e) if (is.empty(i)) return Object.keys(resources).includes(e) ? resources[e] : '' var s = { '{seektime}': t.seekTime, '{title}': t.title } return ( Object.entries(s).forEach(function (_ref7) { var _ref8 = _slicedToArray(_ref7, 2), e = _ref8[0], t = _ref8[1] i = replaceAll(i, e, t) }), i ) } } var Storage = /*#__PURE__*/ (function () { function Storage(e) { var _this6 = this _classCallCheck2(this, Storage) _defineProperty$1(this, 'get', function (e) { if (!Storage.supported || !_this6.enabled) return null var t = window.localStorage.getItem(_this6.key) if (is.empty(t)) return null var i = JSON.parse(t) return is.string(e) && e.length ? i[e] : i }), _defineProperty$1(this, 'set', function (e) { if (!Storage.supported || !_this6.enabled) return if (!is.object(e)) return var t = _this6.get() is.empty(t) && (t = {}), extend(t, e) try { window.localStorage.setItem(_this6.key, JSON.stringify(t)) } catch (e) {} }), (this.enabled = e.config.storage.enabled), (this.key = e.config.storage.key) } _createClass2(Storage, null, [ { key: 'supported', get: function get() { try { if (!('localStorage' in window)) return !1 var e = '___test' return ( window.localStorage.setItem(e, e), window.localStorage.removeItem(e), !0 ) } catch (e) { return !1 } } } ]) return Storage })() function fetch(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'text' return new Promise(function (i, s) { try { var _s2 = new XMLHttpRequest() if (!('withCredentials' in _s2)) return _s2.addEventListener('load', function () { if ('text' === t) try { i(JSON.parse(_s2.responseText)) } catch (e) { i(_s2.responseText) } else i(_s2.response) }), _s2.addEventListener('error', function () { throw new Error(_s2.status) }), _s2.open('GET', e, !0), (_s2.responseType = t), _s2.send() } catch (e) { s(e) } }) } function _loadSprite(e, t) { if (!is.string(e)) return var i = is.string(t) var s = !1 var n = function n() { return null !== document.getElementById(t) }, r = function r(e, t) { ;(e.innerHTML = t), (i && n()) || document.body.insertAdjacentElement('afterbegin', e) } if (!i || !n()) { var _n2 = Storage.supported, a = document.createElement('div') if ( (a.setAttribute('hidden', ''), i && a.setAttribute('id', t), _n2) ) { var _e5 = window.localStorage.getItem('cache-'.concat(t)) if (((s = null !== _e5), s)) { var _t2 = JSON.parse(_e5) r(a, _t2.content) } } fetch(e) .then(function (e) { if (!is.empty(e)) { if (_n2) try { window.localStorage.setItem( 'cache-'.concat(t), JSON.stringify({ content: e }) ) } catch (e) {} r(a, e) } }) .catch(function () {}) } } var getHours = function getHours(e) { return Math.trunc((e / 60 / 60) % 60, 10) }, getSeconds = function getSeconds(e) { return Math.trunc(e % 60, 10) } function _formatTime() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0 var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1 var i = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : !1 if (!is.number(e)) return _formatTime(void 0, t, i) var s = function s(e) { return '0'.concat(e).slice(-2) } var n = getHours(e) var r = ((a = e), Math.trunc((a / 60) % 60, 10)) var a var o = getSeconds(e) return ( (n = t || n > 0 ? ''.concat(n, ':') : ''), '' .concat(i && e > 0 ? '-' : '') .concat(n) .concat(s(r), ':') .concat(s(o)) ) } var controls = { getIconUrl: function getIconUrl() { var e = new URL(this.config.iconUrl, window.location), t = window.location.host ? window.location.host : window.top.location.host, i = e.host !== t || (browser.isIE && !window.svg4everybody) return { url: this.config.iconUrl, cors: i } }, findElements: function findElements() { try { return ( (this.elements.controls = getElement.call( this, this.config.selectors.controls.wrapper )), (this.elements.buttons = { play: getElements.call( this, this.config.selectors.buttons.play ), pause: getElement.call( this, this.config.selectors.buttons.pause ), restart: getElement.call( this, this.config.selectors.buttons.restart ), rewind: getElement.call( this, this.config.selectors.buttons.rewind ), fastForward: getElement.call( this, this.config.selectors.buttons.fastForward ), mute: getElement.call( this, this.config.selectors.buttons.mute ), pip: getElement.call( this, this.config.selectors.buttons.pip ), airplay: getElement.call( this, this.config.selectors.buttons.airplay ), settings: getElement.call( this, this.config.selectors.buttons.settings ), captions: getElement.call( this, this.config.selectors.buttons.captions ), fullscreen: getElement.call( this, this.config.selectors.buttons.fullscreen ) }), (this.elements.progress = getElement.call( this, this.config.selectors.progress )), (this.elements.inputs = { seek: getElement.call( this, this.config.selectors.inputs.seek ), volume: getElement.call( this, this.config.selectors.inputs.volume ) }), (this.elements.display = { buffer: getElement.call( this, this.config.selectors.display.buffer ), currentTime: getElement.call( this, this.config.selectors.display.currentTime ), duration: getElement.call( this, this.config.selectors.display.duration ) }), is.element(this.elements.progress) && (this.elements.display.seekTooltip = this.elements.progress.querySelector( '.'.concat(this.config.classNames.tooltip) )), !0 ) } catch (e) { return ( this.debug.warn( 'It looks like there is a problem with your custom controls HTML', e ), this.toggleNativeControls(!0), !1 ) } }, createIcon: function createIcon(e, t) { var i = 'http://www.w3.org/2000/svg', s = controls.getIconUrl.call(this), n = '' .concat(s.cors ? '' : s.url, '#') .concat(this.config.iconPrefix), r = document.createElementNS(i, 'svg') setAttributes( r, extend(t, { 'aria-hidden': 'true', focusable: 'false' }) ) var a = document.createElementNS(i, 'use'), o = ''.concat(n, '-').concat(e) return ( 'href' in a && a.setAttributeNS('http://www.w3.org/1999/xlink', 'href', o), a.setAttributeNS( 'http://www.w3.org/1999/xlink', 'xlink:href', o ), r.appendChild(a), r ) }, createLabel: function createLabel(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {} var i = i18n.get(e, this.config) return createElement( 'span', _objectSpread( _objectSpread({}, t), {}, { class: [t.class, this.config.classNames.hidden] .filter(Boolean) .join(' ') } ), i ) }, createBadge: function createBadge(e) { if (is.empty(e)) return null var t = createElement('span', { class: this.config.classNames.menu.value }) return ( t.appendChild( createElement( 'span', { class: this.config.classNames.menu.badge }, e ) ), t ) }, createButton: function createButton(e, t) { var _this7 = this var i = extend({}, t) var s = toCamelCase(e) var n = { element: 'button', toggle: !1, label: null, icon: null, labelPressed: null, iconPressed: null } switch ( (['element', 'icon', 'label'].forEach(function (e) { Object.keys(i).includes(e) && ((n[e] = i[e]), delete i[e]) }), 'button' !== n.element || Object.keys(i).includes('type') || (i.type = 'button'), Object.keys(i).includes('class') ? i.class.split(' ').some(function (e) { return e === _this7.config.classNames.control }) || extend(i, { class: '' .concat(i.class, ' ') .concat(this.config.classNames.control) }) : (i.class = this.config.classNames.control), e) ) { case 'play': ;(n.toggle = !0), (n.label = 'play'), (n.labelPressed = 'pause'), (n.icon = 'play'), (n.iconPressed = 'pause') break case 'mute': ;(n.toggle = !0), (n.label = 'mute'), (n.labelPressed = 'unmute'), (n.icon = 'volume'), (n.iconPressed = 'muted') break case 'captions': ;(n.toggle = !0), (n.label = 'enableCaptions'), (n.labelPressed = 'disableCaptions'), (n.icon = 'captions-off'), (n.iconPressed = 'captions-on') break case 'fullscreen': ;(n.toggle = !0), (n.label = 'enterFullscreen'), (n.labelPressed = 'exitFullscreen'), (n.icon = 'enter-fullscreen'), (n.iconPressed = 'exit-fullscreen') break case 'play-large': ;(i.class += ' '.concat( this.config.classNames.control, '--overlaid' )), (s = 'play'), (n.label = 'play'), (n.icon = 'play') break default: is.empty(n.label) && (n.label = s), is.empty(n.icon) && (n.icon = e) } var r = createElement(n.element) return ( n.toggle ? (r.appendChild( controls.createIcon.call(this, n.iconPressed, { class: 'icon--pressed' }) ), r.appendChild( controls.createIcon.call(this, n.icon, { class: 'icon--not-pressed' }) ), r.appendChild( controls.createLabel.call(this, n.labelPressed, { class: 'label--pressed' }) ), r.appendChild( controls.createLabel.call(this, n.label, { class: 'label--not-pressed' }) )) : (r.appendChild(controls.createIcon.call(this, n.icon)), r.appendChild(controls.createLabel.call(this, n.label))), extend( i, getAttributesFromSelector(this.config.selectors.buttons[s], i) ), setAttributes(r, i), 'play' === s ? (is.array(this.elements.buttons[s]) || (this.elements.buttons[s] = []), this.elements.buttons[s].push(r)) : (this.elements.buttons[s] = r), r ) }, createRange: function createRange(e, t) { var i = createElement( 'input', extend( getAttributesFromSelector(this.config.selectors.inputs[e]), { type: 'range', min: 0, max: 100, step: 0.01, value: 0, autocomplete: 'off', role: 'slider', 'aria-label': i18n.get(e, this.config), 'aria-valuemin': 0, 'aria-valuemax': 100, 'aria-valuenow': 0 }, t ) ) return ( (this.elements.inputs[e] = i), controls.updateRangeFill.call(this, i), RangeTouch.setup(i), i ) }, createProgress: function createProgress(e, t) { var i = createElement( 'progress', extend( getAttributesFromSelector(this.config.selectors.display[e]), { min: 0, max: 100, value: 0, role: 'progressbar', 'aria-hidden': !0 }, t ) ) if ('volume' !== e) { i.appendChild(createElement('span', null, '0')) var _t3 = { played: 'played', buffer: 'buffered' }[e], s = _t3 ? i18n.get(_t3, this.config) : '' i.innerText = '% '.concat(s.toLowerCase()) } return (this.elements.display[e] = i), i }, createTime: function createTime(e, t) { var i = getAttributesFromSelector( this.config.selectors.display[e], t ), s = createElement( 'div', extend(i, { class: '' .concat(i.class ? i.class : '', ' ') .concat(this.config.classNames.display.time, ' ') .trim(), 'aria-label': i18n.get(e, this.config) }), '00:00' ) return (this.elements.display[e] = s), s }, bindMenuItemShortcuts: function bindMenuItemShortcuts(e, t) { var _this8 = this on.call( this, e, 'keydown keyup', function (i) { if ( !['Space', 'ArrowUp', 'ArrowDown', 'ArrowRight'].includes( i.key ) ) return if ( (i.preventDefault(), i.stopPropagation(), 'keydown' === i.type) ) return var s = matches(e, '[role="menuitemradio"]') if (!s && ['Space', 'ArrowRight'].includes(i.key)) controls.showMenuPanel.call(_this8, t, !0) else { var _t4 'Space' !== i.key && ('ArrowDown' === i.key || (s && 'ArrowRight' === i.key) ? ((_t4 = e.nextElementSibling), is.element(_t4) || (_t4 = e.parentNode.firstElementChild)) : ((_t4 = e.previousElementSibling), is.element(_t4) || (_t4 = e.parentNode.lastElementChild)), setFocus.call(_this8, _t4, !0)) } }, !1 ), on.call(this, e, 'keyup', function (e) { 'Return' === e.key && controls.focusFirstMenuItem.call(_this8, null, !0) }) }, createMenuItem: function createMenuItem(_ref9) { var _this9 = this var e = _ref9.value, t = _ref9.list, i = _ref9.type, s = _ref9.title, _ref9$badge = _ref9.badge, n = _ref9$badge === void 0 ? null : _ref9$badge, _ref9$checked = _ref9.checked, r = _ref9$checked === void 0 ? !1 : _ref9$checked var a = getAttributesFromSelector( this.config.selectors.inputs[i] ), o = createElement( 'button', extend(a, { type: 'button', role: 'menuitemradio', class: '' .concat(this.config.classNames.control, ' ') .concat(a.class ? a.class : '') .trim(), 'aria-checked': r, value: e }) ), l = createElement('span') ;(l.innerHTML = s), is.element(n) && l.appendChild(n), o.appendChild(l), Object.defineProperty(o, 'checked', { enumerable: !0, get: function get() { return 'true' === o.getAttribute('aria-checked') }, set: function set(e) { e && Array.from(o.parentNode.children) .filter(function (e) { return matches(e, '[role="menuitemradio"]') }) .forEach(function (e) { return e.setAttribute('aria-checked', 'false') }), o.setAttribute('aria-checked', e ? 'true' : 'false') } }), this.listeners.bind( o, 'click keyup', function (t) { if (!is.keyboardEvent(t) || 'Space' === t.key) { switch ( (t.preventDefault(), t.stopPropagation(), (o.checked = !0), i) ) { case 'language': _this9.currentTrack = Number(e) break case 'quality': _this9.quality = e break case 'speed': _this9.speed = parseFloat(e) } controls.showMenuPanel.call( _this9, 'home', is.keyboardEvent(t) ) } }, i, !1 ), controls.bindMenuItemShortcuts.call(this, o, i), t.appendChild(o) }, formatTime: function formatTime() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0 var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1 if (!is.number(e)) return e return _formatTime(e, getHours(this.duration) > 0, t) }, updateTimeDisplay: function updateTimeDisplay() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0 var i = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : !1 is.element(e) && is.number(t) && (e.innerText = controls.formatTime(t, i)) }, updateVolume: function updateVolume() { this.supported.ui && (is.element(this.elements.inputs.volume) && controls.setRange.call( this, this.elements.inputs.volume, this.muted ? 0 : this.volume ), is.element(this.elements.buttons.mute) && (this.elements.buttons.mute.pressed = this.muted || 0 === this.volume)) }, setRange: function setRange(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0 is.element(e) && ((e.value = t), controls.updateRangeFill.call(this, e)) }, updateProgress: function updateProgress(e) { var _this10 = this if (!this.supported.ui || !is.event(e)) return var t = 0 var i = function i(e, t) { var i = is.number(t) ? t : 0, s = is.element(e) ? e : _this10.elements.display.buffer if (is.element(s)) { s.value = i var _e6 = s.getElementsByTagName('span')[0] is.element(_e6) && (_e6.childNodes[0].nodeValue = i) } } if (e) switch (e.type) { case 'timeupdate': case 'seeking': case 'seeked': ;(t = getPercentage(this.currentTime, this.duration)), 'timeupdate' === e.type && controls.setRange.call( this, this.elements.inputs.seek, t ) break case 'playing': case 'progress': i(this.elements.display.buffer, 100 * this.buffered) } }, updateRangeFill: function updateRangeFill(e) { var t = is.event(e) ? e.target : e if (is.element(t) && 'range' === t.getAttribute('type')) { if (matches(t, this.config.selectors.inputs.seek)) { t.setAttribute('aria-valuenow', this.currentTime) var _e7 = controls.formatTime(this.currentTime), i = controls.formatTime(this.duration), s = i18n.get('seekLabel', this.config) t.setAttribute( 'aria-valuetext', s.replace('{currentTime}', _e7).replace('{duration}', i) ) } else if (matches(t, this.config.selectors.inputs.volume)) { var _e8 = 100 * t.value t.setAttribute('aria-valuenow', _e8), t.setAttribute( 'aria-valuetext', ''.concat(_e8.toFixed(1), '%') ) } else t.setAttribute('aria-valuenow', t.value) browser.isWebkit && t.style.setProperty('--value', (t.value / t.max) * 100 + '%') } }, updateSeekTooltip: function updateSeekTooltip(e) { var t, i if ( !this.config.tooltips.seek || !is.element(this.elements.inputs.seek) || !is.element(this.elements.display.seekTooltip) || 0 === this.duration ) return var s = this.elements.display.seekTooltip, n = ''.concat(this.config.classNames.tooltip, '--visible'), r = function r(e) { return toggleClass(s, n, e) } if (this.touch) return void r(!1) var a = 0 var o = this.elements.progress.getBoundingClientRect() if (is.event(e)) a = (100 / o.width) * (e.pageX - o.left) else { if (!hasClass(s, n)) return a = parseFloat(s.style.left, 10) } a < 0 ? (a = 0) : a > 100 && (a = 100) var l = (this.duration / 100) * a s.innerText = controls.formatTime(l) var c = null === (t = this.config.markers) || void 0 === t || null === (i = t.points) || void 0 === i ? void 0 : i.find(function (_ref10) { var e = _ref10.time return e === Math.round(l) }) c && s.insertAdjacentHTML('afterbegin', ''.concat(c.label, '
')), (s.style.left = ''.concat(a, '%')), is.event(e) && ['mouseenter', 'mouseleave'].includes(e.type) && r('mouseenter' === e.type) }, timeUpdate: function timeUpdate(e) { var t = !is.element(this.elements.display.duration) && this.config.invertTime controls.updateTimeDisplay.call( this, this.elements.display.currentTime, t ? this.duration - this.currentTime : this.currentTime, t ), (e && 'timeupdate' === e.type && this.media.seeking) || controls.updateProgress.call(this, e) }, durationUpdate: function durationUpdate() { if ( !this.supported.ui || (!this.config.invertTime && this.currentTime) ) return if (this.duration >= Math.pow(2, 32)) return ( toggleHidden(this.elements.display.currentTime, !0), void toggleHidden(this.elements.progress, !0) ) is.element(this.elements.inputs.seek) && this.elements.inputs.seek.setAttribute( 'aria-valuemax', this.duration ) var e = is.element(this.elements.display.duration) !e && this.config.displayDuration && this.paused && controls.updateTimeDisplay.call( this, this.elements.display.currentTime, this.duration ), e && controls.updateTimeDisplay.call( this, this.elements.display.duration, this.duration ), this.config.markers.enabled && controls.setMarkers.call(this), controls.updateSeekTooltip.call(this) }, toggleMenuButton: function toggleMenuButton(e, t) { toggleHidden(this.elements.settings.buttons[e], !t) }, updateSetting: function updateSetting(e, t, i) { var s = this.elements.settings.panels[e] var n = null, r = t if ('captions' === e) n = this.currentTrack else { if ( ((n = is.empty(i) ? this[e] : i), is.empty(n) && (n = this.config[e].default), !is.empty(this.options[e]) && !this.options[e].includes(n)) ) return void this.debug.warn( "Unsupported value of '".concat(n, "' for ").concat(e) ) if (!this.config[e].options.includes(n)) return void this.debug.warn( "Disabled value of '".concat(n, "' for ").concat(e) ) } if ( (is.element(r) || (r = s && s.querySelector('[role="menu"]')), !is.element(r)) ) return this.elements.settings.buttons[e].querySelector( '.'.concat(this.config.classNames.menu.value) ).innerHTML = controls.getLabel.call(this, e, n) var a = r && r.querySelector('[value="'.concat(n, '"]')) is.element(a) && (a.checked = !0) }, getLabel: function getLabel(e, t) { switch (e) { case 'speed': return 1 === t ? i18n.get('normal', this.config) : ''.concat(t, '×') case 'quality': if (is.number(t)) { var _e9 = i18n.get('qualityLabel.'.concat(t), this.config) return _e9.length ? _e9 : ''.concat(t, 'p') } return toTitleCase(t) case 'captions': return captions.getLabel.call(this) default: return null } }, setQualityMenu: function setQualityMenu(e) { var _this11 = this if (!is.element(this.elements.settings.panels.quality)) return var t = 'quality', i = this.elements.settings.panels.quality.querySelector( '[role="menu"]' ) is.array(e) && (this.options.quality = dedupe(e).filter(function (e) { return _this11.config.quality.options.includes(e) })) var s = !is.empty(this.options.quality) && this.options.quality.length > 1 if ( (controls.toggleMenuButton.call(this, t, s), emptyElement(i), controls.checkMenu.call(this), !s) ) return var n = function n(e) { var t = i18n.get('qualityBadge.'.concat(e), _this11.config) return t.length ? controls.createBadge.call(_this11, t) : null } this.options.quality .sort(function (e, t) { var i = _this11.config.quality.options return i.indexOf(e) > i.indexOf(t) ? 1 : -1 }) .forEach(function (e) { controls.createMenuItem.call(_this11, { value: e, list: i, type: t, title: controls.getLabel.call(_this11, 'quality', e), badge: n(e) }) }), controls.updateSetting.call(this, t, i) }, setCaptionsMenu: function setCaptionsMenu() { var _this12 = this if (!is.element(this.elements.settings.panels.captions)) return var e = 'captions', t = this.elements.settings.panels.captions.querySelector( '[role="menu"]' ), i = captions.getTracks.call(this), s = Boolean(i.length) if ( (controls.toggleMenuButton.call(this, e, s), emptyElement(t), controls.checkMenu.call(this), !s) ) return var n = i.map(function (e, i) { return { value: i, checked: _this12.captions.toggled && _this12.currentTrack === i, title: captions.getLabel.call(_this12, e), badge: e.language && controls.createBadge.call( _this12, e.language.toUpperCase() ), list: t, type: 'language' } }) n.unshift({ value: -1, checked: !this.captions.toggled, title: i18n.get('disabled', this.config), list: t, type: 'language' }), n.forEach(controls.createMenuItem.bind(this)), controls.updateSetting.call(this, e, t) }, setSpeedMenu: function setSpeedMenu() { var _this13 = this if (!is.element(this.elements.settings.panels.speed)) return var e = 'speed', t = this.elements.settings.panels.speed.querySelector( '[role="menu"]' ) this.options.speed = this.options.speed.filter(function (e) { return e >= _this13.minimumSpeed && e <= _this13.maximumSpeed }) var i = !is.empty(this.options.speed) && this.options.speed.length > 1 controls.toggleMenuButton.call(this, e, i), emptyElement(t), controls.checkMenu.call(this), i && (this.options.speed.forEach(function (i) { controls.createMenuItem.call(_this13, { value: i, list: t, type: e, title: controls.getLabel.call(_this13, 'speed', i) }) }), controls.updateSetting.call(this, e, t)) }, checkMenu: function checkMenu() { var e = this.elements.settings.buttons, t = !is.empty(e) && Object.values(e).some(function (e) { return !e.hidden }) toggleHidden(this.elements.settings.menu, !t) }, focusFirstMenuItem: function focusFirstMenuItem(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1 if (this.elements.settings.popup.hidden) return var i = e is.element(i) || (i = Object.values(this.elements.settings.panels).find( function (e) { return !e.hidden } )) var s = i.querySelector('[role^="menuitem"]') setFocus.call(this, s, t) }, toggleMenu: function toggleMenu(e) { var t = this.elements.settings.popup, i = this.elements.buttons.settings if (!is.element(t) || !is.element(i)) return var s = t.hidden var n = s if (is.boolean(e)) n = e else if (is.keyboardEvent(e) && 'Escape' === e.key) n = !1 else if (is.event(e)) { var _s3 = is.function(e.composedPath) ? e.composedPath()[0] : e.target, r = t.contains(_s3) if (r || (!r && e.target !== i && n)) return } i.setAttribute('aria-expanded', n), toggleHidden(t, !n), toggleClass( this.elements.container, this.config.classNames.menu.open, n ), n && is.keyboardEvent(e) ? controls.focusFirstMenuItem.call(this, null, !0) : n || s || setFocus.call(this, i, is.keyboardEvent(e)) }, getMenuSize: function getMenuSize(e) { var t = e.cloneNode(!0) ;(t.style.position = 'absolute'), (t.style.opacity = 0), t.removeAttribute('hidden'), e.parentNode.appendChild(t) var i = t.scrollWidth, s = t.scrollHeight return removeElement(t), { width: i, height: s } }, showMenuPanel: function showMenuPanel() { var _this14 = this var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '' var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1 var i = this.elements.container.querySelector( '#plyr-settings-'.concat(this.id, '-').concat(e) ) if (!is.element(i)) return var s = i.parentNode, n = Array.from(s.children).find(function (e) { return !e.hidden }) if (support.transitions && !support.reducedMotion) { ;(s.style.width = ''.concat(n.scrollWidth, 'px')), (s.style.height = ''.concat(n.scrollHeight, 'px')) var _e10 = controls.getMenuSize.call(this, i), _t5 = function _t5(e) { e.target === s && ['width', 'height'].includes(e.propertyName) && ((s.style.width = ''), (s.style.height = ''), off.call(_this14, s, transitionEndEvent, _t5)) } on.call(this, s, transitionEndEvent, _t5), (s.style.width = ''.concat(_e10.width, 'px')), (s.style.height = ''.concat(_e10.height, 'px')) } toggleHidden(n, !0), toggleHidden(i, !1), controls.focusFirstMenuItem.call(this, i, t) }, setDownloadUrl: function setDownloadUrl() { var e = this.elements.buttons.download is.element(e) && e.setAttribute('href', this.download) }, create: function create(e) { var _this15 = this var t = controls.bindMenuItemShortcuts, i = controls.createButton, s = controls.createProgress, n = controls.createRange, r = controls.createTime, a = controls.setQualityMenu, o = controls.setSpeedMenu, l = controls.showMenuPanel ;(this.elements.controls = null), is.array(this.config.controls) && this.config.controls.includes('play-large') && this.elements.container.appendChild( i.call(this, 'play-large') ) var c = createElement( 'div', getAttributesFromSelector( this.config.selectors.controls.wrapper ) ) this.elements.controls = c var u = { class: 'plyr__controls__item' } return ( dedupe( is.array(this.config.controls) ? this.config.controls : [] ).forEach(function (a) { if ( ('restart' === a && c.appendChild(i.call(_this15, 'restart', u)), 'rewind' === a && c.appendChild(i.call(_this15, 'rewind', u)), 'play' === a && c.appendChild(i.call(_this15, 'play', u)), 'fast-forward' === a && c.appendChild(i.call(_this15, 'fast-forward', u)), 'progress' === a) ) { var _t6 = createElement('div', { class: ''.concat(u.class, ' plyr__progress__container') }), _i3 = createElement( 'div', getAttributesFromSelector( _this15.config.selectors.progress ) ) if ( (_i3.appendChild( n.call(_this15, 'seek', { id: 'plyr-seek-'.concat(e.id) }) ), _i3.appendChild(s.call(_this15, 'buffer')), _this15.config.tooltips.seek) ) { var _e11 = createElement( 'span', { class: _this15.config.classNames.tooltip }, '00:00' ) _i3.appendChild(_e11), (_this15.elements.display.seekTooltip = _e11) } ;(_this15.elements.progress = _i3), _t6.appendChild(_this15.elements.progress), c.appendChild(_t6) } if ( ('current-time' === a && c.appendChild(r.call(_this15, 'currentTime', u)), 'duration' === a && c.appendChild(r.call(_this15, 'duration', u)), 'mute' === a || 'volume' === a) ) { var _t7 = _this15.elements.volume if ( ((is.element(_t7) && c.contains(_t7)) || ((_t7 = createElement( 'div', extend({}, u, { class: ''.concat(u.class, ' plyr__volume').trim() }) )), (_this15.elements.volume = _t7), c.appendChild(_t7)), 'mute' === a && _t7.appendChild(i.call(_this15, 'mute')), 'volume' === a && !browser.isIos) ) { var _i4 = { max: 1, step: 0.05, value: _this15.config.volume } _t7.appendChild( n.call( _this15, 'volume', extend(_i4, { id: 'plyr-volume-'.concat(e.id) }) ) ) } } if ( ('captions' === a && c.appendChild(i.call(_this15, 'captions', u)), 'settings' === a && !is.empty(_this15.config.settings)) ) { var _s4 = createElement( 'div', extend({}, u, { class: ''.concat(u.class, ' plyr__menu').trim(), hidden: '' }) ) _s4.appendChild( i.call(_this15, 'settings', { 'aria-haspopup': !0, 'aria-controls': 'plyr-settings-'.concat(e.id), 'aria-expanded': !1 }) ) var _n3 = createElement('div', { class: 'plyr__menu__container', id: 'plyr-settings-'.concat(e.id), hidden: '' }), _r2 = createElement('div'), _a = createElement('div', { id: 'plyr-settings-'.concat(e.id, '-home') }), _o = createElement('div', { role: 'menu' }) _a.appendChild(_o), _r2.appendChild(_a), (_this15.elements.settings.panels.home = _a), _this15.config.settings.forEach(function (i) { var s = createElement( 'button', extend( getAttributesFromSelector( _this15.config.selectors.buttons.settings ), { type: 'button', class: '' .concat(_this15.config.classNames.control, ' ') .concat( _this15.config.classNames.control, '--forward' ), role: 'menuitem', 'aria-haspopup': !0, hidden: '' } ) ) t.call(_this15, s, i), on.call(_this15, s, 'click', function () { l.call(_this15, i, !1) }) var n = createElement( 'span', null, i18n.get(i, _this15.config) ), a = createElement('span', { class: _this15.config.classNames.menu.value }) ;(a.innerHTML = e[i]), n.appendChild(a), s.appendChild(n), _o.appendChild(s) var c = createElement('div', { id: 'plyr-settings-'.concat(e.id, '-').concat(i), hidden: '' }), u = createElement('button', { type: 'button', class: '' .concat(_this15.config.classNames.control, ' ') .concat( _this15.config.classNames.control, '--back' ) }) u.appendChild( createElement( 'span', { 'aria-hidden': !0 }, i18n.get(i, _this15.config) ) ), u.appendChild( createElement( 'span', { class: _this15.config.classNames.hidden }, i18n.get('menuBack', _this15.config) ) ), on.call( _this15, c, 'keydown', function (e) { 'ArrowLeft' === e.key && (e.preventDefault(), e.stopPropagation(), l.call(_this15, 'home', !0)) }, !1 ), on.call(_this15, u, 'click', function () { l.call(_this15, 'home', !1) }), c.appendChild(u), c.appendChild(createElement('div', { role: 'menu' })), _r2.appendChild(c), (_this15.elements.settings.buttons[i] = s), (_this15.elements.settings.panels[i] = c) }), _n3.appendChild(_r2), _s4.appendChild(_n3), c.appendChild(_s4), (_this15.elements.settings.popup = _n3), (_this15.elements.settings.menu = _s4) } if ( ('pip' === a && support.pip && c.appendChild(i.call(_this15, 'pip', u)), 'airplay' === a && support.airplay && c.appendChild(i.call(_this15, 'airplay', u)), 'download' === a) ) { var _e12 = extend({}, u, { element: 'a', href: _this15.download, target: '_blank' }) _this15.isHTML5 && (_e12.download = '') var _t8 = _this15.config.urls.download !is.url(_t8) && _this15.isEmbed && extend(_e12, { icon: 'logo-'.concat(_this15.provider), label: _this15.provider }), c.appendChild(i.call(_this15, 'download', _e12)) } 'fullscreen' === a && c.appendChild(i.call(_this15, 'fullscreen', u)) }), this.isHTML5 && a.call(this, html5.getQualityOptions.call(this)), o.call(this), c ) }, inject: function inject() { var _this16 = this if (this.config.loadSprite) { var _e13 = controls.getIconUrl.call(this) _e13.cors && _loadSprite(_e13.url, 'sprite-plyr') } this.id = Math.floor(1e4 * Math.random()) var e = null this.elements.controls = null var t = { id: this.id, seektime: this.config.seekTime, title: this.config.title } var i = !0 is.function(this.config.controls) && (this.config.controls = this.config.controls.call(this, t)), this.config.controls || (this.config.controls = []), is.element(this.config.controls) || is.string(this.config.controls) ? (e = this.config.controls) : ((e = controls.create.call(this, { id: this.id, seektime: this.config.seekTime, speed: this.speed, quality: this.quality, captions: captions.getLabel.call(this) })), (i = !1)) var s i && is.string(this.config.controls) && (e = (function (e) { var i = e return ( Object.entries(t).forEach(function (_ref11) { var _ref12 = _slicedToArray(_ref11, 2), e = _ref12[0], t = _ref12[1] i = replaceAll(i, '{'.concat(e, '}'), t) }), i ) })(e)), is.string(this.config.selectors.controls.container) && (s = document.querySelector( this.config.selectors.controls.container )), is.element(s) || (s = this.elements.container) if ( (s[ is.element(e) ? 'insertAdjacentElement' : 'insertAdjacentHTML' ]('afterbegin', e), is.element(this.elements.controls) || controls.findElements.call(this), !is.empty(this.elements.buttons)) ) { var _e14 = function _e14(e) { var t = _this16.config.classNames.controlPressed Object.defineProperty(e, 'pressed', { enumerable: !0, get: function get() { return hasClass(e, t) }, set: function set() { var i = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !1 toggleClass(e, t, i) } }) } Object.values(this.elements.buttons) .filter(Boolean) .forEach(function (t) { is.array(t) || is.nodeList(t) ? Array.from(t).filter(Boolean).forEach(_e14) : _e14(t) }) } if ( (browser.isEdge && repaint(s), this.config.tooltips.controls) ) { var _this$config = this.config, _e15 = _this$config.classNames, _t9 = _this$config.selectors, _i5 = '' .concat(_t9.controls.wrapper, ' ') .concat(_t9.labels, ' .') .concat(_e15.hidden), _s5 = getElements.call(this, _i5) Array.from(_s5).forEach(function (e) { toggleClass(e, _this16.config.classNames.hidden, !1), toggleClass(e, _this16.config.classNames.tooltip, !0) }) } }, setMediaMetadata: function setMediaMetadata() { try { 'mediaSession' in navigator && (navigator.mediaSession.metadata = new window.MediaMetadata({ title: this.config.mediaMetadata.title, artist: this.config.mediaMetadata.artist, album: this.config.mediaMetadata.album, artwork: this.config.mediaMetadata.artwork })) } catch (e) {} }, setMarkers: function setMarkers() { var _this17 = this var e, t if (!this.duration || this.elements.markers) return var i = null === (e = this.config.markers) || void 0 === e || null === (t = e.points) || void 0 === t ? void 0 : t.filter(function (_ref13) { var e = _ref13.time return e > 0 && e < _this17.duration }) if (null == i || !i.length) return var s = document.createDocumentFragment(), n = document.createDocumentFragment() var r = null var a = ''.concat(this.config.classNames.tooltip, '--visible'), o = function o(e) { return toggleClass(r, a, e) } i.forEach(function (e) { var t = createElement( 'span', { class: _this17.config.classNames.marker }, '' ), i = (e.time / _this17.duration) * 100 + '%' r && (t.addEventListener('mouseenter', function () { e.label || ((r.style.left = i), (r.innerHTML = e.label), o(!0)) }), t.addEventListener('mouseleave', function () { o(!1) })), t.addEventListener('click', function () { _this17.currentTime = e.time }), (t.style.left = i), n.appendChild(t) }), s.appendChild(n), this.config.tooltips.seek || ((r = createElement( 'span', { class: this.config.classNames.tooltip }, '' )), s.appendChild(r)), (this.elements.markers = { points: n, tip: r }), this.elements.progress.appendChild(s) } } function parseUrl(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !0 var i = e if (t) { var _e16 = document.createElement('a') ;(_e16.href = i), (i = _e16.href) } try { return new URL(i) } catch (e) { return null } } function buildUrlParams(e) { var t = new URLSearchParams() return ( is.object(e) && Object.entries(e).forEach(function (_ref14) { var _ref15 = _slicedToArray(_ref14, 2), e = _ref15[0], i = _ref15[1] t.set(e, i) }), t ) } var captions = { setup: function setup() { var _e18, _e19, _this$config$captions if (!this.supported.ui) return if ( !this.isVideo || this.isYouTube || (this.isHTML5 && !support.textTracks) ) return void ( is.array(this.config.controls) && this.config.controls.includes('settings') && this.config.settings.includes('captions') && controls.setCaptionsMenu.call(this) ) if ( (is.element(this.elements.captions) || ((this.elements.captions = createElement( 'div', getAttributesFromSelector(this.config.selectors.captions) )), insertAfter(this.elements.captions, this.elements.wrapper)), browser.isIE && window.URL) ) { var _e17 = this.media.querySelectorAll('track') Array.from(_e17).forEach(function (e) { var t = e.getAttribute('src'), i = parseUrl(t) null !== i && i.hostname !== window.location.href.hostname && ['http:', 'https:'].includes(i.protocol) && fetch(t, 'blob') .then(function (t) { e.setAttribute('src', window.URL.createObjectURL(t)) }) .catch(function () { removeElement(e) }) }) } var e = dedupe( ( navigator.languages || [ navigator.language || navigator.userLanguage || 'en' ] ).map(function (e) { return e.split('-')[0] }) ) var t = ( this.storage.get('language') || this.config.captions.language || 'auto' ).toLowerCase() 'auto' === t && ((_e18 = e), (_e19 = _slicedToArray(_e18, 1)), (t = _e19[0]), _e18) var i = this.storage.get('captions') if ( (is.boolean(i) || ((_this$config$captions = this.config.captions), (i = _this$config$captions.active), _this$config$captions), Object.assign(this.captions, { toggled: !1, active: i, language: t, languages: e }), this.isHTML5) ) { var _e20 = this.config.captions.update ? 'addtrack removetrack' : 'removetrack' on.call( this, this.media.textTracks, _e20, captions.update.bind(this) ) } setTimeout(captions.update.bind(this), 0) }, update: function update() { var _this18 = this var e = captions.getTracks.call(this, !0), _this$captions = this.captions, t = _this$captions.active, i = _this$captions.language, s = _this$captions.meta, n = _this$captions.currentTrackNode, r = Boolean( e.find(function (e) { return e.language === i }) ) this.isHTML5 && this.isVideo && e .filter(function (e) { return !s.get(e) }) .forEach(function (e) { _this18.debug.log('Track added', e), s.set(e, { default: 'showing' === e.mode }), 'showing' === e.mode && (e.mode = 'hidden'), on.call(_this18, e, 'cuechange', function () { return captions.updateCues.call(_this18) }) }), ((r && this.language !== i) || !e.includes(n)) && (captions.setLanguage.call(this, i), captions.toggle.call(this, t && r)), this.elements && toggleClass( this.elements.container, this.config.classNames.captions.enabled, !is.empty(e) ), is.array(this.config.controls) && this.config.controls.includes('settings') && this.config.settings.includes('captions') && controls.setCaptionsMenu.call(this) }, toggle: function toggle(e) { var _this19 = this var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !0 if (!this.supported.ui) return var i = this.captions.toggled, s = this.config.classNames.captions.active, n = is.nullOrUndefined(e) ? !i : e if (n !== i) { if ( (t || ((this.captions.active = n), this.storage.set({ captions: n })), !this.language && n && !t) ) { var _e21 = captions.getTracks.call(this), _t10 = captions.findTrack.call( this, [this.captions.language].concat( _toConsumableArray(this.captions.languages) ), !0 ) return ( (this.captions.language = _t10.language), void captions.set.call(this, _e21.indexOf(_t10)) ) } this.elements.buttons.captions && (this.elements.buttons.captions.pressed = n), toggleClass(this.elements.container, s, n), (this.captions.toggled = n), controls.updateSetting.call(this, 'captions'), triggerEvent.call( this, this.media, n ? 'captionsenabled' : 'captionsdisabled' ) } setTimeout(function () { n && _this19.captions.toggled && (_this19.captions.currentTrackNode.mode = 'hidden') }) }, set: function set(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !0 var i = captions.getTracks.call(this) if (-1 !== e) { if (is.number(e)) { if (e in i) { if (this.captions.currentTrack !== e) { this.captions.currentTrack = e var s = i[e], _ref16 = s || {}, n = _ref16.language ;(this.captions.currentTrackNode = s), controls.updateSetting.call(this, 'captions'), t || ((this.captions.language = n), this.storage.set({ language: n })), this.isVimeo && this.embed.enableTextTrack(n), triggerEvent.call(this, this.media, 'languagechange') } captions.toggle.call(this, !0, t), this.isHTML5 && this.isVideo && captions.updateCues.call(this) } else this.debug.warn('Track not found', e) } else this.debug.warn('Invalid caption argument', e) } else captions.toggle.call(this, !1, t) }, setLanguage: function setLanguage(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !0 if (!is.string(e)) return void this.debug.warn('Invalid language argument', e) var i = e.toLowerCase() this.captions.language = i var s = captions.getTracks.call(this), n = captions.findTrack.call(this, [i]) captions.set.call(this, s.indexOf(n), t) }, getTracks: function getTracks() { var _this20 = this var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !1 return Array.from((this.media || {}).textTracks || []) .filter(function (t) { return !_this20.isHTML5 || e || _this20.captions.meta.has(t) }) .filter(function (e) { return ['captions', 'subtitles'].includes(e.kind) }) }, findTrack: function findTrack(e) { var _this21 = this var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1 var i = captions.getTracks.call(this), s = function s(e) { return Number((_this21.captions.meta.get(e) || {}).default) }, n = Array.from(i).sort(function (e, t) { return s(t) - s(e) }) var r return ( e.every(function (e) { return ( (r = n.find(function (t) { return t.language === e })), !r ) }), r || (t ? n[0] : void 0) ) }, getCurrentTrack: function getCurrentTrack() { return captions.getTracks.call(this)[this.currentTrack] }, getLabel: function getLabel(e) { var t = e return ( !is.track(t) && support.textTracks && this.captions.toggled && (t = captions.getCurrentTrack.call(this)), is.track(t) ? is.empty(t.label) ? is.empty(t.language) ? i18n.get('enabled', this.config) : e.language.toUpperCase() : t.label : i18n.get('disabled', this.config) ) }, updateCues: function updateCues(e) { if (!this.supported.ui) return if (!is.element(this.elements.captions)) return void this.debug.warn( 'No captions element to render to' ) if (!is.nullOrUndefined(e) && !Array.isArray(e)) return void this.debug.warn('updateCues: Invalid input', e) var t = e if (!t) { var _e22 = captions.getCurrentTrack.call(this) t = Array.from((_e22 || {}).activeCues || []) .map(function (e) { return e.getCueAsHTML() }) .map(getHTML) } var i = t .map(function (e) { return e.trim() }) .join('\n') if (i !== this.elements.captions.innerHTML) { emptyElement(this.elements.captions) var _e23 = createElement( 'span', getAttributesFromSelector(this.config.selectors.caption) ) ;(_e23.innerHTML = i), this.elements.captions.appendChild(_e23), triggerEvent.call(this, this.media, 'cuechange') } } }, defaults = { enabled: !0, title: '', debug: !1, autoplay: !1, autopause: !0, playsinline: !0, seekTime: 10, volume: 1, muted: !1, duration: null, displayDuration: !0, invertTime: !0, toggleInvert: !0, ratio: null, clickToPlay: !0, hideControls: !0, resetOnEnd: !1, disableContextMenu: !0, loadSprite: !0, iconPrefix: 'plyr', iconUrl: 'https://cdn.plyr.io/3.7.2/plyr.svg', blankVideo: 'https://cdn.plyr.io/static/blank.mp4', quality: { default: 576, options: [ 4320, 2880, 2160, 1440, 1080, 720, 576, 480, 360, 240 ], forced: !1, onChange: null }, loop: { active: !1 }, speed: { selected: 1, options: [0.5, 0.75, 1, 1.25, 1.5, 1.75, 2, 4] }, keyboard: { focused: !0, global: !1 }, tooltips: { controls: !1, seek: !0 }, captions: { active: !1, language: 'auto', update: !1 }, fullscreen: { enabled: !0, fallback: !0, iosNative: !1 }, storage: { enabled: !0, key: 'plyr' }, controls: [ 'play-large', 'play', 'progress', 'current-time', 'mute', 'volume', 'captions', 'settings', 'pip', 'airplay', 'fullscreen' ], settings: ['captions', 'quality', 'speed'], i18n: { restart: 'Restart', rewind: 'Rewind {seektime}s', play: 'Play', pause: 'Pause', fastForward: 'Forward {seektime}s', seek: 'Seek', seekLabel: '{currentTime} of {duration}', played: 'Played', buffered: 'Buffered', currentTime: 'Current time', duration: 'Duration', volume: 'Volume', mute: 'Mute', unmute: 'Unmute', enableCaptions: 'Enable captions', disableCaptions: 'Disable captions', download: 'Download', enterFullscreen: 'Enter fullscreen', exitFullscreen: 'Exit fullscreen', frameTitle: 'Player for {title}', captions: 'Captions', settings: 'Settings', pip: 'PIP', menuBack: 'Go back to previous menu', speed: 'Speed', normal: 'Normal', quality: 'Quality', loop: 'Loop', start: 'Start', end: 'End', all: 'All', reset: 'Reset', disabled: 'Disabled', enabled: 'Enabled', advertisement: 'Ad', qualityBadge: { 2160: '4K', 1440: 'HD', 1080: 'HD', 720: 'HD', 576: 'SD', 480: 'SD' } }, urls: { download: null, vimeo: { sdk: 'https://player.vimeo.com/api/player.js', iframe: 'https://player.vimeo.com/video/{0}?{1}', api: 'https://vimeo.com/api/oembed.json?url={0}' }, youtube: { sdk: 'https://www.youtube.com/iframe_api', api: 'https://noembed.com/embed?url=https://www.youtube.com/watch?v={0}' }, googleIMA: { sdk: 'https://imasdk.googleapis.com/js/sdkloader/ima3.js' } }, listeners: { seek: null, play: null, pause: null, restart: null, rewind: null, fastForward: null, mute: null, volume: null, captions: null, download: null, fullscreen: null, pip: null, airplay: null, speed: null, quality: null, loop: null, language: null }, events: [ 'ended', 'progress', 'stalled', 'playing', 'waiting', 'canplay', 'canplaythrough', 'loadstart', 'loadeddata', 'loadedmetadata', 'timeupdate', 'volumechange', 'play', 'pause', 'error', 'seeking', 'seeked', 'emptied', 'ratechange', 'cuechange', 'download', 'enterfullscreen', 'exitfullscreen', 'captionsenabled', 'captionsdisabled', 'languagechange', 'controlshidden', 'controlsshown', 'ready', 'statechange', 'qualitychange', 'adsloaded', 'adscontentpause', 'adscontentresume', 'adstarted', 'adsmidpoint', 'adscomplete', 'adsallcomplete', 'adsimpression', 'adsclick' ], selectors: { editable: 'input, textarea, select, [contenteditable]', container: '.plyr', controls: { container: null, wrapper: '.plyr__controls' }, labels: '[data-plyr]', buttons: { play: '[data-plyr="play"]', pause: '[data-plyr="pause"]', restart: '[data-plyr="restart"]', rewind: '[data-plyr="rewind"]', fastForward: '[data-plyr="fast-forward"]', mute: '[data-plyr="mute"]', captions: '[data-plyr="captions"]', download: '[data-plyr="download"]', fullscreen: '[data-plyr="fullscreen"]', pip: '[data-plyr="pip"]', airplay: '[data-plyr="airplay"]', settings: '[data-plyr="settings"]', loop: '[data-plyr="loop"]' }, inputs: { seek: '[data-plyr="seek"]', volume: '[data-plyr="volume"]', speed: '[data-plyr="speed"]', language: '[data-plyr="language"]', quality: '[data-plyr="quality"]' }, display: { currentTime: '.plyr__time--current', duration: '.plyr__time--duration', buffer: '.plyr__progress__buffer', loop: '.plyr__progress__loop', volume: '.plyr__volume--display' }, progress: '.plyr__progress', captions: '.plyr__captions', caption: '.plyr__caption' }, classNames: { type: 'plyr--{0}', provider: 'plyr--{0}', video: 'plyr__video-wrapper', embed: 'plyr__video-embed', videoFixedRatio: 'plyr__video-wrapper--fixed-ratio', embedContainer: 'plyr__video-embed__container', poster: 'plyr__poster', posterEnabled: 'plyr__poster-enabled', ads: 'plyr__ads', control: 'plyr__control', controlPressed: 'plyr__control--pressed', playing: 'plyr--playing', paused: 'plyr--paused', stopped: 'plyr--stopped', loading: 'plyr--loading', hover: 'plyr--hover', tooltip: 'plyr__tooltip', cues: 'plyr__cues', marker: 'plyr__progress__marker', hidden: 'plyr__sr-only', hideControls: 'plyr--hide-controls', isIos: 'plyr--is-ios', isTouch: 'plyr--is-touch', uiSupported: 'plyr--full-ui', noTransition: 'plyr--no-transition', display: { time: 'plyr__time' }, menu: { value: 'plyr__menu__value', badge: 'plyr__badge', open: 'plyr--menu-open' }, captions: { enabled: 'plyr--captions-enabled', active: 'plyr--captions-active' }, fullscreen: { enabled: 'plyr--fullscreen-enabled', fallback: 'plyr--fullscreen-fallback' }, pip: { supported: 'plyr--pip-supported', active: 'plyr--pip-active' }, airplay: { supported: 'plyr--airplay-supported', active: 'plyr--airplay-active' }, tabFocus: 'plyr__tab-focus', previewThumbnails: { thumbContainer: 'plyr__preview-thumb', thumbContainerShown: 'plyr__preview-thumb--is-shown', imageContainer: 'plyr__preview-thumb__image-container', timeContainer: 'plyr__preview-thumb__time-container', scrubbingContainer: 'plyr__preview-scrubbing', scrubbingContainerShown: 'plyr__preview-scrubbing--is-shown' } }, attributes: { embed: { provider: 'data-plyr-provider', id: 'data-plyr-embed-id', hash: 'data-plyr-embed-hash' } }, ads: { enabled: !1, publisherId: '', tagUrl: '' }, previewThumbnails: { enabled: !1, src: '' }, vimeo: { byline: !1, portrait: !1, title: !1, speed: !0, transparent: !1, customControls: !0, referrerPolicy: null, premium: !1 }, youtube: { rel: 0, showinfo: 0, iv_load_policy: 3, modestbranding: 1, customControls: !0, noCookie: !1 }, mediaMetadata: { title: '', artist: '', album: '', artwork: [] }, markers: { enabled: !1, points: [] } }, pip = { active: 'picture-in-picture', inactive: 'inline' }, providers = { html5: 'html5', youtube: 'youtube', vimeo: 'vimeo' }, types = { audio: 'audio', video: 'video' } function getProviderByUrl(e) { return /^(https?:\/\/)?(www\.)?(youtube\.com|youtube-nocookie\.com|youtu\.?be)\/.+$/.test( e ) ? providers.youtube : /^https?:\/\/player.vimeo.com\/video\/\d{0,9}(?=\b|\/)/.test(e) ? providers.vimeo : null } var noop = function noop() {} var Console = /*#__PURE__*/ (function () { function Console() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !1 _classCallCheck2(this, Console) ;(this.enabled = window.console && e), this.enabled && this.log('Debugging enabled') } _createClass2(Console, [ { key: 'log', get: function get() { return this.enabled ? Function.prototype.bind.call(console.log, console) : noop } }, { key: 'warn', get: function get() { return this.enabled ? Function.prototype.bind.call(console.warn, console) : noop } }, { key: 'error', get: function get() { return this.enabled ? Function.prototype.bind.call(console.error, console) : noop } } ]) return Console })() var Fullscreen = /*#__PURE__*/ (function () { function Fullscreen(e) { var _this22 = this _classCallCheck2(this, Fullscreen) _defineProperty$1(this, 'onChange', function () { if (!_this22.enabled) return var e = _this22.player.elements.buttons.fullscreen is.element(e) && (e.pressed = _this22.active) var t = _this22.target === _this22.player.media ? _this22.target : _this22.player.elements.container triggerEvent.call( _this22.player, t, _this22.active ? 'enterfullscreen' : 'exitfullscreen', !0 ) }), _defineProperty$1(this, 'toggleFallback', function () { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !1 if ( (e ? (_this22.scrollPosition = { x: window.scrollX || 0, y: window.scrollY || 0 }) : window.scrollTo( _this22.scrollPosition.x, _this22.scrollPosition.y ), (document.body.style.overflow = e ? 'hidden' : ''), toggleClass( _this22.target, _this22.player.config.classNames.fullscreen.fallback, e ), browser.isIos) ) { var t = document.head.querySelector('meta[name="viewport"]') var i = 'viewport-fit=cover' t || ((t = document.createElement('meta')), t.setAttribute('name', 'viewport')) var s = is.string(t.content) && t.content.includes(i) e ? ((_this22.cleanupViewport = !s), s || (t.content += ','.concat(i))) : _this22.cleanupViewport && (t.content = t.content .split(',') .filter(function (e) { return e.trim() !== i }) .join(',')) } _this22.onChange() }), _defineProperty$1(this, 'trapFocus', function (e) { if (browser.isIos || !_this22.active || 'Tab' !== e.key) return var t = document.activeElement, i = getElements.call( _this22.player, 'a[href], button:not(:disabled), input:not(:disabled), [tabindex]' ), _i6 = _slicedToArray(i, 1), s = _i6[0], n = i[i.length - 1] t !== n || e.shiftKey ? t === s && e.shiftKey && (n.focus(), e.preventDefault()) : (s.focus(), e.preventDefault()) }), _defineProperty$1(this, 'update', function () { if (_this22.enabled) { var _e24 ;(_e24 = _this22.forceFallback ? 'Fallback (forced)' : Fullscreen.native ? 'Native' : 'Fallback'), _this22.player.debug.log( ''.concat(_e24, ' fullscreen enabled') ) } else _this22.player.debug.log('Fullscreen not supported and fallback disabled') toggleClass( _this22.player.elements.container, _this22.player.config.classNames.fullscreen.enabled, _this22.enabled ) }), _defineProperty$1(this, 'enter', function () { _this22.enabled && (browser.isIos && _this22.player.config.fullscreen.iosNative ? _this22.player.isVimeo ? _this22.player.embed.requestFullscreen() : _this22.target.webkitEnterFullscreen() : !Fullscreen.native || _this22.forceFallback ? _this22.toggleFallback(!0) : _this22.prefix ? is.empty(_this22.prefix) || _this22.target[ '' .concat(_this22.prefix, 'Request') .concat(_this22.property) ]() : _this22.target.requestFullscreen({ navigationUI: 'hide' })) }), _defineProperty$1(this, 'exit', function () { if (_this22.enabled) if ( browser.isIos && _this22.player.config.fullscreen.iosNative ) _this22.target.webkitExitFullscreen(), silencePromise(_this22.player.play()) else if (!Fullscreen.native || _this22.forceFallback) _this22.toggleFallback(!1) else if (_this22.prefix) { if (!is.empty(_this22.prefix)) { var _e25 = 'moz' === _this22.prefix ? 'Cancel' : 'Exit' document[ '' .concat(_this22.prefix) .concat(_e25) .concat(_this22.property) ]() } } else ( document.cancelFullScreen || document.exitFullscreen ).call(document) }), _defineProperty$1(this, 'toggle', function () { _this22.active ? _this22.exit() : _this22.enter() }), (this.player = e), (this.prefix = Fullscreen.prefix), (this.property = Fullscreen.property), (this.scrollPosition = { x: 0, y: 0 }), (this.forceFallback = 'force' === e.config.fullscreen.fallback), (this.player.elements.fullscreen = e.config.fullscreen.container && closest$1( this.player.elements.container, e.config.fullscreen.container )), on.call( this.player, document, 'ms' === this.prefix ? 'MSFullscreenChange' : ''.concat(this.prefix, 'fullscreenchange'), function () { _this22.onChange() } ), on.call( this.player, this.player.elements.container, 'dblclick', function (e) { ;(is.element(_this22.player.elements.controls) && _this22.player.elements.controls.contains(e.target)) || _this22.player.listeners.proxy( e, _this22.toggle, 'fullscreen' ) } ), on.call( this, this.player.elements.container, 'keydown', function (e) { return _this22.trapFocus(e) } ), this.update() } _createClass2( Fullscreen, [ { key: 'usingNative', get: function get() { return Fullscreen.native && !this.forceFallback } }, { key: 'enabled', get: function get() { return ( (Fullscreen.native || this.player.config.fullscreen.fallback) && this.player.config.fullscreen.enabled && this.player.supported.ui && this.player.isVideo ) } }, { key: 'active', get: function get() { if (!this.enabled) return !1 if (!Fullscreen.native || this.forceFallback) return hasClass( this.target, this.player.config.classNames.fullscreen.fallback ) var e = this.prefix ? this.target.getRootNode()[ '' .concat(this.prefix) .concat(this.property, 'Element') ] : this.target.getRootNode().fullscreenElement return e && e.shadowRoot ? e === this.target.getRootNode().host : e === this.target } }, { key: 'target', get: function get() { return browser.isIos && this.player.config.fullscreen.iosNative ? this.player.media : this.player.elements.fullscreen || this.player.elements.container } } ], [ { key: 'native', get: function get() { return !!( document.fullscreenEnabled || document.webkitFullscreenEnabled || document.mozFullScreenEnabled || document.msFullscreenEnabled ) } }, { key: 'prefix', get: function get() { if (is.function(document.exitFullscreen)) return '' var e = '' return ( ['webkit', 'moz', 'ms'].some(function (t) { return ( !( !is.function( document[''.concat(t, 'ExitFullscreen')] ) && !is.function( document[''.concat(t, 'CancelFullScreen')] ) ) && ((e = t), !0) ) }), e ) } }, { key: 'property', get: function get() { return 'moz' === this.prefix ? 'FullScreen' : 'Fullscreen' } } ] ) return Fullscreen })() function loadImage(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1 return new Promise(function (i, s) { var n = new Image(), r = function r() { delete n.onload, delete n.onerror, (n.naturalWidth >= t ? i : s)(n) } Object.assign(n, { onload: r, onerror: r, src: e }) }) } var ui = { addStyleHook: function addStyleHook() { toggleClass( this.elements.container, this.config.selectors.container.replace('.', ''), !0 ), toggleClass( this.elements.container, this.config.classNames.uiSupported, this.supported.ui ) }, toggleNativeControls: function toggleNativeControls() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !1 e && this.isHTML5 ? this.media.setAttribute('controls', '') : this.media.removeAttribute('controls') }, build: function build() { var _this23 = this if ((this.listeners.media(), !this.supported.ui)) return ( this.debug.warn( 'Basic support only for ' .concat(this.provider, ' ') .concat(this.type) ), void ui.toggleNativeControls.call(this, !0) ) is.element(this.elements.controls) || (controls.inject.call(this), this.listeners.controls()), ui.toggleNativeControls.call(this), this.isHTML5 && captions.setup.call(this), (this.volume = null), (this.muted = null), (this.loop = null), (this.quality = null), (this.speed = null), controls.updateVolume.call(this), controls.timeUpdate.call(this), controls.durationUpdate.call(this), ui.checkPlaying.call(this), toggleClass( this.elements.container, this.config.classNames.pip.supported, support.pip && this.isHTML5 && this.isVideo ), toggleClass( this.elements.container, this.config.classNames.airplay.supported, support.airplay && this.isHTML5 ), toggleClass( this.elements.container, this.config.classNames.isIos, browser.isIos ), toggleClass( this.elements.container, this.config.classNames.isTouch, this.touch ), (this.ready = !0), setTimeout(function () { triggerEvent.call(_this23, _this23.media, 'ready') }, 0), ui.setTitle.call(this), this.poster && ui.setPoster .call(this, this.poster, !1) .catch(function () {}), this.config.duration && controls.durationUpdate.call(this), this.config.mediaMetadata && controls.setMediaMetadata.call(this) }, setTitle: function setTitle() { var e = i18n.get('play', this.config) if ( (is.string(this.config.title) && !is.empty(this.config.title) && (e += ', '.concat(this.config.title)), Array.from(this.elements.buttons.play || []).forEach(function ( t ) { t.setAttribute('aria-label', e) }), this.isEmbed) ) { var _e26 = getElement.call(this, 'iframe') if (!is.element(_e26)) return var t = is.empty(this.config.title) ? 'video' : this.config.title, i = i18n.get('frameTitle', this.config) _e26.setAttribute('title', i.replace('{title}', t)) } }, togglePoster: function togglePoster(e) { toggleClass( this.elements.container, this.config.classNames.posterEnabled, e ) }, setPoster: function setPoster(e) { var _this24 = this var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !0 return t && this.poster ? Promise.reject(new Error('Poster already set')) : (this.media.setAttribute('data-poster', e), this.elements.poster.removeAttribute('hidden'), ready .call(this) .then(function () { return loadImage(e) }) .catch(function (t) { throw ( (e === _this24.poster && ui.togglePoster.call(_this24, !1), t) ) }) .then(function () { if (e !== _this24.poster) throw new Error( 'setPoster cancelled by later call to setPoster' ) }) .then(function () { return ( Object.assign(_this24.elements.poster.style, { backgroundImage: "url('".concat(e, "')"), backgroundSize: '' }), ui.togglePoster.call(_this24, !0), e ) })) }, checkPlaying: function checkPlaying(e) { var _this25 = this toggleClass( this.elements.container, this.config.classNames.playing, this.playing ), toggleClass( this.elements.container, this.config.classNames.paused, this.paused ), toggleClass( this.elements.container, this.config.classNames.stopped, this.stopped ), Array.from(this.elements.buttons.play || []).forEach(function ( e ) { Object.assign(e, { pressed: _this25.playing }), e.setAttribute( 'aria-label', i18n.get( _this25.playing ? 'pause' : 'play', _this25.config ) ) }), (is.event(e) && 'timeupdate' === e.type) || ui.toggleControls.call(this) }, checkLoading: function checkLoading(e) { var _this26 = this ;(this.loading = ['stalled', 'waiting'].includes(e.type)), clearTimeout(this.timers.loading), (this.timers.loading = setTimeout( function () { toggleClass( _this26.elements.container, _this26.config.classNames.loading, _this26.loading ), ui.toggleControls.call(_this26) }, this.loading ? 250 : 0 )) }, toggleControls: function toggleControls(e) { var t = this.elements.controls if (t && this.config.hideControls) { var i = this.touch && this.lastSeekTime + 2e3 > Date.now() this.toggleControls( Boolean( e || this.loading || this.paused || t.pressed || t.hover || i ) ) } }, migrateStyles: function migrateStyles() { var _this27 = this Object.values(_objectSpread({}, this.media.style)) .filter(function (e) { return !is.empty(e) && is.string(e) && e.startsWith('--plyr') }) .forEach(function (e) { _this27.elements.container.style.setProperty( e, _this27.media.style.getPropertyValue(e) ), _this27.media.style.removeProperty(e) }), is.empty(this.media.style) && this.media.removeAttribute('style') } } var Listeners = /*#__PURE__*/ (function () { function Listeners(e) { var _this28 = this _classCallCheck2(this, Listeners) _defineProperty$1(this, 'firstTouch', function () { var e = _this28.player, t = e.elements ;(e.touch = !0), toggleClass(t.container, e.config.classNames.isTouch, !0) }), _defineProperty$1(this, 'setTabFocus', function (e) { var t = _this28.player, i = t.elements, s = e.key, n = e.type, r = e.timeStamp if ( (clearTimeout(_this28.focusTimer), 'keydown' === n && 'Tab' !== s) ) return 'keydown' === n && (_this28.lastKeyDown = r) var a = r - _this28.lastKeyDown <= 20 ;('focus' !== n || a) && ((function () { var e = t.config.classNames.tabFocus toggleClass(getElements.call(t, '.'.concat(e)), e, !1) })(), 'focusout' !== n && (_this28.focusTimer = setTimeout(function () { var e = document.activeElement i.container.contains(e) && toggleClass( document.activeElement, t.config.classNames.tabFocus, !0 ) }, 10))) }), _defineProperty$1(this, 'global', function () { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !0 var t = _this28.player t.config.keyboard.global && toggleListener.call( t, window, 'keydown keyup', _this28.handleKey, e, !1 ), toggleListener.call( t, document.body, 'click', _this28.toggleMenu, e ), once.call( t, document.body, 'touchstart', _this28.firstTouch ), toggleListener.call( t, document.body, 'keydown focus blur focusout', _this28.setTabFocus, e, !1, !0 ) }), _defineProperty$1(this, 'container', function () { var e = _this28.player, t = e.config, i = e.elements, s = e.timers !t.keyboard.global && t.keyboard.focused && on.call( e, i.container, 'keydown keyup', _this28.handleKey, !1 ), on.call( e, i.container, 'mousemove mouseleave touchstart touchmove enterfullscreen exitfullscreen', function (t) { var n = i.controls n && 'enterfullscreen' === t.type && ((n.pressed = !1), (n.hover = !1)) var r = 0 ;['touchstart', 'touchmove', 'mousemove'].includes( t.type ) && (ui.toggleControls.call(e, !0), (r = e.touch ? 3e3 : 2e3)), clearTimeout(s.controls), (s.controls = setTimeout(function () { return ui.toggleControls.call(e, !1) }, r)) } ) var n = function n() { if (!e.isVimeo || e.config.vimeo.premium) return var t = i.wrapper, s = e.fullscreen.active, _getAspectRatio$call = getAspectRatio.call(e), _getAspectRatio$call2 = _slicedToArray( _getAspectRatio$call, 2 ), n = _getAspectRatio$call2[0], r = _getAspectRatio$call2[1], a = supportsCSS( 'aspect-ratio: '.concat(n, ' / ').concat(r) ) if (!s) return void (a ? ((t.style.width = null), (t.style.height = null)) : ((t.style.maxWidth = null), (t.style.margin = null))) var _getViewportSize = getViewportSize(), _getViewportSize2 = _slicedToArray(_getViewportSize, 2), o = _getViewportSize2[0], l = _getViewportSize2[1], c = o / l > n / r a ? ((t.style.width = c ? 'auto' : '100%'), (t.style.height = c ? '100%' : 'auto')) : ((t.style.maxWidth = c ? (l / r) * n + 'px' : null), (t.style.margin = c ? '0 auto' : null)) }, r = function r() { clearTimeout(s.resized), (s.resized = setTimeout(n, 50)) } on.call( e, i.container, 'enterfullscreen exitfullscreen', function (t) { var s = e.fullscreen.target if (s !== i.container) return if (!e.isEmbed && is.empty(e.config.ratio)) return n() ;('enterfullscreen' === t.type ? on : off).call( e, window, 'resize', r ) } ) }), _defineProperty$1(this, 'media', function () { var e = _this28.player, t = e.elements if ( (on.call( e, e.media, 'timeupdate seeking seeked', function (t) { return controls.timeUpdate.call(e, t) } ), on.call( e, e.media, 'durationchange loadeddata loadedmetadata', function (t) { return controls.durationUpdate.call(e, t) } ), on.call(e, e.media, 'ended', function () { e.isHTML5 && e.isVideo && e.config.resetOnEnd && (e.restart(), e.pause()) }), on.call( e, e.media, 'progress playing seeking seeked', function (t) { return controls.updateProgress.call(e, t) } ), on.call(e, e.media, 'volumechange', function (t) { return controls.updateVolume.call(e, t) }), on.call( e, e.media, 'playing play pause ended emptied timeupdate', function (t) { return ui.checkPlaying.call(e, t) } ), on.call( e, e.media, 'waiting canplay seeked playing', function (t) { return ui.checkLoading.call(e, t) } ), e.supported.ui && e.config.clickToPlay && !e.isAudio) ) { var _i7 = getElement.call( e, '.'.concat(e.config.classNames.video) ) if (!is.element(_i7)) return on.call(e, t.container, 'click', function (s) { ;([t.container, _i7].includes(s.target) || _i7.contains(s.target)) && ((e.touch && e.config.hideControls) || (e.ended ? (_this28.proxy(s, e.restart, 'restart'), _this28.proxy( s, function () { silencePromise(e.play()) }, 'play' )) : _this28.proxy( s, function () { silencePromise(e.togglePlay()) }, 'play' ))) }) } e.supported.ui && e.config.disableContextMenu && on.call( e, t.wrapper, 'contextmenu', function (e) { e.preventDefault() }, !1 ), on.call(e, e.media, 'volumechange', function () { e.storage.set({ volume: e.volume, muted: e.muted }) }), on.call(e, e.media, 'ratechange', function () { controls.updateSetting.call(e, 'speed'), e.storage.set({ speed: e.speed }) }), on.call(e, e.media, 'qualitychange', function (t) { controls.updateSetting.call( e, 'quality', null, t.detail.quality ) }), on.call(e, e.media, 'ready qualitychange', function () { controls.setDownloadUrl.call(e) }) var i = e.config.events.concat(['keyup', 'keydown']).join(' ') on.call(e, e.media, i, function (i) { var _i$detail = i.detail, s = _i$detail === void 0 ? {} : _i$detail 'error' === i.type && (s = e.media.error), triggerEvent.call(e, t.container, i.type, !0, s) }) }), _defineProperty$1(this, 'proxy', function (e, t, i) { var s = _this28.player, n = s.config.listeners[i] var r = !0 is.function(n) && (r = n.call(s, e)), !1 !== r && is.function(t) && t.call(s, e) }), _defineProperty$1(this, 'bind', function (e, t, i, s) { var n = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : !0 var r = _this28.player, a = r.config.listeners[s], o = is.function(a) on.call( r, e, t, function (e) { return _this28.proxy(e, i, s) }, n && !o ) }), _defineProperty$1(this, 'controls', function () { var e = _this28.player, t = e.elements, i = browser.isIE ? 'change' : 'input' if ( (t.buttons.play && Array.from(t.buttons.play).forEach(function (t) { _this28.bind( t, 'click', function () { silencePromise(e.togglePlay()) }, 'play' ) }), _this28.bind( t.buttons.restart, 'click', e.restart, 'restart' ), _this28.bind( t.buttons.rewind, 'click', function () { ;(e.lastSeekTime = Date.now()), e.rewind() }, 'rewind' ), _this28.bind( t.buttons.fastForward, 'click', function () { ;(e.lastSeekTime = Date.now()), e.forward() }, 'fastForward' ), _this28.bind( t.buttons.mute, 'click', function () { e.muted = !e.muted }, 'mute' ), _this28.bind(t.buttons.captions, 'click', function () { return e.toggleCaptions() }), _this28.bind( t.buttons.download, 'click', function () { triggerEvent.call(e, e.media, 'download') }, 'download' ), _this28.bind( t.buttons.fullscreen, 'click', function () { e.fullscreen.toggle() }, 'fullscreen' ), _this28.bind( t.buttons.pip, 'click', function () { e.pip = 'toggle' }, 'pip' ), _this28.bind( t.buttons.airplay, 'click', e.airplay, 'airplay' ), _this28.bind( t.buttons.settings, 'click', function (t) { t.stopPropagation(), t.preventDefault(), controls.toggleMenu.call(e, t) }, null, !1 ), _this28.bind( t.buttons.settings, 'keyup', function (t) { ;['Space', 'Enter'].includes(t.key) && ('Enter' !== t.key ? (t.preventDefault(), t.stopPropagation(), controls.toggleMenu.call(e, t)) : controls.focusFirstMenuItem.call(e, null, !0)) }, null, !1 ), _this28.bind(t.settings.menu, 'keydown', function (t) { 'Escape' === t.key && controls.toggleMenu.call(e, t) }), _this28.bind( t.inputs.seek, 'mousedown mousemove', function (e) { var i = t.progress.getBoundingClientRect(), s = (100 / i.width) * (e.pageX - i.left) e.currentTarget.setAttribute('seek-value', s) } ), _this28.bind( t.inputs.seek, 'mousedown mouseup keydown keyup touchstart touchend', function (t) { var i = t.currentTarget, s = 'play-on-seeked' if ( is.keyboardEvent(t) && !['ArrowLeft', 'ArrowRight'].includes(t.key) ) return e.lastSeekTime = Date.now() var n = i.hasAttribute(s), r = ['mouseup', 'touchend', 'keyup'].includes(t.type) n && r ? (i.removeAttribute(s), silencePromise(e.play())) : !r && e.playing && (i.setAttribute(s, ''), e.pause()) } ), browser.isIos) ) { var _t11 = getElements.call(e, 'input[type="range"]') Array.from(_t11).forEach(function (e) { return _this28.bind(e, i, function (e) { return repaint(e.target) }) }) } _this28.bind( t.inputs.seek, i, function (t) { var i = t.currentTarget var s = i.getAttribute('seek-value') is.empty(s) && (s = i.value), i.removeAttribute('seek-value'), (e.currentTime = (s / i.max) * e.duration) }, 'seek' ), _this28.bind( t.progress, 'mouseenter mouseleave mousemove', function (t) { return controls.updateSeekTooltip.call(e, t) } ), _this28.bind( t.progress, 'mousemove touchmove', function (t) { var i = e.previewThumbnails i && i.loaded && i.startMove(t) } ), _this28.bind( t.progress, 'mouseleave touchend click', function () { var t = e.previewThumbnails t && t.loaded && t.endMove(!1, !0) } ), _this28.bind( t.progress, 'mousedown touchstart', function (t) { var i = e.previewThumbnails i && i.loaded && i.startScrubbing(t) } ), _this28.bind(t.progress, 'mouseup touchend', function (t) { var i = e.previewThumbnails i && i.loaded && i.endScrubbing(t) }), browser.isWebkit && Array.from( getElements.call(e, 'input[type="range"]') ).forEach(function (t) { _this28.bind(t, 'input', function (t) { return controls.updateRangeFill.call(e, t.target) }) }), e.config.toggleInvert && !is.element(t.display.duration) && _this28.bind(t.display.currentTime, 'click', function () { 0 !== e.currentTime && ((e.config.invertTime = !e.config.invertTime), controls.timeUpdate.call(e)) }), _this28.bind( t.inputs.volume, i, function (t) { e.volume = t.target.value }, 'volume' ), _this28.bind( t.controls, 'mouseenter mouseleave', function (i) { t.controls.hover = !e.touch && 'mouseenter' === i.type } ), t.fullscreen && Array.from(t.fullscreen.children) .filter(function (e) { return !e.contains(t.container) }) .forEach(function (i) { _this28.bind( i, 'mouseenter mouseleave', function (i) { t.controls && (t.controls.hover = !e.touch && 'mouseenter' === i.type) } ) }), _this28.bind( t.controls, 'mousedown mouseup touchstart touchend touchcancel', function (e) { t.controls.pressed = [ 'mousedown', 'touchstart' ].includes(e.type) } ), _this28.bind(t.controls, 'focusin', function () { var i = e.config, s = e.timers toggleClass(t.controls, i.classNames.noTransition, !0), ui.toggleControls.call(e, !0), setTimeout(function () { toggleClass(t.controls, i.classNames.noTransition, !1) }, 0) var n = _this28.touch ? 3e3 : 4e3 clearTimeout(s.controls), (s.controls = setTimeout(function () { return ui.toggleControls.call(e, !1) }, n)) }), _this28.bind( t.inputs.volume, 'wheel', function (t) { var i = t.webkitDirectionInvertedFromDevice, _map = [t.deltaX, -t.deltaY].map(function (e) { return i ? -e : e }), _map2 = _slicedToArray(_map, 2), s = _map2[0], n = _map2[1], r = Math.sign(Math.abs(s) > Math.abs(n) ? s : n) e.increaseVolume(r / 50) var a = e.media.volume ;((1 === r && a < 1) || (-1 === r && a > 0)) && t.preventDefault() }, 'volume', !1 ) }), (this.player = e), (this.lastKey = null), (this.focusTimer = null), (this.lastKeyDown = null), (this.handleKey = this.handleKey.bind(this)), (this.toggleMenu = this.toggleMenu.bind(this)), (this.setTabFocus = this.setTabFocus.bind(this)), (this.firstTouch = this.firstTouch.bind(this)) } _createClass2(Listeners, [ { key: 'handleKey', value: function handleKey(e) { var t = this.player, i = t.elements, s = e.key, n = e.type, r = e.altKey, a = e.ctrlKey, o = e.metaKey, l = e.shiftKey, c = 'keydown' === n, u = c && s === this.lastKey if (r || a || o || l) return if (!s) return if (c) { var _n4 = document.activeElement if (is.element(_n4)) { var _s6 = t.config.selectors.editable, _r3 = i.inputs.seek if (_n4 !== _r3 && matches(_n4, _s6)) return if ( 'Space' === e.key && matches(_n4, 'button, [role^="menuitem"]') ) return } switch ( ([ 'Space', 'ArrowLeft', 'ArrowUp', 'ArrowRight', 'ArrowDown', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'c', 'f', 'k', 'l', 'm' ].includes(s) && (e.preventDefault(), e.stopPropagation()), s) ) { case '0': case '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9': u || ((d = parseInt(s, 10)), (t.currentTime = (t.duration / 10) * d)) break case 'Space': case 'k': u || silencePromise(t.togglePlay()) break case 'ArrowUp': t.increaseVolume(0.1) break case 'ArrowDown': t.decreaseVolume(0.1) break case 'm': u || (t.muted = !t.muted) break case 'ArrowRight': t.forward() break case 'ArrowLeft': t.rewind() break case 'f': t.fullscreen.toggle() break case 'c': u || t.toggleCaptions() break case 'l': t.loop = !t.loop } 'Escape' === s && !t.fullscreen.usingNative && t.fullscreen.active && t.fullscreen.toggle(), (this.lastKey = s) } else this.lastKey = null var d } }, { key: 'toggleMenu', value: function toggleMenu(e) { controls.toggleMenu.call(this.player, e) } } ]) return Listeners })() function createCommonjsModule(e, t) { return e((t = { exports: {} }), t.exports), t.exports } var loadjs_umd = createCommonjsModule(function (e, t) { e.exports = (function () { var e = function e() {}, t = {}, i = {}, s = {} function n(e, t) { e = e.push ? e : [e] var n, r, a, o = [], l = e.length, c = l for ( n = function n(e, i) { i.length && o.push(e), --c || t(o) }; l--; ) { ;(r = e[l]), (a = i[r]) ? n(r, a) : (s[r] = s[r] || []).push(n) } } function r(e, t) { if (e) { var n = s[e] if (((i[e] = t), n)) for (; n.length; ) { n[0](e, t), n.splice(0, 1) } } } function a(t, i) { t.call && (t = { success: t }), i.length ? (t.error || e)(i) : (t.success || e)(t) } function o(t, i, s, n) { var r, a, l = document, c = s.async, u = (s.numRetries || 0) + 1, d = s.before || e, h = t.replace(/[\?|#].*$/, ''), m = t.replace(/^(css|img)!/, '') ;(n = n || 0), /(^css!|\.css$)/.test(h) ? (((a = l.createElement('link')).rel = 'stylesheet'), (a.href = m), (r = 'hideFocus' in a) && a.relList && ((r = 0), (a.rel = 'preload'), (a.as = 'style'))) : /(^img!|\.(png|gif|jpg|svg|webp)$)/.test(h) ? ((a = l.createElement('img')).src = m) : (((a = l.createElement('script')).src = t), (a.async = void 0 === c || c)), (a.onload = a.onerror = a.onbeforeload = function (e) { var l = e.type[0] if (r) try { a.sheet.cssText.length || (l = 'e') } catch (e) { 18 != e.code && (l = 'e') } if ('e' == l) { if ((n += 1) < u) return o(t, i, s, n) } else if ('preload' == a.rel && 'style' == a.as) return (a.rel = 'stylesheet') i(t, l, e.defaultPrevented) }), !1 !== d(t, a) && l.head.appendChild(a) } function l(e, t, i) { var s, n, r = (e = e.push ? e : [e]).length, a = r, l = [] for ( s = function s(e, i, _s7) { if (('e' == i && l.push(e), 'b' == i)) { if (!_s7) return l.push(e) } --r || t(l) }, n = 0; n < a; n++ ) { o(e[n], s, i) } } function c(e, i, s) { var n, o if ((i && i.trim && (n = i), (o = (n ? s : i) || {}), n)) { if (n in t) throw 'LoadJS' t[n] = !0 } function c(t, i) { l( e, function (e) { a(o, e), t && a({ success: t, error: i }, e), r(n, e) }, o ) } if (o.returnPromise) return new Promise(c) c() } return ( (c.ready = function (e, t) { return ( n(e, function (e) { a(t, e) }), c ) }), (c.done = function (e) { r(e, []) }), (c.reset = function () { ;(t = {}), (i = {}), (s = {}) }), (c.isDefined = function (e) { return e in t }), c ) })() }) function loadScript(e) { return new Promise(function (t, i) { loadjs_umd(e, { success: t, error: i }) }) } function parseId$1(e) { if (is.empty(e)) return null if (is.number(Number(e))) return e return e.match(/^.*(vimeo.com\/|video\/)(\d+).*/) ? RegExp.$2 : e } function parseHash(e) { var t = e.match( /^.*(vimeo.com\/|video\/)(\d+)(\?.*&*h=|\/)+([\d,a-f]+)/ ) return t && 5 === t.length ? t[4] : null } function assurePlaybackState$1(e) { e && !this.embed.hasPlayed && (this.embed.hasPlayed = !0), this.media.paused === e && ((this.media.paused = !e), triggerEvent.call(this, this.media, e ? 'play' : 'pause')) } var vimeo = { setup: function setup() { var e = this toggleClass(e.elements.wrapper, e.config.classNames.embed, !0), (e.options.speed = e.config.speed.options), setAspectRatio.call(e), is.object(window.Vimeo) ? vimeo.ready.call(e) : loadScript(e.config.urls.vimeo.sdk) .then(function () { vimeo.ready.call(e) }) .catch(function (t) { e.debug.warn('Vimeo SDK (player.js) failed to load', t) }) }, ready: function ready() { var _this29 = this var e = this, t = e.config.vimeo, i = t.premium, s = t.referrerPolicy, n = _objectWithoutProperties(t, _excluded) var r = e.media.getAttribute('src'), a = '' is.empty(r) ? ((r = e.media.getAttribute(e.config.attributes.embed.id)), (a = e.media.getAttribute(e.config.attributes.embed.hash))) : (a = parseHash(r)) var o = a ? { h: a } : {} i && Object.assign(n, { controls: !1, sidedock: !1 }) var l = buildUrlParams( _objectSpread( _objectSpread( { loop: e.config.loop.active, autoplay: e.autoplay, muted: e.muted, gesture: 'media', playsinline: !this.config.fullscreen.iosNative }, o ), n ) ), c = parseId$1(r), u = createElement('iframe'), d = format(e.config.urls.vimeo.iframe, c, l) if ( (u.setAttribute('src', d), u.setAttribute('allowfullscreen', ''), u.setAttribute( 'allow', [ 'autoplay', 'fullscreen', 'picture-in-picture', 'encrypted-media', 'accelerometer', 'gyroscope' ].join('; ') ), is.empty(s) || u.setAttribute('referrerPolicy', s), i || !t.customControls) ) u.setAttribute('data-poster', e.poster), (e.media = replaceElement(u, e.media)) else { var _t12 = createElement('div', { class: e.config.classNames.embedContainer, 'data-poster': e.poster }) _t12.appendChild(u), (e.media = replaceElement(_t12, e.media)) } t.customControls || fetch(format(e.config.urls.vimeo.api, d)).then(function (t) { !is.empty(t) && t.thumbnail_url && ui.setPoster.call(e, t.thumbnail_url).catch(function () {}) }), (e.embed = new window.Vimeo.Player(u, { autopause: e.config.autopause, muted: e.muted })), (e.media.paused = !0), (e.media.currentTime = 0), e.supported.ui && e.embed.disableTextTrack(), (e.media.play = function () { return assurePlaybackState$1.call(e, !0), e.embed.play() }), (e.media.pause = function () { return assurePlaybackState$1.call(e, !1), e.embed.pause() }), (e.media.stop = function () { e.pause(), (e.currentTime = 0) }) var h = e.media.currentTime Object.defineProperty(e.media, 'currentTime', { get: function get() { return h }, set: function set(t) { var i = e.embed, s = e.media, n = e.paused, r = e.volume, a = n && !i.hasPlayed ;(s.seeking = !0), triggerEvent.call(e, s, 'seeking'), Promise.resolve(a && i.setVolume(0)) .then(function () { return i.setCurrentTime(t) }) .then(function () { return a && i.pause() }) .then(function () { return a && i.setVolume(r) }) .catch(function () {}) } }) var m = e.config.speed.selected Object.defineProperty(e.media, 'playbackRate', { get: function get() { return m }, set: function set(t) { e.embed .setPlaybackRate(t) .then(function () { ;(m = t), triggerEvent.call(e, e.media, 'ratechange') }) .catch(function () { e.options.speed = [1] }) } }) var p = e.config.volume Object.defineProperty(e.media, 'volume', { get: function get() { return p }, set: function set(t) { e.embed.setVolume(t).then(function () { ;(p = t), triggerEvent.call(e, e.media, 'volumechange') }) } }) var g = e.config.muted Object.defineProperty(e.media, 'muted', { get: function get() { return g }, set: function set(t) { var i = !!is.boolean(t) && t e.embed.setVolume(i ? 0 : e.config.volume).then(function () { ;(g = i), triggerEvent.call(e, e.media, 'volumechange') }) } }) var f, y = e.config.loop Object.defineProperty(e.media, 'loop', { get: function get() { return y }, set: function set(t) { var i = is.boolean(t) ? t : e.config.loop.active e.embed.setLoop(i).then(function () { y = i }) } }), e.embed .getVideoUrl() .then(function (t) { ;(f = t), controls.setDownloadUrl.call(e) }) .catch(function (e) { _this29.debug.warn(e) }), Object.defineProperty(e.media, 'currentSrc', { get: function get() { return f } }), Object.defineProperty(e.media, 'ended', { get: function get() { return e.currentTime === e.duration } }), Promise.all([ e.embed.getVideoWidth(), e.embed.getVideoHeight() ]).then(function (t) { var _t13 = _slicedToArray(t, 2), i = _t13[0], s = _t13[1] ;(e.embed.ratio = roundAspectRatio(i, s)), setAspectRatio.call(_this29) }), e.embed.setAutopause(e.config.autopause).then(function (t) { e.config.autopause = t }), e.embed.getVideoTitle().then(function (t) { ;(e.config.title = t), ui.setTitle.call(_this29) }), e.embed.getCurrentTime().then(function (t) { ;(h = t), triggerEvent.call(e, e.media, 'timeupdate') }), e.embed.getDuration().then(function (t) { ;(e.media.duration = t), triggerEvent.call(e, e.media, 'durationchange') }), e.embed.getTextTracks().then(function (t) { ;(e.media.textTracks = t), captions.setup.call(e) }), e.embed.on('cuechange', function (_ref17) { var _ref17$cues = _ref17.cues, t = _ref17$cues === void 0 ? [] : _ref17$cues var i = t.map(function (e) { return stripHTML(e.text) }) captions.updateCues.call(e, i) }), e.embed.on('loaded', function () { if ( (e.embed.getPaused().then(function (t) { assurePlaybackState$1.call(e, !t), t || triggerEvent.call(e, e.media, 'playing') }), is.element(e.embed.element) && e.supported.ui) ) { e.embed.element.setAttribute('tabindex', -1) } }), e.embed.on('bufferstart', function () { triggerEvent.call(e, e.media, 'waiting') }), e.embed.on('bufferend', function () { triggerEvent.call(e, e.media, 'playing') }), e.embed.on('play', function () { assurePlaybackState$1.call(e, !0), triggerEvent.call(e, e.media, 'playing') }), e.embed.on('pause', function () { assurePlaybackState$1.call(e, !1) }), e.embed.on('timeupdate', function (t) { ;(e.media.seeking = !1), (h = t.seconds), triggerEvent.call(e, e.media, 'timeupdate') }), e.embed.on('progress', function (t) { ;(e.media.buffered = t.percent), triggerEvent.call(e, e.media, 'progress'), 1 === parseInt(t.percent, 10) && triggerEvent.call(e, e.media, 'canplaythrough'), e.embed.getDuration().then(function (t) { t !== e.media.duration && ((e.media.duration = t), triggerEvent.call(e, e.media, 'durationchange')) }) }), e.embed.on('seeked', function () { ;(e.media.seeking = !1), triggerEvent.call(e, e.media, 'seeked') }), e.embed.on('ended', function () { ;(e.media.paused = !0), triggerEvent.call(e, e.media, 'ended') }), e.embed.on('error', function (t) { ;(e.media.error = t), triggerEvent.call(e, e.media, 'error') }), t.customControls && setTimeout(function () { return ui.build.call(e) }, 0) } } function parseId(e) { if (is.empty(e)) return null return e.match( /^.*(youtu.be\/|v\/|u\/\w\/|embed\/|watch\?v=|&v=)([^#&?]*).*/ ) ? RegExp.$2 : e } function assurePlaybackState(e) { e && !this.embed.hasPlayed && (this.embed.hasPlayed = !0), this.media.paused === e && ((this.media.paused = !e), triggerEvent.call(this, this.media, e ? 'play' : 'pause')) } function getHost(e) { return e.noCookie ? 'https://www.youtube-nocookie.com' : 'http:' === window.location.protocol ? 'http://www.youtube.com' : void 0 } var youtube = { setup: function setup() { var _this30 = this if ( (toggleClass( this.elements.wrapper, this.config.classNames.embed, !0 ), is.object(window.YT) && is.function(window.YT.Player)) ) youtube.ready.call(this) else { var e = window.onYouTubeIframeAPIReady ;(window.onYouTubeIframeAPIReady = function () { is.function(e) && e(), youtube.ready.call(_this30) }), loadScript(this.config.urls.youtube.sdk).catch(function ( e ) { _this30.debug.warn('YouTube API failed to load', e) }) } }, getTitle: function getTitle(e) { var _this31 = this fetch(format(this.config.urls.youtube.api, e)) .then(function (e) { if (is.object(e)) { var t = e.title, i = e.height, s = e.width ;(_this31.config.title = t), ui.setTitle.call(_this31), (_this31.embed.ratio = roundAspectRatio(s, i)) } setAspectRatio.call(_this31) }) .catch(function () { setAspectRatio.call(_this31) }) }, ready: function ready() { var e = this, t = e.config.youtube, i = e.media && e.media.getAttribute('id') if (!is.empty(i) && i.startsWith('youtube-')) return var s = e.media.getAttribute('src') is.empty(s) && (s = e.media.getAttribute(this.config.attributes.embed.id)) var n = parseId(s), r = createElement('div', { id: generateId(e.provider), 'data-poster': t.customControls ? e.poster : void 0 }) if ( ((e.media = replaceElement(r, e.media)), t.customControls) ) { var _t14 = function _t14(e) { return 'https://i.ytimg.com/vi/' .concat(n, '/') .concat(e, 'default.jpg') } loadImage(_t14('maxres'), 121) .catch(function () { return loadImage(_t14('sd'), 121) }) .catch(function () { return loadImage(_t14('hq')) }) .then(function (t) { return ui.setPoster.call(e, t.src) }) .then(function (t) { t.includes('maxres') || (e.elements.poster.style.backgroundSize = 'cover') }) .catch(function () {}) } e.embed = new window.YT.Player(e.media, { videoId: n, host: getHost(t), playerVars: extend( {}, { autoplay: e.config.autoplay ? 1 : 0, hl: e.config.hl, controls: e.supported.ui && t.customControls ? 0 : 1, disablekb: 1, playsinline: e.config.fullscreen.iosNative ? 0 : 1, cc_load_policy: e.captions.active ? 1 : 0, cc_lang_pref: e.config.captions.language, widget_referrer: window ? window.location.href : null }, t ), events: { onError: function onError(t) { if (!e.media.error) { var _i8 = t.data, _s8 = { 2: 'The request contains an invalid parameter value. For example, this error occurs if you specify a video ID that does not have 11 characters, or if the video ID contains invalid characters, such as exclamation points or asterisks.', 5: 'The requested content cannot be played in an HTML5 player or another error related to the HTML5 player has occurred.', 100: 'The video requested was not found. This error occurs when a video has been removed (for any reason) or has been marked as private.', 101: 'The owner of the requested video does not allow it to be played in embedded players.', 150: 'The owner of the requested video does not allow it to be played in embedded players.' }[_i8] || 'An unknown error occured' ;(e.media.error = { code: _i8, message: _s8 }), triggerEvent.call(e, e.media, 'error') } }, onPlaybackRateChange: function onPlaybackRateChange(t) { var i = t.target ;(e.media.playbackRate = i.getPlaybackRate()), triggerEvent.call(e, e.media, 'ratechange') }, onReady: function onReady(i) { if (is.function(e.media.play)) return var s = i.target youtube.getTitle.call(e, n), (e.media.play = function () { assurePlaybackState.call(e, !0), s.playVideo() }), (e.media.pause = function () { assurePlaybackState.call(e, !1), s.pauseVideo() }), (e.media.stop = function () { s.stopVideo() }), (e.media.duration = s.getDuration()), (e.media.paused = !0), (e.media.currentTime = 0), Object.defineProperty(e.media, 'currentTime', { get: function get() { return Number(s.getCurrentTime()) }, set: function set(t) { e.paused && !e.embed.hasPlayed && e.embed.mute(), (e.media.seeking = !0), triggerEvent.call(e, e.media, 'seeking'), s.seekTo(t) } }), Object.defineProperty(e.media, 'playbackRate', { get: function get() { return s.getPlaybackRate() }, set: function set(e) { s.setPlaybackRate(e) } }) var r = e.config.volume Object.defineProperty(e.media, 'volume', { get: function get() { return r }, set: function set(t) { ;(r = t), s.setVolume(100 * r), triggerEvent.call(e, e.media, 'volumechange') } }) var a = e.config.muted Object.defineProperty(e.media, 'muted', { get: function get() { return a }, set: function set(t) { var i = is.boolean(t) ? t : a ;(a = i), s[i ? 'mute' : 'unMute'](), s.setVolume(100 * r), triggerEvent.call(e, e.media, 'volumechange') } }), Object.defineProperty(e.media, 'currentSrc', { get: function get() { return s.getVideoUrl() } }), Object.defineProperty(e.media, 'ended', { get: function get() { return e.currentTime === e.duration } }) var o = s.getAvailablePlaybackRates() ;(e.options.speed = o.filter(function (t) { return e.config.speed.options.includes(t) })), e.supported.ui && t.customControls && e.media.setAttribute('tabindex', -1), triggerEvent.call(e, e.media, 'timeupdate'), triggerEvent.call(e, e.media, 'durationchange'), clearInterval(e.timers.buffering), (e.timers.buffering = setInterval(function () { ;(e.media.buffered = s.getVideoLoadedFraction()), (null === e.media.lastBuffered || e.media.lastBuffered < e.media.buffered) && triggerEvent.call(e, e.media, 'progress'), (e.media.lastBuffered = e.media.buffered), 1 === e.media.buffered && (clearInterval(e.timers.buffering), triggerEvent.call(e, e.media, 'canplaythrough')) }, 200)), t.customControls && setTimeout(function () { return ui.build.call(e) }, 50) }, onStateChange: function onStateChange(i) { var s = i.target clearInterval(e.timers.playing) switch ( (e.media.seeking && [1, 2].includes(i.data) && ((e.media.seeking = !1), triggerEvent.call(e, e.media, 'seeked')), i.data) ) { case -1: triggerEvent.call(e, e.media, 'timeupdate'), (e.media.buffered = s.getVideoLoadedFraction()), triggerEvent.call(e, e.media, 'progress') break case 0: assurePlaybackState.call(e, !1), e.media.loop ? (s.stopVideo(), s.playVideo()) : triggerEvent.call(e, e.media, 'ended') break case 1: t.customControls && !e.config.autoplay && e.media.paused && !e.embed.hasPlayed ? e.media.pause() : (assurePlaybackState.call(e, !0), triggerEvent.call(e, e.media, 'playing'), (e.timers.playing = setInterval(function () { triggerEvent.call(e, e.media, 'timeupdate') }, 50)), e.media.duration !== s.getDuration() && ((e.media.duration = s.getDuration()), triggerEvent.call( e, e.media, 'durationchange' ))) break case 2: e.muted || e.embed.unMute(), assurePlaybackState.call(e, !1) break case 3: triggerEvent.call(e, e.media, 'waiting') } triggerEvent.call( e, e.elements.container, 'statechange', !1, { code: i.data } ) } } }) } }, media = { setup: function setup() { this.media ? (toggleClass( this.elements.container, this.config.classNames.type.replace('{0}', this.type), !0 ), toggleClass( this.elements.container, this.config.classNames.provider.replace( '{0}', this.provider ), !0 ), this.isEmbed && toggleClass( this.elements.container, this.config.classNames.type.replace('{0}', 'video'), !0 ), this.isVideo && ((this.elements.wrapper = createElement('div', { class: this.config.classNames.video })), wrap(this.media, this.elements.wrapper), (this.elements.poster = createElement('div', { class: this.config.classNames.poster })), this.elements.wrapper.appendChild(this.elements.poster)), this.isHTML5 ? html5.setup.call(this) : this.isYouTube ? youtube.setup.call(this) : this.isVimeo && vimeo.setup.call(this)) : this.debug.warn('No media element found!') } } var Ads = /*#__PURE__*/ (function () { function Ads(e) { var _this32 = this _classCallCheck2(this, Ads) _defineProperty$1(this, 'load', function () { _this32.enabled && (is.object(window.google) && is.object(window.google.ima) ? _this32.ready() : loadScript(_this32.player.config.urls.googleIMA.sdk) .then(function () { _this32.ready() }) .catch(function () { _this32.trigger( 'error', new Error('Google IMA SDK failed to load') ) })) }), _defineProperty$1(this, 'ready', function () { var e _this32.enabled || ((e = _this32).manager && e.manager.destroy(), e.elements.displayContainer && e.elements.displayContainer.destroy(), e.elements.container.remove()), _this32.startSafetyTimer(12e3, 'ready()'), _this32.managerPromise.then(function () { _this32.clearSafetyTimer('onAdsManagerLoaded()') }), _this32.listeners(), _this32.setupIMA() }), _defineProperty$1(this, 'setupIMA', function () { ;(_this32.elements.container = createElement('div', { class: _this32.player.config.classNames.ads })), _this32.player.elements.container.appendChild( _this32.elements.container ), google.ima.settings.setVpaidMode( google.ima.ImaSdkSettings.VpaidMode.ENABLED ), google.ima.settings.setLocale( _this32.player.config.ads.language ), google.ima.settings.setDisableCustomPlaybackForIOS10Plus( _this32.player.config.playsinline ), (_this32.elements.displayContainer = new google.ima.AdDisplayContainer( _this32.elements.container, _this32.player.media )), (_this32.loader = new google.ima.AdsLoader( _this32.elements.displayContainer )), _this32.loader.addEventListener( google.ima.AdsManagerLoadedEvent.Type.ADS_MANAGER_LOADED, function (e) { return _this32.onAdsManagerLoaded(e) }, !1 ), _this32.loader.addEventListener( google.ima.AdErrorEvent.Type.AD_ERROR, function (e) { return _this32.onAdError(e) }, !1 ), _this32.requestAds() }), _defineProperty$1(this, 'requestAds', function () { var e = _this32.player.elements.container try { var t = new google.ima.AdsRequest() ;(t.adTagUrl = _this32.tagUrl), (t.linearAdSlotWidth = e.offsetWidth), (t.linearAdSlotHeight = e.offsetHeight), (t.nonLinearAdSlotWidth = e.offsetWidth), (t.nonLinearAdSlotHeight = e.offsetHeight), (t.forceNonLinearFullSlot = !1), t.setAdWillPlayMuted(!_this32.player.muted), _this32.loader.requestAds(t) } catch (e) { _this32.onAdError(e) } }), _defineProperty$1(this, 'pollCountdown', function () { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !1 if (!e) return ( clearInterval(_this32.countdownTimer), void _this32.elements.container.removeAttribute( 'data-badge-text' ) ) _this32.countdownTimer = setInterval(function () { var e = _formatTime( Math.max(_this32.manager.getRemainingTime(), 0) ), t = '' .concat( i18n.get('advertisement', _this32.player.config), ' - ' ) .concat(e) _this32.elements.container.setAttribute( 'data-badge-text', t ) }, 100) }), _defineProperty$1(this, 'onAdsManagerLoaded', function (e) { if (!_this32.enabled) return var t = new google.ima.AdsRenderingSettings() ;(t.restoreCustomPlaybackStateOnAdBreakComplete = !0), (t.enablePreloading = !0), (_this32.manager = e.getAdsManager(_this32.player, t)), (_this32.cuePoints = _this32.manager.getCuePoints()), _this32.manager.addEventListener( google.ima.AdErrorEvent.Type.AD_ERROR, function (e) { return _this32.onAdError(e) } ), Object.keys(google.ima.AdEvent.Type).forEach(function (e) { _this32.manager.addEventListener( google.ima.AdEvent.Type[e], function (e) { return _this32.onAdEvent(e) } ) }), _this32.trigger('loaded') }), _defineProperty$1(this, 'addCuePoints', function () { is.empty(_this32.cuePoints) || _this32.cuePoints.forEach(function (e) { if (0 !== e && -1 !== e && e < _this32.player.duration) { var t = _this32.player.elements.progress if (is.element(t)) { var i = (100 / _this32.player.duration) * e, s = createElement('span', { class: _this32.player.config.classNames.cues }) ;(s.style.left = ''.concat(i.toString(), '%')), t.appendChild(s) } } }) }), _defineProperty$1(this, 'onAdEvent', function (e) { var t = _this32.player.elements.container, i = e.getAd(), s = e.getAdData() switch ( ((function (e) { triggerEvent.call( _this32.player, _this32.player.media, 'ads'.concat(e.replace(/_/g, '').toLowerCase()) ) })(e.type), e.type) ) { case google.ima.AdEvent.Type.LOADED: _this32.trigger('loaded'), _this32.pollCountdown(!0), i.isLinear() || ((i.width = t.offsetWidth), (i.height = t.offsetHeight)) break case google.ima.AdEvent.Type.STARTED: _this32.manager.setVolume(_this32.player.volume) break case google.ima.AdEvent.Type.ALL_ADS_COMPLETED: _this32.player.ended ? _this32.loadAds() : _this32.loader.contentComplete() break case google.ima.AdEvent.Type.CONTENT_PAUSE_REQUESTED: _this32.pauseContent() break case google.ima.AdEvent.Type.CONTENT_RESUME_REQUESTED: _this32.pollCountdown(), _this32.resumeContent() break case google.ima.AdEvent.Type.LOG: s.adError && _this32.player.debug.warn( 'Non-fatal ad error: '.concat(s.adError.getMessage()) ) } }), _defineProperty$1(this, 'onAdError', function (e) { _this32.cancel(), _this32.player.debug.warn('Ads error', e) }), _defineProperty$1(this, 'listeners', function () { var e = _this32.player.elements.container var t _this32.player.on('canplay', function () { _this32.addCuePoints() }), _this32.player.on('ended', function () { _this32.loader.contentComplete() }), _this32.player.on('timeupdate', function () { t = _this32.player.currentTime }), _this32.player.on('seeked', function () { var e = _this32.player.currentTime is.empty(_this32.cuePoints) || _this32.cuePoints.forEach(function (i, s) { t < i && i < e && (_this32.manager.discardAdBreak(), _this32.cuePoints.splice(s, 1)) }) }), window.addEventListener('resize', function () { _this32.manager && _this32.manager.resize( e.offsetWidth, e.offsetHeight, google.ima.ViewMode.NORMAL ) }) }), _defineProperty$1(this, 'play', function () { var e = _this32.player.elements.container _this32.managerPromise || _this32.resumeContent(), _this32.managerPromise .then(function () { _this32.manager.setVolume(_this32.player.volume), _this32.elements.displayContainer.initialize() try { _this32.initialized || (_this32.manager.init( e.offsetWidth, e.offsetHeight, google.ima.ViewMode.NORMAL ), _this32.manager.start()), (_this32.initialized = !0) } catch (e) { _this32.onAdError(e) } }) .catch(function () {}) }), _defineProperty$1(this, 'resumeContent', function () { ;(_this32.elements.container.style.zIndex = ''), (_this32.playing = !1), silencePromise(_this32.player.media.play()) }), _defineProperty$1(this, 'pauseContent', function () { ;(_this32.elements.container.style.zIndex = 3), (_this32.playing = !0), _this32.player.media.pause() }), _defineProperty$1(this, 'cancel', function () { _this32.initialized && _this32.resumeContent(), _this32.trigger('error'), _this32.loadAds() }), _defineProperty$1(this, 'loadAds', function () { _this32.managerPromise .then(function () { _this32.manager && _this32.manager.destroy(), (_this32.managerPromise = new Promise(function (e) { _this32.on('loaded', e), _this32.player.debug.log(_this32.manager) })), (_this32.initialized = !1), _this32.requestAds() }) .catch(function () {}) }), _defineProperty$1(this, 'trigger', function (e) { for ( var _len4 = arguments.length, t = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++ ) { t[_key4 - 1] = arguments[_key4] } var i = _this32.events[e] is.array(i) && i.forEach(function (e) { is.function(e) && e.apply(_this32, t) }) }), _defineProperty$1(this, 'on', function (e, t) { return ( is.array(_this32.events[e]) || (_this32.events[e] = []), _this32.events[e].push(t), _this32 ) }), _defineProperty$1(this, 'startSafetyTimer', function (e, t) { _this32.player.debug.log( 'Safety timer invoked from: '.concat(t) ), (_this32.safetyTimer = setTimeout(function () { _this32.cancel(), _this32.clearSafetyTimer('startSafetyTimer()') }, e)) }), _defineProperty$1(this, 'clearSafetyTimer', function (e) { is.nullOrUndefined(_this32.safetyTimer) || (_this32.player.debug.log( 'Safety timer cleared from: '.concat(e) ), clearTimeout(_this32.safetyTimer), (_this32.safetyTimer = null)) }), (this.player = e), (this.config = e.config.ads), (this.playing = !1), (this.initialized = !1), (this.elements = { container: null, displayContainer: null }), (this.manager = null), (this.loader = null), (this.cuePoints = null), (this.events = {}), (this.safetyTimer = null), (this.countdownTimer = null), (this.managerPromise = new Promise(function (e, t) { _this32.on('loaded', e), _this32.on('error', t) })), this.load() } _createClass2(Ads, [ { key: 'enabled', get: function get() { var e = this.config return ( this.player.isHTML5 && this.player.isVideo && e.enabled && (!is.empty(e.publisherId) || is.url(e.tagUrl)) ) } }, { key: 'tagUrl', get: function get() { var e = this.config if (is.url(e.tagUrl)) return e.tagUrl return 'https://go.aniview.com/api/adserver6/vast/?'.concat( buildUrlParams({ AV_PUBLISHERID: '58c25bb0073ef448b1087ad6', AV_CHANNELID: '5a0458dc28a06145e4519d21', AV_URL: window.location.hostname, cb: Date.now(), AV_WIDTH: 640, AV_HEIGHT: 480, AV_CDIM2: e.publisherId }) ) } } ]) return Ads })() function clamp() { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0 var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0 var i = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 255 return Math.min(Math.max(e, t), i) } var parseVtt = function parseVtt(e) { var t = [] return ( e.split(/\r\n\r\n|\n\n|\r\r/).forEach(function (e) { var i = {} e.split(/\r\n|\n|\r/).forEach(function (e) { if (is.number(i.startTime)) { if (!is.empty(e.trim()) && is.empty(i.text)) { var _t16, _t17, _t15$1$split, _t15$1$split2 var _t15 = e.trim().split('#xywh=') ;((_t16 = _t15), (_t17 = _slicedToArray(_t16, 1)), (i.text = _t17[0]), _t16), _t15[1] && ((_t15$1$split = _t15[1].split(',')), (_t15$1$split2 = _slicedToArray(_t15$1$split, 4)), (i.x = _t15$1$split2[0]), (i.y = _t15$1$split2[1]), (i.w = _t15$1$split2[2]), (i.h = _t15$1$split2[3]), _t15$1$split) } } else { var _t18 = e.match( /([0-9]{2})?:?([0-9]{2}):([0-9]{2}).([0-9]{2,3})( ?--> ?)([0-9]{2})?:?([0-9]{2}):([0-9]{2}).([0-9]{2,3})/ ) _t18 && ((i.startTime = 60 * Number(_t18[1] || 0) * 60 + 60 * Number(_t18[2]) + Number(_t18[3]) + Number('0.'.concat(_t18[4]))), (i.endTime = 60 * Number(_t18[6] || 0) * 60 + 60 * Number(_t18[7]) + Number(_t18[8]) + Number('0.'.concat(_t18[9])))) } }), i.text && t.push(i) }), t ) }, fitRatio = function fitRatio(e, t) { var i = {} return ( e > t.width / t.height ? ((i.width = t.width), (i.height = (1 / e) * t.width)) : ((i.height = t.height), (i.width = e * t.height)), i ) } var PreviewThumbnails = /*#__PURE__*/ (function () { function PreviewThumbnails(e) { var _this33 = this _classCallCheck2(this, PreviewThumbnails) _defineProperty$1(this, 'load', function () { _this33.player.elements.display.seekTooltip && (_this33.player.elements.display.seekTooltip.hidden = _this33.enabled), _this33.enabled && _this33.getThumbnails().then(function () { _this33.enabled && (_this33.render(), _this33.determineContainerAutoSizing(), (_this33.loaded = !0)) }) }), _defineProperty$1(this, 'getThumbnails', function () { return new Promise(function (e) { var t = _this33.player.config.previewThumbnails.src if (is.empty(t)) throw new Error( 'Missing previewThumbnails.src config attribute' ) var i = function i() { _this33.thumbnails.sort(function (e, t) { return e.height - t.height }), _this33.player.debug.log( 'Preview thumbnails', _this33.thumbnails ), e() } if (is.function(t)) t(function (e) { ;(_this33.thumbnails = e), i() }) else { var _e27 = (is.string(t) ? [t] : t).map(function (e) { return _this33.getThumbnail(e) }) Promise.all(_e27).then(i) } }) }), _defineProperty$1(this, 'getThumbnail', function (e) { return new Promise(function (t) { fetch(e).then(function (i) { var s = { frames: parseVtt(i), height: null, urlPrefix: '' } s.frames[0].text.startsWith('/') || s.frames[0].text.startsWith('http://') || s.frames[0].text.startsWith('https://') || (s.urlPrefix = e.substring(0, e.lastIndexOf('/') + 1)) var n = new Image() ;(n.onload = function () { ;(s.height = n.naturalHeight), (s.width = n.naturalWidth), _this33.thumbnails.push(s), t() }), (n.src = s.urlPrefix + s.frames[0].text) }) }) }), _defineProperty$1(this, 'startMove', function (e) { if ( _this33.loaded && is.event(e) && ['touchmove', 'mousemove'].includes(e.type) && _this33.player.media.duration ) { if ('touchmove' === e.type) _this33.seekTime = _this33.player.media.duration * (_this33.player.elements.inputs.seek.value / 100) else { var t, i var s = _this33.player.elements.progress.getBoundingClientRect(), n = (100 / s.width) * (e.pageX - s.left) ;(_this33.seekTime = _this33.player.media.duration * (n / 100)), _this33.seekTime < 0 && (_this33.seekTime = 0), _this33.seekTime > _this33.player.media.duration - 1 && (_this33.seekTime = _this33.player.media.duration - 1), (_this33.mousePosX = e.pageX), (_this33.elements.thumb.time.innerText = _formatTime( _this33.seekTime )) var r = null === (t = _this33.player.config.markers) || void 0 === t || null === (i = t.points) || void 0 === i ? void 0 : i.find(function (_ref18) { var e = _ref18.time return e === Math.round(_this33.seekTime) }) r && _this33.elements.thumb.time.insertAdjacentHTML( 'afterbegin', ''.concat(r.label, '
') ) } _this33.showImageAtCurrentTime() } }), _defineProperty$1(this, 'endMove', function () { _this33.toggleThumbContainer(!1, !0) }), _defineProperty$1(this, 'startScrubbing', function (e) { ;(is.nullOrUndefined(e.button) || !1 === e.button || 0 === e.button) && ((_this33.mouseDown = !0), _this33.player.media.duration && (_this33.toggleScrubbingContainer(!0), _this33.toggleThumbContainer(!1, !0), _this33.showImageAtCurrentTime())) }), _defineProperty$1(this, 'endScrubbing', function () { ;(_this33.mouseDown = !1), Math.ceil(_this33.lastTime) === Math.ceil(_this33.player.media.currentTime) ? _this33.toggleScrubbingContainer(!1) : once.call( _this33.player, _this33.player.media, 'timeupdate', function () { _this33.mouseDown || _this33.toggleScrubbingContainer(!1) } ) }), _defineProperty$1(this, 'listeners', function () { _this33.player.on('play', function () { _this33.toggleThumbContainer(!1, !0) }), _this33.player.on('seeked', function () { _this33.toggleThumbContainer(!1) }), _this33.player.on('timeupdate', function () { _this33.lastTime = _this33.player.media.currentTime }) }), _defineProperty$1(this, 'render', function () { ;(_this33.elements.thumb.container = createElement('div', { class: _this33.player.config.classNames.previewThumbnails .thumbContainer })), (_this33.elements.thumb.imageContainer = createElement( 'div', { class: _this33.player.config.classNames.previewThumbnails .imageContainer } )), _this33.elements.thumb.container.appendChild( _this33.elements.thumb.imageContainer ) var e = createElement('div', { class: _this33.player.config.classNames.previewThumbnails .timeContainer }) ;(_this33.elements.thumb.time = createElement( 'span', {}, '00:00' )), e.appendChild(_this33.elements.thumb.time), _this33.elements.thumb.imageContainer.appendChild(e), is.element(_this33.player.elements.progress) && _this33.player.elements.progress.appendChild( _this33.elements.thumb.container ), (_this33.elements.scrubbing.container = createElement( 'div', { class: _this33.player.config.classNames.previewThumbnails .scrubbingContainer } )), _this33.player.elements.wrapper.appendChild( _this33.elements.scrubbing.container ) }), _defineProperty$1(this, 'destroy', function () { _this33.elements.thumb.container && _this33.elements.thumb.container.remove(), _this33.elements.scrubbing.container && _this33.elements.scrubbing.container.remove() }), _defineProperty$1(this, 'showImageAtCurrentTime', function () { _this33.mouseDown ? _this33.setScrubbingContainerSize() : _this33.setThumbContainerSizeAndPos() var e = _this33.thumbnails[0].frames.findIndex(function (e) { return ( _this33.seekTime >= e.startTime && _this33.seekTime <= e.endTime ) }), t = e >= 0 var i = 0 _this33.mouseDown || _this33.toggleThumbContainer(t), t && (_this33.thumbnails.forEach(function (t, s) { _this33.loadedImages.includes(t.frames[e].text) && (i = s) }), e !== _this33.showingThumb && ((_this33.showingThumb = e), _this33.loadImage(i))) }), _defineProperty$1(this, 'loadImage', function () { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0 var t = _this33.showingThumb, i = _this33.thumbnails[e], s = i.urlPrefix, n = i.frames[t], r = i.frames[t].text, a = s + r if ( _this33.currentImageElement && _this33.currentImageElement.dataset.filename === r ) _this33.showImage( _this33.currentImageElement, n, e, t, r, !1 ), (_this33.currentImageElement.dataset.index = t), _this33.removeOldImages(_this33.currentImageElement) else { _this33.loadingImage && _this33.usingSprites && (_this33.loadingImage.onload = null) var _i9 = new Image() ;(_i9.src = a), (_i9.dataset.index = t), (_i9.dataset.filename = r), (_this33.showingThumbFilename = r), _this33.player.debug.log('Loading image: '.concat(a)), (_i9.onload = function () { return _this33.showImage(_i9, n, e, t, r, !0) }), (_this33.loadingImage = _i9), _this33.removeOldImages(_i9) } }), _defineProperty$1(this, 'showImage', function (e, t, i, s, n) { var r = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : !0 _this33.player.debug.log( 'Showing thumb: ' .concat(n, '. num: ') .concat(s, '. qual: ') .concat(i, '. newimg: ') .concat(r) ), _this33.setImageSizeAndOffset(e, t), r && (_this33.currentImageContainer.appendChild(e), (_this33.currentImageElement = e), _this33.loadedImages.includes(n) || _this33.loadedImages.push(n)), _this33 .preloadNearby(s, !0) .then(_this33.preloadNearby(s, !1)) .then(_this33.getHigherQuality(i, e, t, n)) }), _defineProperty$1(this, 'removeOldImages', function (e) { Array.from(_this33.currentImageContainer.children).forEach( function (t) { if ('img' !== t.tagName.toLowerCase()) return var i = _this33.usingSprites ? 500 : 1e3 if ( t.dataset.index !== e.dataset.index && !t.dataset.deleting ) { t.dataset.deleting = !0 var _e28 = _this33.currentImageContainer setTimeout(function () { _e28.removeChild(t), _this33.player.debug.log( 'Removing thumb: '.concat(t.dataset.filename) ) }, i) } } ) }), _defineProperty$1(this, 'preloadNearby', function (e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !0 return new Promise(function (i) { setTimeout(function () { var s = _this33.thumbnails[0].frames[e].text if (_this33.showingThumbFilename === s) { var n n = t ? _this33.thumbnails[0].frames.slice(e) : _this33.thumbnails[0].frames.slice(0, e).reverse() var r = !1 n.forEach(function (e) { var t = e.text if (t !== s && !_this33.loadedImages.includes(t)) { ;(r = !0), _this33.player.debug.log( 'Preloading thumb filename: '.concat(t) ) var _e29 = _this33.thumbnails[0].urlPrefix, _s9 = _e29 + t, _n5 = new Image() ;(_n5.src = _s9), (_n5.onload = function () { _this33.player.debug.log( 'Preloaded thumb filename: '.concat(t) ), _this33.loadedImages.includes(t) || _this33.loadedImages.push(t), i() }) } }), r || i() } }, 300) }) }), _defineProperty$1( this, 'getHigherQuality', function (e, t, i, s) { if (e < _this33.thumbnails.length - 1) { var n = t.naturalHeight _this33.usingSprites && (n = i.h), n < _this33.thumbContainerHeight && setTimeout(function () { _this33.showingThumbFilename === s && (_this33.player.debug.log( 'Showing higher quality thumb for: '.concat(s) ), _this33.loadImage(e + 1)) }, 300) } } ), _defineProperty$1(this, 'toggleThumbContainer', function () { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !1 var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1 var i = _this33.player.config.classNames.previewThumbnails .thumbContainerShown _this33.elements.thumb.container.classList.toggle(i, e), !e && t && ((_this33.showingThumb = null), (_this33.showingThumbFilename = null)) }), _defineProperty$1( this, 'toggleScrubbingContainer', function () { var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : !1 var t = _this33.player.config.classNames.previewThumbnails .scrubbingContainerShown _this33.elements.scrubbing.container.classList.toggle(t, e), e || ((_this33.showingThumb = null), (_this33.showingThumbFilename = null)) } ), _defineProperty$1( this, 'determineContainerAutoSizing', function () { ;(_this33.elements.thumb.imageContainer.clientHeight > 20 || _this33.elements.thumb.imageContainer.clientWidth > 20) && (_this33.sizeSpecifiedInCSS = !0) } ), _defineProperty$1( this, 'setThumbContainerSizeAndPos', function () { var e = _this33.elements.thumb.imageContainer if (_this33.sizeSpecifiedInCSS) { if (e.clientHeight > 20 && e.clientWidth < 20) { var t = Math.floor( e.clientHeight * _this33.thumbAspectRatio ) e.style.width = ''.concat(t, 'px') } else if (e.clientHeight < 20 && e.clientWidth > 20) { var _t19 = Math.floor( e.clientWidth / _this33.thumbAspectRatio ) e.style.height = ''.concat(_t19, 'px') } } else { var _t20 = Math.floor( _this33.thumbContainerHeight * _this33.thumbAspectRatio ) ;(e.style.height = ''.concat( _this33.thumbContainerHeight, 'px' )), (e.style.width = ''.concat(_t20, 'px')) } _this33.setThumbContainerPos() } ), _defineProperty$1(this, 'setThumbContainerPos', function () { var e = _this33.player.elements.progress.getBoundingClientRect(), t = _this33.player.elements.container.getBoundingClientRect(), i = _this33.elements.thumb.container, s = t.left - e.left + 10, n = t.right - e.left - i.clientWidth - 10, r = _this33.mousePosX - e.left - i.clientWidth / 2, a = clamp(r, s, n) ;(i.style.left = ''.concat(a, 'px')), i.style.setProperty('--preview-arrow-offset', r - a + 'px') }), _defineProperty$1( this, 'setScrubbingContainerSize', function () { var _fitRatio = fitRatio(_this33.thumbAspectRatio, { width: _this33.player.media.clientWidth, height: _this33.player.media.clientHeight }), e = _fitRatio.width, t = _fitRatio.height ;(_this33.elements.scrubbing.container.style.width = ''.concat(e, 'px')), (_this33.elements.scrubbing.container.style.height = ''.concat(t, 'px')) } ), _defineProperty$1( this, 'setImageSizeAndOffset', function (e, t) { if (!_this33.usingSprites) return var i = _this33.thumbContainerHeight / t.h ;(e.style.height = e.naturalHeight * i + 'px'), (e.style.width = e.naturalWidth * i + 'px'), (e.style.left = '-'.concat(t.x * i, 'px')), (e.style.top = '-'.concat(t.y * i, 'px')) } ), (this.player = e), (this.thumbnails = []), (this.loaded = !1), (this.lastMouseMoveTime = Date.now()), (this.mouseDown = !1), (this.loadedImages = []), (this.elements = { thumb: {}, scrubbing: {} }), this.load() } _createClass2(PreviewThumbnails, [ { key: 'enabled', get: function get() { return ( this.player.isHTML5 && this.player.isVideo && this.player.config.previewThumbnails.enabled ) } }, { key: 'currentImageContainer', get: function get() { return this.mouseDown ? this.elements.scrubbing.container : this.elements.thumb.imageContainer } }, { key: 'usingSprites', get: function get() { return Object.keys(this.thumbnails[0].frames[0]).includes('w') } }, { key: 'thumbAspectRatio', get: function get() { return this.usingSprites ? this.thumbnails[0].frames[0].w / this.thumbnails[0].frames[0].h : this.thumbnails[0].width / this.thumbnails[0].height } }, { key: 'thumbContainerHeight', get: function get() { if (this.mouseDown) { var _fitRatio2 = fitRatio(this.thumbAspectRatio, { width: this.player.media.clientWidth, height: this.player.media.clientHeight }), e = _fitRatio2.height return e } return this.sizeSpecifiedInCSS ? this.elements.thumb.imageContainer.clientHeight : Math.floor( this.player.media.clientWidth / this.thumbAspectRatio / 4 ) } }, { key: 'currentImageElement', get: function get() { return this.mouseDown ? this.currentScrubbingImageElement : this.currentThumbnailImageElement }, set: function set(e) { this.mouseDown ? (this.currentScrubbingImageElement = e) : (this.currentThumbnailImageElement = e) } } ]) return PreviewThumbnails })() var source = { insertElements: function insertElements(e, t) { var _this34 = this is.string(t) ? insertElement(e, this.media, { src: t }) : is.array(t) && t.forEach(function (t) { insertElement(e, _this34.media, t) }) }, change: function change(e) { var _this35 = this getDeep(e, 'sources.length') ? (html5.cancelRequests.call(this), this.destroy.call( this, function () { ;(_this35.options.quality = []), removeElement(_this35.media), (_this35.media = null), is.element(_this35.elements.container) && _this35.elements.container.removeAttribute('class') var t = e.sources, i = e.type, _t21 = _slicedToArray(t, 1), _t21$ = _t21[0], _t21$$provider = _t21$.provider, s = _t21$$provider === void 0 ? providers.html5 : _t21$$provider, n = _t21$.src, r = 'html5' === s ? i : 'div', a = 'html5' === s ? {} : { src: n } Object.assign(_this35, { provider: s, type: i, supported: support.check( i, s, _this35.config.playsinline ), media: createElement(r, a) }), _this35.elements.container.appendChild(_this35.media), is.boolean(e.autoplay) && (_this35.config.autoplay = e.autoplay), _this35.isHTML5 && (_this35.config.crossorigin && _this35.media.setAttribute('crossorigin', ''), _this35.config.autoplay && _this35.media.setAttribute('autoplay', ''), is.empty(e.poster) || (_this35.poster = e.poster), _this35.config.loop.active && _this35.media.setAttribute('loop', ''), _this35.config.muted && _this35.media.setAttribute('muted', ''), _this35.config.playsinline && _this35.media.setAttribute('playsinline', '')), ui.addStyleHook.call(_this35), _this35.isHTML5 && source.insertElements.call(_this35, 'source', t), (_this35.config.title = e.title), media.setup.call(_this35), _this35.isHTML5 && Object.keys(e).includes('tracks') && source.insertElements.call( _this35, 'track', e.tracks ), (_this35.isHTML5 || (_this35.isEmbed && !_this35.supported.ui)) && ui.build.call(_this35), _this35.isHTML5 && _this35.media.load(), is.empty(e.previewThumbnails) || (Object.assign( _this35.config.previewThumbnails, e.previewThumbnails ), _this35.previewThumbnails && _this35.previewThumbnails.loaded && (_this35.previewThumbnails.destroy(), (_this35.previewThumbnails = null)), _this35.config.previewThumbnails.enabled && (_this35.previewThumbnails = new PreviewThumbnails( _this35 ))), _this35.fullscreen.update() }, !0 )) : this.debug.warn('Invalid source format') } } var Plyr = /*#__PURE__*/ (function () { function Plyr(e, t) { var _this36 = this _classCallCheck2(this, Plyr) if ( (_defineProperty$1(this, 'play', function () { return is.function(_this36.media.play) ? (_this36.ads && _this36.ads.enabled && _this36.ads.managerPromise .then(function () { return _this36.ads.play() }) .catch(function () { return silencePromise(_this36.media.play()) }), _this36.media.play()) : null }), _defineProperty$1(this, 'pause', function () { return _this36.playing && is.function(_this36.media.pause) ? _this36.media.pause() : null }), _defineProperty$1(this, 'togglePlay', function (e) { return (is.boolean(e) ? e : !_this36.playing) ? _this36.play() : _this36.pause() }), _defineProperty$1(this, 'stop', function () { _this36.isHTML5 ? (_this36.pause(), _this36.restart()) : is.function(_this36.media.stop) && _this36.media.stop() }), _defineProperty$1(this, 'restart', function () { _this36.currentTime = 0 }), _defineProperty$1(this, 'rewind', function (e) { _this36.currentTime -= is.number(e) ? e : _this36.config.seekTime }), _defineProperty$1(this, 'forward', function (e) { _this36.currentTime += is.number(e) ? e : _this36.config.seekTime }), _defineProperty$1(this, 'increaseVolume', function (e) { var t = _this36.media.muted ? 0 : _this36.volume _this36.volume = t + (is.number(e) ? e : 0) }), _defineProperty$1(this, 'decreaseVolume', function (e) { _this36.increaseVolume(-e) }), _defineProperty$1(this, 'airplay', function () { support.airplay && _this36.media.webkitShowPlaybackTargetPicker() }), _defineProperty$1(this, 'toggleControls', function (e) { if (_this36.supported.ui && !_this36.isAudio) { var _t22 = hasClass( _this36.elements.container, _this36.config.classNames.hideControls ), _i10 = void 0 === e ? void 0 : !e, _s10 = toggleClass( _this36.elements.container, _this36.config.classNames.hideControls, _i10 ) if ( (_s10 && is.array(_this36.config.controls) && _this36.config.controls.includes('settings') && !is.empty(_this36.config.settings) && controls.toggleMenu.call(_this36, !1), _s10 !== _t22) ) { var _e30 = _s10 ? 'controlshidden' : 'controlsshown' triggerEvent.call(_this36, _this36.media, _e30) } return !_s10 } return !1 }), _defineProperty$1(this, 'on', function (e, t) { on.call(_this36, _this36.elements.container, e, t) }), _defineProperty$1(this, 'once', function (e, t) { once.call(_this36, _this36.elements.container, e, t) }), _defineProperty$1(this, 'off', function (e, t) { off(_this36.elements.container, e, t) }), _defineProperty$1(this, 'destroy', function (e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1 if (!_this36.ready) return var i = function i() { ;(document.body.style.overflow = ''), (_this36.embed = null), t ? (Object.keys(_this36.elements).length && (removeElement(_this36.elements.buttons.play), removeElement(_this36.elements.captions), removeElement(_this36.elements.controls), removeElement(_this36.elements.wrapper), (_this36.elements.buttons.play = null), (_this36.elements.captions = null), (_this36.elements.controls = null), (_this36.elements.wrapper = null)), is.function(e) && e()) : (unbindListeners.call(_this36), html5.cancelRequests.call(_this36), replaceElement( _this36.elements.original, _this36.elements.container ), triggerEvent.call( _this36, _this36.elements.original, 'destroyed', !0 ), is.function(e) && e.call(_this36.elements.original), (_this36.ready = !1), setTimeout(function () { ;(_this36.elements = null), (_this36.media = null) }, 200)) } _this36.stop(), clearTimeout(_this36.timers.loading), clearTimeout(_this36.timers.controls), clearTimeout(_this36.timers.resized), _this36.isHTML5 ? (ui.toggleNativeControls.call(_this36, !0), i()) : _this36.isYouTube ? (clearInterval(_this36.timers.buffering), clearInterval(_this36.timers.playing), null !== _this36.embed && is.function(_this36.embed.destroy) && _this36.embed.destroy(), i()) : _this36.isVimeo && (null !== _this36.embed && _this36.embed.unload().then(i), setTimeout(i, 200)) }), _defineProperty$1(this, 'supports', function (e) { return support.mime.call(_this36, e) }), (this.timers = {}), (this.ready = !1), (this.loading = !1), (this.failed = !1), (this.touch = support.touch), (this.media = e), is.string(this.media) && (this.media = document.querySelectorAll(this.media)), ((window.jQuery && this.media instanceof jQuery) || is.nodeList(this.media) || is.array(this.media)) && (this.media = this.media[0]), (this.config = extend( {}, defaults, Plyr.defaults, t || {}, (function () { try { return JSON.parse( _this36.media.getAttribute('data-plyr-config') ) } catch (e) { return {} } })() )), (this.elements = { container: null, fullscreen: null, captions: null, buttons: {}, display: {}, progress: {}, inputs: {}, settings: { popup: null, menu: null, panels: {}, buttons: {} } }), (this.captions = { active: null, currentTrack: -1, meta: new WeakMap() }), (this.fullscreen = { active: !1 }), (this.options = { speed: [], quality: [] }), (this.debug = new Console(this.config.debug)), this.debug.log('Config', this.config), this.debug.log('Support', support), is.nullOrUndefined(this.media) || !is.element(this.media)) ) return void this.debug.error( 'Setup failed: no suitable element passed' ) if (this.media.plyr) return void this.debug.warn('Target already setup') if (!this.config.enabled) return void this.debug.error('Setup failed: disabled by config') if (!support.check().api) return void this.debug.error('Setup failed: no support') var i = this.media.cloneNode(!0) ;(i.autoplay = !1), (this.elements.original = i) var s = this.media.tagName.toLowerCase() var n = null, r = null switch (s) { case 'div': if ( ((n = this.media.querySelector('iframe')), is.element(n)) ) { if ( ((r = parseUrl(n.getAttribute('src'))), (this.provider = getProviderByUrl(r.toString())), (this.elements.container = this.media), (this.media = n), (this.elements.container.className = ''), r.search.length) ) { var _e31 = ['1', 'true'] _e31.includes(r.searchParams.get('autoplay')) && (this.config.autoplay = !0), _e31.includes(r.searchParams.get('loop')) && (this.config.loop.active = !0), this.isYouTube ? ((this.config.playsinline = _e31.includes( r.searchParams.get('playsinline') )), (this.config.youtube.hl = r.searchParams.get('hl'))) : (this.config.playsinline = !0) } } else (this.provider = this.media.getAttribute( this.config.attributes.embed.provider )), this.media.removeAttribute( this.config.attributes.embed.provider ) if ( is.empty(this.provider) || !Object.values(providers).includes(this.provider) ) return void this.debug.error( 'Setup failed: Invalid provider' ) this.type = types.video break case 'video': case 'audio': ;(this.type = s), (this.provider = providers.html5), this.media.hasAttribute('crossorigin') && (this.config.crossorigin = !0), this.media.hasAttribute('autoplay') && (this.config.autoplay = !0), (this.media.hasAttribute('playsinline') || this.media.hasAttribute('webkit-playsinline')) && (this.config.playsinline = !0), this.media.hasAttribute('muted') && (this.config.muted = !0), this.media.hasAttribute('loop') && (this.config.loop.active = !0) break default: return void this.debug.error('Setup failed: unsupported type') } ;(this.supported = support.check( this.type, this.provider, this.config.playsinline )), this.supported.api ? ((this.eventListeners = []), (this.listeners = new Listeners(this)), (this.storage = new Storage(this)), (this.media.plyr = this), is.element(this.elements.container) || ((this.elements.container = createElement('div', { tabindex: 0 })), wrap(this.media, this.elements.container)), ui.migrateStyles.call(this), ui.addStyleHook.call(this), media.setup.call(this), this.config.debug && on.call( this, this.elements.container, this.config.events.join(' '), function (e) { _this36.debug.log('event: '.concat(e.type)) } ), (this.fullscreen = new Fullscreen(this)), (this.isHTML5 || (this.isEmbed && !this.supported.ui)) && ui.build.call(this), this.listeners.container(), this.listeners.global(), this.config.ads.enabled && (this.ads = new Ads(this)), this.isHTML5 && this.config.autoplay && this.once('canplay', function () { return silencePromise(_this36.play()) }), (this.lastSeekTime = 0), this.config.previewThumbnails.enabled && (this.previewThumbnails = new PreviewThumbnails(this))) : this.debug.error('Setup failed: no support') } _createClass2( Plyr, [ { key: 'isHTML5', get: function get() { return this.provider === providers.html5 } }, { key: 'isEmbed', get: function get() { return this.isYouTube || this.isVimeo } }, { key: 'isYouTube', get: function get() { return this.provider === providers.youtube } }, { key: 'isVimeo', get: function get() { return this.provider === providers.vimeo } }, { key: 'isVideo', get: function get() { return this.type === types.video } }, { key: 'isAudio', get: function get() { return this.type === types.audio } }, { key: 'playing', get: function get() { return Boolean(this.ready && !this.paused && !this.ended) } }, { key: 'paused', get: function get() { return Boolean(this.media.paused) } }, { key: 'stopped', get: function get() { return Boolean(this.paused && 0 === this.currentTime) } }, { key: 'ended', get: function get() { return Boolean(this.media.ended) } }, { key: 'currentTime', get: function get() { return Number(this.media.currentTime) }, set: function set(e) { if (!this.duration) return var t = is.number(e) && e > 0 ;(this.media.currentTime = t ? Math.min(e, this.duration) : 0), this.debug.log( 'Seeking to '.concat(this.currentTime, ' seconds') ) } }, { key: 'buffered', get: function get() { var e = this.media.buffered return is.number(e) ? e : e && e.length && this.duration > 0 ? e.end(0) / this.duration : 0 } }, { key: 'seeking', get: function get() { return Boolean(this.media.seeking) } }, { key: 'duration', get: function get() { var e = parseFloat(this.config.duration), t = (this.media || {}).duration, i = is.number(t) && t !== 1 / 0 ? t : 0 return e || i } }, { key: 'volume', get: function get() { return Number(this.media.volume) }, set: function set(e) { var _this$config2 var t = e is.string(t) && (t = Number(t)), is.number(t) || (t = this.storage.get('volume')), is.number(t) || ((_this$config2 = this.config), (t = _this$config2.volume), _this$config2), t > 1 && (t = 1), t < 0 && (t = 0), (this.config.volume = t), (this.media.volume = t), !is.empty(e) && this.muted && t > 0 && (this.muted = !1) } }, { key: 'muted', get: function get() { return Boolean(this.media.muted) }, set: function set(e) { var t = e is.boolean(t) || (t = this.storage.get('muted')), is.boolean(t) || (t = this.config.muted), (this.config.muted = t), (this.media.muted = t) } }, { key: 'hasAudio', get: function get() { return ( !this.isHTML5 || !!this.isAudio || Boolean(this.media.mozHasAudio) || Boolean(this.media.webkitAudioDecodedByteCount) || Boolean( this.media.audioTracks && this.media.audioTracks.length ) ) } }, { key: 'speed', get: function get() { return Number(this.media.playbackRate) }, set: function set(e) { var _this37 = this var t = null is.number(e) && (t = e), is.number(t) || (t = this.storage.get('speed')), is.number(t) || (t = this.config.speed.selected) var i = this.minimumSpeed, s = this.maximumSpeed ;(t = clamp(t, i, s)), (this.config.speed.selected = t), setTimeout(function () { _this37.media && (_this37.media.playbackRate = t) }, 0) } }, { key: 'minimumSpeed', get: function get() { return this.isYouTube ? Math.min.apply( Math, _toConsumableArray(this.options.speed) ) : this.isVimeo ? 0.5 : 0.0625 } }, { key: 'maximumSpeed', get: function get() { return this.isYouTube ? Math.max.apply( Math, _toConsumableArray(this.options.speed) ) : this.isVimeo ? 2 : 16 } }, { key: 'quality', get: function get() { return this.media.quality }, set: function set(e) { var t = this.config.quality, i = this.options.quality if (!i.length) return var s = [ !is.empty(e) && Number(e), this.storage.get('quality'), t.selected, t.default ].find(is.number), n = !0 if (!i.includes(s)) { var _e32 = closest(i, s) this.debug.warn( 'Unsupported quality option: ' .concat(s, ', using ') .concat(_e32, ' instead') ), (s = _e32), (n = !1) } ;(t.selected = s), (this.media.quality = s), n && this.storage.set({ quality: s }) } }, { key: 'loop', get: function get() { return Boolean(this.media.loop) }, set: function set(e) { var t = is.boolean(e) ? e : this.config.loop.active ;(this.config.loop.active = t), (this.media.loop = t) } }, { key: 'source', get: function get() { return this.media.currentSrc }, set: function set(e) { source.change.call(this, e) } }, { key: 'download', get: function get() { var e = this.config.urls.download return is.url(e) ? e : this.source }, set: function set(e) { is.url(e) && ((this.config.urls.download = e), controls.setDownloadUrl.call(this)) } }, { key: 'poster', get: function get() { return this.isVideo ? this.media.getAttribute('poster') || this.media.getAttribute('data-poster') : null }, set: function set(e) { this.isVideo ? ui.setPoster.call(this, e, !1).catch(function () {}) : this.debug.warn('Poster can only be set for video') } }, { key: 'ratio', get: function get() { if (!this.isVideo) return null var e = reduceAspectRatio(getAspectRatio.call(this)) return is.array(e) ? e.join(':') : e }, set: function set(e) { this.isVideo ? is.string(e) && validateAspectRatio(e) ? ((this.config.ratio = reduceAspectRatio(e)), setAspectRatio.call(this)) : this.debug.error( 'Invalid aspect ratio specified ('.concat(e, ')') ) : this.debug.warn( 'Aspect ratio can only be set for video' ) } }, { key: 'autoplay', get: function get() { return Boolean(this.config.autoplay) }, set: function set(e) { this.config.autoplay = is.boolean(e) ? e : this.config.autoplay } }, { key: 'toggleCaptions', value: function toggleCaptions(e) { captions.toggle.call(this, e, !1) } }, { key: 'currentTrack', get: function get() { var _this$captions2 = this.captions, e = _this$captions2.toggled, t = _this$captions2.currentTrack return e ? t : -1 }, set: function set(e) { captions.set.call(this, e, !1), captions.setup.call(this) } }, { key: 'language', get: function get() { return (captions.getCurrentTrack.call(this) || {}).language }, set: function set(e) { captions.setLanguage.call(this, e, !1) } }, { key: 'pip', get: function get() { return support.pip ? is.empty(this.media.webkitPresentationMode) ? this.media === document.pictureInPictureElement : this.media.webkitPresentationMode === pip.active : null }, set: function set(e) { if (!support.pip) return var t = is.boolean(e) ? e : !this.pip is.function(this.media.webkitSetPresentationMode) && this.media.webkitSetPresentationMode( t ? pip.active : pip.inactive ), is.function(this.media.requestPictureInPicture) && (!this.pip && t ? this.media.requestPictureInPicture() : this.pip && !t && document.exitPictureInPicture()) } }, { key: 'setPreviewThumbnails', value: function setPreviewThumbnails(e) { this.previewThumbnails && this.previewThumbnails.loaded && (this.previewThumbnails.destroy(), (this.previewThumbnails = null)), Object.assign(this.config.previewThumbnails, e), this.config.previewThumbnails.enabled && (this.previewThumbnails = new PreviewThumbnails(this)) } } ], [ { key: 'supported', value: function supported(e, t, i) { return support.check(e, t, i) } }, { key: 'loadSprite', value: function loadSprite(e, t) { return _loadSprite(e, t) } }, { key: 'setup', value: function setup(e) { var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {} var i = null return ( is.string(e) ? (i = Array.from(document.querySelectorAll(e))) : is.nodeList(e) ? (i = Array.from(e)) : is.array(e) && (i = e.filter(is.element)), is.empty(i) ? null : i.map(function (e) { return new Plyr(e, t) }) ) } } ] ) return Plyr })() Plyr.defaults = cloneDeep(defaults) var plyr = '' var iconVideoPlay = '' var ColVideo = exports( 'C', defineComponent({ name: 'col-video', props: { trySee: { // 是否试看 type: Boolean, default: false }, freeTitleStatus: { type: Boolean, default: true }, // 试看比例 freeRate: { type: Number, default: 100 }, setting: { type: Object, default: function _default() {} }, controls: Boolean, height: String, src: { type: String, default: '' }, poster: { type: String, default: '' }, styleValue: { type: Object, default: function _default() { return {} } }, preload: { type: String, default: 'auto' }, currentTime: { type: Boolean, default: true }, playsinline: { type: Boolean, default: true }, onPlay: { type: Function, default: function _default() {} } }, data: function data() { return { player: null, // playTime: 0, loading: true, // 首次进入加载中 trySeeOver: false, // 试看是否结束 showSeeStatus: true // 是否显示试看状态 } }, mounted: function mounted() { var _this38 = this this._init() listenerMessage('setVideoPlayer', function (result) { var content = result === null || result === void 0 ? void 0 : result.content if (content.status === 'pause') { _this38.player.pause() } }) }, computed: { computedSeeStatus: function computedSeeStatus() { console.log( this.showSeeStatus, this.trySee, this.trySeeOver, 'this.showSeeStatus, this.trySee' ) return this.showSeeStatus && this.trySee }, playTime: function playTime() { // 允许播放时间 var player = this.player var playTime = (player.duration * this.freeRate) / 100 return playTime || 0 } }, methods: { _init: function _init() { var _this39 = this // controls: [ // 'play-large' , // 中间的大播放按钮 // 'restart' , // 重新开始播放 // 'rewind' , // 按寻道时间倒带(默认 10 秒) // 'play' , // 播放/暂停播放 // 'fast-forward' , // 快进查找时间(默认 10 秒) // 'progress' , // 播放和缓冲的进度条和滑动条 // 'current-time' , // 播放的当前时间 // ' duration' , // 媒体的完整持续时间 // 'mute' , // 切换静音 // 'volume', // 音量控制 // 'captions' , // 切换字幕 // 'settings' , // 设置菜单 // 'pip' , // 画中画(当前仅 Safari) // 'airplay' , // Airplay(当前仅 Safari) // 'download ' , // 显示一个下载按钮,其中包含指向当前源或您在选项中指定的自定义 URL 的链接 // 'fullscreen' , // 切换全屏 // ] ; var controls = [ 'play-large', 'play', 'progress', 'captions', 'fullscreen' ] if (this.currentTime) { controls.push('current-time') } var params = _objectSpread( _objectSpread({ controls: controls }, this.setting), {}, { invertTime: false } ) if (browser$1().iPhone) { params.fullscreen = { enabled: true, fallback: 'force', iosNative: true } } this.player = new Plyr(this.$refs.video, params) // fullscreen: { // enabled: true, // fallback: 'force', // iosNative: true // } this.player.elements.container ? (this.player.elements.container.style.height = this.height || '210px') : null if (this.preload === 'none') { this.loading = false } this.player.on('loadedmetadata', function () { _this39.loading = false console.log('loading 1111') if (_this39.trySee) { _this39.domPlayVisibility() } else { _this39.domPlayVisibility(false) } // 监听播放事件 var _this = _this39 _this39.player.on('timeupdate', function () { var players = _this.player if ( players.currentTime >= _this39.playTime && _this.trySee ) { players.pause() _this.trySeeOver = true _this.showSeeStatus = true _this.domPlayVisibility() // 试看结束后隐藏播放按钮 } }) }) this.player.on('play', function () { postMessage( { api: 'getDeviceStatus', content: { type: 'video' } }, function (res) { // 判断是否在录屏中, 如果在录屏则不允许播放 if (res.content.status == '1') { Toast('为了保证数据安全,请不要录屏') _this39.player.pause() } } ) _this39.onPlay && _this39.onPlay() }) this.player.on('enterfullscreen', function () { console.log('fullscreen') var i = document.createElement('i') i.id = 'fullscreen-back' i.className = 'van-icon van-icon-arrow-left video-back' i.addEventListener('click', function () { _this39.player.fullscreen.exit() }) console.log(document.getElementsByClassName('plyr')) document.getElementsByClassName('plyr')[0].appendChild(i) }) this.player.on('exitfullscreen', function () { console.log('exitfullscreen') var i = document.getElementById('fullscreen-back') i && i.remove() }) }, // 操作功能 domPlayVisibility: function domPlayVisibility() { var hide = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true var controls = document.querySelector('.plyr__controls') var controls2 = document.querySelector( '.plyr__control--overlaid' ) if (hide) { controls === null || controls === void 0 ? void 0 : controls.setAttribute('style', 'display:none') controls2 === null || controls2 === void 0 ? void 0 : controls2.setAttribute('style', 'display:none') } else { controls === null || controls === void 0 ? void 0 : controls.removeAttribute('style') setTimeout(function () { controls2 === null || controls2 === void 0 ? void 0 : controls2.removeAttribute('style') }, 200) } }, onClickPlay: function onClickPlay() { this.player.play() this.domPlayVisibility(false) this.showSeeStatus = false }, onBuy: function onBuy() { this.$router.back() }, onReplay: function onReplay() { this.player.restart() this.player.play() this.domPlayVisibility(false) this.trySeeOver = false this.showSeeStatus = false } }, unmounted: function unmounted() { var _this$player ;(_this$player = this.player) === null || _this$player === void 0 ? void 0 : _this$player.destroy() }, render: function render() { var _this40 = this return createVNode( 'div', { class: styles['video-container'] }, [ createVNode( 'video', { ref: 'video', class: styles['video'], src: this.src, playsinline: this.playsinline, poster: this.poster, preload: this.preload, style: _objectSpread({}, this.styleValue) }, null ), this.loading && createVNode( 'div', { class: styles.loadingVideo, style: { height: this.height || '210px' } }, [ createVNode( Loading, { size: 36, color: '#01C1B5', vertical: true, style: { height: '100%', justifyContent: 'center' } }, { default: function _default() { return [ createTextVNode('\u52A0\u8F7D\u4E2D...') ] } } ) ] ), this.trySee && this.computedSeeStatus && !this.loading && createVNode( 'div', { class: [styles.loadingVideo, styles.playOver], style: { height: this.height || '210px' } }, [ !this.trySeeOver ? createVNode(Fragment, null, [ createVNode( Icon, { name: iconVideoPlay, size: 50, onClick: this.onClickPlay }, null ), createVNode('p', { class: styles.freeTxt }, [ createTextVNode('\u514D\u8D39'), this.freeTitleStatus ? '试看' : '领取' ]) ]) : createVNode(Fragment, null, [ createVNode('p', { class: styles.tips }, [ this.freeTitleStatus ? '免费试看结束,购买完整课程后继续学习' : '试看结束,领取课程后继续学习' ]), createVNode( Button, { class: styles.btn, type: 'primary', round: true, size: 'small', onClick: this.onBuy }, { default: function _default() { return [ state.platformType === 'STUDENT' ? _this40.freeTitleStatus ? '立即购买' : '免费领取' : '返回' ] } } ), createVNode( 'div', { class: styles.replay, onClick: this.onReplay }, [ createVNode( Icon, { name: 'replay', style: { marginRight: '5px' }, size: 16 }, null ), createTextVNode('\u91CD\u64AD') ] ) ]) ] ) ] ) } }) ) } } } ) })()