AlkantarClanX12

Your IP : 3.145.97.235


Current Path : /home/thanudqk/128shen.com/wp-content/plugins/embedpress/assets/js/
Upload File :
Current File : /home/thanudqk/128shen.com/wp-content/plugins/embedpress/assets/js/plyr.js

"object" == typeof navigator &&
    (function (e, t) {
        "object" == typeof exports && "undefined" != typeof module ? (module.exports = t()) : "function" == typeof define && define.amd ? define("Plyr", t) : ((e = "undefined" != typeof globalThis ? globalThis : e || self).Plyr = t());
    })(this, function () {
        "use strict";
        !(function () {
            if ("undefined" != typeof window)
                try {
                    var e = new window.CustomEvent("test", { cancelable: !0 });
                    if ((e.preventDefault(), !0 !== e.defaultPrevented)) throw new Error("Could not prevent default");
                } catch (e) {
                    var t = function (e, t) {
                        var i, s;
                        return (
                            ((t = t || {}).bubbles = !!t.bubbles),
                            (t.cancelable = !!t.cancelable),
                            (i = document.createEvent("CustomEvent")).initCustomEvent(e, t.bubbles, t.cancelable, t.detail),
                            (s = i.preventDefault),
                            (i.preventDefault = function () {
                                s.call(this);
                                try {
                                    Object.defineProperty(this, "defaultPrevented", {
                                        get: function () {
                                            return !0;
                                        },
                                    });
                                } catch (e) {
                                    this.defaultPrevented = !0;
                                }
                            }),
                            i
                        );
                    };
                    (t.prototype = window.Event.prototype), (window.CustomEvent = t);
                }
        })();
        var e = "undefined" != typeof globalThis ? globalThis : "undefined" != typeof window ? window : "undefined" != typeof global ? global : "undefined" != typeof self ? self : {};
        function t(e, t, i) {
            return (
                (t = (function (e) {
                    var t = (function (e, t) {
                        if ("object" != typeof e || null === e) return e;
                        var i = e[Symbol.toPrimitive];
                        if (void 0 !== i) {
                            var s = i.call(e, t || "default");
                            if ("object" != typeof s) return s;
                            throw new TypeError("@@toPrimitive must return a primitive value.");
                        }
                        return ("string" === t ? String : Number)(e);
                    })(e, "string");
                    return "symbol" == typeof t ? t : String(t);
                })(t)) in e
                    ? Object.defineProperty(e, t, { value: i, enumerable: !0, configurable: !0, writable: !0 })
                    : (e[t] = i),
                e
            );
        }
        function i(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 s(e, t, i) {
            return t in e ? Object.defineProperty(e, t, { value: i, enumerable: !0, configurable: !0, writable: !0 }) : (e[t] = i), e;
        }
        function n(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 a(e) {
            for (var t = 1; t < arguments.length; t++) {
                var i = null != arguments[t] ? arguments[t] : {};
                t % 2
                    ? n(Object(i), !0).forEach(function (t) {
                        s(e, t, i[t]);
                    })
                    : Object.getOwnPropertyDescriptors
                        ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(i))
                        : n(Object(i)).forEach(function (t) {
                            Object.defineProperty(e, t, Object.getOwnPropertyDescriptor(i, t));
                        });
            }
            return e;
        }
        !(function (e) {
            var t = (function () {
                try {
                    return !!Symbol.iterator;
                } catch (e) {
                    return !1;
                }
            })(),
                i = function (e) {
                    var i = {
                        next: function () {
                            var t = e.shift();
                            return { done: void 0 === t, value: t };
                        },
                    };
                    return (
                        t &&
                        (i[Symbol.iterator] = function () {
                            return i;
                        }),
                        i
                    );
                },
                s = function (e) {
                    return encodeURIComponent(e).replace(/%20/g, "+");
                },
                n = function (e) {
                    return decodeURIComponent(String(e).replace(/\+/g, " "));
                };
            (function () {
                try {
                    var t = e.URLSearchParams;
                    return "a=1" === new t("?a=1").toString() && "function" == typeof t.prototype.set && "function" == typeof t.prototype.entries;
                } catch (e) {
                    return !1;
                }
            })() ||
                (function () {
                    var n = function (e) {
                        Object.defineProperty(this, "_entries", { writable: !0, value: {} });
                        var t = typeof e;
                        if ("undefined" === t);
                        else if ("string" === t) "" !== e && this._fromString(e);
                        else if (e instanceof n) {
                            var i = this;
                            e.forEach(function (e, t) {
                                i.append(t, e);
                            });
                        } else {
                            if (null === e || "object" !== t) throw new TypeError("Unsupported input's type for URLSearchParams");
                            if ("[object Array]" === Object.prototype.toString.call(e))
                                for (var s = 0; s < e.length; s++) {
                                    var a = e[s];
                                    if ("[object Array]" !== Object.prototype.toString.call(a) && 2 === a.length) throw new TypeError("Expected [string, any] as entry at index " + s + " of URLSearchParams's input");
                                    this.append(a[0], a[1]);
                                }
                            else for (var r in e) e.hasOwnProperty(r) && this.append(r, e[r]);
                        }
                    },
                        a = n.prototype;
                    (a.append = function (e, t) {
                        e in this._entries ? this._entries[e].push(String(t)) : (this._entries[e] = [String(t)]);
                    }),
                        (a.delete = function (e) {
                            delete this._entries[e];
                        }),
                        (a.get = function (e) {
                            return e in this._entries ? this._entries[e][0] : null;
                        }),
                        (a.getAll = function (e) {
                            return e in this._entries ? this._entries[e].slice(0) : [];
                        }),
                        (a.has = function (e) {
                            return e in this._entries;
                        }),
                        (a.set = function (e, t) {
                            this._entries[e] = [String(t)];
                        }),
                        (a.forEach = function (e, t) {
                            var i;
                            for (var s in this._entries)
                                if (this._entries.hasOwnProperty(s)) {
                                    i = this._entries[s];
                                    for (var n = 0; n < i.length; n++) e.call(t, i[n], s, this);
                                }
                        }),
                        (a.keys = function () {
                            var e = [];
                            return (
                                this.forEach(function (t, i) {
                                    e.push(i);
                                }),
                                i(e)
                            );
                        }),
                        (a.values = function () {
                            var e = [];
                            return (
                                this.forEach(function (t) {
                                    e.push(t);
                                }),
                                i(e)
                            );
                        }),
                        (a.entries = function () {
                            var e = [];
                            return (
                                this.forEach(function (t, i) {
                                    e.push([i, t]);
                                }),
                                i(e)
                            );
                        }),
                        t && (a[Symbol.iterator] = a.entries),
                        (a.toString = function () {
                            var e = [];
                            return (
                                this.forEach(function (t, i) {
                                    e.push(s(i) + "=" + s(t));
                                }),
                                e.join("&")
                            );
                        }),
                        (e.URLSearchParams = n);
                })();
            var a = e.URLSearchParams.prototype;
            "function" != typeof a.sort &&
                (a.sort = function () {
                    var e = this,
                        t = [];
                    this.forEach(function (i, s) {
                        t.push([s, i]), e._entries || e.delete(s);
                    }),
                        t.sort(function (e, t) {
                            return e[0] < t[0] ? -1 : e[0] > t[0] ? 1 : 0;
                        }),
                        e._entries && (e._entries = {});
                    for (var i = 0; i < t.length; i++) this.append(t[i][0], t[i][1]);
                }),
                "function" != typeof a._fromString &&
                Object.defineProperty(a, "_fromString", {
                    enumerable: !1,
                    configurable: !1,
                    writable: !1,
                    value: function (e) {
                        if (this._entries) this._entries = {};
                        else {
                            var t = [];
                            this.forEach(function (e, i) {
                                t.push(i);
                            });
                            for (var i = 0; i < t.length; i++) this.delete(t[i]);
                        }
                        var s,
                            a = (e = e.replace(/^\?/, "")).split("&");
                        for (i = 0; i < a.length; i++) (s = a[i].split("=")), this.append(n(s[0]), s.length > 1 ? n(s[1]) : "");
                    },
                });
        })(void 0 !== e ? e : "undefined" != typeof window ? window : "undefined" != typeof self ? self : e),
            (function (e) {
                if (
                    ((function () {
                        try {
                            var t = new e.URL("b", "http://a");
                            return (t.pathname = "c d"), "http://a/c%20d" === t.href && t.searchParams;
                        } catch (e) {
                            return !1;
                        }
                    })() ||
                        (function () {
                            var t = e.URL,
                                i = function (t, i) {
                                    "string" != typeof t && (t = String(t)), i && "string" != typeof i && (i = String(i));
                                    var s,
                                        n = document;
                                    if (i && (void 0 === e.location || i !== e.location.href)) {
                                        (i = i.toLowerCase()), ((s = (n = document.implementation.createHTMLDocument("")).createElement("base")).href = i), n.head.appendChild(s);
                                        try {
                                            if (0 !== s.href.indexOf(i)) throw new Error(s.href);
                                        } catch (e) {
                                            throw new Error("URL unable to set base " + i + " due to " + e);
                                        }
                                    }
                                    var a = n.createElement("a");
                                    (a.href = t), s && (n.body.appendChild(a), (a.href = a.href));
                                    var r = n.createElement("input");
                                    if (((r.type = "url"), (r.value = t), ":" === a.protocol || !/:/.test(a.href) || (!r.checkValidity() && !i))) throw new TypeError("Invalid URL");
                                    Object.defineProperty(this, "_anchorElement", { value: a });
                                    var o = new e.URLSearchParams(this.search),
                                        l = !0,
                                        c = !0,
                                        u = this;
                                    ["append", "delete", "set"].forEach(function (e) {
                                        var t = o[e];
                                        o[e] = function () {
                                            t.apply(o, arguments), l && ((c = !1), (u.search = o.toString()), (c = !0));
                                        };
                                    }),
                                        Object.defineProperty(this, "searchParams", { value: o, enumerable: !0 });
                                    var h = void 0;
                                    Object.defineProperty(this, "_updateSearchParams", {
                                        enumerable: !1,
                                        configurable: !1,
                                        writable: !1,
                                        value: function () {
                                            this.search !== h && ((h = this.search), c && ((l = !1), this.searchParams._fromString(this.search), (l = !0)));
                                        },
                                    });
                                },
                                s = i.prototype;
                            ["hash", "host", "hostname", "port", "protocol"].forEach(function (e) {
                                !(function (e) {
                                    Object.defineProperty(s, e, {
                                        get: function () {
                                            return this._anchorElement[e];
                                        },
                                        set: function (t) {
                                            this._anchorElement[e] = t;
                                        },
                                        enumerable: !0,
                                    });
                                })(e);
                            }),
                                Object.defineProperty(s, "search", {
                                    get: function () {
                                        return this._anchorElement.search;
                                    },
                                    set: function (e) {
                                        (this._anchorElement.search = e), this._updateSearchParams();
                                    },
                                    enumerable: !0,
                                }),
                                Object.defineProperties(s, {
                                    toString: {
                                        get: function () {
                                            var e = this;
                                            return function () {
                                                return e.href;
                                            };
                                        },
                                    },
                                    href: {
                                        get: function () {
                                            return this._anchorElement.href.replace(/\?$/, "");
                                        },
                                        set: function (e) {
                                            (this._anchorElement.href = e), this._updateSearchParams();
                                        },
                                        enumerable: !0,
                                    },
                                    pathname: {
                                        get: function () {
                                            return this._anchorElement.pathname.replace(/(^\/?)/, "/");
                                        },
                                        set: function (e) {
                                            this._anchorElement.pathname = e;
                                        },
                                        enumerable: !0,
                                    },
                                    origin: {
                                        get: function () {
                                            var e = { "http:": 80, "https:": 443, "ftp:": 21 }[this._anchorElement.protocol],
                                                t = this._anchorElement.port != e && "" !== this._anchorElement.port;
                                            return this._anchorElement.protocol + "//" + this._anchorElement.hostname + (t ? ":" + this._anchorElement.port : "");
                                        },
                                        enumerable: !0,
                                    },
                                    password: {
                                        get: function () {
                                            return "";
                                        },
                                        set: function (e) { },
                                        enumerable: !0,
                                    },
                                    username: {
                                        get: function () {
                                            return "";
                                        },
                                        set: function (e) { },
                                        enumerable: !0,
                                    },
                                }),
                                (i.createObjectURL = function (e) {
                                    return t.createObjectURL.apply(t, arguments);
                                }),
                                (i.revokeObjectURL = function (e) {
                                    return t.revokeObjectURL.apply(t, arguments);
                                }),
                                (e.URL = i);
                        })(),
                        void 0 !== e.location && !("origin" in e.location))
                ) {
                    var t = function () {
                        return e.location.protocol + "//" + e.location.hostname + (e.location.port ? ":" + e.location.port : "");
                    };
                    try {
                        Object.defineProperty(e.location, "origin", { get: t, enumerable: !0 });
                    } catch (i) {
                        setInterval(function () {
                            e.location.origin = t();
                        }, 100);
                    }
                }
            })(void 0 !== e ? e : "undefined" != typeof window ? window : "undefined" != typeof self ? self : e);
        var r = { addCSS: !0, thumbWidth: 15, watch: !0 };
        var o = function (e) {
            return null != e ? e.constructor : null;
        },
            l = function (e, t) {
                return !!(e && t && e instanceof t);
            },
            c = function (e) {
                return null == e;
            },
            u = function (e) {
                return o(e) === Object;
            },
            h = function (e) {
                return o(e) === String;
            },
            d = function (e) {
                return Array.isArray(e);
            },
            m = function (e) {
                return l(e, NodeList);
            },
            p = {
                nullOrUndefined: c,
                object: u,
                number: function (e) {
                    return o(e) === Number && !Number.isNaN(e);
                },
                string: h,
                boolean: function (e) {
                    return o(e) === Boolean;
                },
                function: function (e) {
                    return o(e) === Function;
                },
                array: d,
                nodeList: m,
                element: function (e) {
                    return l(e, Element);
                },
                event: function (e) {
                    return l(e, Event);
                },
                empty: function (e) {
                    return c(e) || ((h(e) || d(e) || m(e)) && !e.length) || (u(e) && !Object.keys(e).length);
                },
            };
        function g(e, t) {
            if (1 > t) {
                var i = (function (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;
                })(t);
                return parseFloat(e.toFixed(i));
            }
            return Math.round(e / t) * t;
        }
        var f = (function () {
            function e(t, i) {
                (function (e, t) {
                    if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function");
                })(this, e),
                    p.element(t) ? (this.element = t) : p.string(t) && (this.element = document.querySelector(t)),
                    p.element(this.element) && p.empty(this.element.rangeTouch) && ((this.config = a({}, r, {}, i)), this.init());
            }
            return (
                (function (e, t, s) {
                    t && i(e.prototype, t), s && i(e, s);
                })(
                    e,
                    [
                        {
                            key: "init",
                            value: function () {
                                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 () {
                                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 (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 (t) {
                                if (!e.enabled || !p.event(t)) return null;
                                var i,
                                    s = t.target,
                                    n = t.changedTouches[0],
                                    a = parseFloat(s.getAttribute("min")) || 0,
                                    r = 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), a + g((i / 100) * (r - a), o);
                            },
                        },
                        {
                            key: "set",
                            value: function (t) {
                                e.enabled &&
                                    p.event(t) &&
                                    !t.target.disabled &&
                                    (t.preventDefault(),
                                        (t.target.value = this.get(t)),
                                        (function (e, t) {
                                            if (e && t) {
                                                var i = new Event(t, { bubbles: !0 });
                                                e.dispatchEvent(i);
                                            }
                                        })(t.target, "touchend" === t.type ? "change" : "input"));
                            },
                        },
                    ],
                    [
                        {
                            key: "setup",
                            value: function (t) {
                                var i = 1 < arguments.length && void 0 !== arguments[1] ? arguments[1] : {},
                                    s = null;
                                if (
                                    (p.empty(t) || p.string(t)
                                        ? (s = Array.from(document.querySelectorAll(p.string(t) ? t : 'input[type="range"]')))
                                        : p.element(t)
                                            ? (s = [t])
                                            : p.nodeList(t)
                                                ? (s = Array.from(t))
                                                : p.array(t) && (s = t.filter(p.element)),
                                        p.empty(s))
                                )
                                    return null;
                                var n = a({}, r, {}, i);
                                if (p.string(t) && n.watch) {
                                    var o = new MutationObserver(function (i) {
                                        Array.from(i).forEach(function (i) {
                                            Array.from(i.addedNodes).forEach(function (i) {
                                                p.element(i) &&
                                                    (function (e, t) {
                                                        return function () {
                                                            return Array.from(document.querySelectorAll(t)).includes(this);
                                                        }.call(e, t);
                                                    })(i, t) &&
                                                    new e(i, n);
                                            });
                                        });
                                    });
                                    o.observe(document.body, { childList: !0, subtree: !0 });
                                }
                                return s.map(function (t) {
                                    return new e(t, i);
                                });
                            },
                        },
                        {
                            key: "enabled",
                            get: function () {
                                return "ontouchstart" in document.documentElement;
                            },
                        },
                    ]
                ),
                e
            );
        })();
        const y = (e) => (null != e ? e.constructor : null),
            b = (e, t) => Boolean(e && t && e instanceof t),
            v = (e) => null == e,
            w = (e) => y(e) === Object,
            T = (e) => y(e) === String,
            k = (e) => "function" == typeof e,
            E = (e) => Array.isArray(e),
            C = (e) => b(e, NodeList),
            S = (e) => v(e) || ((T(e) || E(e) || C(e)) && !e.length) || (w(e) && !Object.keys(e).length);
        var A = {
            nullOrUndefined: v,
            object: w,
            number: (e) => y(e) === Number && !Number.isNaN(e),
            string: T,
            boolean: (e) => y(e) === Boolean,
            function: k,
            array: E,
            weakMap: (e) => b(e, WeakMap),
            nodeList: C,
            element: (e) => null !== e && "object" == typeof e && 1 === e.nodeType && "object" == typeof e.style && "object" == typeof e.ownerDocument,
            textNode: (e) => y(e) === Text,
            event: (e) => b(e, Event),
            keyboardEvent: (e) => b(e, KeyboardEvent),
            cue: (e) => b(e, window.TextTrackCue) || b(e, window.VTTCue),
            track: (e) => b(e, TextTrack) || (!v(e) && T(e.kind)),
            promise: (e) => b(e, Promise) && k(e.then),
            url: (e) => {
                if (b(e, window.URL)) return !0;
                if (!T(e)) return !1;
                let t = e;
                (e.startsWith("http://") && e.startsWith("https://")) || (t = `http://${e}`);
                try {
                    return !S(new URL(t).hostname);
                } catch (e) {
                    return !1;
                }
            },
            empty: S,
        };
        const P = (() => {
            const e = document.createElement("span"),
                t = { WebkitTransition: "webkitTransitionEnd", MozTransition: "transitionend", OTransition: "oTransitionEnd otransitionend", transition: "transitionend" },
                i = Object.keys(t).find((t) => void 0 !== e.style[t]);
            return !!A.string(i) && t[i];
        })();
        function M(e, t) {
            setTimeout(() => {
                try {
                    (e.hidden = !0), e.offsetHeight, (e.hidden = !1);
                } catch (e) { }
            }, t);
        }
        var x = {
            isIE: Boolean(window.document.documentMode),
            isEdge: /Edge/g.test(navigator.userAgent),
            isWebKit: "WebkitAppearance" in document.documentElement.style && !/Edge/g.test(navigator.userAgent),
            isIPhone: /iPhone|iPod/gi.test(navigator.userAgent) && navigator.maxTouchPoints > 1,
            isIPadOS: "MacIntel" === navigator.platform && navigator.maxTouchPoints > 1,
            isIos: /iPad|iPhone|iPod/gi.test(navigator.userAgent) && navigator.maxTouchPoints > 1,
        };
        function L(e, t) {
            return t.split(".").reduce((e, t) => e && e[t], e);
        }
        function N(e = {}, ...t) {
            if (!t.length) return e;
            const i = t.shift();
            return A.object(i)
                ? (Object.keys(i).forEach((t) => {
                    A.object(i[t]) ? (Object.keys(e).includes(t) || Object.assign(e, { [t]: {} }), N(e[t], i[t])) : Object.assign(e, { [t]: i[t] });
                }),
                    N(e, ...t))
                : e;
        }
        function _(e, t) {
            const i = e.length ? e : [e];
            Array.from(i)
                .reverse()
                .forEach((e, i) => {
                    const s = i > 0 ? t.cloneNode(!0) : t,
                        n = e.parentNode,
                        a = e.nextSibling;
                    s.appendChild(e), a ? n.insertBefore(s, a) : n.appendChild(s);
                });
        }
        function I(e, t) {
            A.element(e) &&
                !A.empty(t) &&
                Object.entries(t)
                    .filter(([, e]) => !A.nullOrUndefined(e))
                    .forEach(([t, i]) => e.setAttribute(t, i));
        }
        function O(e, t, i) {
            const s = document.createElement(e);
            return A.object(t) && I(s, t), A.string(i) && (s.innerText = i), s;
        }
        function $(e, t, i, s) {
            A.element(t) && t.appendChild(O(e, i, s));
        }
        function j(e) {
            A.nodeList(e) || A.array(e) ? Array.from(e).forEach(j) : A.element(e) && A.element(e.parentNode) && e.parentNode.removeChild(e);
        }
        function R(e) {
            if (!A.element(e)) return;
            let { length: t } = e.childNodes;
            for (; t > 0;) e.removeChild(e.lastChild), (t -= 1);
        }
        function D(e, t) {
            return A.element(t) && A.element(t.parentNode) && A.element(e) ? (t.parentNode.replaceChild(e, t), e) : null;
        }
        function q(e, t) {
            if (!A.string(e) || A.empty(e)) return {};
            const i = {},
                s = N({}, t);
            return (
                e.split(",").forEach((e) => {
                    const t = e.trim(),
                        n = t.replace(".", ""),
                        a = t.replace(/[[\]]/g, "").split("="),
                        [r] = a,
                        o = a.length > 1 ? a[1].replace(/["']/g, "") : "";
                    switch (t.charAt(0)) {
                        case ".":
                            A.string(s.class) ? (i.class = `${s.class} ${n}`) : (i.class = n);
                            break;
                        case "#":
                            i.id = t.replace("#", "");
                            break;
                        case "[":
                            i[r] = o;
                    }
                }),
                N(s, i)
            );
        }
        function H(e, t) {
            if (!A.element(e)) return;
            let i = t;
            A.boolean(i) || (i = !e.hidden), (e.hidden = i);
        }
        function F(e, t, i) {
            if (A.nodeList(e)) return Array.from(e).map((e) => F(e, t, i));
            if (A.element(e)) {
                let s = "toggle";
                return void 0 !== i && (s = i ? "add" : "remove"), e.classList[s](t), e.classList.contains(t);
            }
            return !1;
        }
        function U(e, t) {
            return A.element(e) && e.classList.contains(t);
        }
        function V(e, t) {
            const { prototype: i } = Element;
            return (
                i.matches ||
                i.webkitMatchesSelector ||
                i.mozMatchesSelector ||
                i.msMatchesSelector ||
                function () {
                    return Array.from(document.querySelectorAll(t)).includes(this);
                }
            ).call(e, t);
        }
        function B(e) {
            return this.elements.container.querySelectorAll(e);
        }
        function W(e) {
            return this.elements.container.querySelector(e);
        }
        function z(e = null, t = !1) {
            A.element(e) && e.focus({ preventScroll: !0, focusVisible: t });
        }
        const K = { "audio/ogg": "vorbis", "audio/wav": "1", "video/webm": "vp8, vorbis", "video/mp4": "avc1.42E01E, mp4a.40.2", "video/ogg": "theora" },
            Y = {
                audio: "canPlayType" in document.createElement("audio"),
                video: "canPlayType" in document.createElement("video"),
                check(e, t) {
                    const i = Y[e] || "html5" !== t;
                    return { api: i, ui: i && Y.rangeInput };
                },
                pip: !(x.isIPhone || (!A.function(O("video").webkitSetPresentationMode) && (!document.pictureInPictureEnabled || O("video").disablePictureInPicture))),
                airplay: A.function(window.WebKitPlaybackTargetAvailabilityEvent),
                playsinline: "playsInline" in document.createElement("video"),
                mime(e) {
                    if (A.empty(e)) return !1;
                    const [t] = e.split("/");
                    let i = e;
                    if (!this.isHTML5 || t !== this.type) return !1;
                    Object.keys(K).includes(i) && (i += `; codecs="${K[e]}"`);
                    try {
                        return Boolean(i && this.media.canPlayType(i).replace(/no/, ""));
                    } catch (e) {
                        return !1;
                    }
                },
                textTracks: "textTracks" in document.createElement("video"),
                rangeInput: (() => {
                    const e = document.createElement("input");
                    return (e.type = "range"), "range" === e.type;
                })(),
                touch: "ontouchstart" in document.documentElement,
                transitions: !1 !== P,
                reducedMotion: "matchMedia" in window && window.matchMedia("(prefers-reduced-motion)").matches,
            },
            Q = (() => {
                let e = !1;
                try {
                    const t = Object.defineProperty({}, "passive", { get: () => ((e = !0), null) });
                    window.addEventListener("test", null, t), window.removeEventListener("test", null, t);
                } catch (e) { }
                return e;
            })();
        function X(e, t, i, s = !1, n = !0, a = !1) {
            if (!e || !("addEventListener" in e) || A.empty(t) || !A.function(i)) return;
            const r = t.split(" ");
            let o = a;
            Q && (o = { passive: n, capture: a }),
                r.forEach((t) => {
                    this && this.eventListeners && s && this.eventListeners.push({ element: e, type: t, callback: i, options: o }), e[s ? "addEventListener" : "removeEventListener"](t, i, o);
                });
        }
        function J(e, t = "", i, s = !0, n = !1) {
            X.call(this, e, t, i, !0, s, n);
        }
        function G(e, t = "", i, s = !0, n = !1) {
            X.call(this, e, t, i, !1, s, n);
        }
        function Z(e, t = "", i, s = !0, n = !1) {
            const a = (...r) => {
                G(e, t, a, s, n), i.apply(this, r);
            };
            X.call(this, e, t, a, !0, s, n);
        }
        function ee(e, t = "", i = !1, s = {}) {
            if (!A.element(e) || A.empty(t)) return;
            const n = new CustomEvent(t, { bubbles: i, detail: { ...s, plyr: this } });
            e.dispatchEvent(n);
        }
        function te() {
            this &&
                this.eventListeners &&
                (this.eventListeners.forEach((e) => {
                    const { element: t, type: i, callback: s, options: n } = e;
                    t.removeEventListener(i, s, n);
                }),
                    (this.eventListeners = []));
        }
        function ie() {
            return new Promise((e) => (this.ready ? setTimeout(e, 0) : J.call(this, this.elements.container, "ready", e))).then(() => { });
        }
        function se(e) {
            A.promise(e) && e.then(null, () => { });
        }
        function ne(e) {
            return A.array(e) ? e.filter((t, i) => e.indexOf(t) === i) : e;
        }
        function ae(e, t) {
            return A.array(e) && e.length ? e.reduce((e, i) => (Math.abs(i - t) < Math.abs(e - t) ? i : e)) : null;
        }
        function re(e) {
            return !(!window || !window.CSS) && window.CSS.supports(e);
        }
        const oe = [
            [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((e, [t, i]) => ({ ...e, [t / i]: [t, i] }), {});
        function le(e) {
            if (!(A.array(e) || (A.string(e) && e.includes(":")))) return !1;
            return (A.array(e) ? e : e.split(":")).map(Number).every(A.number);
        }
        function ce(e) {
            if (!A.array(e) || !e.every(A.number)) return null;
            const [t, i] = e,
                s = (e, t) => (0 === t ? e : s(t, e % t)),
                n = s(t, i);
            return [t / n, i / n];
        }
        function ue(e) {
            const t = (e) => (le(e) ? e.split(":").map(Number) : null);
            let i = t(e);
            if ((null === i && (i = t(this.config.ratio)), null === i && !A.empty(this.embed) && A.array(this.embed.ratio) && ({ ratio: i } = this.embed), null === i && this.isHTML5)) {
                const { videoWidth: e, videoHeight: t } = this.media;
                i = [e, t];
            }
            return ce(i);
        }
        function he(e) {
            if (!this.isVideo) return {};
            const { wrapper: t } = this.elements,
                i = ue.call(this, e);
            if (!A.array(i)) return {};
            const [s, n] = ce(i),
                a = (100 / s) * n;
            if ((re(`aspect-ratio: ${s}/${n}`) ? (t.style.aspectRatio = `${s}/${n}`) : (t.style.paddingBottom = `${a}%`), this.isVimeo && !this.config.vimeo.premium && this.supported.ui)) {
                const e = (100 / this.media.offsetWidth) * parseInt(window.getComputedStyle(this.media).paddingBottom, 10),
                    i = (e - a) / (e / 50);
                this.fullscreen.active ? (t.style.paddingBottom = null) : (this.media.style.transform = `translateY(-${i}%)`);
            } else this.isHTML5 && t.classList.add(this.config.classNames.videoFixedRatio);
            return { padding: a, ratio: i };
        }
        function de(e, t, i = 0.05) {
            const s = e / t,
                n = ae(Object.keys(oe), s);
            return Math.abs(n - s) <= i ? oe[n] : [e, t];
        }
        const me = {
            getSources() {
                if (!this.isHTML5) return [];
                return Array.from(this.media.querySelectorAll("source")).filter((e) => {
                    const t = e.getAttribute("type");
                    return !!A.empty(t) || Y.mime.call(this, t);
                });
            },
            getQualityOptions() {
                return this.config.quality.forced
                    ? this.config.quality.options
                    : me.getSources
                        .call(this)
                        .map((e) => Number(e.getAttribute("size")))
                        .filter(Boolean);
            },
            setup() {
                if (!this.isHTML5) return;
                const e = this;
                (e.options.speed = e.config.speed.options),
                    A.empty(this.config.ratio) || he.call(e),
                    Object.defineProperty(e.media, "quality", {
                        get() {
                            const t = me.getSources.call(e).find((t) => t.getAttribute("src") === e.source);
                            return t && Number(t.getAttribute("size"));
                        },
                        set(t) {
                            if (e.quality !== t) {
                                if (e.config.quality.forced && A.function(e.config.quality.onChange)) e.config.quality.onChange(t);
                                else {
                                    const i = me.getSources.call(e).find((e) => Number(e.getAttribute("size")) === t);
                                    if (!i) return;
                                    const { currentTime: s, paused: n, preload: a, readyState: r, playbackRate: o } = e.media;
                                    (e.media.src = i.getAttribute("src")),
                                        ("none" !== a || r) &&
                                        (e.once("loadedmetadata", () => {
                                            (e.speed = o), (e.currentTime = s), n || se(e.play());
                                        }),
                                            e.media.load());
                                }
                                ee.call(e, e.media, "qualitychange", !1, { quality: t });
                            }
                        },
                    });
            },
            cancelRequests() {
                this.isHTML5 && (j(me.getSources.call(this)), this.media.setAttribute("src", this.config.blankVideo), this.media.load(), this.debug.log("Cancelled network requests"));
            },
        };
        function pe(e, ...t) {
            return A.empty(e) ? e : e.toString().replace(/{(\d+)}/g, (e, i) => t[i].toString());
        }
        const ge = (e = "", t = "", i = "") => e.replace(new RegExp(t.toString().replace(/([.*+?^=!:${}()|[\]/\\])/g, "\\$1"), "g"), i.toString()),
            fe = (e = "") => e.toString().replace(/\w\S*/g, (e) => e.charAt(0).toUpperCase() + e.slice(1).toLowerCase());
        function ye(e = "") {
            let t = e.toString();
            return (
                (t = (function (e = "") {
                    let t = e.toString();
                    return (t = ge(t, "-", " ")), (t = ge(t, "_", " ")), (t = fe(t)), ge(t, " ", "");
                })(t)),
                t.charAt(0).toLowerCase() + t.slice(1)
            );
        }
        function be(e) {
            const t = document.createElement("div");
            return t.appendChild(e), t.innerHTML;
        }
        const ve = { pip: "PIP", airplay: "AirPlay", html5: "HTML5", vimeo: "Vimeo", youtube: "YouTube" },
            we = {
                get(e = "", t = {}) {
                    if (A.empty(e) || A.empty(t)) return "";
                    let i = L(t.i18n, e);
                    if (A.empty(i)) return Object.keys(ve).includes(e) ? ve[e] : "";
                    const s = { "{seektime}": t.seekTime, "{title}": t.title };
                    return (
                        Object.entries(s).forEach(([e, t]) => {
                            i = ge(i, e, t);
                        }),
                        i
                    );
                },
            };
        class Te {
            constructor(e) {
                t(this, "get", (e) => {
                    if (!Te.supported || !this.enabled) return null;
                    const t = window.localStorage.getItem(this.key);
                    if (A.empty(t)) return null;
                    const i = JSON.parse(t);
                    return A.string(e) && e.length ? i[e] : i;
                }),
                    t(this, "set", (e) => {
                        if (!Te.supported || !this.enabled) return;
                        if (!A.object(e)) return;
                        let t = this.get();
                        A.empty(t) && (t = {}), N(t, e);
                        try {
                            window.localStorage.setItem(this.key, JSON.stringify(t));
                        } catch (e) { }
                    }),
                    (this.enabled = e.config.storage.enabled),
                    (this.key = e.config.storage.key);
            }
            static get supported() {
                try {
                    if (!("localStorage" in window)) return !1;
                    const e = "___test";
                    return window.localStorage.setItem(e, e), window.localStorage.removeItem(e), !0;
                } catch (e) {
                    return !1;
                }
            }
        }
        function ke(e, t = "text") {
            return new Promise((i, s) => {
                try {
                    const s = new XMLHttpRequest();
                    if (!("withCredentials" in s)) return;
                    s.addEventListener("load", () => {
                        if ("text" === t)
                            try {
                                i(JSON.parse(s.responseText));
                            } catch (e) {
                                i(s.responseText);
                            }
                        else i(s.response);
                    }),
                        s.addEventListener("error", () => {
                            throw new Error(s.status);
                        }),
                        s.open("GET", e, !0),
                        (s.responseType = t),
                        s.send();
                } catch (e) {
                    s(e);
                }
            });
        }
        function Ee(e, t) {
            if (!A.string(e)) return;
            const i = "cache",
                s = A.string(t);
            let n = !1;
            const a = () => null !== document.getElementById(t),
                r = (e, t) => {
                    (e.innerHTML = t), (s && a()) || document.body.insertAdjacentElement("afterbegin", e);
                };
            if (!s || !a()) {
                const a = Te.supported,
                    o = document.createElement("div");
                if ((o.setAttribute("hidden", ""), s && o.setAttribute("id", t), a)) {
                    const e = window.localStorage.getItem(`${i}-${t}`);
                    if (((n = null !== e), n)) {
                        const t = JSON.parse(e);
                        r(o, t.content);
                    }
                }
                ke(e)
                    .then((e) => {
                        if (!A.empty(e)) {
                            if (a)
                                try {
                                    window.localStorage.setItem(`${i}-${t}`, JSON.stringify({ content: e }));
                                } catch (e) { }
                            r(o, e);
                        }
                    })
                    .catch(() => { });
            }
        }
        const Ce = (e) => Math.trunc((e / 60 / 60) % 60, 10),
            Se = (e) => Math.trunc((e / 60) % 60, 10),
            Ae = (e) => Math.trunc(e % 60, 10);
        function Pe(e = 0, t = !1, i = !1) {
            if (!A.number(e)) return Pe(void 0, t, i);
            const s = (e) => `0${e}`.slice(-2);
            let n = Ce(e);
            const a = Se(e),
                r = Ae(e);
            return (n = t || n > 0 ? `${n}:` : ""), `${i && e > 0 ? "-" : ""}${n}${s(a)}:${s(r)}`;
        }
        const Me = {
            getIconUrl() {
                const e = new URL(this.config.iconUrl, window.location),
                    t = window.location.host ? window.location.host : window.top.location.host,
                    i = e.host !== t || (x.isIE && !window.svg4everybody);
                return { url: this.config.iconUrl, cors: i };
            },
            findElements() {
                try {
                    return (
                        (this.elements.controls = W.call(this, this.config.selectors.controls.wrapper)),
                        (this.elements.buttons = {
                            play: B.call(this, this.config.selectors.buttons.play),
                            pause: W.call(this, this.config.selectors.buttons.pause),
                            restart: W.call(this, this.config.selectors.buttons.restart),
                            rewind: W.call(this, this.config.selectors.buttons.rewind),
                            fastForward: W.call(this, this.config.selectors.buttons.fastForward),
                            mute: W.call(this, this.config.selectors.buttons.mute),
                            pip: W.call(this, this.config.selectors.buttons.pip),
                            airplay: W.call(this, this.config.selectors.buttons.airplay),
                            settings: W.call(this, this.config.selectors.buttons.settings),
                            captions: W.call(this, this.config.selectors.buttons.captions),
                            fullscreen: W.call(this, this.config.selectors.buttons.fullscreen),
                        }),
                        (this.elements.progress = W.call(this, this.config.selectors.progress)),
                        (this.elements.inputs = { seek: W.call(this, this.config.selectors.inputs.seek), volume: W.call(this, this.config.selectors.inputs.volume) }),
                        (this.elements.display = {
                            buffer: W.call(this, this.config.selectors.display.buffer),
                            currentTime: W.call(this, this.config.selectors.display.currentTime),
                            duration: W.call(this, this.config.selectors.display.duration),
                        }),
                        A.element(this.elements.progress) && (this.elements.display.seekTooltip = this.elements.progress.querySelector(`.${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(e, t) {
                const i = "http://www.w3.org/2000/svg",
                    s = Me.getIconUrl.call(this),
                    n = `${s.cors ? "" : s.url}#${this.config.iconPrefix}`,
                    a = document.createElementNS(i, "svg");
                I(a, N(t, { "aria-hidden": "true", focusable: "false" }));
                const r = document.createElementNS(i, "use"),
                    o = `${n}-${e}`;
                return "href" in r && r.setAttributeNS("http://www.w3.org/1999/xlink", "href", o), r.setAttributeNS("http://www.w3.org/1999/xlink", "xlink:href", o), a.appendChild(r), a;
            },
            createLabel(e, t = {}) {
                const i = we.get(e, this.config);
                return O("span", { ...t, class: [t.class, this.config.classNames.hidden].filter(Boolean).join(" ") }, i);
            },
            createBadge(e) {
                if (A.empty(e)) return null;
                const t = O("span", { class: this.config.classNames.menu.value });
                return t.appendChild(O("span", { class: this.config.classNames.menu.badge }, e)), t;
            },
            createButton(e, t) {
                const i = N({}, t);
                let s = ye(e);
                const n = { element: "button", toggle: !1, label: null, icon: null, labelPressed: null, iconPressed: null };
                switch (
                (["element", "icon", "label"].forEach((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((e) => e === this.config.classNames.control) || N(i, { class: `${i.class} ${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 += ` ${this.config.classNames.control}--overlaid`), (s = "play"), (n.label = "play"), (n.icon = "play");
                        break;
                    default:
                        A.empty(n.label) && (n.label = s), A.empty(n.icon) && (n.icon = e);
                }
                const a = O(n.element);
                return (
                    n.toggle
                        ? (a.appendChild(Me.createIcon.call(this, n.iconPressed, { class: "icon--pressed" })),
                            a.appendChild(Me.createIcon.call(this, n.icon, { class: "icon--not-pressed" })),
                            a.appendChild(Me.createLabel.call(this, n.labelPressed, { class: "label--pressed" })),
                            a.appendChild(Me.createLabel.call(this, n.label, { class: "label--not-pressed" })))
                        : (a.appendChild(Me.createIcon.call(this, n.icon)), a.appendChild(Me.createLabel.call(this, n.label))),
                    N(i, q(this.config.selectors.buttons[s], i)),
                    I(a, i),
                    "play" === s ? (A.array(this.elements.buttons[s]) || (this.elements.buttons[s] = []), this.elements.buttons[s].push(a)) : (this.elements.buttons[s] = a),
                    a
                );
            },
            createRange(e, t) {
                const i = O(
                    "input",
                    N(
                        q(this.config.selectors.inputs[e]),
                        { type: "range", min: 0, max: 100, step: 0.01, value: 0, autocomplete: "off", role: "slider", "aria-label": we.get(e, this.config), "aria-valuemin": 0, "aria-valuemax": 100, "aria-valuenow": 0 },
                        t
                    )
                );
                return (this.elements.inputs[e] = i), Me.updateRangeFill.call(this, i), f.setup(i), i;
            },
            createProgress(e, t) {
                const i = O("progress", N(q(this.config.selectors.display[e]), { min: 0, max: 100, value: 0, role: "progressbar", "aria-hidden": !0 }, t));
                if ("volume" !== e) {
                    i.appendChild(O("span", null, "0"));
                    const t = { played: "played", buffer: "buffered" }[e],
                        s = t ? we.get(t, this.config) : "";
                    i.innerText = `% ${s.toLowerCase()}`;
                }
                return (this.elements.display[e] = i), i;
            },
            createTime(e, t) {
                const i = q(this.config.selectors.display[e], t),
                    s = O("div", N(i, { class: `${i.class ? i.class : ""} ${this.config.classNames.display.time} `.trim(), "aria-label": we.get(e, this.config), role: "timer" }), "00:00");
                return (this.elements.display[e] = s), s;
            },
            bindMenuItemShortcuts(e, t) {
                J.call(
                    this,
                    e,
                    "keydown keyup",
                    (i) => {
                        if (![" ", "ArrowUp", "ArrowDown", "ArrowRight"].includes(i.key)) return;
                        if ((i.preventDefault(), i.stopPropagation(), "keydown" === i.type)) return;
                        const s = V(e, '[role="menuitemradio"]');
                        if (!s && [" ", "ArrowRight"].includes(i.key)) Me.showMenuPanel.call(this, t, !0);
                        else {
                            let t;
                            " " !== i.key &&
                                ("ArrowDown" === i.key || (s && "ArrowRight" === i.key)
                                    ? ((t = e.nextElementSibling), A.element(t) || (t = e.parentNode.firstElementChild))
                                    : ((t = e.previousElementSibling), A.element(t) || (t = e.parentNode.lastElementChild)),
                                    z.call(this, t, !0));
                        }
                    },
                    !1
                ),
                    J.call(this, e, "keyup", (e) => {
                        "Return" === e.key && Me.focusFirstMenuItem.call(this, null, !0);
                    });
            },
            createMenuItem({ value: e, list: t, type: i, title: s, badge: n = null, checked: a = !1 }) {
                const r = q(this.config.selectors.inputs[i]),
                    o = O("button", N(r, { type: "button", role: "menuitemradio", class: `${this.config.classNames.control} ${r.class ? r.class : ""}`.trim(), "aria-checked": a, value: e })),
                    l = O("span");
                (l.innerHTML = s),
                    A.element(n) && l.appendChild(n),
                    o.appendChild(l),
                    Object.defineProperty(o, "checked", {
                        enumerable: !0,
                        get: () => "true" === o.getAttribute("aria-checked"),
                        set(e) {
                            e &&
                                Array.from(o.parentNode.children)
                                    .filter((e) => V(e, '[role="menuitemradio"]'))
                                    .forEach((e) => e.setAttribute("aria-checked", "false")),
                                o.setAttribute("aria-checked", e ? "true" : "false");
                        },
                    }),
                    this.listeners.bind(
                        o,
                        "click keyup",
                        (t) => {
                            if (!A.keyboardEvent(t) || " " === t.key) {
                                switch ((t.preventDefault(), t.stopPropagation(), (o.checked = !0), i)) {
                                    case "language":
                                        this.currentTrack = Number(e);
                                        break;
                                    case "quality":
                                        this.quality = e;
                                        break;
                                    case "speed":
                                        this.speed = parseFloat(e);
                                }
                                Me.showMenuPanel.call(this, "home", A.keyboardEvent(t));
                            }
                        },
                        i,
                        !1
                    ),
                    Me.bindMenuItemShortcuts.call(this, o, i),
                    t.appendChild(o);
            },
            formatTime(e = 0, t = !1) {
                if (!A.number(e)) return e;
                return Pe(e, Ce(this.duration) > 0, t);
            },
            updateTimeDisplay(e = null, t = 0, i = !1) {
                A.element(e) && A.number(t) && (e.innerText = Me.formatTime(t, i));
            },
            updateVolume() {
                this.supported.ui &&
                    (A.element(this.elements.inputs.volume) && Me.setRange.call(this, this.elements.inputs.volume, this.muted ? 0 : this.volume),
                        A.element(this.elements.buttons.mute) && (this.elements.buttons.mute.pressed = this.muted || 0 === this.volume));
            },
            setRange(e, t = 0) {
                A.element(e) && ((e.value = t), Me.updateRangeFill.call(this, e));
            },
            updateProgress(e) {
                if (!this.supported.ui || !A.event(e)) return;
                let t = 0;
                const i = (e, t) => {
                    const i = A.number(t) ? t : 0,
                        s = A.element(e) ? e : this.elements.display.buffer;
                    if (A.element(s)) {
                        s.value = i;
                        const e = s.getElementsByTagName("span")[0];
                        A.element(e) && (e.childNodes[0].nodeValue = i);
                    }
                };
                if (e)
                    switch (e.type) {
                        case "timeupdate":
                        case "seeking":
                        case "seeked":
                            (s = this.currentTime),
                                (n = this.duration),
                                (t = 0 === s || 0 === n || Number.isNaN(s) || Number.isNaN(n) ? 0 : ((s / n) * 100).toFixed(2)),
                                "timeupdate" === e.type && Me.setRange.call(this, this.elements.inputs.seek, t);
                            break;
                        case "playing":
                        case "progress":
                            i(this.elements.display.buffer, 100 * this.buffered);
                    }
                var s, n;
            },
            updateRangeFill(e) {
                const t = A.event(e) ? e.target : e;
                if (A.element(t) && "range" === t.getAttribute("type")) {
                    if (V(t, this.config.selectors.inputs.seek)) {
                        t.setAttribute("aria-valuenow", this.currentTime);
                        const e = Me.formatTime(this.currentTime),
                            i = Me.formatTime(this.duration),
                            s = we.get("seekLabel", this.config);
                        t.setAttribute("aria-valuetext", s.replace("{currentTime}", e).replace("{duration}", i));
                    } else if (V(t, this.config.selectors.inputs.volume)) {
                        const e = 100 * t.value;
                        t.setAttribute("aria-valuenow", e), t.setAttribute("aria-valuetext", `${e.toFixed(1)}%`);
                    } else t.setAttribute("aria-valuenow", t.value);
                    (x.isWebKit || x.isIPadOS) && t.style.setProperty("--value", (t.value / t.max) * 100 + "%");
                }
            },
            updateSeekTooltip(e) {
                var t, i;
                if (!this.config.tooltips.seek || !A.element(this.elements.inputs.seek) || !A.element(this.elements.display.seekTooltip) || 0 === this.duration) return;
                const s = this.elements.display.seekTooltip,
                    n = `${this.config.classNames.tooltip}--visible`,
                    a = (e) => F(s, n, e);
                if (this.touch) return void a(!1);
                let r = 0;
                const o = this.elements.progress.getBoundingClientRect();
                if (A.event(e)) r = (100 / o.width) * (e.pageX - o.left);
                else {
                    if (!U(s, n)) return;
                    r = parseFloat(s.style.left, 10);
                }
                r < 0 ? (r = 0) : r > 100 && (r = 100);
                const l = (this.duration / 100) * r;
                s.innerText = Me.formatTime(l);
                const c = null === (t = this.config.markers) || void 0 === t || null === (i = t.points) || void 0 === i ? void 0 : i.find(({ time: e }) => e === Math.round(l));
                c && s.insertAdjacentHTML("afterbegin", `${c.label}<br>`), (s.style.left = `${r}%`), A.event(e) && ["mouseenter", "mouseleave"].includes(e.type) && a("mouseenter" === e.type);
            },
            timeUpdate(e) {
                const t = !A.element(this.elements.display.duration) && this.config.invertTime;
                Me.updateTimeDisplay.call(this, this.elements.display.currentTime, t ? this.duration - this.currentTime : this.currentTime, t), (e && "timeupdate" === e.type && this.media.seeking) || Me.updateProgress.call(this, e);
            },
            durationUpdate() {
                if (!this.supported.ui || (!this.config.invertTime && this.currentTime)) return;
                if (this.duration >= 2 ** 32) return H(this.elements.display.currentTime, !0), void H(this.elements.progress, !0);
                A.element(this.elements.inputs.seek) && this.elements.inputs.seek.setAttribute("aria-valuemax", this.duration);
                const e = A.element(this.elements.display.duration);
                !e && this.config.displayDuration && this.paused && Me.updateTimeDisplay.call(this, this.elements.display.currentTime, this.duration),
                    e && Me.updateTimeDisplay.call(this, this.elements.display.duration, this.duration),
                    this.config.markers.enabled && Me.setMarkers.call(this),
                    Me.updateSeekTooltip.call(this);
            },
            toggleMenuButton(e, t) {
                H(this.elements.settings.buttons[e], !t);
            },
            updateSetting(e, t, i) {
                const s = this.elements.settings.panels[e];
                let n = null,
                    a = t;
                if ("captions" === e) n = this.currentTrack;
                else {
                    if (((n = A.empty(i) ? this[e] : i), A.empty(n) && (n = this.config[e].default), !A.empty(this.options[e]) && !this.options[e].includes(n))) return void this.debug.warn(`Unsupported value of '${n}' for ${e}`);
                    if (!this.config[e].options.includes(n)) return void this.debug.warn(`Disabled value of '${n}' for ${e}`);
                }
                if ((A.element(a) || (a = s && s.querySelector('[role="menu"]')), !A.element(a))) return;
                this.elements.settings.buttons[e].querySelector(`.${this.config.classNames.menu.value}`).innerHTML = Me.getLabel.call(this, e, n);
                const r = a && a.querySelector(`[value="${n}"]`);
                A.element(r) && (r.checked = !0);
            },
            getLabel(e, t) {
                switch (e) {
                    case "speed":
                        return 1 === t ? we.get("normal", this.config) : `${t}&times;`;
                    case "quality":
                        if (A.number(t)) {
                            const e = we.get(`qualityLabel.${t}`, this.config);
                            return e.length ? e : `${t}p`;
                        }
                        return fe(t);
                    case "captions":
                        return Ne.getLabel.call(this);
                    default:
                        return null;
                }
            },
            setQualityMenu(e) {
                if (!A.element(this.elements.settings.panels.quality)) return;
                const t = "quality",
                    i = this.elements.settings.panels.quality.querySelector('[role="menu"]');
                A.array(e) && (this.options.quality = ne(e).filter((e) => this.config.quality.options.includes(e)));
                const s = !A.empty(this.options.quality) && this.options.quality.length > 1;
                if ((Me.toggleMenuButton.call(this, t, s), R(i), Me.checkMenu.call(this), !s)) return;
                const n = (e) => {
                    const t = we.get(`qualityBadge.${e}`, this.config);
                    return t.length ? Me.createBadge.call(this, t) : null;
                };
                this.options.quality
                    .sort((e, t) => {
                        const i = this.config.quality.options;
                        return i.indexOf(e) > i.indexOf(t) ? 1 : -1;
                    })
                    .forEach((e) => {
                        Me.createMenuItem.call(this, { value: e, list: i, type: t, title: Me.getLabel.call(this, "quality", e), badge: n(e) });
                    }),
                    Me.updateSetting.call(this, t, i);
            },
            setCaptionsMenu() {
                if (!A.element(this.elements.settings.panels.captions)) return;
                const e = "captions",
                    t = this.elements.settings.panels.captions.querySelector('[role="menu"]'),
                    i = Ne.getTracks.call(this),
                    s = Boolean(i.length);
                if ((Me.toggleMenuButton.call(this, e, s), R(t), Me.checkMenu.call(this), !s)) return;
                const n = i.map((e, i) => ({
                    value: i,
                    checked: this.captions.toggled && this.currentTrack === i,
                    title: Ne.getLabel.call(this, e),
                    badge: e.language && Me.createBadge.call(this, e.language.toUpperCase()),
                    list: t,
                    type: "language",
                }));
                n.unshift({ value: -1, checked: !this.captions.toggled, title: we.get("disabled", this.config), list: t, type: "language" }), n.forEach(Me.createMenuItem.bind(this)), Me.updateSetting.call(this, e, t);
            },
            setSpeedMenu() {
                if (!A.element(this.elements.settings.panels.speed)) return;
                const e = "speed",
                    t = this.elements.settings.panels.speed.querySelector('[role="menu"]');
                this.options.speed = this.options.speed.filter((e) => e >= this.minimumSpeed && e <= this.maximumSpeed);
                const i = !A.empty(this.options.speed) && this.options.speed.length > 1;
                Me.toggleMenuButton.call(this, e, i),
                    R(t),
                    Me.checkMenu.call(this),
                    i &&
                    (this.options.speed.forEach((i) => {
                        Me.createMenuItem.call(this, { value: i, list: t, type: e, title: Me.getLabel.call(this, "speed", i) });
                    }),
                        Me.updateSetting.call(this, e, t));
            },
            checkMenu() {
                const { buttons: e } = this.elements.settings,
                    t = !A.empty(e) && Object.values(e).some((e) => !e.hidden);
                H(this.elements.settings.menu, !t);
            },
            focusFirstMenuItem(e, t = !1) {
                if (this.elements.settings.popup.hidden) return;
                let i = e;
                A.element(i) || (i = Object.values(this.elements.settings.panels).find((e) => !e.hidden));
                const s = i.querySelector('[role^="menuitem"]');
                z.call(this, s, t);
            },
            toggleMenu(e) {
                const { popup: t } = this.elements.settings,
                    i = this.elements.buttons.settings;
                if (!A.element(t) || !A.element(i)) return;
                const { hidden: s } = t;
                let n = s;
                if (A.boolean(e)) n = e;
                else if (A.keyboardEvent(e) && "Escape" === e.key) n = !1;
                else if (A.event(e)) {
                    const s = A.function(e.composedPath) ? e.composedPath()[0] : e.target,
                        a = t.contains(s);
                    if (a || (!a && e.target !== i && n)) return;
                }
                i.setAttribute("aria-expanded", n),
                    H(t, !n),
                    F(this.elements.container, this.config.classNames.menu.open, n),
                    n && A.keyboardEvent(e) ? Me.focusFirstMenuItem.call(this, null, !0) : n || s || z.call(this, i, A.keyboardEvent(e));
            },
            getMenuSize(e) {
                const t = e.cloneNode(!0);
                (t.style.position = "absolute"), (t.style.opacity = 0), t.removeAttribute("hidden"), e.parentNode.appendChild(t);
                const i = t.scrollWidth,
                    s = t.scrollHeight;
                return j(t), { width: i, height: s };
            },
            showMenuPanel(e = "", t = !1) {
                const i = this.elements.container.querySelector(`#plyr-settings-${this.id}-${e}`);
                if (!A.element(i)) return;
                const s = i.parentNode,
                    n = Array.from(s.children).find((e) => !e.hidden);
                if (Y.transitions && !Y.reducedMotion) {
                    (s.style.width = `${n.scrollWidth}px`), (s.style.height = `${n.scrollHeight}px`);
                    const e = Me.getMenuSize.call(this, i),
                        t = (e) => {
                            e.target === s && ["width", "height"].includes(e.propertyName) && ((s.style.width = ""), (s.style.height = ""), G.call(this, s, P, t));
                        };
                    J.call(this, s, P, t), (s.style.width = `${e.width}px`), (s.style.height = `${e.height}px`);
                }
                H(n, !0), H(i, !1), Me.focusFirstMenuItem.call(this, i, t);
            },
            setDownloadUrl() {
                const e = this.elements.buttons.download;
                A.element(e) && e.setAttribute("href", this.download);
            },
            create(e) {
                const { bindMenuItemShortcuts: t, createButton: i, createProgress: s, createRange: n, createTime: a, setQualityMenu: r, setSpeedMenu: o, showMenuPanel: l } = Me;
                (this.elements.controls = null), A.array(this.config.controls) && this.config.controls.includes("play-large") && this.elements.container.appendChild(i.call(this, "play-large"));
                const c = O("div", q(this.config.selectors.controls.wrapper));
                this.elements.controls = c;
                const u = { class: "plyr__controls__item" };
                return (
                    ne(A.array(this.config.controls) ? this.config.controls : []).forEach((r) => {
                        if (
                            ("restart" === r && c.appendChild(i.call(this, "restart", u)),
                                "rewind" === r && c.appendChild(i.call(this, "rewind", u)),
                                "play" === r && c.appendChild(i.call(this, "play", u)),
                                "fast-forward" === r && c.appendChild(i.call(this, "fast-forward", u)),
                                "progress" === r)
                        ) {
                            const t = O("div", { class: `${u.class} plyr__progress__container` }),
                                i = O("div", q(this.config.selectors.progress));
                            if ((i.appendChild(n.call(this, "seek", { id: `plyr-seek-${e.id}` })), i.appendChild(s.call(this, "buffer")), this.config.tooltips.seek)) {
                                const e = O("span", { class: this.config.classNames.tooltip }, "00:00");
                                i.appendChild(e), (this.elements.display.seekTooltip = e);
                            }
                            (this.elements.progress = i), t.appendChild(this.elements.progress), c.appendChild(t);
                        }
                        if (("current-time" === r && c.appendChild(a.call(this, "currentTime", u)), "duration" === r && c.appendChild(a.call(this, "duration", u)), "mute" === r || "volume" === r)) {
                            let { volume: t } = this.elements;
                            if (
                                ((A.element(t) && c.contains(t)) || ((t = O("div", N({}, u, { class: `${u.class} plyr__volume`.trim() }))), (this.elements.volume = t), c.appendChild(t)),
                                    "mute" === r && t.appendChild(i.call(this, "mute")),
                                    "volume" === r && !x.isIos && !x.isIPadOS)
                            ) {
                                const i = { max: 1, step: 0.05, value: this.config.volume };
                                t.appendChild(n.call(this, "volume", N(i, { id: `plyr-volume-${e.id}` })));
                            }
                        }
                        if (("captions" === r && c.appendChild(i.call(this, "captions", u)), "settings" === r && !A.empty(this.config.settings))) {
                            const s = O("div", N({}, u, { class: `${u.class} plyr__menu`.trim(), hidden: "" }));
                            s.appendChild(i.call(this, "settings", { "aria-haspopup": !0, "aria-controls": `plyr-settings-${e.id}`, "aria-expanded": !1 }));
                            const n = O("div", { class: "plyr__menu__container", id: `plyr-settings-${e.id}`, hidden: "" }),
                                a = O("div"),
                                r = O("div", { id: `plyr-settings-${e.id}-home` }),
                                o = O("div", { role: "menu" });
                            r.appendChild(o),
                                a.appendChild(r),
                                (this.elements.settings.panels.home = r),
                                this.config.settings.forEach((i) => {
                                    const s = O(
                                        "button",
                                        N(q(this.config.selectors.buttons.settings), {
                                            type: "button",
                                            class: `${this.config.classNames.control} ${this.config.classNames.control}--forward`,
                                            role: "menuitem",
                                            "aria-haspopup": !0,
                                            hidden: "",
                                        })
                                    );
                                    t.call(this, s, i),
                                        J.call(this, s, "click", () => {
                                            l.call(this, i, !1);
                                        });
                                    const n = O("span", null, we.get(i, this.config)),
                                        r = O("span", { class: this.config.classNames.menu.value });
                                    (r.innerHTML = e[i]), n.appendChild(r), s.appendChild(n), o.appendChild(s);
                                    const c = O("div", { id: `plyr-settings-${e.id}-${i}`, hidden: "" }),
                                        u = O("button", { type: "button", class: `${this.config.classNames.control} ${this.config.classNames.control}--back` });
                                    u.appendChild(O("span", { "aria-hidden": !0 }, we.get(i, this.config))),
                                        u.appendChild(O("span", { class: this.config.classNames.hidden }, we.get("menuBack", this.config))),
                                        J.call(
                                            this,
                                            c,
                                            "keydown",
                                            (e) => {
                                                "ArrowLeft" === e.key && (e.preventDefault(), e.stopPropagation(), l.call(this, "home", !0));
                                            },
                                            !1
                                        ),
                                        J.call(this, u, "click", () => {
                                            l.call(this, "home", !1);
                                        }),
                                        c.appendChild(u),
                                        c.appendChild(O("div", { role: "menu" })),
                                        a.appendChild(c),
                                        (this.elements.settings.buttons[i] = s),
                                        (this.elements.settings.panels[i] = c);
                                }),
                                n.appendChild(a),
                                s.appendChild(n),
                                c.appendChild(s),
                                (this.elements.settings.popup = n),
                                (this.elements.settings.menu = s);
                        }
                        if (("pip" === r && Y.pip && c.appendChild(i.call(this, "pip", u)), "airplay" === r && Y.airplay && c.appendChild(i.call(this, "airplay", u)), "download" === r)) {
                            const e = N({}, u, { element: "a", href: this.download, target: "_blank" });
                            this.isHTML5 && (e.download = "");
                            const { download: t } = this.config.urls;
                            !A.url(t) && this.isEmbed && N(e, { icon: `logo-${this.provider}`, label: this.provider }), c.appendChild(i.call(this, "download", e));
                        }
                        "fullscreen" === r && c.appendChild(i.call(this, "fullscreen", u));
                    }),
                    this.isHTML5 && r.call(this, me.getQualityOptions.call(this)),
                    o.call(this),
                    c
                );
            },
            inject() {
                if (this.config.loadSprite) {
                    const e = Me.getIconUrl.call(this);
                    e.cors && Ee(e.url, "sprite-plyr");
                }
                this.id = Math.floor(1e4 * Math.random());
                let e = null;
                this.elements.controls = null;
                const t = { id: this.id, seektime: this.config.seekTime, title: this.config.title };
                let i = !0;
                A.function(this.config.controls) && (this.config.controls = this.config.controls.call(this, t)),
                    this.config.controls || (this.config.controls = []),
                    A.element(this.config.controls) || A.string(this.config.controls)
                        ? (e = this.config.controls)
                        : ((e = Me.create.call(this, { id: this.id, seektime: this.config.seekTime, speed: this.speed, quality: this.quality, captions: Ne.getLabel.call(this) })), (i = !1));
                let s;
                i &&
                    A.string(this.config.controls) &&
                    (e = ((e) => {
                        let i = e;
                        return (
                            Object.entries(t).forEach(([e, t]) => {
                                i = ge(i, `{${e}}`, t);
                            }),
                            i
                        );
                    })(e)),
                    A.string(this.config.selectors.controls.container) && (s = document.querySelector(this.config.selectors.controls.container)),
                    A.element(s) || (s = this.elements.container);
                if ((s[A.element(e) ? "insertAdjacentElement" : "insertAdjacentHTML"]("afterbegin", e), A.element(this.elements.controls) || Me.findElements.call(this), !A.empty(this.elements.buttons))) {
                    const e = (e) => {
                        const t = this.config.classNames.controlPressed;
                        e.setAttribute("aria-pressed", "false"),
                            Object.defineProperty(e, "pressed", {
                                configurable: !0,
                                enumerable: !0,
                                get: () => U(e, t),
                                set(i = !1) {
                                    F(e, t, i), e.setAttribute("aria-pressed", i ? "true" : "false");
                                },
                            });
                    };
                    Object.values(this.elements.buttons)
                        .filter(Boolean)
                        .forEach((t) => {
                            A.array(t) || A.nodeList(t) ? Array.from(t).filter(Boolean).forEach(e) : e(t);
                        });
                }
                if ((x.isEdge && M(s), this.config.tooltips.controls)) {
                    const { classNames: e, selectors: t } = this.config,
                        i = `${t.controls.wrapper} ${t.labels} .${e.hidden}`,
                        s = B.call(this, i);
                    Array.from(s).forEach((e) => {
                        F(e, this.config.classNames.hidden, !1), F(e, this.config.classNames.tooltip, !0);
                    });
                }
            },
            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() {
                var e, t;
                if (!this.duration || this.elements.markers) return;
                const i = null === (e = this.config.markers) || void 0 === e || null === (t = e.points) || void 0 === t ? void 0 : t.filter(({ time: e }) => e > 0 && e < this.duration);
                if (null == i || !i.length) return;
                const s = document.createDocumentFragment(),
                    n = document.createDocumentFragment();
                let a = null;
                const r = `${this.config.classNames.tooltip}--visible`,
                    o = (e) => F(a, r, e);
                i.forEach((e) => {
                    const t = O("span", { class: this.config.classNames.marker }, ""),
                        i = (e.time / this.duration) * 100 + "%";
                    a &&
                        (t.addEventListener("mouseenter", () => {
                            e.label || ((a.style.left = i), (a.innerHTML = e.label), o(!0));
                        }),
                            t.addEventListener("mouseleave", () => {
                                o(!1);
                            })),
                        t.addEventListener("click", () => {
                            this.currentTime = e.time;
                        }),
                        (t.style.left = i),
                        n.appendChild(t);
                }),
                    s.appendChild(n),
                    this.config.tooltips.seek || ((a = O("span", { class: this.config.classNames.tooltip }, "")), s.appendChild(a)),
                    (this.elements.markers = { points: n, tip: a }),
                    this.elements.progress.appendChild(s);
            },
        };
        function xe(e, t = !0) {
            let i = e;
            if (t) {
                const e = document.createElement("a");
                (e.href = i), (i = e.href);
            }
            try {
                return new URL(i);
            } catch (e) {
                return null;
            }
        }
        function Le(e) {
            const t = new URLSearchParams();
            return (
                A.object(e) &&
                Object.entries(e).forEach(([e, i]) => {
                    t.set(e, i);
                }),
                t
            );
        }
        const Ne = {
            setup() {
                if (!this.supported.ui) return;
                if (!this.isVideo || this.isYouTube || (this.isHTML5 && !Y.textTracks))
                    return void (A.array(this.config.controls) && this.config.controls.includes("settings") && this.config.settings.includes("captions") && Me.setCaptionsMenu.call(this));
                var e, t;
                if (
                    (A.element(this.elements.captions) ||
                        ((this.elements.captions = O("div", q(this.config.selectors.captions))),
                            this.elements.captions.setAttribute("dir", "auto"),
                            (e = this.elements.captions),
                            (t = this.elements.wrapper),
                            A.element(e) && A.element(t) && t.parentNode.insertBefore(e, t.nextSibling)),
                        x.isIE && window.URL)
                ) {
                    const e = this.media.querySelectorAll("track");
                    Array.from(e).forEach((e) => {
                        const t = e.getAttribute("src"),
                            i = xe(t);
                        null !== i &&
                            i.hostname !== window.location.href.hostname &&
                            ["http:", "https:"].includes(i.protocol) &&
                            ke(t, "blob")
                                .then((t) => {
                                    e.setAttribute("src", window.URL.createObjectURL(t));
                                })
                                .catch(() => {
                                    j(e);
                                });
                    });
                }
                const i = ne((navigator.languages || [navigator.language || navigator.userLanguage || "en"]).map((e) => e.split("-")[0]));
                let s = (this.storage.get("language") || this.config.captions.language || "auto").toLowerCase();
                "auto" === s && ([s] = i);
                let n = this.storage.get("captions");
                if ((A.boolean(n) || ({ active: n } = this.config.captions), Object.assign(this.captions, { toggled: !1, active: n, language: s, languages: i }), this.isHTML5)) {
                    const e = this.config.captions.update ? "addtrack removetrack" : "removetrack";
                    J.call(this, this.media.textTracks, e, Ne.update.bind(this));
                }
                setTimeout(Ne.update.bind(this), 0);
            },
            update() {
                const e = Ne.getTracks.call(this, !0),
                    { active: t, language: i, meta: s, currentTrackNode: n } = this.captions,
                    a = Boolean(e.find((e) => e.language === i));
                this.isHTML5 &&
                    this.isVideo &&
                    e
                        .filter((e) => !s.get(e))
                        .forEach((e) => {
                            this.debug.log("Track added", e), s.set(e, { default: "showing" === e.mode }), "showing" === e.mode && (e.mode = "hidden"), J.call(this, e, "cuechange", () => Ne.updateCues.call(this));
                        }),
                    ((a && this.language !== i) || !e.includes(n)) && (Ne.setLanguage.call(this, i), Ne.toggle.call(this, t && a)),
                    this.elements && F(this.elements.container, this.config.classNames.captions.enabled, !A.empty(e)),
                    A.array(this.config.controls) && this.config.controls.includes("settings") && this.config.settings.includes("captions") && Me.setCaptionsMenu.call(this);
            },
            toggle(e, t = !0) {
                if (!this.supported.ui) return;
                const { toggled: i } = this.captions,
                    s = this.config.classNames.captions.active,
                    n = A.nullOrUndefined(e) ? !i : e;
                if (n !== i) {
                    if ((t || ((this.captions.active = n), this.storage.set({ captions: n })), !this.language && n && !t)) {
                        const e = Ne.getTracks.call(this),
                            t = Ne.findTrack.call(this, [this.captions.language, ...this.captions.languages], !0);
                        return (this.captions.language = t.language), void Ne.set.call(this, e.indexOf(t));
                    }
                    this.elements.buttons.captions && (this.elements.buttons.captions.pressed = n),
                        F(this.elements.container, s, n),
                        (this.captions.toggled = n),
                        Me.updateSetting.call(this, "captions"),
                        ee.call(this, this.media, n ? "captionsenabled" : "captionsdisabled");
                }
                setTimeout(() => {
                    n && this.captions.toggled && (this.captions.currentTrackNode.mode = "hidden");
                });
            },
            set(e, t = !0) {
                const i = Ne.getTracks.call(this);
                if (-1 !== e)
                    if (A.number(e))
                        if (e in i) {
                            if (this.captions.currentTrack !== e) {
                                this.captions.currentTrack = e;
                                const s = i[e],
                                    { language: n } = s || {};
                                (this.captions.currentTrackNode = s),
                                    Me.updateSetting.call(this, "captions"),
                                    t || ((this.captions.language = n), this.storage.set({ language: n })),
                                    this.isVimeo && this.embed.enableTextTrack(n),
                                    ee.call(this, this.media, "languagechange");
                            }
                            Ne.toggle.call(this, !0, t), this.isHTML5 && this.isVideo && Ne.updateCues.call(this);
                        } else this.debug.warn("Track not found", e);
                    else this.debug.warn("Invalid caption argument", e);
                else Ne.toggle.call(this, !1, t);
            },
            setLanguage(e, t = !0) {
                if (!A.string(e)) return void this.debug.warn("Invalid language argument", e);
                const i = e.toLowerCase();
                this.captions.language = i;
                const s = Ne.getTracks.call(this),
                    n = Ne.findTrack.call(this, [i]);
                Ne.set.call(this, s.indexOf(n), t);
            },
            getTracks(e = !1) {
                return Array.from((this.media || {}).textTracks || [])
                    .filter((t) => !this.isHTML5 || e || this.captions.meta.has(t))
                    .filter((e) => ["captions", "subtitles"].includes(e.kind));
            },
            findTrack(e, t = !1) {
                const i = Ne.getTracks.call(this),
                    s = (e) => Number((this.captions.meta.get(e) || {}).default),
                    n = Array.from(i).sort((e, t) => s(t) - s(e));
                let a;
                return e.every((e) => ((a = n.find((t) => t.language === e)), !a)), a || (t ? n[0] : void 0);
            },
            getCurrentTrack() {
                return Ne.getTracks.call(this)[this.currentTrack];
            },
            getLabel(e) {
                let t = e;
                return (
                    !A.track(t) && Y.textTracks && this.captions.toggled && (t = Ne.getCurrentTrack.call(this)),
                    A.track(t) ? (A.empty(t.label) ? (A.empty(t.language) ? we.get("enabled", this.config) : e.language.toUpperCase()) : t.label) : we.get("disabled", this.config)
                );
            },
            updateCues(e) {
                if (!this.supported.ui) return;
                if (!A.element(this.elements.captions)) return void this.debug.warn("No captions element to render to");
                if (!A.nullOrUndefined(e) && !Array.isArray(e)) return void this.debug.warn("updateCues: Invalid input", e);
                let t = e;
                if (!t) {
                    const e = Ne.getCurrentTrack.call(this);
                    t = Array.from((e || {}).activeCues || [])
                        .map((e) => e.getCueAsHTML())
                        .map(be);
                }
                const i = t.map((e) => e.trim()).join("\n");
                if (i !== this.elements.captions.innerHTML) {
                    R(this.elements.captions);
                    const e = O("span", q(this.config.selectors.caption));
                    (e.innerHTML = i), this.elements.captions.appendChild(e), ee.call(this, this.media, "cuechange");
                }
            },
        },
            _e = {
                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.8/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: "Fullscreen",
                    exitFullscreen: "Exit fullscreen",
                    frameTitle: "Player for {title}",
                    captions: "Captions",
                    settings: "Settings",
                    pip: "Pop-up",
                    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",
                    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" },
                    posterThumbnails: {
                        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: "" },
                posterThumbnails: { 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: [] },
            },
            Ie = "picture-in-picture",
            Oe = "inline",
            $e = { html5: "html5", youtube: "youtube", vimeo: "vimeo" },
            je = "audio",
            Re = "video";
        const De = () => { };
        class qe {
            constructor(e = !1) {
                (this.enabled = window.console && e), this.enabled && this.log("Debugging enabled");
            }
            get log() {
                return this.enabled ? Function.prototype.bind.call(console.log, console) : De;
            }
            get warn() {
                return this.enabled ? Function.prototype.bind.call(console.warn, console) : De;
            }
            get error() {
                return this.enabled ? Function.prototype.bind.call(console.error, console) : De;
            }
        }
        class He {
            constructor(e) {
                t(this, "onChange", () => {
                    if (!this.supported) return;
                    const e = this.player.elements.buttons.fullscreen;
                    A.element(e) && (e.pressed = this.active);
                    const t = this.target === this.player.media ? this.target : this.player.elements.container;
                    ee.call(this.player, t, this.active ? "enterfullscreen" : "exitfullscreen", !0);
                }),
                    t(this, "toggleFallback", (e = !1) => {
                        if (
                            (e ? (this.scrollPosition = { x: window.scrollX ?? 0, y: window.scrollY ?? 0 }) : window.scrollTo(this.scrollPosition.x, this.scrollPosition.y),
                                (document.body.style.overflow = e ? "hidden" : ""),
                                F(this.target, this.player.config.classNames.fullscreen.fallback, e),
                                x.isIos)
                        ) {
                            let t = document.head.querySelector('meta[name="viewport"]');
                            const i = "viewport-fit=cover";
                            t || ((t = document.createElement("meta")), t.setAttribute("name", "viewport"));
                            const s = A.string(t.content) && t.content.includes(i);
                            e
                                ? ((this.cleanupViewport = !s), s || (t.content += `,${i}`))
                                : this.cleanupViewport &&
                                (t.content = t.content
                                    .split(",")
                                    .filter((e) => e.trim() !== i)
                                    .join(","));
                        }
                        this.onChange();
                    }),
                    t(this, "trapFocus", (e) => {
                        if (x.isIos || x.isIPadOS || !this.active || "Tab" !== e.key) return;
                        const t = document.activeElement,
                            i = B.call(this.player, "a[href], button:not(:disabled), input:not(:disabled), [tabindex]"),
                            [s] = i,
                            n = i[i.length - 1];
                        t !== n || e.shiftKey ? t === s && e.shiftKey && (n.focus(), e.preventDefault()) : (s.focus(), e.preventDefault());
                    }),
                    t(this, "update", () => {
                        if (this.supported) {
                            let e;
                            (e = this.forceFallback ? "Fallback (forced)" : He.nativeSupported ? "Native" : "Fallback"), this.player.debug.log(`${e} fullscreen enabled`);
                        } else this.player.debug.log("Fullscreen not supported and fallback disabled");
                        F(this.player.elements.container, this.player.config.classNames.fullscreen.enabled, this.supported);
                    }),
                    t(this, "enter", () => {
                        this.supported &&
                            (x.isIos && this.player.config.fullscreen.iosNative
                                ? this.player.isVimeo
                                    ? this.player.embed.requestFullscreen()
                                    : this.target.webkitEnterFullscreen()
                                : !He.nativeSupported || this.forceFallback
                                    ? this.toggleFallback(!0)
                                    : this.prefix
                                        ? A.empty(this.prefix) || this.target[`${this.prefix}Request${this.property}`]()
                                        : this.target.requestFullscreen({ navigationUI: "hide" }));
                    }),
                    t(this, "exit", () => {
                        if (this.supported)
                            if (x.isIos && this.player.config.fullscreen.iosNative) this.player.isVimeo ? this.player.embed.exitFullscreen() : this.target.webkitEnterFullscreen(), se(this.player.play());
                            else if (!He.nativeSupported || this.forceFallback) this.toggleFallback(!1);
                            else if (this.prefix) {
                                if (!A.empty(this.prefix)) {
                                    const e = "moz" === this.prefix ? "Cancel" : "Exit";
                                    document[`${this.prefix}${e}${this.property}`]();
                                }
                            } else (document.cancelFullScreen || document.exitFullscreen).call(document);
                    }),
                    t(this, "toggle", () => {
                        this.active ? this.exit() : this.enter();
                    }),
                    (this.player = e),
                    (this.prefix = He.prefix),
                    (this.property = He.property),
                    (this.scrollPosition = { x: 0, y: 0 }),
                    (this.forceFallback = "force" === e.config.fullscreen.fallback),
                    (this.player.elements.fullscreen =
                        e.config.fullscreen.container &&
                        (function (e, t) {
                            const { prototype: i } = Element;
                            return (
                                i.closest ||
                                function () {
                                    let e = this;
                                    do {
                                        if (V.matches(e, t)) return e;
                                        e = e.parentElement || e.parentNode;
                                    } while (null !== e && 1 === e.nodeType);
                                    return null;
                                }
                            ).call(e, t);
                        })(this.player.elements.container, e.config.fullscreen.container)),
                    J.call(this.player, document, "ms" === this.prefix ? "MSFullscreenChange" : `${this.prefix}fullscreenchange`, () => {
                        this.onChange();
                    }),
                    J.call(this.player, this.player.elements.container, "dblclick", (e) => {
                        (A.element(this.player.elements.controls) && this.player.elements.controls.contains(e.target)) || this.player.listeners.proxy(e, this.toggle, "fullscreen");
                    }),
                    J.call(this, this.player.elements.container, "keydown", (e) => this.trapFocus(e)),
                    this.update();
            }
            static get nativeSupported() {
                return !!(document.fullscreenEnabled || document.webkitFullscreenEnabled || document.mozFullScreenEnabled || document.msFullscreenEnabled);
            }
            get useNative() {
                return He.nativeSupported && !this.forceFallback;
            }
            static get prefix() {
                if (A.function(document.exitFullscreen)) return "";
                let e = "";
                return ["webkit", "moz", "ms"].some((t) => !(!A.function(document[`${t}ExitFullscreen`]) && !A.function(document[`${t}CancelFullScreen`])) && ((e = t), !0)), e;
            }
            static get property() {
                return "moz" === this.prefix ? "FullScreen" : "Fullscreen";
            }
            get supported() {
                return [
                    this.player.config.fullscreen.enabled,
                    this.player.isVideo,
                    He.nativeSupported || this.player.config.fullscreen.fallback,
                    !this.player.isYouTube || He.nativeSupported || !x.isIos || (this.player.config.playsinline && !this.player.config.fullscreen.iosNative),
                ].every(Boolean);
            }
            get active() {
                if (!this.supported) return !1;
                if (!He.nativeSupported || this.forceFallback) return U(this.target, this.player.config.classNames.fullscreen.fallback);
                const e = this.prefix ? this.target.getRootNode()[`${this.prefix}${this.property}Element`] : this.target.getRootNode().fullscreenElement;
                return e && e.shadowRoot ? e === this.target.getRootNode().host : e === this.target;
            }
            get target() {
                return x.isIos && this.player.config.fullscreen.iosNative ? this.player.media : this.player.elements.fullscreen ?? this.player.elements.container;
            }
        }
        function Fe(e, t = 1) {
            return new Promise((i, s) => {
                const n = new Image(),
                    a = () => {
                        delete n.onload, delete n.onerror, (n.naturalWidth >= t ? i : s)(n);
                    };
                Object.assign(n, { onload: a, onerror: a, src: e });
            });
        }
        const Ue = {
            addStyleHook() {
                F(this.elements.container, this.config.selectors.container.replace(".", ""), !0), F(this.elements.container, this.config.classNames.uiSupported, this.supported.ui);
            },
            toggleNativeControls(e = !1) {
                e && this.isHTML5 ? this.media.setAttribute("controls", "") : this.media.removeAttribute("controls");
            },
            build() {
                if ((this.listeners.media(), !this.supported.ui)) return this.debug.warn(`Basic support only for ${this.provider} ${this.type}`), void Ue.toggleNativeControls.call(this, !0);
                A.element(this.elements.controls) || (Me.inject.call(this), this.listeners.controls()),
                    Ue.toggleNativeControls.call(this),
                    this.isHTML5 && Ne.setup.call(this),
                    (this.volume = null),
                    (this.muted = null),
                    (this.loop = null),
                    (this.quality = null),
                    (this.speed = null),
                    Me.updateVolume.call(this),
                    Me.timeUpdate.call(this),
                    Me.durationUpdate.call(this),
                    Ue.checkPlaying.call(this),
                    F(this.elements.container, this.config.classNames.pip.supported, Y.pip && this.isHTML5 && this.isVideo),
                    F(this.elements.container, this.config.classNames.airplay.supported, Y.airplay && this.isHTML5),
                    F(this.elements.container, this.config.classNames.isTouch, this.touch),
                    (this.ready = !0),
                    setTimeout(() => {
                        ee.call(this, this.media, "ready");
                    }, 0),
                    Ue.setTitle.call(this),
                    this.poster && Ue.setPoster.call(this, this.poster, !1).catch(() => { }),
                    this.config.duration && Me.durationUpdate.call(this),
                    this.config.mediaMetadata && Me.setMediaMetadata.call(this);
            },
            setTitle() {
                let e = we.get("play", this.config);
                if (
                    (A.string(this.config.title) && !A.empty(this.config.title) && (e += `, ${this.config.title}`),
                        Array.from(this.elements.buttons.play || []).forEach((t) => {
                            t.setAttribute("aria-label", e);
                        }),
                        this.isEmbed)
                ) {
                    const e = W.call(this, "iframe");
                    if (!A.element(e)) return;
                    const t = A.empty(this.config.title) ? "video" : this.config.title,
                        i = we.get("frameTitle", this.config);
                    e.setAttribute("title", i.replace("{title}", t));
                }
            },
            togglePoster(e) {
                F(this.elements.container, this.config.classNames.posterEnabled, e);
            },
            setPoster(e, t = !0) {
                return t && this.poster
                    ? Promise.reject(new Error("Poster already set"))
                    : (this.media.setAttribute("data-poster", e),
                        this.elements.poster.removeAttribute("hidden"),
                        ie
                            .call(this)
                            .then(() => Fe(e))
                            .catch((t) => {
                                throw (e === this.poster && Ue.togglePoster.call(this, !1), t);
                            })
                            .then(() => {
                                if (e !== this.poster) throw new Error("setPoster cancelled by later call to setPoster");
                            })
                            .then(() => (Object.assign(this.elements.poster.style, { backgroundImage: `url('${e}')`, backgroundSize: "" }), Ue.togglePoster.call(this, !0), e)));
            },
            checkPlaying(e) {
                F(this.elements.container, this.config.classNames.playing, this.playing),
                    F(this.elements.container, this.config.classNames.paused, this.paused),
                    F(this.elements.container, this.config.classNames.stopped, this.stopped),
                    Array.from(this.elements.buttons.play || []).forEach((e) => {
                        Object.assign(e, { pressed: this.playing }), e.setAttribute("aria-label", we.get(this.playing ? "pause" : "play", this.config));
                    }),
                    (A.event(e) && "timeupdate" === e.type) || Ue.toggleControls.call(this);
            },
            checkLoading(e) {
                (this.loading = ["stalled", "waiting"].includes(e.type)),
                    clearTimeout(this.timers.loading),
                    (this.timers.loading = setTimeout(
                        () => {
                            F(this.elements.container, this.config.classNames.loading, this.loading), Ue.toggleControls.call(this);
                        },
                        this.loading ? 250 : 0
                    ));
            },
            toggleControls(e) {
                const { controls: t } = this.elements;
                if (t && this.config.hideControls) {
                    const i = this.touch && this.lastSeekTime + 2e3 > Date.now();
                    this.toggleControls(Boolean(e || this.loading || this.paused || t.pressed || t.hover || i));
                }
            },
            migrateStyles() {
                Object.values({ ...this.media.style })
                    .filter((e) => !A.empty(e) && A.string(e) && e.startsWith("--plyr"))
                    .forEach((e) => {
                        this.elements.container.style.setProperty(e, this.media.style.getPropertyValue(e)), this.media.style.removeProperty(e);
                    }),
                    A.empty(this.media.style) && this.media.removeAttribute("style");
            },
        };
        class Ve {
            constructor(e) {
                t(this, "firstTouch", () => {
                    const { player: e } = this,
                        { elements: t } = e;
                    (e.touch = !0), F(t.container, e.config.classNames.isTouch, !0);
                }),
                    t(this, "global", (e = !0) => {
                        const { player: t } = this;
                        t.config.keyboard.global && X.call(t, window, "keydown keyup", this.handleKey, e, !1), X.call(t, document.body, "click", this.toggleMenu, e), Z.call(t, document.body, "touchstart", this.firstTouch);
                    }),
                    t(this, "container", () => {
                        const { player: e } = this,
                            { config: t, elements: i, timers: s } = e;
                        !t.keyboard.global && t.keyboard.focused && J.call(e, i.container, "keydown keyup", this.handleKey, !1),
                            J.call(e, i.container, "mousemove mouseleave touchstart touchmove enterfullscreen exitfullscreen", (t) => {
                                const { controls: n } = i;
                                n && "enterfullscreen" === t.type && ((n.pressed = !1), (n.hover = !1));
                                let a = 0;
                                ["touchstart", "touchmove", "mousemove"].includes(t.type) && (Ue.toggleControls.call(e, !0), (a = e.touch ? 3e3 : 2e3)),
                                    clearTimeout(s.controls),
                                    (s.controls = setTimeout(() => Ue.toggleControls.call(e, !1), a));
                            });
                        const n = () => {
                            if (!e.isVimeo || e.config.vimeo.premium) return;
                            const t = i.wrapper,
                                { active: s } = e.fullscreen,
                                [n, a] = ue.call(e),
                                r = re(`aspect-ratio: ${n} / ${a}`);
                            if (!s) return void (r ? ((t.style.width = null), (t.style.height = null)) : ((t.style.maxWidth = null), (t.style.margin = null)));
                            const [o, l] = [Math.max(document.documentElement.clientWidth || 0, window.innerWidth || 0), Math.max(document.documentElement.clientHeight || 0, window.innerHeight || 0)],
                                c = o / l > n / a;
                            r ? ((t.style.width = c ? "auto" : "100%"), (t.style.height = c ? "100%" : "auto")) : ((t.style.maxWidth = c ? (l / a) * n + "px" : null), (t.style.margin = c ? "0 auto" : null));
                        },
                            a = () => {
                                clearTimeout(s.resized), (s.resized = setTimeout(n, 50));
                            };
                        J.call(e, i.container, "enterfullscreen exitfullscreen", (t) => {
                            const { target: s } = e.fullscreen;
                            if (s !== i.container) return;
                            if (!e.isEmbed && A.empty(e.config.ratio)) return;
                            n();
                            ("enterfullscreen" === t.type ? J : G).call(e, window, "resize", a);
                        });
                    }),
                    t(this, "media", () => {
                        const { player: e } = this,
                            { elements: t } = e;
                        if (
                            (J.call(e, e.media, "timeupdate seeking seeked", (t) => Me.timeUpdate.call(e, t)),
                                J.call(e, e.media, "durationchange loadeddata loadedmetadata", (t) => Me.durationUpdate.call(e, t)),
                                J.call(e, e.media, "ended", () => {
                                    e.isHTML5 && e.isVideo && e.config.resetOnEnd && (e.restart(), e.pause());
                                }),
                                J.call(e, e.media, "progress playing seeking seeked", (t) => Me.updateProgress.call(e, t)),
                                J.call(e, e.media, "volumechange", (t) => Me.updateVolume.call(e, t)),
                                J.call(e, e.media, "playing play pause ended emptied timeupdate", (t) => Ue.checkPlaying.call(e, t)),
                                J.call(e, e.media, "waiting canplay seeked playing", (t) => Ue.checkLoading.call(e, t)),
                                e.supported.ui && e.config.clickToPlay && !e.isAudio)
                        ) {
                            const i = W.call(e, `.${e.config.classNames.video}`);
                            if (!A.element(i)) return;
                            J.call(e, t.container, "click", (s) => {
                                ([t.container, i].includes(s.target) || i.contains(s.target)) &&
                                    ((e.touch && e.config.hideControls) ||
                                        (e.ended
                                            ? (this.proxy(s, e.restart, "restart"),
                                                this.proxy(
                                                    s,
                                                    () => {
                                                        se(e.play());
                                                    },
                                                    "play"
                                                ))
                                            : this.proxy(
                                                s,
                                                () => {
                                                    se(e.togglePlay());
                                                },
                                                "play"
                                            )));
                            });
                        }
                        e.supported.ui &&
                            e.config.disableContextMenu &&
                            J.call(
                                e,
                                t.wrapper,
                                "contextmenu",
                                (e) => {
                                    e.preventDefault();
                                },
                                !1
                            ),
                            J.call(e, e.media, "volumechange", () => {
                                e.storage.set({ volume: e.volume, muted: e.muted });
                            }),
                            J.call(e, e.media, "ratechange", () => {
                                Me.updateSetting.call(e, "speed"), e.storage.set({ speed: e.speed });
                            }),
                            J.call(e, e.media, "qualitychange", (t) => {
                                Me.updateSetting.call(e, "quality", null, t.detail.quality);
                            }),
                            J.call(e, e.media, "ready qualitychange", () => {
                                Me.setDownloadUrl.call(e);
                            });
                        const i = e.config.events.concat(["keyup", "keydown"]).join(" ");
                        J.call(e, e.media, i, (i) => {
                            let { detail: s = {} } = i;
                            "error" === i.type && (s = e.media.error), ee.call(e, t.container, i.type, !0, s);
                        });
                    }),
                    t(this, "proxy", (e, t, i) => {
                        const { player: s } = this,
                            n = s.config.listeners[i];
                        let a = !0;
                        A.function(n) && (a = n.call(s, e)), !1 !== a && A.function(t) && t.call(s, e);
                    }),
                    t(this, "bind", (e, t, i, s, n = !0) => {
                        const { player: a } = this,
                            r = a.config.listeners[s],
                            o = A.function(r);
                        J.call(a, e, t, (e) => this.proxy(e, i, s), n && !o);
                    }),
                    t(this, "controls", () => {
                        const { player: e } = this,
                            { elements: t } = e,
                            i = x.isIE ? "change" : "input";
                        if (
                            (t.buttons.play &&
                                Array.from(t.buttons.play).forEach((t) => {
                                    this.bind(
                                        t,
                                        "click",
                                        () => {
                                            se(e.togglePlay());
                                        },
                                        "play"
                                    );
                                }),
                                this.bind(t.buttons.restart, "click", e.restart, "restart"),
                                this.bind(
                                    t.buttons.rewind,
                                    "click",
                                    () => {
                                        (e.lastSeekTime = Date.now()), e.rewind();
                                    },
                                    "rewind"
                                ),
                                this.bind(
                                    t.buttons.fastForward,
                                    "click",
                                    () => {
                                        (e.lastSeekTime = Date.now()), e.forward();
                                    },
                                    "fastForward"
                                ),
                                this.bind(
                                    t.buttons.mute,
                                    "click",
                                    () => {
                                        e.muted = !e.muted;
                                    },
                                    "mute"
                                ),
                                this.bind(t.buttons.captions, "click", () => e.toggleCaptions()),
                                this.bind(
                                    t.buttons.download,
                                    "click",
                                    () => {
                                        ee.call(e, e.media, "download");
                                    },
                                    "download"
                                ),
                                this.bind(
                                    t.buttons.fullscreen,
                                    "click",
                                    () => {
                                        e.fullscreen.toggle();
                                    },
                                    "fullscreen"
                                ),
                                this.bind(
                                    t.buttons.pip,
                                    "click",
                                    () => {
                                        e.pip = "toggle";
                                    },
                                    "pip"
                                ),
                                this.bind(t.buttons.airplay, "click", e.airplay, "airplay"),
                                this.bind(
                                    t.buttons.settings,
                                    "click",
                                    (t) => {
                                        t.stopPropagation(), t.preventDefault(), Me.toggleMenu.call(e, t);
                                    },
                                    null,
                                    !1
                                ),
                                this.bind(
                                    t.buttons.settings,
                                    "keyup",
                                    (t) => {
                                        [" ", "Enter"].includes(t.key) && ("Enter" !== t.key ? (t.preventDefault(), t.stopPropagation(), Me.toggleMenu.call(e, t)) : Me.focusFirstMenuItem.call(e, null, !0));
                                    },
                                    null,
                                    !1
                                ),
                                this.bind(t.settings.menu, "keydown", (t) => {
                                    "Escape" === t.key && Me.toggleMenu.call(e, t);
                                }),
                                this.bind(t.inputs.seek, "mousedown mousemove", (e) => {
                                    const i = t.progress.getBoundingClientRect(),
                                        s = (100 / i.width) * (e.pageX - i.left);
                                    e.currentTarget.setAttribute("seek-value", s);
                                }),
                                this.bind(t.inputs.seek, "mousedown mouseup keydown keyup touchstart touchend", (t) => {
                                    const i = t.currentTarget,
                                        s = "play-on-seeked";
                                    if (A.keyboardEvent(t) && !["ArrowLeft", "ArrowRight"].includes(t.key)) return;
                                    e.lastSeekTime = Date.now();
                                    const n = i.hasAttribute(s),
                                        a = ["mouseup", "touchend", "keyup"].includes(t.type);
                                    n && a ? (i.removeAttribute(s), se(e.play())) : !a && e.playing && (i.setAttribute(s, ""), e.pause());
                                }),
                                x.isIos)
                        ) {
                            const t = B.call(e, 'input[type="range"]');
                            Array.from(t).forEach((e) => this.bind(e, i, (e) => M(e.target)));
                        }
                        this.bind(
                            t.inputs.seek,
                            i,
                            (t) => {
                                const i = t.currentTarget;
                                let s = i.getAttribute("seek-value");
                                A.empty(s) && (s = i.value), i.removeAttribute("seek-value"), (e.currentTime = (s / i.max) * e.duration);
                            },
                            "seek"
                        ),
                            this.bind(t.progress, "mouseenter mouseleave mousemove", (t) => Me.updateSeekTooltip.call(e, t)),
                            this.bind(t.progress, "mousemove touchmove", (t) => {
                                const { posterThumbnails: i } = e;
                                i && i.loaded && i.startMove(t);
                            }),
                            this.bind(t.progress, "mouseleave touchend click", () => {
                                const { posterThumbnails: t } = e;
                                t && t.loaded && t.endMove(!1, !0);
                            }),
                            this.bind(t.progress, "mousedown touchstart", (t) => {
                                const { posterThumbnails: i } = e;
                                i && i.loaded && i.startScrubbing(t);
                            }),
                            this.bind(t.progress, "mouseup touchend", (t) => {
                                const { posterThumbnails: i } = e;
                                i && i.loaded && i.endScrubbing(t);
                            }),
                            x.isWebKit &&
                            Array.from(B.call(e, 'input[type="range"]')).forEach((t) => {
                                this.bind(t, "input", (t) => Me.updateRangeFill.call(e, t.target));
                            }),
                            e.config.toggleInvert &&
                            !A.element(t.display.duration) &&
                            this.bind(t.display.currentTime, "click", () => {
                                0 !== e.currentTime && ((e.config.invertTime = !e.config.invertTime), Me.timeUpdate.call(e));
                            }),
                            this.bind(
                                t.inputs.volume,
                                i,
                                (t) => {
                                    e.volume = t.target.value;
                                },
                                "volume"
                            ),
                            this.bind(t.controls, "mouseenter mouseleave", (i) => {
                                t.controls.hover = !e.touch && "mouseenter" === i.type;
                            }),
                            t.fullscreen &&
                            Array.from(t.fullscreen.children)
                                .filter((e) => !e.contains(t.container))
                                .forEach((i) => {
                                    this.bind(i, "mouseenter mouseleave", (i) => {
                                        t.controls && (t.controls.hover = !e.touch && "mouseenter" === i.type);
                                    });
                                }),
                            this.bind(t.controls, "mousedown mouseup touchstart touchend touchcancel", (e) => {
                                t.controls.pressed = ["mousedown", "touchstart"].includes(e.type);
                            }),
                            this.bind(t.controls, "focusin", () => {
                                const { config: i, timers: s } = e;
                                F(t.controls, i.classNames.noTransition, !0),
                                    Ue.toggleControls.call(e, !0),
                                    setTimeout(() => {
                                        F(t.controls, i.classNames.noTransition, !1);
                                    }, 0);
                                const n = this.touch ? 3e3 : 4e3;
                                clearTimeout(s.controls), (s.controls = setTimeout(() => Ue.toggleControls.call(e, !1), n));
                            }),
                            this.bind(
                                t.inputs.volume,
                                "wheel",
                                (t) => {
                                    const i = t.webkitDirectionInvertedFromDevice,
                                        [s, n] = [t.deltaX, -t.deltaY].map((e) => (i ? -e : e)),
                                        a = Math.sign(Math.abs(s) > Math.abs(n) ? s : n);
                                    e.increaseVolume(a / 50);
                                    const { volume: r } = e.media;
                                    ((1 === a && r < 1) || (-1 === a && r > 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.firstTouch = this.firstTouch.bind(this));
            }
            handleKey(e) {
                const { player: t } = this,
                    { elements: i } = t,
                    { key: s, type: n, altKey: a, ctrlKey: r, metaKey: o, shiftKey: l } = e,
                    c = "keydown" === n,
                    u = c && s === this.lastKey;
                if (a || r || o || l) return;
                if (!s) return;
                if (c) {
                    const n = document.activeElement;
                    if (A.element(n)) {
                        const { editable: s } = t.config.selectors,
                            { seek: a } = i.inputs;
                        if (n !== a && V(n, s)) return;
                        if (" " === e.key && V(n, 'button, [role^="menuitem"]')) return;
                    }
                    switch (([" ", "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 || ((h = parseInt(s, 10)), (t.currentTime = (t.duration / 10) * h));
                            break;
                        case " ":
                        case "k":
                            u || se(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 h;
            }
            toggleMenu(e) {
                Me.toggleMenu.call(this.player, e);
            }
        }
        var Be = (function (e, t) {
            return e((t = { exports: {} }), t.exports), t.exports;
        })(function (e, t) {
            e.exports = (function () {
                var e = function () { },
                    t = {},
                    i = {},
                    s = {};
                function n(e, t) {
                    e = e.push ? e : [e];
                    var n,
                        a,
                        r,
                        o = [],
                        l = e.length,
                        c = l;
                    for (
                        n = function (e, i) {
                            i.length && o.push(e), --c || t(o);
                        };
                        l--;

                    )
                        (a = e[l]), (r = i[a]) ? n(a, r) : (s[a] = s[a] || []).push(n);
                }
                function a(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 r(t, i) {
                    t.call && (t = { success: t }), i.length ? (t.error || e)(i) : (t.success || e)(t);
                }
                function o(t, i, s, n) {
                    var a,
                        r,
                        l = document,
                        c = s.async,
                        u = (s.numRetries || 0) + 1,
                        h = s.before || e,
                        d = t.replace(/[\?|#].*$/, ""),
                        m = t.replace(/^(css|img)!/, "");
                    (n = n || 0),
                        /(^css!|\.css$)/.test(d)
                            ? (((r = l.createElement("link")).rel = "stylesheet"), (r.href = m), (a = "hideFocus" in r) && r.relList && ((a = 0), (r.rel = "preload"), (r.as = "style")))
                            : /(^img!|\.(png|gif|jpg|svg|webp)$)/.test(d)
                                ? ((r = l.createElement("img")).src = m)
                                : (((r = l.createElement("script")).src = t), (r.async = void 0 === c || c)),
                        (r.onload = r.onerror = r.onbeforeload = function (e) {
                            var l = e.type[0];
                            if (a)
                                try {
                                    r.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" == r.rel && "style" == r.as) return (r.rel = "stylesheet");
                            i(t, l, e.defaultPrevented);
                        }),
                        !1 !== h(t, r) && l.head.appendChild(r);
                }
                function l(e, t, i) {
                    var s,
                        n,
                        a = (e = e.push ? e : [e]).length,
                        r = a,
                        l = [];
                    for (
                        s = function (e, i, s) {
                            if (("e" == i && l.push(e), "b" == i)) {
                                if (!s) return;
                                l.push(e);
                            }
                            --a || t(l);
                        },
                        n = 0;
                        n < r;
                        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) {
                                r(o, e), t && r({ success: t, error: i }, e), a(n, e);
                            },
                            o
                        );
                    }
                    if (o.returnPromise) return new Promise(c);
                    c();
                }
                return (
                    (c.ready = function (e, t) {
                        return (
                            n(e, function (e) {
                                r(t, e);
                            }),
                            c
                        );
                    }),
                    (c.done = function (e) {
                        a(e, []);
                    }),
                    (c.reset = function () {
                        (t = {}), (i = {}), (s = {});
                    }),
                    (c.isDefined = function (e) {
                        return e in t;
                    }),
                    c
                );
            })();
        });
        function We(e) {
            return new Promise((t, i) => {
                Be(e, { success: t, error: i });
            });
        }
        function ze(e) {
            e && !this.embed.hasPlayed && (this.embed.hasPlayed = !0), this.media.paused === e && ((this.media.paused = !e), ee.call(this, this.media, e ? "play" : "pause"));
        }
        const Ke = {
            setup() {
                const e = this;
                F(e.elements.wrapper, e.config.classNames.embed, !0),
                    (e.options.speed = e.config.speed.options),
                    he.call(e),
                    A.object(window.Vimeo)
                        ? Ke.ready.call(e)
                        : We(e.config.urls.vimeo.sdk)
                            .then(() => {
                                Ke.ready.call(e);
                            })
                            .catch((t) => {
                                e.debug.warn("Vimeo SDK (player.js) failed to load", t);
                            });
            },
            ready() {
                const e = this,
                    t = e.config.vimeo,
                    { premium: i, referrerPolicy: s, ...n } = t;
                let a = e.media.getAttribute("src"),
                    r = "";
                A.empty(a)
                    ? ((a = e.media.getAttribute(e.config.attributes.embed.id)), (r = e.media.getAttribute(e.config.attributes.embed.hash)))
                    : (r = (function (e) {
                        const t = e.match(/^.*(vimeo.com\/|video\/)(\d+)(\?.*&*h=|\/)+([\d,a-f]+)/);
                        return t && 5 === t.length ? t[4] : null;
                    })(a));
                const o = r ? { h: r } : {};
                i && Object.assign(n, { controls: !1, sidedock: !1 });
                const l = Le({ loop: e.config.loop.active, autoplay: e.autoplay, muted: e.muted, gesture: "media", playsinline: e.config.playsinline, ...o, ...n }),
                    c = ((u = a), A.empty(u) ? null : A.number(Number(u)) ? u : u.match(/^.*(vimeo.com\/|video\/)(\d+).*/) ? RegExp.$2 : u);
                var u;
                const h = O("iframe"),
                    d = pe(e.config.urls.vimeo.iframe, c, l);
                if (
                    (h.setAttribute("src", d),
                        h.setAttribute("allowfullscreen", ""),
                        h.setAttribute("allow", ["autoplay", "fullscreen", "picture-in-picture", "encrypted-media", "accelerometer", "gyroscope"].join("; ")),
                        A.empty(s) || h.setAttribute("referrerPolicy", s),
                        i || !t.customControls)
                )
                    h.setAttribute("data-poster", e.poster), (e.media = D(h, e.media));
                else {
                    const t = O("div", { class: e.config.classNames.embedContainer, "data-poster": e.poster });
                    t.appendChild(h), (e.media = D(t, e.media));
                }
                t.customControls ||
                    ke(pe(e.config.urls.vimeo.api, d)).then((t) => {
                        !A.empty(t) && t.thumbnail_url && Ue.setPoster.call(e, t.thumbnail_url).catch(() => { });
                    }),
                    (e.embed = new window.Vimeo.Player(h, { autopause: e.config.autopause, muted: e.muted })),
                    (e.media.paused = !0),
                    (e.media.currentTime = 0),
                    e.supported.ui && e.embed.disableTextTrack(),
                    (e.media.play = () => (ze.call(e, !0), e.embed.play())),
                    (e.media.pause = () => (ze.call(e, !1), e.embed.pause())),
                    (e.media.stop = () => {
                        e.pause(), (e.currentTime = 0);
                    });
                let { currentTime: m } = e.media;
                Object.defineProperty(e.media, "currentTime", {
                    get: () => m,
                    set(t) {
                        const { embed: i, media: s, paused: n, volume: a } = e,
                            r = n && !i.hasPlayed;
                        (s.seeking = !0),
                            ee.call(e, s, "seeking"),
                            Promise.resolve(r && i.setVolume(0))
                                .then(() => i.setCurrentTime(t))
                                .then(() => r && i.pause())
                                .then(() => r && i.setVolume(a))
                                .catch(() => { });
                    },
                });
                let p = e.config.speed.selected;
                Object.defineProperty(e.media, "playbackRate", {
                    get: () => p,
                    set(t) {
                        e.embed
                            .setPlaybackRate(t)
                            .then(() => {
                                (p = t), ee.call(e, e.media, "ratechange");
                            })
                            .catch(() => {
                                e.options.speed = [1];
                            });
                    },
                });
                let { volume: g } = e.config;
                Object.defineProperty(e.media, "volume", {
                    get: () => g,
                    set(t) {
                        e.embed.setVolume(t).then(() => {
                            (g = t), ee.call(e, e.media, "volumechange");
                        });
                    },
                });
                let { muted: f } = e.config;
                Object.defineProperty(e.media, "muted", {
                    get: () => f,
                    set(t) {
                        const i = !!A.boolean(t) && t;
                        e.embed.setMuted(!!i || e.config.muted).then(() => {
                            (f = i), ee.call(e, e.media, "volumechange");
                        });
                    },
                });
                let y,
                    { loop: b } = e.config;
                Object.defineProperty(e.media, "loop", {
                    get: () => b,
                    set(t) {
                        const i = A.boolean(t) ? t : e.config.loop.active;
                        e.embed.setLoop(i).then(() => {
                            b = i;
                        });
                    },
                }),
                    e.embed
                        .getVideoUrl()
                        .then((t) => {
                            (y = t), Me.setDownloadUrl.call(e);
                        })
                        .catch((e) => {
                            this.debug.warn(e);
                        }),
                    Object.defineProperty(e.media, "currentSrc", { get: () => y }),
                    Object.defineProperty(e.media, "ended", { get: () => e.currentTime === e.duration }),
                    Promise.all([e.embed.getVideoWidth(), e.embed.getVideoHeight()]).then((t) => {
                        const [i, s] = t;
                        (e.embed.ratio = de(i, s)), he.call(this);
                    }),
                    e.embed.setAutopause(e.config.autopause).then((t) => {
                        e.config.autopause = t;
                    }),
                    e.embed.getVideoTitle().then((t) => {
                        (e.config.title = t), Ue.setTitle.call(this);
                    }),
                    e.embed.getCurrentTime().then((t) => {
                        (m = t), ee.call(e, e.media, "timeupdate");
                    }),
                    e.embed.getDuration().then((t) => {
                        (e.media.duration = t), ee.call(e, e.media, "durationchange");
                    }),
                    e.embed.getTextTracks().then((t) => {
                        (e.media.textTracks = t), Ne.setup.call(e);
                    }),
                    e.embed.on("cuechange", ({ cues: t = [] }) => {
                        const i = t.map((e) =>
                            (function (e) {
                                const t = document.createDocumentFragment(),
                                    i = document.createElement("div");
                                return t.appendChild(i), (i.innerHTML = e), t.firstChild.innerText;
                            })(e.text)
                        );
                        Ne.updateCues.call(e, i);
                    }),
                    e.embed.on("loaded", () => {
                        if (
                            (e.embed.getPaused().then((t) => {
                                ze.call(e, !t), t || ee.call(e, e.media, "playing");
                            }),
                                A.element(e.embed.element) && e.supported.ui)
                        ) {
                            e.embed.element.setAttribute("tabindex", -1);
                        }
                    }),
                    e.embed.on("bufferstart", () => {
                        ee.call(e, e.media, "waiting");
                    }),
                    e.embed.on("bufferend", () => {
                        ee.call(e, e.media, "playing");
                    }),
                    e.embed.on("play", () => {
                        ze.call(e, !0), ee.call(e, e.media, "playing");
                    }),
                    e.embed.on("pause", () => {
                        ze.call(e, !1);
                    }),
                    e.embed.on("timeupdate", (t) => {
                        (e.media.seeking = !1), (m = t.seconds), ee.call(e, e.media, "timeupdate");
                    }),
                    e.embed.on("progress", (t) => {
                        (e.media.buffered = t.percent),
                            ee.call(e, e.media, "progress"),
                            1 === parseInt(t.percent, 10) && ee.call(e, e.media, "canplaythrough"),
                            e.embed.getDuration().then((t) => {
                                t !== e.media.duration && ((e.media.duration = t), ee.call(e, e.media, "durationchange"));
                            });
                    }),
                    e.embed.on("seeked", () => {
                        (e.media.seeking = !1), ee.call(e, e.media, "seeked");
                    }),
                    e.embed.on("ended", () => {
                        (e.media.paused = !0), ee.call(e, e.media, "ended");
                    }),
                    e.embed.on("error", (t) => {
                        (e.media.error = t), ee.call(e, e.media, "error");
                    }),
                    t.customControls && setTimeout(() => Ue.build.call(e), 0);
            },
        };
        function Ye(e) {
            e && !this.embed.hasPlayed && (this.embed.hasPlayed = !0), this.media.paused === e && ((this.media.paused = !e), ee.call(this, this.media, e ? "play" : "pause"));
        }
        function Qe(e) {
            return e.noCookie ? "https://www.youtube-nocookie.com" : "http:" === window.location.protocol ? "http://www.youtube.com" : void 0;
        }
        const Xe = {
            setup() {
                if ((F(this.elements.wrapper, this.config.classNames.embed, !0), A.object(window.YT) && A.function(window.YT.Player))) Xe.ready.call(this);
                else {
                    const e = window.onYouTubeIframeAPIReady;
                    (window.onYouTubeIframeAPIReady = () => {
                        A.function(e) && e(), Xe.ready.call(this);
                    }),
                        We(this.config.urls.youtube.sdk).catch((e) => {
                            this.debug.warn("YouTube API failed to load", e);
                        });
                }
            },
            getTitle(e) {
                ke(pe(this.config.urls.youtube.api, e))
                    .then((e) => {
                        if (A.object(e)) {
                            const { title: t, height: i, width: s } = e;
                            (this.config.title = t), Ue.setTitle.call(this), (this.embed.ratio = de(s, i));
                        }
                        he.call(this);
                    })
                    .catch(() => {
                        he.call(this);
                    });
            },
            ready() {
                const e = this,
                    t = e.config.youtube,
                    i = e.media && e.media.getAttribute("id");
                if (!A.empty(i) && i.startsWith("youtube-")) return;
                let s = e.media.getAttribute("src");
                A.empty(s) && (s = e.media.getAttribute(this.config.attributes.embed.id));
                const n = ((a = s), A.empty(a) ? null : a.match(/^.*(youtu.be\/|v\/|u\/\w\/|embed\/|watch\?v=|&v=)([^#&?]*).*/) ? RegExp.$2 : a);
                var a;
                const r = O("div", { id: `${e.provider}-${Math.floor(1e4 * Math.random())}`, "data-poster": t.customControls ? e.poster : void 0 });
                if (((e.media = D(r, e.media)), t.customControls)) {
                    const t = (e) => `https://i.ytimg.com/vi/${n}/${e}default.jpg`;
                    Fe(t("maxres"), 121)
                        .catch(() => Fe(t("sd"), 121))
                        .catch(() => Fe(t("hq")))
                        .then((t) => Ue.setPoster.call(e, t.src))
                        .then((t) => {
                            t.includes("maxres") || (e.elements.poster.style.backgroundSize = "cover");
                        })
                        .catch(() => { });
                }
                e.embed = new window.YT.Player(e.media, {
                    videoId: n,
                    host: Qe(t),
                    playerVars: N(
                        {},
                        {
                            autoplay: e.config.autoplay ? 1 : 0,
                            hl: e.config.hl,
                            controls: e.supported.ui && t.customControls ? 0 : 1,
                            disablekb: 1,
                            playsinline: e.config.playsinline && !e.config.fullscreen.iosNative ? 1 : 0,
                            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(t) {
                            if (!e.media.error) {
                                const i = t.data,
                                    s =
                                        {
                                            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.",
                                        }[i] || "An unknown error occurred";
                                (e.media.error = { code: i, message: s }), ee.call(e, e.media, "error");
                            }
                        },
                        onPlaybackRateChange(t) {
                            const i = t.target;
                            (e.media.playbackRate = i.getPlaybackRate()), ee.call(e, e.media, "ratechange");
                        },
                        onReady(i) {
                            if (A.function(e.media.play)) return;
                            const s = i.target;
                            Xe.getTitle.call(e, n),
                                (e.media.play = () => {
                                    Ye.call(e, !0), s.playVideo();
                                }),
                                (e.media.pause = () => {
                                    Ye.call(e, !1), s.pauseVideo();
                                }),
                                (e.media.stop = () => {
                                    s.stopVideo();
                                }),
                                (e.media.duration = s.getDuration()),
                                (e.media.paused = !0),
                                (e.media.currentTime = 0),
                                Object.defineProperty(e.media, "currentTime", {
                                    get: () => Number(s.getCurrentTime()),
                                    set(t) {
                                        e.paused && !e.embed.hasPlayed && e.embed.mute(), (e.media.seeking = !0), ee.call(e, e.media, "seeking"), s.seekTo(t);
                                    },
                                }),
                                Object.defineProperty(e.media, "playbackRate", {
                                    get: () => s.getPlaybackRate(),
                                    set(e) {
                                        s.setPlaybackRate(e);
                                    },
                                });
                            let { volume: a } = e.config;
                            Object.defineProperty(e.media, "volume", {
                                get: () => a,
                                set(t) {
                                    (a = t), s.setVolume(100 * a), ee.call(e, e.media, "volumechange");
                                },
                            });
                            let { muted: r } = e.config;
                            Object.defineProperty(e.media, "muted", {
                                get: () => r,
                                set(t) {
                                    const i = A.boolean(t) ? t : r;
                                    (r = i), s[i ? "mute" : "unMute"](), s.setVolume(100 * a), ee.call(e, e.media, "volumechange");
                                },
                            }),
                                Object.defineProperty(e.media, "currentSrc", { get: () => s.getVideoUrl() }),
                                Object.defineProperty(e.media, "ended", { get: () => e.currentTime === e.duration });
                            const o = s.getAvailablePlaybackRates();
                            (e.options.speed = o.filter((t) => e.config.speed.options.includes(t))),
                                e.supported.ui && t.customControls && e.media.setAttribute("tabindex", -1),
                                ee.call(e, e.media, "timeupdate"),
                                ee.call(e, e.media, "durationchange"),
                                clearInterval(e.timers.buffering),
                                (e.timers.buffering = setInterval(() => {
                                    (e.media.buffered = s.getVideoLoadedFraction()),
                                        (null === e.media.lastBuffered || e.media.lastBuffered < e.media.buffered) && ee.call(e, e.media, "progress"),
                                        (e.media.lastBuffered = e.media.buffered),
                                        1 === e.media.buffered && (clearInterval(e.timers.buffering), ee.call(e, e.media, "canplaythrough"));
                                }, 200)),
                                t.customControls && setTimeout(() => Ue.build.call(e), 50);
                        },
                        onStateChange(i) {
                            const s = i.target;
                            clearInterval(e.timers.playing);
                            switch ((e.media.seeking && [1, 2].includes(i.data) && ((e.media.seeking = !1), ee.call(e, e.media, "seeked")), i.data)) {
                                case -1:
                                    ee.call(e, e.media, "timeupdate"), (e.media.buffered = s.getVideoLoadedFraction()), ee.call(e, e.media, "progress");
                                    break;
                                case 0:
                                    Ye.call(e, !1), e.media.loop ? (s.stopVideo(), s.playVideo()) : ee.call(e, e.media, "ended");
                                    break;
                                case 1:
                                    t.customControls && !e.config.autoplay && e.media.paused && !e.embed.hasPlayed
                                        ? e.media.pause()
                                        : (Ye.call(e, !0),
                                            ee.call(e, e.media, "playing"),
                                            (e.timers.playing = setInterval(() => {
                                                ee.call(e, e.media, "timeupdate");
                                            }, 50)),
                                            e.media.duration !== s.getDuration() && ((e.media.duration = s.getDuration()), ee.call(e, e.media, "durationchange")));
                                    break;
                                case 2:
                                    e.muted || e.embed.unMute(), Ye.call(e, !1);
                                    break;
                                case 3:
                                    ee.call(e, e.media, "waiting");
                            }
                            ee.call(e, e.elements.container, "statechange", !1, { code: i.data });
                        },
                    },
                });
            },
        },
            Je = {
                setup() {
                    this.media
                        ? (F(this.elements.container, this.config.classNames.type.replace("{0}", this.type), !0),
                            F(this.elements.container, this.config.classNames.provider.replace("{0}", this.provider), !0),
                            this.isEmbed && F(this.elements.container, this.config.classNames.type.replace("{0}", "video"), !0),
                            this.isVideo &&
                            ((this.elements.wrapper = O("div", { class: this.config.classNames.video })),
                                _(this.media, this.elements.wrapper),
                                (this.elements.poster = O("div", { class: this.config.classNames.poster })),
                                this.elements.wrapper.appendChild(this.elements.poster)),
                            this.isHTML5 ? me.setup.call(this) : this.isYouTube ? Xe.setup.call(this) : this.isVimeo && Ke.setup.call(this))
                        : this.debug.warn("No media element found!");
                },
            };
        class Ge {
            constructor(e) {
                t(this, "load", () => {
                    this.enabled &&
                        (A.object(window.google) && A.object(window.google.ima)
                            ? this.ready()
                            : We(this.player.config.urls.googleIMA.sdk)
                                .then(() => {
                                    this.ready();
                                })
                                .catch(() => {
                                    this.trigger("error", new Error("Google IMA SDK failed to load"));
                                }));
                }),
                    t(this, "ready", () => {
                        var e;
                        this.enabled || ((e = this).manager && e.manager.destroy(), e.elements.displayContainer && e.elements.displayContainer.destroy(), e.elements.container.remove()),
                            this.startSafetyTimer(12e3, "ready()"),
                            this.managerPromise.then(() => {
                                this.clearSafetyTimer("onAdsManagerLoaded()");
                            }),
                            this.listeners(),
                            this.setupIMA();
                    }),
                    t(this, "setupIMA", () => {
                        (this.elements.container = O("div", { class: this.player.config.classNames.ads })),
                            this.player.elements.container.appendChild(this.elements.container),
                            google.ima.settings.setVpaidMode(google.ima.ImaSdkSettings.VpaidMode.ENABLED),
                            google.ima.settings.setLocale(this.player.config.ads.language),
                            google.ima.settings.setDisableCustomPlaybackForIOS10Plus(this.player.config.playsinline),
                            (this.elements.displayContainer = new google.ima.AdDisplayContainer(this.elements.container, this.player.media)),
                            (this.loader = new google.ima.AdsLoader(this.elements.displayContainer)),
                            this.loader.addEventListener(google.ima.AdsManagerLoadedEvent.Type.ADS_MANAGER_LOADED, (e) => this.onAdsManagerLoaded(e), !1),
                            this.loader.addEventListener(google.ima.AdErrorEvent.Type.AD_ERROR, (e) => this.onAdError(e), !1),
                            this.requestAds();
                    }),
                    t(this, "requestAds", () => {
                        const { container: e } = this.player.elements;
                        try {
                            const t = new google.ima.AdsRequest();
                            (t.adTagUrl = this.tagUrl),
                                (t.linearAdSlotWidth = e.offsetWidth),
                                (t.linearAdSlotHeight = e.offsetHeight),
                                (t.nonLinearAdSlotWidth = e.offsetWidth),
                                (t.nonLinearAdSlotHeight = e.offsetHeight),
                                (t.forceNonLinearFullSlot = !1),
                                t.setAdWillPlayMuted(!this.player.muted),
                                this.loader.requestAds(t);
                        } catch (e) {
                            this.onAdError(e);
                        }
                    }),
                    t(this, "pollCountdown", (e = !1) => {
                        if (!e) return clearInterval(this.countdownTimer), void this.elements.container.removeAttribute("data-badge-text");
                        this.countdownTimer = setInterval(() => {
                            const e = Pe(Math.max(this.manager.getRemainingTime(), 0)),
                                t = `${we.get("advertisement", this.player.config)} - ${e}`;
                            this.elements.container.setAttribute("data-badge-text", t);
                        }, 100);
                    }),
                    t(this, "onAdsManagerLoaded", (e) => {
                        if (!this.enabled) return;
                        const t = new google.ima.AdsRenderingSettings();
                        (t.restoreCustomPlaybackStateOnAdBreakComplete = !0),
                            (t.enablePreloading = !0),
                            (this.manager = e.getAdsManager(this.player, t)),
                            (this.cuePoints = this.manager.getCuePoints()),
                            this.manager.addEventListener(google.ima.AdErrorEvent.Type.AD_ERROR, (e) => this.onAdError(e)),
                            Object.keys(google.ima.AdEvent.Type).forEach((e) => {
                                this.manager.addEventListener(google.ima.AdEvent.Type[e], (e) => this.onAdEvent(e));
                            }),
                            this.trigger("loaded");
                    }),
                    t(this, "addCuePoints", () => {
                        A.empty(this.cuePoints) ||
                            this.cuePoints.forEach((e) => {
                                if (0 !== e && -1 !== e && e < this.player.duration) {
                                    const t = this.player.elements.progress;
                                    if (A.element(t)) {
                                        const i = (100 / this.player.duration) * e,
                                            s = O("span", { class: this.player.config.classNames.cues });
                                        (s.style.left = `${i.toString()}%`), t.appendChild(s);
                                    }
                                }
                            });
                    }),
                    t(this, "onAdEvent", (e) => {
                        const { container: t } = this.player.elements,
                            i = e.getAd(),
                            s = e.getAdData();
                        switch (
                        (((e) => {
                            ee.call(this.player, this.player.media, `ads${e.replace(/_/g, "").toLowerCase()}`);
                        })(e.type),
                            e.type)
                        ) {
                            case google.ima.AdEvent.Type.LOADED:
                                this.trigger("loaded"), this.pollCountdown(!0), i.isLinear() || ((i.width = t.offsetWidth), (i.height = t.offsetHeight));
                                break;
                            case google.ima.AdEvent.Type.STARTED:
                                this.manager.setVolume(this.player.volume);
                                break;
                            case google.ima.AdEvent.Type.ALL_ADS_COMPLETED:
                                this.player.ended ? this.loadAds() : this.loader.contentComplete();
                                break;
                            case google.ima.AdEvent.Type.CONTENT_PAUSE_REQUESTED:
                                this.pauseContent();
                                break;
                            case google.ima.AdEvent.Type.CONTENT_RESUME_REQUESTED:
                                this.pollCountdown(), this.resumeContent();
                                break;
                            case google.ima.AdEvent.Type.LOG:
                                s.adError && this.player.debug.warn(`Non-fatal ad error: ${s.adError.getMessage()}`);
                        }
                    }),
                    t(this, "onAdError", (e) => {
                        this.cancel(), this.player.debug.warn("Ads error", e);
                    }),
                    t(this, "listeners", () => {
                        const { container: e } = this.player.elements;
                        let t;
                        this.player.on("canplay", () => {
                            this.addCuePoints();
                        }),
                            this.player.on("ended", () => {
                                this.loader.contentComplete();
                            }),
                            this.player.on("timeupdate", () => {
                                t = this.player.currentTime;
                            }),
                            this.player.on("seeked", () => {
                                const e = this.player.currentTime;
                                A.empty(this.cuePoints) ||
                                    this.cuePoints.forEach((i, s) => {
                                        t < i && i < e && (this.manager.discardAdBreak(), this.cuePoints.splice(s, 1));
                                    });
                            }),
                            window.addEventListener("resize", () => {
                                this.manager && this.manager.resize(e.offsetWidth, e.offsetHeight, google.ima.ViewMode.NORMAL);
                            });
                    }),
                    t(this, "play", () => {
                        const { container: e } = this.player.elements;
                        this.managerPromise || this.resumeContent(),
                            this.managerPromise
                                .then(() => {
                                    this.manager.setVolume(this.player.volume), this.elements.displayContainer.initialize();
                                    try {
                                        this.initialized || (this.manager.init(e.offsetWidth, e.offsetHeight, google.ima.ViewMode.NORMAL), this.manager.start()), (this.initialized = !0);
                                    } catch (e) {
                                        this.onAdError(e);
                                    }
                                })
                                .catch(() => { });
                    }),
                    t(this, "resumeContent", () => {
                        (this.elements.container.style.zIndex = ""), (this.playing = !1), se(this.player.media.play());
                    }),
                    t(this, "pauseContent", () => {
                        (this.elements.container.style.zIndex = 3), (this.playing = !0), this.player.media.pause();
                    }),
                    t(this, "cancel", () => {
                        this.initialized && this.resumeContent(), this.trigger("error"), this.loadAds();
                    }),
                    t(this, "loadAds", () => {
                        this.managerPromise
                            .then(() => {
                                this.manager && this.manager.destroy(),
                                    (this.managerPromise = new Promise((e) => {
                                        this.on("loaded", e), this.player.debug.log(this.manager);
                                    })),
                                    (this.initialized = !1),
                                    this.requestAds();
                            })
                            .catch(() => { });
                    }),
                    t(this, "trigger", (e, ...t) => {
                        const i = this.events[e];
                        A.array(i) &&
                            i.forEach((e) => {
                                A.function(e) && e.apply(this, t);
                            });
                    }),
                    t(this, "on", (e, t) => (A.array(this.events[e]) || (this.events[e] = []), this.events[e].push(t), this)),
                    t(this, "startSafetyTimer", (e, t) => {
                        this.player.debug.log(`Safety timer invoked from: ${t}`),
                            (this.safetyTimer = setTimeout(() => {
                                this.cancel(), this.clearSafetyTimer("startSafetyTimer()");
                            }, e));
                    }),
                    t(this, "clearSafetyTimer", (e) => {
                        A.nullOrUndefined(this.safetyTimer) || (this.player.debug.log(`Safety timer cleared from: ${e}`), clearTimeout(this.safetyTimer), (this.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((e, t) => {
                        this.on("loaded", e), this.on("error", t);
                    })),
                    this.load();
            }
            get enabled() {
                const { config: e } = this;
                return this.player.isHTML5 && this.player.isVideo && e.enabled && (!A.empty(e.publisherId) || A.url(e.tagUrl));
            }
            get tagUrl() {
                const { config: e } = this;
                if (A.url(e.tagUrl)) return e.tagUrl;
                return `https://go.aniview.com/api/adserver6/vast/?${Le({
                    AV_PUBLISHERID: "58c25bb0073ef448b1087ad6",
                    AV_CHANNELID: "5a0458dc28a06145e4519d21",
                    AV_URL: window.location.hostname,
                    cb: Date.now(),
                    AV_WIDTH: 640,
                    AV_HEIGHT: 480,
                    AV_CDIM2: e.publisherId,
                })}`;
            }
        }
        function Ze(e = 0, t = 0, i = 255) {
            return Math.min(Math.max(e, t), i);
        }
        const et = (e) => {
            const t = [];
            return (
                e.split(/\r\n\r\n|\n\n|\r\r/).forEach((e) => {
                    const i = {};
                    e.split(/\r\n|\n|\r/).forEach((e) => {
                        if (A.number(i.startTime)) {
                            if (!A.empty(e.trim()) && A.empty(i.text)) {
                                const t = e.trim().split("#xywh=");
                                ([i.text] = t), t[1] && ([i.x, i.y, i.w, i.h] = t[1].split(","));
                            }
                        } else {
                            const t = 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})/);
                            t && ((i.startTime = 60 * Number(t[1] || 0) * 60 + 60 * Number(t[2]) + Number(t[3]) + Number(`0.${t[4]}`)), (i.endTime = 60 * Number(t[6] || 0) * 60 + 60 * Number(t[7]) + Number(t[8]) + Number(`0.${t[9]}`)));
                        }
                    }),
                        i.text && t.push(i);
                }),
                t
            );
        },
            tt = (e, t) => {
                const 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;
            };
        class it {
            constructor(e) {
                t(this, "load", () => {
                    this.player.elements.display.seekTooltip && (this.player.elements.display.seekTooltip.hidden = this.enabled),
                        this.enabled &&
                        this.getThumbnails().then(() => {
                            this.enabled && (this.render(), this.determineContainerAutoSizing(), this.listeners(), (this.loaded = !0));
                        });
                }),
                    t(
                        this,
                        "getThumbnails",
                        () =>
                            new Promise((e) => {
                                const { src: t } = this.player.config.posterThumbnails;
                                if (A.empty(t)) throw new Error("Missing posterThumbnails.src config attribute");
                                const i = () => {
                                    this.thumbnails.sort((e, t) => e.height - t.height), this.player.debug.log("Preview thumbnails", this.thumbnails), e();
                                };
                                if (A.function(t))
                                    t((e) => {
                                        (this.thumbnails = e), i();
                                    });
                                else {
                                    const e = (A.string(t) ? [t] : t).map((e) => this.getThumbnail(e));
                                    Promise.all(e).then(i);
                                }
                            })
                    ),
                    t(
                        this,
                        "getThumbnail",
                        (e) =>
                            new Promise((t) => {
                                ke(e).then((i) => {
                                    const s = { frames: et(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));
                                    const n = new Image();
                                    (n.onload = () => {
                                        (s.height = n.naturalHeight), (s.width = n.naturalWidth), this.thumbnails.push(s), t();
                                    }),
                                        (n.src = s.urlPrefix + s.frames[0].text);
                                });
                            })
                    ),
                    t(this, "startMove", (e) => {
                        if (this.loaded && A.event(e) && ["touchmove", "mousemove"].includes(e.type) && this.player.media.duration) {
                            if ("touchmove" === e.type) this.seekTime = this.player.media.duration * (this.player.elements.inputs.seek.value / 100);
                            else {
                                var t, i;
                                const s = this.player.elements.progress.getBoundingClientRect(),
                                    n = (100 / s.width) * (e.pageX - s.left);
                                (this.seekTime = this.player.media.duration * (n / 100)),
                                    this.seekTime < 0 && (this.seekTime = 0),
                                    this.seekTime > this.player.media.duration - 1 && (this.seekTime = this.player.media.duration - 1),
                                    (this.mousePosX = e.pageX),
                                    (this.elements.thumb.time.innerText = Pe(this.seekTime));
                                const a = null === (t = this.player.config.markers) || void 0 === t || null === (i = t.points) || void 0 === i ? void 0 : i.find(({ time: e }) => e === Math.round(this.seekTime));
                                a && this.elements.thumb.time.insertAdjacentHTML("afterbegin", `${a.label}<br>`);
                            }
                            this.showImageAtCurrentTime();
                        }
                    }),
                    t(this, "endMove", () => {
                        this.toggleThumbContainer(!1, !0);
                    }),
                    t(this, "startScrubbing", (e) => {
                        (A.nullOrUndefined(e.button) || !1 === e.button || 0 === e.button) &&
                            ((this.mouseDown = !0), this.player.media.duration && (this.toggleScrubbingContainer(!0), this.toggleThumbContainer(!1, !0), this.showImageAtCurrentTime()));
                    }),
                    t(this, "endScrubbing", () => {
                        (this.mouseDown = !1),
                            Math.ceil(this.lastTime) === Math.ceil(this.player.media.currentTime)
                                ? this.toggleScrubbingContainer(!1)
                                : Z.call(this.player, this.player.media, "timeupdate", () => {
                                    this.mouseDown || this.toggleScrubbingContainer(!1);
                                });
                    }),
                    t(this, "listeners", () => {
                        this.player.on("play", () => {
                            this.toggleThumbContainer(!1, !0);
                        }),
                            this.player.on("seeked", () => {
                                this.toggleThumbContainer(!1);
                            }),
                            this.player.on("timeupdate", () => {
                                this.lastTime = this.player.media.currentTime;
                            });
                    }),
                    t(this, "render", () => {
                        (this.elements.thumb.container = O("div", { class: this.player.config.classNames.posterThumbnails.thumbContainer })),
                            (this.elements.thumb.imageContainer = O("div", { class: this.player.config.classNames.posterThumbnails.imageContainer })),
                            this.elements.thumb.container.appendChild(this.elements.thumb.imageContainer);
                        const e = O("div", { class: this.player.config.classNames.posterThumbnails.timeContainer });
                        (this.elements.thumb.time = O("span", {}, "00:00")),
                            e.appendChild(this.elements.thumb.time),
                            this.elements.thumb.imageContainer.appendChild(e),
                            A.element(this.player.elements.progress) && this.player.elements.progress.appendChild(this.elements.thumb.container),
                            (this.elements.scrubbing.container = O("div", { class: this.player.config.classNames.posterThumbnails.scrubbingContainer })),
                            this.player.elements.wrapper.appendChild(this.elements.scrubbing.container);
                    }),
                    t(this, "destroy", () => {
                        this.elements.thumb.container && this.elements.thumb.container.remove(), this.elements.scrubbing.container && this.elements.scrubbing.container.remove();
                    }),
                    t(this, "showImageAtCurrentTime", () => {
                        this.mouseDown ? this.setScrubbingContainerSize() : this.setThumbContainerSizeAndPos();
                        const e = this.thumbnails[0].frames.findIndex((e) => this.seekTime >= e.startTime && this.seekTime <= e.endTime),
                            t = e >= 0;
                        let i = 0;
                        this.mouseDown || this.toggleThumbContainer(t),
                            t &&
                            (this.thumbnails.forEach((t, s) => {
                                this.loadedImages.includes(t.frames[e].text) && (i = s);
                            }),
                                e !== this.showingThumb && ((this.showingThumb = e), this.loadImage(i)));
                    }),
                    t(this, "loadImage", (e = 0) => {
                        const t = this.showingThumb,
                            i = this.thumbnails[e],
                            { urlPrefix: s } = i,
                            n = i.frames[t],
                            a = i.frames[t].text,
                            r = s + a;
                        if (this.currentImageElement && this.currentImageElement.dataset.filename === a)
                            this.showImage(this.currentImageElement, n, e, t, a, !1), (this.currentImageElement.dataset.index = t), this.removeOldImages(this.currentImageElement);
                        else {
                            this.loadingImage && this.usingSprites && (this.loadingImage.onload = null);
                            const i = new Image();
                            (i.src = r),
                                (i.dataset.index = t),
                                (i.dataset.filename = a),
                                (this.showingThumbFilename = a),
                                this.player.debug.log(`Loading image: ${r}`),
                                (i.onload = () => this.showImage(i, n, e, t, a, !0)),
                                (this.loadingImage = i),
                                this.removeOldImages(i);
                        }
                    }),
                    t(this, "showImage", (e, t, i, s, n, a = !0) => {
                        this.player.debug.log(`Showing thumb: ${n}. num: ${s}. qual: ${i}. newimg: ${a}`),
                            this.setImageSizeAndOffset(e, t),
                            a && (this.currentImageContainer.appendChild(e), (this.currentImageElement = e), this.loadedImages.includes(n) || this.loadedImages.push(n)),
                            this.preloadNearby(s, !0).then(this.preloadNearby(s, !1)).then(this.getHigherQuality(i, e, t, n));
                    }),
                    t(this, "removeOldImages", (e) => {
                        Array.from(this.currentImageContainer.children).forEach((t) => {
                            if ("img" !== t.tagName.toLowerCase()) return;
                            const i = this.usingSprites ? 500 : 1e3;
                            if (t.dataset.index !== e.dataset.index && !t.dataset.deleting) {
                                t.dataset.deleting = !0;
                                const { currentImageContainer: e } = this;
                                setTimeout(() => {
                                    e.removeChild(t), this.player.debug.log(`Removing thumb: ${t.dataset.filename}`);
                                }, i);
                            }
                        });
                    }),
                    t(
                        this,
                        "preloadNearby",
                        (e, t = !0) =>
                            new Promise((i) => {
                                setTimeout(() => {
                                    const s = this.thumbnails[0].frames[e].text;
                                    if (this.showingThumbFilename === s) {
                                        let n;
                                        n = t ? this.thumbnails[0].frames.slice(e) : this.thumbnails[0].frames.slice(0, e).reverse();
                                        let a = !1;
                                        n.forEach((e) => {
                                            const t = e.text;
                                            if (t !== s && !this.loadedImages.includes(t)) {
                                                (a = !0), this.player.debug.log(`Preloading thumb filename: ${t}`);
                                                const { urlPrefix: e } = this.thumbnails[0],
                                                    s = e + t,
                                                    n = new Image();
                                                (n.src = s),
                                                    (n.onload = () => {
                                                        this.player.debug.log(`Preloaded thumb filename: ${t}`), this.loadedImages.includes(t) || this.loadedImages.push(t), i();
                                                    });
                                            }
                                        }),
                                            a || i();
                                    }
                                }, 300);
                            })
                    ),
                    t(this, "getHigherQuality", (e, t, i, s) => {
                        if (e < this.thumbnails.length - 1) {
                            let n = t.naturalHeight;
                            this.usingSprites && (n = i.h),
                                n < this.thumbContainerHeight &&
                                setTimeout(() => {
                                    this.showingThumbFilename === s && (this.player.debug.log(`Showing higher quality thumb for: ${s}`), this.loadImage(e + 1));
                                }, 300);
                        }
                    }),
                    t(this, "toggleThumbContainer", (e = !1, t = !1) => {
                        const i = this.player.config.classNames.posterThumbnails.thumbContainerShown;
                        this.elements.thumb.container.classList.toggle(i, e), !e && t && ((this.showingThumb = null), (this.showingThumbFilename = null));
                    }),
                    t(this, "toggleScrubbingContainer", (e = !1) => {
                        const t = this.player.config.classNames.posterThumbnails.scrubbingContainerShown;
                        this.elements.scrubbing.container.classList.toggle(t, e), e || ((this.showingThumb = null), (this.showingThumbFilename = null));
                    }),
                    t(this, "determineContainerAutoSizing", () => {
                        (this.elements.thumb.imageContainer.clientHeight > 20 || this.elements.thumb.imageContainer.clientWidth > 20) && (this.sizeSpecifiedInCSS = !0);
                    }),
                    t(this, "setThumbContainerSizeAndPos", () => {
                        const { imageContainer: e } = this.elements.thumb;
                        if (this.sizeSpecifiedInCSS) {
                            if (e.clientHeight > 20 && e.clientWidth < 20) {
                                const t = Math.floor(e.clientHeight * this.thumbAspectRatio);
                                e.style.width = `${t}px`;
                            } else if (e.clientHeight < 20 && e.clientWidth > 20) {
                                const t = Math.floor(e.clientWidth / this.thumbAspectRatio);
                                e.style.height = `${t}px`;
                            }
                        } else {
                            const t = Math.floor(this.thumbContainerHeight * this.thumbAspectRatio);
                            (e.style.height = `${this.thumbContainerHeight}px`), (e.style.width = `${t}px`);
                        }
                        this.setThumbContainerPos();
                    }),
                    t(this, "setThumbContainerPos", () => {
                        const e = this.player.elements.progress.getBoundingClientRect(),
                            t = this.player.elements.container.getBoundingClientRect(),
                            { container: i } = this.elements.thumb,
                            s = t.left - e.left + 10,
                            n = t.right - e.left - i.clientWidth - 10,
                            a = this.mousePosX - e.left - i.clientWidth / 2,
                            r = Ze(a, s, n);
                        (i.style.left = `${r}px`), i.style.setProperty("--preview-arrow-offset", a - r + "px");
                    }),
                    t(this, "setScrubbingContainerSize", () => {
                        const { width: e, height: t } = tt(this.thumbAspectRatio, { width: this.player.media.clientWidth, height: this.player.media.clientHeight });
                        (this.elements.scrubbing.container.style.width = `${e}px`), (this.elements.scrubbing.container.style.height = `${t}px`);
                    }),
                    t(this, "setImageSizeAndOffset", (e, t) => {
                        if (!this.usingSprites) return;
                        const i = this.thumbContainerHeight / t.h;
                        (e.style.height = e.naturalHeight * i + "px"), (e.style.width = e.naturalWidth * i + "px"), (e.style.left = `-${t.x * i}px`), (e.style.top = `-${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();
            }
            get enabled() {
                return this.player.isHTML5 && this.player.isVideo && this.player.config.posterThumbnails.enabled;
            }
            get currentImageContainer() {
                return this.mouseDown ? this.elements.scrubbing.container : this.elements.thumb.imageContainer;
            }
            get usingSprites() {
                return Object.keys(this.thumbnails[0].frames[0]).includes("w");
            }
            get thumbAspectRatio() {
                return this.usingSprites ? this.thumbnails[0].frames[0].w / this.thumbnails[0].frames[0].h : this.thumbnails[0].width / this.thumbnails[0].height;
            }
            get thumbContainerHeight() {
                if (this.mouseDown) {
                    const { height: e } = tt(this.thumbAspectRatio, { width: this.player.media.clientWidth, height: this.player.media.clientHeight });
                    return e;
                }
                return this.sizeSpecifiedInCSS ? this.elements.thumb.imageContainer.clientHeight : Math.floor(this.player.media.clientWidth / this.thumbAspectRatio / 4);
            }
            get currentImageElement() {
                return this.mouseDown ? this.currentScrubbingImageElement : this.currentThumbnailImageElement;
            }
            set currentImageElement(e) {
                this.mouseDown ? (this.currentScrubbingImageElement = e) : (this.currentThumbnailImageElement = e);
            }
        }
        const st = {
            insertElements(e, t) {
                A.string(t)
                    ? $(e, this.media, { src: t })
                    : A.array(t) &&
                    t.forEach((t) => {
                        $(e, this.media, t);
                    });
            },
            change(e) {
                L(e, "sources.length")
                    ? (me.cancelRequests.call(this),
                        this.destroy.call(
                            this,
                            () => {
                                (this.options.quality = []), j(this.media), (this.media = null), A.element(this.elements.container) && this.elements.container.removeAttribute("class");
                                const { sources: t, type: i } = e,
                                    [{ provider: s = $e.html5, src: n }] = t,
                                    a = "html5" === s ? i : "div",
                                    r = "html5" === s ? {} : { src: n };
                                Object.assign(this, { provider: s, type: i, supported: Y.check(i, s, this.config.playsinline), media: O(a, r) }),
                                    this.elements.container.appendChild(this.media),
                                    A.boolean(e.autoplay) && (this.config.autoplay = e.autoplay),
                                    this.isHTML5 &&
                                    (this.config.crossorigin && this.media.setAttribute("crossorigin", ""),
                                        this.config.autoplay && this.media.setAttribute("autoplay", ""),
                                        A.empty(e.poster) || (this.poster = e.poster),
                                        this.config.loop.active && this.media.setAttribute("loop", ""),
                                        this.config.muted && this.media.setAttribute("muted", ""),
                                        this.config.playsinline && this.media.setAttribute("playsinline", "")),
                                    Ue.addStyleHook.call(this),
                                    this.isHTML5 && st.insertElements.call(this, "source", t),
                                    (this.config.title = e.title),
                                    Je.setup.call(this),
                                    this.isHTML5 && Object.keys(e).includes("tracks") && st.insertElements.call(this, "track", e.tracks),
                                    (this.isHTML5 || (this.isEmbed && !this.supported.ui)) && Ue.build.call(this),
                                    this.isHTML5 && this.media.load(),
                                    A.empty(e.posterThumbnails) ||
                                    (Object.assign(this.config.posterThumbnails, e.posterThumbnails),
                                        this.posterThumbnails && this.posterThumbnails.loaded && (this.posterThumbnails.destroy(), (this.posterThumbnails = null)),
                                        this.config.posterThumbnails.enabled && (this.posterThumbnails = new it(this))),
                                    this.fullscreen.update();
                            },
                            !0
                        ))
                    : this.debug.warn("Invalid source format");
            },
        };
        class nt {
            constructor(e, i) {
                if (
                    (t(this, "play", () => (A.function(this.media.play) ? (this.ads && this.ads.enabled && this.ads.managerPromise.then(() => this.ads.play()).catch(() => se(this.media.play())), this.media.play()) : null)),
                        t(this, "pause", () => (this.playing && A.function(this.media.pause) ? this.media.pause() : null)),
                        t(this, "togglePlay", (e) => ((A.boolean(e) ? e : !this.playing) ? this.play() : this.pause())),
                        t(this, "stop", () => {
                            this.isHTML5 ? (this.pause(), this.restart()) : A.function(this.media.stop) && this.media.stop();
                        }),
                        t(this, "restart", () => {
                            this.currentTime = 0;
                        }),
                        t(this, "rewind", (e) => {
                            this.currentTime -= A.number(e) ? e : this.config.seekTime;
                        }),
                        t(this, "forward", (e) => {
                            this.currentTime += A.number(e) ? e : this.config.seekTime;
                        }),
                        t(this, "increaseVolume", (e) => {
                            const t = this.media.muted ? 0 : this.volume;
                            this.volume = t + (A.number(e) ? e : 0);
                        }),
                        t(this, "decreaseVolume", (e) => {
                            this.increaseVolume(-e);
                        }),
                        t(this, "airplay", () => {
                            Y.airplay && this.media.webkitShowPlaybackTargetPicker();
                        }),
                        t(this, "toggleControls", (e) => {
                            if (this.supported.ui && !this.isAudio) {
                                const t = U(this.elements.container, this.config.classNames.hideControls),
                                    i = void 0 === e ? void 0 : !e,
                                    s = F(this.elements.container, this.config.classNames.hideControls, i);
                                if ((s && A.array(this.config.controls) && this.config.controls.includes("settings") && !A.empty(this.config.settings) && Me.toggleMenu.call(this, !1), s !== t)) {
                                    const e = s ? "controlshidden" : "controlsshown";
                                    ee.call(this, this.media, e);
                                }
                                return !s;
                            }
                            return !1;
                        }),
                        t(this, "on", (e, t) => {
                            J.call(this, this.elements.container, e, t);
                        }),
                        t(this, "once", (e, t) => {
                            Z.call(this, this.elements.container, e, t);
                        }),
                        t(this, "off", (e, t) => {
                            G(this.elements.container, e, t);
                        }),
                        t(this, "destroy", (e, t = !1) => {
                            if (!this.ready) return;
                            const i = () => {
                                (document.body.style.overflow = ""),
                                    (this.embed = null),
                                    t
                                        ? (Object.keys(this.elements).length &&
                                            (j(this.elements.buttons.play),
                                                j(this.elements.captions),
                                                j(this.elements.controls),
                                                j(this.elements.wrapper),
                                                (this.elements.buttons.play = null),
                                                (this.elements.captions = null),
                                                (this.elements.controls = null),
                                                (this.elements.wrapper = null)),
                                            A.function(e) && e())
                                        : (te.call(this),
                                            me.cancelRequests.call(this),
                                            D(this.elements.original, this.elements.container),
                                            ee.call(this, this.elements.original, "destroyed", !0),
                                            A.function(e) && e.call(this.elements.original),
                                            (this.ready = !1),
                                            setTimeout(() => {
                                                (this.elements = null), (this.media = null);
                                            }, 200));
                            };
                            this.stop(),
                                clearTimeout(this.timers.loading),
                                clearTimeout(this.timers.controls),
                                clearTimeout(this.timers.resized),
                                this.isHTML5
                                    ? (Ue.toggleNativeControls.call(this, !0), i())
                                    : this.isYouTube
                                        ? (clearInterval(this.timers.buffering), clearInterval(this.timers.playing), null !== this.embed && A.function(this.embed.destroy) && this.embed.destroy(), i())
                                        : this.isVimeo && (null !== this.embed && this.embed.unload().then(i), setTimeout(i, 200));
                        }),
                        t(this, "supports", (e) => Y.mime.call(this, e)),
                        (this.timers = {}),
                        (this.ready = !1),
                        (this.loading = !1),
                        (this.failed = !1),
                        (this.touch = Y.touch),
                        (this.media = e),
                        A.string(this.media) && (this.media = document.querySelectorAll(this.media)),
                        ((window.jQuery && this.media instanceof jQuery) || A.nodeList(this.media) || A.array(this.media)) && (this.media = this.media[0]),
                        (this.config = N(
                            {},
                            _e,
                            nt.defaults,
                            i || {},
                            (() => {
                                try {
                                    return JSON.parse(this.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 qe(this.config.debug)),
                        this.debug.log("Config", this.config),
                        this.debug.log("Support", Y),
                        A.nullOrUndefined(this.media) || !A.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 (!Y.check().api) return void this.debug.error("Setup failed: no support");
                const s = this.media.cloneNode(!0);
                (s.autoplay = !1), (this.elements.original = s);
                const n = this.media.tagName.toLowerCase();
                let a = null,
                    r = null;
                switch (n) {
                    case "div":
                        if (((a = this.media.querySelector("iframe")), A.element(a))) {
                            if (
                                ((r = xe(a.getAttribute("src"))),
                                    (this.provider = (function (e) {
                                        return /^(https?:\/\/)?(www\.)?(youtube\.com|youtube-nocookie\.com|youtu\.?be)\/.+$/.test(e) ? $e.youtube : /^https?:\/\/player.vimeo.com\/video\/\d{0,9}(?=\b|\/)/.test(e) ? $e.vimeo : null;
                                    })(r.toString())),
                                    (this.elements.container = this.media),
                                    (this.media = a),
                                    (this.elements.container.className = ""),
                                    r.search.length)
                            ) {
                                const e = ["1", "true"];
                                e.includes(r.searchParams.get("autoplay")) && (this.config.autoplay = !0),
                                    e.includes(r.searchParams.get("loop")) && (this.config.loop.active = !0),
                                    this.isYouTube ? ((this.config.playsinline = e.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 (A.empty(this.provider) || !Object.values($e).includes(this.provider)) return void this.debug.error("Setup failed: Invalid provider");
                        this.type = Re;
                        break;
                    case "video":
                    case "audio":
                        (this.type = n),
                            (this.provider = $e.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 = Y.check(this.type, this.provider)),
                    this.supported.api
                        ? ((this.eventListeners = []),
                            (this.listeners = new Ve(this)),
                            (this.storage = new Te(this)),
                            (this.media.plyr = this),
                            A.element(this.elements.container) || ((this.elements.container = O("div")), _(this.media, this.elements.container)),
                            Ue.migrateStyles.call(this),
                            Ue.addStyleHook.call(this),
                            Je.setup.call(this),
                            this.config.debug &&
                            J.call(this, this.elements.container, this.config.events.join(" "), (e) => {
                                this.debug.log(`event: ${e.type}`);
                            }),
                            (this.fullscreen = new He(this)),
                            (this.isHTML5 || (this.isEmbed && !this.supported.ui)) && Ue.build.call(this),
                            this.listeners.container(),
                            this.listeners.global(),
                            this.config.ads.enabled && (this.ads = new Ge(this)),
                            this.isHTML5 && this.config.autoplay && this.once("canplay", () => se(this.play())),
                            (this.lastSeekTime = 0),
                            this.config.posterThumbnails.enabled && (this.posterThumbnails = new it(this)))
                        : this.debug.error("Setup failed: no support");
            }
            get isHTML5() {
                return this.provider === $e.html5;
            }
            get isEmbed() {
                return this.isYouTube || this.isVimeo;
            }
            get isYouTube() {
                return this.provider === $e.youtube;
            }
            get isVimeo() {
                return this.provider === $e.vimeo;
            }
            get isVideo() {
                return this.type === Re;
            }
            get isAudio() {
                return this.type === je;
            }
            get playing() {
                return Boolean(this.ready && !this.paused && !this.ended);
            }
            get paused() {
                return Boolean(this.media.paused);
            }
            get stopped() {
                return Boolean(this.paused && 0 === this.currentTime);
            }
            get ended() {
                return Boolean(this.media.ended);
            }
            set currentTime(e) {
                if (!this.duration) return;
                const t = A.number(e) && e > 0;
                (this.media.currentTime = t ? Math.min(e, this.duration) : 0), this.debug.log(`Seeking to ${this.currentTime} seconds`);
            }
            get currentTime() {
                return Number(this.media.currentTime);
            }
            get buffered() {
                const { buffered: e } = this.media;
                return A.number(e) ? e : e && e.length && this.duration > 0 ? e.end(0) / this.duration : 0;
            }
            get seeking() {
                return Boolean(this.media.seeking);
            }
            get duration() {
                const e = parseFloat(this.config.duration),
                    t = (this.media || {}).duration,
                    i = A.number(t) && t !== 1 / 0 ? t : 0;
                return e || i;
            }
            set volume(e) {
                let t = e;
                A.string(t) && (t = Number(t)),
                    A.number(t) || (t = this.storage.get("volume")),
                    A.number(t) || ({ volume: t } = this.config),
                    t > 1 && (t = 1),
                    t < 0 && (t = 0),
                    (this.config.volume = t),
                    (this.media.volume = t),
                    !A.empty(e) && this.muted && t > 0 && (this.muted = !1);
            }
            get volume() {
                return Number(this.media.volume);
            }
            set muted(e) {
                let t = e;
                A.boolean(t) || (t = this.storage.get("muted")), A.boolean(t) || (t = this.config.muted), (this.config.muted = t), (this.media.muted = t);
            }
            get muted() {
                return Boolean(this.media.muted);
            }
            get hasAudio() {
                return !this.isHTML5 || !!this.isAudio || Boolean(this.media.mozHasAudio) || Boolean(this.media.webkitAudioDecodedByteCount) || Boolean(this.media.audioTracks && this.media.audioTracks.length);
            }
            set speed(e) {
                let t = null;
                A.number(e) && (t = e), A.number(t) || (t = this.storage.get("speed")), A.number(t) || (t = this.config.speed.selected);
                const { minimumSpeed: i, maximumSpeed: s } = this;
                (t = Ze(t, i, s)),
                    (this.config.speed.selected = t),
                    setTimeout(() => {
                        this.media && (this.media.playbackRate = t);
                    }, 0);
            }
            get speed() {
                return Number(this.media.playbackRate);
            }
            get minimumSpeed() {
                return this.isYouTube ? Math.min(...this.options.speed) : this.isVimeo ? 0.5 : 0.0625;
            }
            get maximumSpeed() {
                return this.isYouTube ? Math.max(...this.options.speed) : this.isVimeo ? 2 : 16;
            }
            set quality(e) {
                const t = this.config.quality,
                    i = this.options.quality;
                if (!i.length) return;
                let s = [!A.empty(e) && Number(e), this.storage.get("quality"), t.selected, t.default].find(A.number),
                    n = !0;
                if (!i.includes(s)) {
                    const e = ae(i, s);
                    this.debug.warn(`Unsupported quality option: ${s}, using ${e} instead`), (s = e), (n = !1);
                }
                (t.selected = s), (this.media.quality = s), n && this.storage.set({ quality: s });
            }
            get quality() {
                return this.media.quality;
            }
            set loop(e) {
                const t = A.boolean(e) ? e : this.config.loop.active;
                (this.config.loop.active = t), (this.media.loop = t);
            }
            get loop() {
                return Boolean(this.media.loop);
            }
            set source(e) {
                st.change.call(this, e);
            }
            get source() {
                return this.media.currentSrc;
            }
            get download() {
                const { download: e } = this.config.urls;
                return A.url(e) ? e : this.source;
            }
            set download(e) {
                A.url(e) && ((this.config.urls.download = e), Me.setDownloadUrl.call(this));
            }
            set poster(e) {
                this.isVideo ? Ue.setPoster.call(this, e, !1).catch(() => { }) : this.debug.warn("Poster can only be set for video");
            }
            get poster() {
                return this.isVideo ? this.media.getAttribute("poster") || this.media.getAttribute("data-poster") : null;
            }
            get ratio() {
                if (!this.isVideo) return null;
                const e = ce(ue.call(this));
                return A.array(e) ? e.join(":") : e;
            }
            set ratio(e) {
                this.isVideo ? (A.string(e) && le(e) ? ((this.config.ratio = ce(e)), he.call(this)) : this.debug.error(`Invalid aspect ratio specified (${e})`)) : this.debug.warn("Aspect ratio can only be set for video");
            }
            set autoplay(e) {
                this.config.autoplay = A.boolean(e) ? e : this.config.autoplay;
            }
            get autoplay() {
                return Boolean(this.config.autoplay);
            }
            toggleCaptions(e) {
                Ne.toggle.call(this, e, !1);
            }
            set currentTrack(e) {
                Ne.set.call(this, e, !1), Ne.setup.call(this);
            }
            get currentTrack() {
                const { toggled: e, currentTrack: t } = this.captions;
                return e ? t : -1;
            }
            set language(e) {
                Ne.setLanguage.call(this, e, !1);
            }
            get language() {
                return (Ne.getCurrentTrack.call(this) || {}).language;
            }
            set pip(e) {
                if (!Y.pip) return;
                const t = A.boolean(e) ? e : !this.pip;
                A.function(this.media.webkitSetPresentationMode) && this.media.webkitSetPresentationMode(t ? Ie : Oe),
                    A.function(this.media.requestPictureInPicture) && (!this.pip && t ? this.media.requestPictureInPicture() : this.pip && !t && document.exitPictureInPicture());
            }
            get pip() {
                return Y.pip ? (A.empty(this.media.webkitPresentationMode) ? this.media === document.pictureInPictureElement : this.media.webkitPresentationMode === Ie) : null;
            }
            setposterThumbnails(e) {
                this.posterThumbnails && this.posterThumbnails.loaded && (this.posterThumbnails.destroy(), (this.posterThumbnails = null)),
                    Object.assign(this.config.posterThumbnails, e),
                    this.config.posterThumbnails.enabled && (this.posterThumbnails = new it(this));
            }
            static supported(e, t) {
                return Y.check(e, t);
            }
            static loadSprite(e, t) {
                return Ee(e, t);
            }
            static setup(e, t = {}) {
                let i = null;
                return A.string(e) ? (i = Array.from(document.querySelectorAll(e))) : A.nodeList(e) ? (i = Array.from(e)) : A.array(e) && (i = e.filter(A.element)), A.empty(i) ? null : i.map((e) => new nt(e, t));
            }
        }
        var at;
        return (nt.defaults = ((at = _e), JSON.parse(JSON.stringify(at)))), nt;
    });