@videojs/html 10.0.0-beta.2 → 10.0.0-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cdn/audio-minimal.dev.js +25 -39
- package/cdn/audio-minimal.dev.js.map +1 -1
- package/cdn/audio-minimal.js +4 -4
- package/cdn/audio-minimal.js.map +1 -1
- package/cdn/audio.css +1 -1
- package/cdn/audio.dev.js +26 -40
- package/cdn/audio.dev.js.map +1 -1
- package/cdn/audio.js +4 -4
- package/cdn/audio.js.map +1 -1
- package/cdn/background.dev.js +13 -7
- package/cdn/background.dev.js.map +1 -1
- package/cdn/background.js +4 -4
- package/cdn/background.js.map +1 -1
- package/cdn/video-minimal.css +1 -1
- package/cdn/video-minimal.dev.js +26 -52
- package/cdn/video-minimal.dev.js.map +1 -1
- package/cdn/video-minimal.js +5 -5
- package/cdn/video-minimal.js.map +1 -1
- package/cdn/video.css +1 -1
- package/cdn/video.dev.js +27 -53
- package/cdn/video.dev.js.map +1 -1
- package/cdn/video.js +5 -5
- package/cdn/video.js.map +1 -1
- package/dist/default/_virtual/inline-css_src/define/audio/skin.js +1 -1
- package/dist/default/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
- package/dist/default/_virtual/inline-css_src/define/base.js +6 -0
- package/dist/default/_virtual/inline-css_src/define/base.js.map +1 -0
- package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
- package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
- package/dist/default/_virtual/inline-css_src/define/video/skin.js +1 -1
- package/dist/default/_virtual/inline-css_src/define/video/skin.js.map +1 -1
- package/dist/default/define/audio/skin.css +2 -0
- package/dist/default/define/base.css +25 -0
- package/dist/default/define/skin-mixin.js +10 -18
- package/dist/default/define/skin-mixin.js.map +1 -1
- package/dist/default/define/video/minimal-skin.css +1 -64
- package/dist/default/define/video/minimal-skin.js.map +1 -1
- package/dist/default/define/video/minimal-skin.tailwind.js +1 -2
- package/dist/default/define/video/minimal-skin.tailwind.js.map +1 -1
- package/dist/default/define/video/skin.css +3 -64
- package/dist/default/define/video/skin.js +1 -1
- package/dist/default/define/video/skin.js.map +1 -1
- package/dist/default/define/video/skin.tailwind.js +2 -2
- package/dist/default/define/video/skin.tailwind.js.map +1 -1
- package/dist/default/skins/dist/default/default/tailwind/components/root.js +1 -1
- package/dist/default/skins/dist/default/default/tailwind/components/root.js.map +1 -1
- package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js +1 -1
- package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -1
- package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js +0 -1
- package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -1
- package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js +0 -1
- package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -1
- package/dist/dev/_virtual/inline-css_src/define/audio/skin.js +1 -1
- package/dist/dev/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
- package/dist/dev/_virtual/inline-css_src/define/base.js +6 -0
- package/dist/dev/_virtual/inline-css_src/define/base.js.map +1 -0
- package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
- package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
- package/dist/dev/_virtual/inline-css_src/define/video/skin.js +1 -1
- package/dist/dev/_virtual/inline-css_src/define/video/skin.js.map +1 -1
- package/dist/dev/define/audio/skin.css +2 -0
- package/dist/dev/define/base.css +25 -0
- package/dist/dev/define/skin-mixin.d.ts +2 -2
- package/dist/dev/define/skin-mixin.d.ts.map +1 -1
- package/dist/dev/define/skin-mixin.js +10 -32
- package/dist/dev/define/skin-mixin.js.map +1 -1
- package/dist/dev/define/video/minimal-skin.css +1 -64
- package/dist/dev/define/video/minimal-skin.d.ts.map +1 -1
- package/dist/dev/define/video/minimal-skin.js +0 -12
- package/dist/dev/define/video/minimal-skin.js.map +1 -1
- package/dist/dev/define/video/minimal-skin.tailwind.d.ts.map +1 -1
- package/dist/dev/define/video/minimal-skin.tailwind.js +0 -13
- package/dist/dev/define/video/minimal-skin.tailwind.js.map +1 -1
- package/dist/dev/define/video/skin.css +3 -64
- package/dist/dev/define/video/skin.d.ts.map +1 -1
- package/dist/dev/define/video/skin.js +1 -13
- package/dist/dev/define/video/skin.js.map +1 -1
- package/dist/dev/define/video/skin.tailwind.d.ts.map +1 -1
- package/dist/dev/define/video/skin.tailwind.js +1 -13
- package/dist/dev/define/video/skin.tailwind.js.map +1 -1
- package/dist/dev/skins/dist/default/default/tailwind/components/root.js +1 -1
- package/dist/dev/skins/dist/default/default/tailwind/components/root.js.map +1 -1
- package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js +1 -1
- package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -1
- package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js +0 -1
- package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -1
- package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js +0 -1
- package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -1
- package/package.json +8 -8
- package/dist/default/skins/dist/default/minimal/tailwind/components/error.js +0 -15
- package/dist/default/skins/dist/default/minimal/tailwind/components/error.js.map +0 -1
- package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js +0 -15
- package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js.map +0 -1
package/cdn/background.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"background.js","names":["#base","#keys","#current","#markPending","#listeners","#pending","s","s","t","t","createContext","ContextConsumer","#contextStore","#attachMedia","#observer","#onSlotChange","#detach","#getSlottedMedia","#destroyed","#trackedControllers","#updatePromise","#instanceProperties","#controllers","#changedProperties","#enqueueUpdate","ContextProvider","#store","#provider","#host","#state","#selector","#cached","#subscribe","#unsubscribe","#onAvailable","#directStore","#consumer","ContextConsumer","#host","#selector","#accessor","#connect","#snapshot","#host","#selector","#consumer","ContextConsumer","#connect","#store"],"sources":["../../store/dist/default/core/abort-controller-registry.js","../../store/dist/default/core/combine.js","../../store/dist/default/core/errors.js","../../utils/dist/predicate/predicate.js","../../utils/dist/object/pick.js","../../store/dist/default/core/selector.js","../../store/dist/default/core/shallow-equal.js","../../store/dist/default/core/slice.js","../../utils/dist/function/noop.js","../../store/dist/default/core/state.js","../../store/dist/default/core/store.js","../../core/dist/default/dom/feature.js","../../utils/dist/dom/attributes.js","../../utils/dist/dom/event.js","../../utils/dist/dom/listen.js","../../utils/dist/dom/text-track.js","../../utils/dist/dom/time-ranges.js","../../core/dist/default/dom/store/features/buffer.js","../../core/dist/default/dom/store/features/controls.js","../../core/dist/default/dom/store/features/error.js","../../core/dist/default/dom/presentation/fullscreen.js","../../core/dist/default/dom/presentation/pip.js","../../core/dist/default/dom/store/features/fullscreen.js","../../core/dist/default/dom/store/features/pip.js","../../core/dist/default/dom/store/features/playback.js","../../core/dist/default/dom/store/features/playback-rate.js","../../core/dist/default/dom/store/features/source.js","../../core/dist/default/dom/store/features/text-track.js","../../core/dist/default/dom/media/predicate.js","../../core/dist/default/dom/store/signal-keys.js","../../core/dist/default/dom/store/features/time.js","../../core/dist/default/dom/store/features/volume.js","../../core/dist/default/dom/store/features/presets.js","../../core/dist/default/dom/store/selectors.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/context-request-event.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/create-context.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/controllers/context-consumer.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/value-notifier.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/controllers/context-provider.js","../src/player/context.ts","../src/store/container-mixin.ts","../../element/dist/default/destroy-mixin.js","../../element/dist/default/reactive-element.js","../src/ui/media-element.ts","../src/media/container-element.ts","../src/store/provider-mixin.ts","../../store/dist/default/html/controllers/snapshot-controller.js","../../store/dist/default/html/store-accessor.js","../../store/dist/default/html/controllers/store-controller.js","../src/player/player-controller.ts","../src/player/create-player.ts","../src/define/safe-define.ts","../src/define/background/player.ts","../src/define/background/skin.ts"],"sourcesContent":["//#region src/core/abort-controller-registry.ts\nvar AbortControllerRegistry = class {\n\t#base = new AbortController();\n\t#keys = /* @__PURE__ */ new Map();\n\t/** The attach-scoped signal. Aborts on detach or reattach. */\n\tget base() {\n\t\treturn this.#base.signal;\n\t}\n\t/** Clears all keyed signals, leaving base intact. */\n\tclear() {\n\t\tfor (const controller of this.#keys.values()) controller.abort();\n\t\tthis.#keys.clear();\n\t}\n\t/** Resets base and clears all keyed signals. */\n\treset() {\n\t\tthis.clear();\n\t\tthis.#base.abort();\n\t\tthis.#base = new AbortController();\n\t}\n\t/** Creates a new signal for the key, superseding any previous signal. */\n\tsupersede(key) {\n\t\tthis.#keys.get(key)?.abort();\n\t\tconst controller = new AbortController();\n\t\tthis.#keys.set(key, controller);\n\t\treturn AbortSignal.any([this.#base.signal, controller.signal]);\n\t}\n};\n\n//#endregion\nexport { AbortControllerRegistry };\n//# sourceMappingURL=abort-controller-registry.js.map","//#region src/core/combine.ts\n/**\n* Combines multiple slices into a single slice.\n*\n* @param slices - The slices to combine.\n* @returns A new slice that represents the combination of the input slices.\n*/\nfunction combine(...slices) {\n\treturn {\n\t\tstate: (ctx) => {\n\t\t\tconst states = slices.map((slice) => slice.state(ctx));\n\t\t\treturn Object.assign({}, ...states);\n\t\t},\n\t\tattach: (ctx) => {\n\t\t\tfor (const slice of slices) try {\n\t\t\t\tslice.attach?.(ctx);\n\t\t\t} catch (err) {\n\t\t\t\tctx.reportError(err);\n\t\t\t}\n\t\t}\n\t};\n}\n\n//#endregion\nexport { combine };\n//# sourceMappingURL=combine.js.map","//#region src/core/errors.ts\nvar StoreError = class extends Error {\n\tcode;\n\tcause;\n\tconstructor(code, options) {\n\t\tsuper(options?.message ?? code);\n\t\tthis.name = \"StoreError\";\n\t\tthis.code = code;\n\t\tthis.cause = options?.cause;\n\t}\n};\nfunction isStoreError(error) {\n\treturn error instanceof StoreError;\n}\nfunction throwNoTargetError() {\n\tthrow new StoreError(\"NO_TARGET\");\n}\nfunction throwDestroyedError() {\n\tthrow new StoreError(\"DESTROYED\");\n}\n\n//#endregion\nexport { StoreError, isStoreError, throwDestroyedError, throwNoTargetError };\n//# sourceMappingURL=errors.js.map","//#region src/predicate/predicate.ts\nfunction isString(value) {\n\treturn typeof value === \"string\";\n}\nfunction isNumber(value) {\n\treturn typeof value === \"number\";\n}\nfunction isBoolean(value) {\n\treturn typeof value === \"boolean\";\n}\nfunction isFunction(value) {\n\treturn typeof value === \"function\";\n}\nfunction isNull(value) {\n\treturn value === null;\n}\nfunction isUndefined(value) {\n\treturn typeof value === \"undefined\";\n}\nfunction isNil(value) {\n\treturn value == null;\n}\nfunction isPromise(value) {\n\treturn value instanceof Promise;\n}\n/**\n* Check if a value is an object, excluding null.\n*/\nfunction isObject(value) {\n\treturn value !== null && typeof value === \"object\";\n}\n/**\n* Check if a value is a plain object (not a class instance like Date, Map, etc).\n*/\nfunction isPlainObject(value) {\n\tif (!isObject(value)) return false;\n\tconst proto = Object.getPrototypeOf(value);\n\treturn proto === null || proto === Object.prototype;\n}\n/**\n* Check if a value is an AbortError.\n*/\nfunction isAbortError(value) {\n\treturn value instanceof Error && value.name === \"AbortError\";\n}\n\n//#endregion\nexport { isAbortError, isBoolean, isFunction, isNil, isNull, isNumber, isObject, isPlainObject, isPromise, isString, isUndefined };\n//# sourceMappingURL=predicate.js.map","//#region src/object/pick.ts\n/**\n* Creates a new object with only the specified keys.\n*\n* @example\n* const obj = { a: 1, b: 2, c: 3 };\n* pick(obj, ['a', 'c']); // { a: 1, c: 3 }\n*/\nfunction pick(obj, keys) {\n\tconst result = {};\n\tfor (const key of keys) result[key] = obj[key];\n\treturn result;\n}\n\n//#endregion\nexport { pick };\n//# sourceMappingURL=pick.js.map","import { AbortControllerRegistry } from \"./abort-controller-registry.js\";\nimport { throwNoTargetError } from \"./errors.js\";\nimport { pick } from \"@videojs/utils/object\";\n\n//#region src/core/selector.ts\nconst stateContext = {\n\ttarget: throwNoTargetError,\n\tsignals: new AbortControllerRegistry(),\n\tset: throwNoTargetError\n};\n/**\n* Create a type-safe selector for a slice's state.\n*\n* The selector returns the slice's state, or `undefined` if the slice\n* is not configured in the store.\n*\n* @example\n* ```ts\n* const selectPlayback = createSelector(playbackSlice);\n* selectPlayback(store.state); // { paused, play, pause, ... } | undefined\n* selectPlayback.displayName; // 'playback' (from slice name)\n* ```\n*\n* @param slice - The slice to create a selector for.\n*/\nfunction createSelector(slice) {\n\tconst initialState = slice.state(stateContext);\n\tconst keys = Object.keys(initialState);\n\tconst firstKey = keys[0];\n\tif (!firstKey) return Object.assign(() => void 0, { displayName: slice.name });\n\treturn Object.assign((state) => {\n\t\tif (!(firstKey in state)) return void 0;\n\t\treturn pick(state, keys);\n\t}, { displayName: slice.name });\n}\n\n//#endregion\nexport { createSelector };\n//# sourceMappingURL=selector.js.map","//#region src/core/shallow-equal.ts\nconst hasOwn = Object.prototype.hasOwnProperty;\nfunction shallowEqual(a, b) {\n\tif (Object.is(a, b)) return true;\n\tif (typeof a !== \"object\" || a === null || typeof b !== \"object\" || b === null) return false;\n\tconst keysA = Object.keys(a);\n\tconst keysB = Object.keys(b);\n\tif (keysA.length !== keysB.length) return false;\n\tfor (const key of keysA) if (!hasOwn.call(b, key) || !Object.is(a[key], b[key])) return false;\n\treturn true;\n}\n\n//#endregion\nexport { shallowEqual };\n//# sourceMappingURL=shallow-equal.js.map","//#region src/core/slice.ts\nfunction defineSlice() {\n\treturn (config) => config;\n}\n\n//#endregion\nexport { defineSlice };\n//# sourceMappingURL=slice.js.map","//#region src/function/noop.ts\nfunction noop(..._args) {}\n\n//#endregion\nexport { noop };\n//# sourceMappingURL=noop.js.map","import { noop } from \"@videojs/utils/function\";\n\n//#region src/core/state.ts\nlet isFlushScheduled = false;\nfunction scheduleFlush() {\n\tif (isFlushScheduled) return;\n\tisFlushScheduled = true;\n\tqueueMicrotask(flush);\n}\nconst pendingContainers = /* @__PURE__ */ new Set();\nfunction flush() {\n\tisFlushScheduled = false;\n\tfor (const container of pendingContainers) container.flush();\n\tpendingContainers.clear();\n}\nconst hasOwnProp = Object.prototype.hasOwnProperty;\nvar StateContainer = class {\n\t#current;\n\t#listeners = /* @__PURE__ */ new Set();\n\t#pending = false;\n\tconstructor(initial) {\n\t\tthis.#current = Object.freeze({ ...initial });\n\t}\n\tget current() {\n\t\treturn this.#current;\n\t}\n\tpatch(partial) {\n\t\tconst next = { ...this.#current };\n\t\tlet changed = false;\n\t\tfor (const key in partial) {\n\t\t\tif (!hasOwnProp.call(partial, key)) continue;\n\t\t\tconst value = partial[key];\n\t\t\tif (!Object.is(this.#current[key], value)) {\n\t\t\t\tnext[key] = value;\n\t\t\t\tchanged = true;\n\t\t\t}\n\t\t}\n\t\tif (changed) {\n\t\t\tthis.#current = Object.freeze(next);\n\t\t\tthis.#markPending();\n\t\t}\n\t}\n\tsubscribe(callback, options) {\n\t\tconst signal = options?.signal;\n\t\tif (signal?.aborted) return noop;\n\t\tthis.#listeners.add(callback);\n\t\tif (!signal) return () => this.#listeners.delete(callback);\n\t\tconst onAbort = () => this.#listeners.delete(callback);\n\t\tsignal.addEventListener(\"abort\", onAbort, { once: true });\n\t\treturn () => {\n\t\t\tsignal.removeEventListener(\"abort\", onAbort);\n\t\t\tthis.#listeners.delete(callback);\n\t\t};\n\t}\n\tflush() {\n\t\tif (!this.#pending) return;\n\t\tthis.#pending = false;\n\t\tfor (const fn of this.#listeners) fn();\n\t}\n\t#markPending() {\n\t\tthis.#pending = true;\n\t\tpendingContainers.add(this);\n\t\tscheduleFlush();\n\t}\n};\nfunction createState(initial) {\n\treturn new StateContainer(initial);\n}\nfunction isState(value) {\n\treturn value instanceof StateContainer;\n}\n\n//#endregion\nexport { createState, flush, isState };\n//# sourceMappingURL=state.js.map","import { AbortControllerRegistry } from \"./abort-controller-registry.js\";\nimport { throwDestroyedError, throwNoTargetError } from \"./errors.js\";\nimport { createState } from \"./state.js\";\nimport { isNull, isObject } from \"@videojs/utils/predicate\";\n\n//#region src/core/store.ts\nconst STORE_SYMBOL = Symbol(\"@videojs/store\");\nfunction createStore() {\n\treturn (slice, options = {}) => {\n\t\tlet target = null;\n\t\tlet destroyed = false;\n\t\tconst setupAbort = new AbortController();\n\t\tconst signals = new AbortControllerRegistry();\n\t\tlet state;\n\t\tfunction validate() {\n\t\t\tif (destroyed) throwDestroyedError();\n\t\t\tif (!target) throwNoTargetError();\n\t\t}\n\t\tconst initialState = slice.state({\n\t\t\ttarget: () => {\n\t\t\t\tvalidate();\n\t\t\t\treturn target;\n\t\t\t},\n\t\t\tsignals,\n\t\t\tset: (partial) => state.patch(partial)\n\t\t});\n\t\tstate = createState(initialState);\n\t\tconst store = {\n\t\t\t[STORE_SYMBOL]: true,\n\t\t\tget $state() {\n\t\t\t\treturn state;\n\t\t\t},\n\t\t\tget target() {\n\t\t\t\treturn target;\n\t\t\t},\n\t\t\tget destroyed() {\n\t\t\t\treturn destroyed;\n\t\t\t},\n\t\t\tget state() {\n\t\t\t\treturn state.current;\n\t\t\t},\n\t\t\tattach,\n\t\t\tdestroy,\n\t\t\tsubscribe\n\t\t};\n\t\tfor (const key of Object.keys(initialState)) Object.defineProperty(store, key, {\n\t\t\tget: () => state.current[key],\n\t\t\tenumerable: true\n\t\t});\n\t\ttry {\n\t\t\toptions.onSetup?.({\n\t\t\t\tstore,\n\t\t\t\tsignal: setupAbort.signal\n\t\t\t});\n\t\t} catch (error) {\n\t\t\treportError(error);\n\t\t}\n\t\treturn store;\n\t\tfunction attach(newTarget) {\n\t\t\tif (destroyed) throwDestroyedError();\n\t\t\tsignals.reset();\n\t\t\ttarget = newTarget;\n\t\t\tconst attachContext = {\n\t\t\t\ttarget: newTarget,\n\t\t\t\tsignal: signals.base,\n\t\t\t\tget: () => state.current,\n\t\t\t\tset: (partial) => state.patch(partial),\n\t\t\t\treportError,\n\t\t\t\tstore: {\n\t\t\t\t\tget state() {\n\t\t\t\t\t\treturn state.current;\n\t\t\t\t\t},\n\t\t\t\t\tsubscribe\n\t\t\t\t}\n\t\t\t};\n\t\t\ttry {\n\t\t\t\tslice.attach?.(attachContext);\n\t\t\t} catch (error) {\n\t\t\t\treportError(error);\n\t\t\t}\n\t\t\ttry {\n\t\t\t\toptions.onAttach?.({\n\t\t\t\t\tstore,\n\t\t\t\t\ttarget: newTarget,\n\t\t\t\t\tsignal: signals.base\n\t\t\t\t});\n\t\t\t} catch (error) {\n\t\t\t\treportError(error);\n\t\t\t}\n\t\t\treturn detach;\n\t\t}\n\t\tfunction detach() {\n\t\t\tif (isNull(target)) return;\n\t\t\tsignals.reset();\n\t\t\ttarget = null;\n\t\t\tstate.patch(initialState);\n\t\t}\n\t\tfunction destroy() {\n\t\t\tif (destroyed) return;\n\t\t\tdestroyed = true;\n\t\t\tdetach();\n\t\t\tsetupAbort.abort();\n\t\t}\n\t\tfunction subscribe(callback, options) {\n\t\t\treturn state.subscribe(callback, options);\n\t\t}\n\t\tfunction reportError(error) {\n\t\t\tif (options.onError) options.onError({\n\t\t\t\tstore,\n\t\t\t\terror\n\t\t\t});\n\t\t\telse console.error(\"[vjs-store]\", error);\n\t\t}\n\t};\n}\nfunction isStore(value) {\n\treturn isObject(value) && STORE_SYMBOL in value;\n}\n\n//#endregion\nexport { createStore, isStore };\n//# sourceMappingURL=store.js.map","import { defineSlice } from \"@videojs/store\";\n\n//#region src/dom/feature.ts\nconst definePlayerFeature = defineSlice();\n\n//#endregion\nexport { definePlayerFeature };\n//# sourceMappingURL=feature.js.map","//#region src/dom/attributes.ts\nfunction namedNodeMapToObject(namedNodeMap) {\n\tconst obj = {};\n\tfor (const attr of namedNodeMap) obj[attr.name] = attr.value;\n\treturn obj;\n}\n\n//#endregion\nexport { namedNodeMapToObject };\n//# sourceMappingURL=attributes.js.map","//#region src/dom/event.ts\nfunction onEvent(target, type, options) {\n\treturn new Promise((resolve, reject) => {\n\t\tconst handleAbort = () => {\n\t\t\treject(options?.signal?.reason ?? \"Aborted\");\n\t\t};\n\t\tif (options?.signal?.aborted) {\n\t\t\thandleAbort();\n\t\t\treturn;\n\t\t}\n\t\toptions?.signal?.addEventListener(\"abort\", handleAbort, { once: true });\n\t\ttarget.addEventListener(type, (event) => {\n\t\t\toptions?.signal?.removeEventListener(\"abort\", handleAbort);\n\t\t\tresolve(event);\n\t\t}, {\n\t\t\t...options,\n\t\t\tonce: true\n\t\t});\n\t});\n}\n\n//#endregion\nexport { onEvent };\n//# sourceMappingURL=event.js.map","//#region src/dom/listen.ts\nfunction listen(target, type, listener, options) {\n\ttarget.addEventListener(type, listener, options);\n\treturn () => target.removeEventListener(type, listener, options);\n}\n\n//#endregion\nexport { listen };\n//# sourceMappingURL=listen.js.map","//#region src/dom/text-track.ts\n/** Find the `<track>` element that owns the given `TextTrack`. */\nfunction findTrackElement(media, track) {\n\tfor (const el of media.querySelectorAll(\"track\")) if (el.track === track) return el;\n\treturn null;\n}\nfunction getTextTrackList(media, filterPred) {\n\tif (!media?.textTracks) return [];\n\treturn Array.from(media.textTracks).filter(filterPred).sort(sortByTextTrackKind);\n}\nfunction sortByTextTrackKind(a, b) {\n\treturn a.kind >= b.kind ? 1 : -1;\n}\n\n//#endregion\nexport { findTrackElement, getTextTrackList };\n//# sourceMappingURL=text-track.js.map","//#region src/dom/time-ranges.ts\n/** Converts a TimeRanges object to an array of [start, end] tuples. */\nfunction serializeTimeRanges(ranges) {\n\tconst result = [];\n\tfor (let i = 0; i < ranges.length; i++) result.push([ranges.start(i), ranges.end(i)]);\n\treturn result;\n}\n\n//#endregion\nexport { serializeTimeRanges };\n//# sourceMappingURL=time-ranges.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen, serializeTimeRanges } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/buffer.ts\nconst bufferFeature = definePlayerFeature({\n\tname: \"buffer\",\n\tstate: () => ({\n\t\tbuffered: [],\n\t\tseekable: []\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({\n\t\t\tbuffered: serializeTimeRanges(media.buffered),\n\t\t\tseekable: serializeTimeRanges(media.seekable)\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"progress\", sync, { signal });\n\t\tlisten(media, \"emptied\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { bufferFeature };\n//# sourceMappingURL=buffer.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { isNull } from \"@videojs/utils/predicate\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/controls.ts\nconst IDLE_DELAY = 2e3;\nconst TAP_THRESHOLD = 250;\nconst controlsFeature = definePlayerFeature({\n\tname: \"controls\",\n\tstate: () => ({\n\t\tuserActive: true,\n\t\tcontrolsVisible: true\n\t}),\n\tattach({ target, signal, get, set }) {\n\t\tconst { media, container } = target;\n\t\tif (isNull(container)) return;\n\t\tfunction computeVisible(userActive) {\n\t\t\treturn userActive || media.paused;\n\t\t}\n\t\tlet idleTimer;\n\t\tfunction clearIdle() {\n\t\t\tclearTimeout(idleTimer);\n\t\t\tidleTimer = void 0;\n\t\t}\n\t\tfunction scheduleIdle() {\n\t\t\tclearIdle();\n\t\t\tidleTimer = setTimeout(setInactive, IDLE_DELAY);\n\t\t}\n\t\tfunction setActive() {\n\t\t\tif (!get().userActive) set({\n\t\t\t\tuserActive: true,\n\t\t\t\tcontrolsVisible: true\n\t\t\t});\n\t\t\tscheduleIdle();\n\t\t}\n\t\tfunction setInactive() {\n\t\t\tclearIdle();\n\t\t\tset({\n\t\t\t\tuserActive: false,\n\t\t\t\tcontrolsVisible: computeVisible(false)\n\t\t\t});\n\t\t}\n\t\tlet pointerDownTime = 0;\n\t\tfunction onPointerDown() {\n\t\t\tpointerDownTime = Date.now();\n\t\t}\n\t\tfunction onPointerUp(event) {\n\t\t\tif (event.pointerType === \"touch\" && Date.now() - pointerDownTime < TAP_THRESHOLD) if (get().controlsVisible) {\n\t\t\t\tclearIdle();\n\t\t\t\tset({\n\t\t\t\t\tuserActive: false,\n\t\t\t\t\tcontrolsVisible: computeVisible(false)\n\t\t\t\t});\n\t\t\t} else setActive();\n\t\t\telse setActive();\n\t\t}\n\t\tfunction onPlaybackChange() {\n\t\t\tconst { userActive } = get();\n\t\t\tset({ controlsVisible: computeVisible(userActive) });\n\t\t\tif (!media.paused && userActive) scheduleIdle();\n\t\t}\n\t\tlisten(container, \"pointermove\", setActive, { signal });\n\t\tlisten(container, \"pointerdown\", onPointerDown, { signal });\n\t\tlisten(container, \"pointerup\", onPointerUp, { signal });\n\t\tlisten(container, \"keyup\", setActive, { signal });\n\t\tlisten(container, \"focusin\", setActive, { signal });\n\t\tlisten(container, \"pointerleave\", setInactive, { signal });\n\t\tlisten(media, \"play\", onPlaybackChange, { signal });\n\t\tlisten(media, \"pause\", onPlaybackChange, { signal });\n\t\tlisten(media, \"ended\", onPlaybackChange, { signal });\n\t\tsignal.addEventListener(\"abort\", clearIdle, { once: true });\n\t\tscheduleIdle();\n\t}\n});\n\n//#endregion\nexport { controlsFeature };\n//# sourceMappingURL=controls.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/error.ts\nconst errorFeature = definePlayerFeature({\n\tname: \"error\",\n\tstate: ({ set }) => ({\n\t\terror: null,\n\t\tdismissError() {\n\t\t\tset({ error: null });\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst syncError = () => set({ error: media.error });\n\t\tlisten(media, \"error\", syncError, { signal });\n\t\tlisten(media, \"emptied\", () => set({ error: null }), { signal });\n\t}\n});\n\n//#endregion\nexport { errorFeature };\n//# sourceMappingURL=error.js.map","import { isFunction } from \"@videojs/utils/predicate\";\n\n//#region src/dom/presentation/fullscreen.ts\n/** Check if the Fullscreen API is supported on this platform. */\nfunction isFullscreenEnabled() {\n\tconst doc = document;\n\tif (doc.fullscreenEnabled || doc.webkitFullscreenEnabled) return true;\n\treturn document.createElement(\"video\").webkitSupportsFullscreen === true;\n}\n/** Get the current fullscreen element from the document. */\nfunction getFullscreenElement() {\n\tconst doc = document;\n\treturn doc.fullscreenElement ?? doc.webkitFullscreenElement ?? null;\n}\n/**\n* Check if a specific element (or its media) is currently in fullscreen.\n*\n* Uses `:fullscreen` pseudo-class which works across Shadow DOM boundaries.\n*/\nfunction isFullscreenElement(container, media) {\n\tconst video = media;\n\tif (video.webkitDisplayingFullscreen && video.webkitPresentationMode === \"fullscreen\") return true;\n\tconst target = container ?? media;\n\tif (getFullscreenElement() === target) return true;\n\ttry {\n\t\treturn target.matches(\":fullscreen\");\n\t} catch {\n\t\treturn false;\n\t}\n}\n/**\n* Request fullscreen mode.\n*\n* Tries container first (to show custom UI), falls back to media element\n* for platforms that only support video fullscreen (iOS Safari).\n*/\nasync function requestFullscreen(container, media) {\n\tconst video = media;\n\tif (container) {\n\t\tconst el = container;\n\t\tif (isFunction(el.requestFullscreen)) return el.requestFullscreen();\n\t\tif (isFunction(el.webkitRequestFullscreen)) return el.webkitRequestFullscreen();\n\t\tif (isFunction(el.webkitRequestFullScreen)) return el.webkitRequestFullScreen();\n\t}\n\tif (isFunction(video.webkitEnterFullscreen)) {\n\t\tvideo.webkitEnterFullscreen();\n\t\treturn;\n\t}\n\tif (isFunction(media.requestFullscreen)) return media.requestFullscreen();\n\tthrow new DOMException(\"Fullscreen not supported\", \"NotSupportedError\");\n}\n/** Exit fullscreen mode. */\nasync function exitFullscreen() {\n\tconst doc = document;\n\tconst video = getFullscreenElement();\n\tif (isFunction(doc.exitFullscreen)) return doc.exitFullscreen();\n\tif (isFunction(doc.webkitExitFullscreen)) return doc.webkitExitFullscreen();\n\tif (isFunction(doc.webkitCancelFullScreen)) return doc.webkitCancelFullScreen();\n\tif (video && isFunction(video.webkitExitFullscreen)) {\n\t\tvideo.webkitExitFullscreen();\n\t\treturn;\n\t}\n}\n\n//#endregion\nexport { exitFullscreen, isFullscreenElement, isFullscreenEnabled, requestFullscreen };\n//# sourceMappingURL=fullscreen.js.map","import { isFunction } from \"@videojs/utils/predicate\";\n\n//#region src/dom/presentation/pip.ts\n/**\n* Check if Picture-in-Picture is supported on this platform.\n*\n* Note: Safari PWAs don't support PiP even though the API exists.\n*/\nfunction isPictureInPictureEnabled() {\n\tif (document.pictureInPictureEnabled) {\n\t\tconst isSafari = /.*Version\\/.*Safari\\/.*/.test(navigator.userAgent);\n\t\tconst isPWA = typeof matchMedia === \"function\" && matchMedia(\"(display-mode: standalone)\").matches;\n\t\treturn !isSafari || !isPWA;\n\t}\n\treturn isFunction(document.createElement(\"video\").webkitSetPresentationMode);\n}\n/**\n* Check if Picture-in-Picture is currently active for a media element.\n*/\nfunction isPictureInPictureElement(media) {\n\tif (document.pictureInPictureElement === media) return true;\n\treturn media.webkitPresentationMode === \"picture-in-picture\";\n}\n/**\n* Request Picture-in-Picture mode.\n*\n* Uses standard API where available, falls back to iOS Safari's\n* WebKit presentation mode.\n*/\nasync function requestPictureInPicture(media) {\n\tconst video = media;\n\tif (isFunction(video.requestPictureInPicture)) {\n\t\tawait video.requestPictureInPicture();\n\t\treturn;\n\t}\n\tif (isFunction(video.webkitSetPresentationMode)) {\n\t\tvideo.webkitSetPresentationMode(\"picture-in-picture\");\n\t\treturn;\n\t}\n\tthrow new DOMException(\"Picture-in-Picture not supported\", \"NotSupportedError\");\n}\n/**\n* Exit Picture-in-Picture mode.\n*\n* Uses standard API where available, falls back to iOS Safari's\n* WebKit presentation mode.\n*/\nasync function exitPictureInPicture(media) {\n\tif (document.pictureInPictureElement && isFunction(document.exitPictureInPicture)) {\n\t\tawait document.exitPictureInPicture();\n\t\treturn;\n\t}\n\tif (media) {\n\t\tconst video = media;\n\t\tif (video.webkitPresentationMode === \"picture-in-picture\" && isFunction(video.webkitSetPresentationMode)) {\n\t\t\tvideo.webkitSetPresentationMode(\"inline\");\n\t\t\treturn;\n\t\t}\n\t}\n}\n\n//#endregion\nexport { exitPictureInPicture, isPictureInPictureElement, isPictureInPictureEnabled, requestPictureInPicture };\n//# sourceMappingURL=pip.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { exitFullscreen, isFullscreenElement, isFullscreenEnabled, requestFullscreen } from \"../../presentation/fullscreen.js\";\nimport { exitPictureInPicture, isPictureInPictureElement } from \"../../presentation/pip.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/fullscreen.ts\nconst fullscreenFeature = definePlayerFeature({\n\tname: \"fullscreen\",\n\tstate: ({ target }) => ({\n\t\tfullscreen: false,\n\t\tfullscreenAvailability: \"unavailable\",\n\t\tasync requestFullscreen() {\n\t\t\tconst { media, container } = target();\n\t\t\tif (isPictureInPictureElement(media)) await exitPictureInPicture(media);\n\t\t\treturn requestFullscreen(container, media);\n\t\t},\n\t\tasync exitFullscreen() {\n\t\t\treturn exitFullscreen();\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media, container } = target;\n\t\tset({ fullscreenAvailability: isFullscreenEnabled() ? \"available\" : \"unsupported\" });\n\t\tconst sync = () => set({ fullscreen: isFullscreenElement(container, media) });\n\t\tsync();\n\t\tlisten(document, \"fullscreenchange\", sync, { signal });\n\t\tlisten(document, \"webkitfullscreenchange\", sync, { signal });\n\t\tif (\"webkitPresentationMode\" in media) listen(media, \"webkitpresentationmodechanged\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { fullscreenFeature };\n//# sourceMappingURL=fullscreen.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { exitFullscreen, isFullscreenElement } from \"../../presentation/fullscreen.js\";\nimport { exitPictureInPicture, isPictureInPictureElement, isPictureInPictureEnabled, requestPictureInPicture } from \"../../presentation/pip.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/pip.ts\nconst pipFeature = definePlayerFeature({\n\tname: \"pip\",\n\tstate: ({ target }) => ({\n\t\tpip: false,\n\t\tpipAvailability: \"unavailable\",\n\t\tasync requestPictureInPicture() {\n\t\t\tconst { media, container } = target();\n\t\t\tif (isFullscreenElement(container, media)) await exitFullscreen();\n\t\t\treturn requestPictureInPicture(media);\n\t\t},\n\t\tasync exitPictureInPicture() {\n\t\t\tconst { media } = target();\n\t\t\treturn exitPictureInPicture(media);\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tset({ pipAvailability: isPictureInPictureEnabled() ? \"available\" : \"unsupported\" });\n\t\tconst sync = () => set({ pip: isPictureInPictureElement(media) });\n\t\tsync();\n\t\tlisten(media, \"enterpictureinpicture\", sync, { signal });\n\t\tlisten(media, \"leavepictureinpicture\", sync, { signal });\n\t\tif (\"webkitPresentationMode\" in media) listen(media, \"webkitpresentationmodechanged\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { pipFeature };\n//# sourceMappingURL=pip.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/playback.ts\nconst playbackFeature = definePlayerFeature({\n\tname: \"playback\",\n\tstate: ({ target }) => ({\n\t\tpaused: true,\n\t\tended: false,\n\t\tstarted: false,\n\t\twaiting: false,\n\t\tplay() {\n\t\t\treturn target().media.play();\n\t\t},\n\t\tpause() {\n\t\t\ttarget().media.pause();\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({\n\t\t\tpaused: media.paused,\n\t\t\tended: media.ended,\n\t\t\tstarted: !media.paused || media.currentTime > 0,\n\t\t\twaiting: media.readyState < HTMLMediaElement.HAVE_FUTURE_DATA && !media.paused\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"emptied\", sync, { signal });\n\t\tlisten(media, \"play\", sync, { signal });\n\t\tlisten(media, \"pause\", sync, { signal });\n\t\tlisten(media, \"ended\", sync, { signal });\n\t\tlisten(media, \"playing\", sync, { signal });\n\t\tlisten(media, \"waiting\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { playbackFeature };\n//# sourceMappingURL=playback.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/playback-rate.ts\nconst DEFAULT_RATES = [\n\t1,\n\t1.2,\n\t1.5,\n\t1.7,\n\t2\n];\nconst playbackRateFeature = definePlayerFeature({\n\tname: \"playbackRate\",\n\tstate: ({ target }) => ({\n\t\tplaybackRates: DEFAULT_RATES,\n\t\tplaybackRate: 1,\n\t\tsetPlaybackRate(rate) {\n\t\t\ttarget().media.playbackRate = rate;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({ playbackRate: media.playbackRate });\n\t\tsync();\n\t\tlisten(media, \"ratechange\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { playbackRateFeature };\n//# sourceMappingURL=playback-rate.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/source.ts\nconst sourceFeature = definePlayerFeature({\n\tname: \"source\",\n\tstate: ({ target, signals }) => ({\n\t\tsource: null,\n\t\tcanPlay: false,\n\t\tloadSource(src) {\n\t\t\tsignals.clear();\n\t\t\tconst { media } = target();\n\t\t\tmedia.src = src;\n\t\t\tmedia.load();\n\t\t\treturn src;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({\n\t\t\tsource: media.currentSrc || media.src || null,\n\t\t\tcanPlay: media.readyState >= HTMLMediaElement.HAVE_ENOUGH_DATA\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"canplay\", sync, { signal });\n\t\tlisten(media, \"canplaythrough\", sync, { signal });\n\t\tlisten(media, \"loadstart\", sync, { signal });\n\t\tlisten(media, \"emptied\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { sourceFeature };\n//# sourceMappingURL=source.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { findTrackElement, getTextTrackList, listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/text-track.ts\nconst textTrackFeature = definePlayerFeature({\n\tname: \"textTrack\",\n\tstate: ({ target }) => ({\n\t\tchaptersCues: [],\n\t\tthumbnailCues: [],\n\t\tthumbnailTrackSrc: null,\n\t\ttextTrackList: [],\n\t\tsubtitlesShowing: false,\n\t\ttoggleSubtitles(forceShow) {\n\t\t\tconst subtitlesTracks = getTextTrackList(target().media, (track) => track.kind === \"subtitles\" || track.kind === \"captions\");\n\t\t\tif (!subtitlesTracks.length) return false;\n\t\t\tconst showing = subtitlesTracks.some((track) => track.mode === \"showing\");\n\t\t\tconst nextShowing = forceShow ?? !showing;\n\t\t\tfor (const track of subtitlesTracks) track.mode = nextShowing ? \"showing\" : \"disabled\";\n\t\t\treturn nextShowing;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tlet trackCleanup = null;\n\t\tfunction sync() {\n\t\t\ttrackCleanup?.abort();\n\t\t\ttrackCleanup = new AbortController();\n\t\t\tlet chaptersTrack = null;\n\t\t\tlet thumbnailTrack = null;\n\t\t\tconst textTrackList = [];\n\t\t\tlet subtitlesShowing = false;\n\t\t\tfor (let i = 0; i < media.textTracks.length; i++) {\n\t\t\t\tconst track = media.textTracks[i];\n\t\t\t\tif (!chaptersTrack && track.kind === \"chapters\") chaptersTrack = track;\n\t\t\t\tif (!thumbnailTrack && track.kind === \"metadata\" && track.label === \"thumbnails\") thumbnailTrack = track;\n\t\t\t\ttextTrackList.push({\n\t\t\t\t\tkind: track.kind,\n\t\t\t\t\tlabel: track.label,\n\t\t\t\t\tlanguage: track.language,\n\t\t\t\t\tmode: track.mode\n\t\t\t\t});\n\t\t\t\tif ((track.kind === \"captions\" || track.kind === \"subtitles\") && track.mode === \"showing\") subtitlesShowing = true;\n\t\t\t}\n\t\t\tconst chaptersCues = chaptersTrack?.cues ? Array.from(chaptersTrack.cues) : [];\n\t\t\tconst thumbnailCues = thumbnailTrack?.cues ? Array.from(thumbnailTrack.cues) : [];\n\t\t\tlet thumbnailTrackSrc = null;\n\t\t\tif (thumbnailTrack) thumbnailTrackSrc = findTrackElement(media, thumbnailTrack)?.src ?? null;\n\t\t\tfor (const trackEl of media.querySelectorAll?.(\"track\") ?? []) if (!trackEl.track?.cues?.length) listen(trackEl, \"load\", sync, { signal: trackCleanup.signal });\n\t\t\tset({\n\t\t\t\tchaptersCues,\n\t\t\t\tthumbnailCues,\n\t\t\t\tthumbnailTrackSrc,\n\t\t\t\ttextTrackList,\n\t\t\t\tsubtitlesShowing\n\t\t\t});\n\t\t}\n\t\tsync();\n\t\tlisten(media.textTracks, \"addtrack\", sync, { signal });\n\t\tlisten(media.textTracks, \"removetrack\", sync, { signal });\n\t\tlisten(media.textTracks, \"change\", sync, { signal });\n\t\tlisten(media, \"loadstart\", sync, { signal });\n\t\tsignal.addEventListener(\"abort\", () => trackCleanup?.abort(), { once: true });\n\t}\n});\n\n//#endregion\nexport { textTrackFeature };\n//# sourceMappingURL=text-track.js.map","//#region src/dom/media/predicate.ts\nfunction hasMetadata(media) {\n\treturn media.readyState >= HTMLMediaElement.HAVE_METADATA;\n}\n\n//#endregion\nexport { hasMetadata };\n//# sourceMappingURL=predicate.js.map","//#region src/dom/store/signal-keys.ts\nconst signalKeys = { seek: Symbol.for(\"@videojs/seek\") };\n\n//#endregion\nexport { signalKeys };\n//# sourceMappingURL=signal-keys.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { hasMetadata } from \"../../media/predicate.js\";\nimport { signalKeys } from \"../signal-keys.js\";\nimport { listen, onEvent } from \"@videojs/utils/dom\";\nimport { noop } from \"@videojs/utils/function\";\n\n//#region src/dom/store/features/time.ts\nconst timeFeature = definePlayerFeature({\n\tname: \"time\",\n\tstate: ({ target, signals, set }) => ({\n\t\tcurrentTime: 0,\n\t\tduration: 0,\n\t\tseeking: false,\n\t\tasync seek(time) {\n\t\t\tconst { media } = target(), signal = signals.supersede(signalKeys.seek);\n\t\t\tif (!hasMetadata(media)) {\n\t\t\t\tif (!await onEvent(media, \"loadedmetadata\", { signal }).catch(() => false)) return media.currentTime;\n\t\t\t}\n\t\t\tconst clampedTime = Math.max(0, Math.min(time, media.duration || Infinity));\n\t\t\tset({\n\t\t\t\tcurrentTime: clampedTime,\n\t\t\t\tseeking: true\n\t\t\t});\n\t\t\tmedia.currentTime = clampedTime;\n\t\t\tawait onEvent(media, \"seeked\", { signal }).catch(noop);\n\t\t\treturn media.currentTime;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({\n\t\t\tcurrentTime: media.currentTime,\n\t\t\tduration: Number.isFinite(media.duration) ? media.duration : 0,\n\t\t\tseeking: media.seeking\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"timeupdate\", sync, { signal });\n\t\tlisten(media, \"durationchange\", sync, { signal });\n\t\tlisten(media, \"seeking\", sync, { signal });\n\t\tlisten(media, \"seeked\", sync, { signal });\n\t\tlisten(media, \"loadedmetadata\", sync, { signal });\n\t\tlisten(media, \"emptied\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { timeFeature };\n//# sourceMappingURL=time.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/volume.ts\n/** Volume to restore when unmuting at zero. */\nconst UNMUTE_VOLUME = .25;\nconst volumeFeature = definePlayerFeature({\n\tname: \"volume\",\n\tstate: ({ target }) => ({\n\t\tvolume: 1,\n\t\tmuted: false,\n\t\tvolumeAvailability: \"unavailable\",\n\t\tsetVolume(volume) {\n\t\t\tconst { media } = target();\n\t\t\tconst clamped = Math.max(0, Math.min(1, volume));\n\t\t\tif (clamped > 0 && media.muted) media.muted = false;\n\t\t\tmedia.volume = clamped;\n\t\t\treturn media.volume;\n\t\t},\n\t\ttoggleMuted() {\n\t\t\tconst { media } = target();\n\t\t\tif (media.muted || media.volume === 0) {\n\t\t\t\tmedia.muted = false;\n\t\t\t\tif (media.volume === 0) media.volume = UNMUTE_VOLUME;\n\t\t\t} else media.muted = true;\n\t\t\treturn media.muted;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tset({ volumeAvailability: canSetVolume() });\n\t\tconst sync = () => set({\n\t\t\tvolume: media.volume,\n\t\t\tmuted: media.muted\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"volumechange\", sync, { signal });\n\t}\n});\n/** Check if volume can be programmatically set (fails on iOS Safari). */\nfunction canSetVolume() {\n\tconst video = document.createElement(\"video\");\n\ttry {\n\t\tvideo.volume = .5;\n\t\treturn video.volume === .5 ? \"available\" : \"unsupported\";\n\t} catch {\n\t\treturn \"unsupported\";\n\t}\n}\n\n//#endregion\nexport { volumeFeature };\n//# sourceMappingURL=volume.js.map","import { bufferFeature } from \"./buffer.js\";\nimport { controlsFeature } from \"./controls.js\";\nimport { errorFeature } from \"./error.js\";\nimport { fullscreenFeature } from \"./fullscreen.js\";\nimport { pipFeature } from \"./pip.js\";\nimport { playbackFeature } from \"./playback.js\";\nimport { playbackRateFeature } from \"./playback-rate.js\";\nimport { sourceFeature } from \"./source.js\";\nimport { textTrackFeature } from \"./text-track.js\";\nimport { timeFeature } from \"./time.js\";\nimport { volumeFeature } from \"./volume.js\";\n\n//#region src/dom/store/features/presets.ts\nconst videoFeatures = [\n\tplaybackFeature,\n\tplaybackRateFeature,\n\tvolumeFeature,\n\ttimeFeature,\n\tsourceFeature,\n\tbufferFeature,\n\tfullscreenFeature,\n\tpipFeature,\n\tcontrolsFeature,\n\ttextTrackFeature,\n\terrorFeature\n];\nconst audioFeatures = [\n\tplaybackFeature,\n\tplaybackRateFeature,\n\tvolumeFeature,\n\ttimeFeature,\n\tsourceFeature,\n\tbufferFeature\n];\nconst backgroundFeatures = [];\n\n//#endregion\nexport { audioFeatures, backgroundFeatures, videoFeatures };\n//# sourceMappingURL=presets.js.map","import { bufferFeature } from \"./features/buffer.js\";\nimport { controlsFeature } from \"./features/controls.js\";\nimport { errorFeature } from \"./features/error.js\";\nimport { fullscreenFeature } from \"./features/fullscreen.js\";\nimport { pipFeature } from \"./features/pip.js\";\nimport { playbackFeature } from \"./features/playback.js\";\nimport { playbackRateFeature } from \"./features/playback-rate.js\";\nimport { sourceFeature } from \"./features/source.js\";\nimport { textTrackFeature } from \"./features/text-track.js\";\nimport { timeFeature } from \"./features/time.js\";\nimport { volumeFeature } from \"./features/volume.js\";\nimport { createSelector } from \"@videojs/store\";\n\n//#region src/dom/store/selectors.ts\n/** Select the buffer state (buffered ranges, percent buffered). */\nconst selectBuffer = createSelector(bufferFeature);\n/** Select the controls state (controls visible, user-active). */\nconst selectControls = createSelector(controlsFeature);\n/** Select the error state (error, dismissed, dismissError). */\nconst selectError = createSelector(errorFeature);\n/** Select the fullscreen state (fullscreen active, availability). */\nconst selectFullscreen = createSelector(fullscreenFeature);\n/** Select the PiP state (picture-in-picture active, availability). */\nconst selectPiP = createSelector(pipFeature);\n/** Select the playback state (paused, ended, play, pause, toggle). */\nconst selectPlayback = createSelector(playbackFeature);\n/** Select the playback rate state (playbackRate, playbackRates, setPlaybackRate). */\nconst selectPlaybackRate = createSelector(playbackRateFeature);\n/** Select the source state (src, type). */\nconst selectSource = createSelector(sourceFeature);\n/** Select the text track state (chapters cues, thumbnail cues). */\nconst selectTextTrack = createSelector(textTrackFeature);\n/** Select the time state (currentTime, duration, seek). */\nconst selectTime = createSelector(timeFeature);\n/** Select the volume state (volume, muted, setVolume, setMuted). */\nconst selectVolume = createSelector(volumeFeature);\n\n//#endregion\nexport { selectBuffer, selectControls, selectError, selectFullscreen, selectPiP, selectPlayback, selectPlaybackRate, selectSource, selectTextTrack, selectTime, selectVolume };\n//# sourceMappingURL=selectors.js.map","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nclass s extends Event{constructor(s,t,e,o){super(\"context-request\",{bubbles:!0,composed:!0}),this.context=s,this.contextTarget=t,this.callback=e,this.subscribe=o??!1}}export{s as ContextRequestEvent};\n//# sourceMappingURL=context-request-event.js.map\n","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nfunction n(n){return n}export{n as createContext};\n//# sourceMappingURL=create-context.js.map\n","import{ContextRequestEvent as t}from\"../context-request-event.js\";\n/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */class s{constructor(t,s,i,h){if(this.subscribe=!1,this.provided=!1,this.value=void 0,this.t=(t,s)=>{this.unsubscribe&&(this.unsubscribe!==s&&(this.provided=!1,this.unsubscribe()),this.subscribe||this.unsubscribe()),this.value=t,this.host.requestUpdate(),this.provided&&!this.subscribe||(this.provided=!0,this.callback&&this.callback(t,s)),this.unsubscribe=s},this.host=t,void 0!==s.context){const t=s;this.context=t.context,this.callback=t.callback,this.subscribe=t.subscribe??!1}else this.context=s,this.callback=i,this.subscribe=h??!1;this.host.addController(this)}hostConnected(){this.dispatchRequest()}hostDisconnected(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=void 0)}dispatchRequest(){this.host.dispatchEvent(new t(this.context,this.host,this.t,this.subscribe))}}export{s as ContextConsumer};\n//# sourceMappingURL=context-consumer.js.map\n","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nclass s{get value(){return this.o}set value(s){this.setValue(s)}setValue(s,t=!1){const i=t||!Object.is(s,this.o);this.o=s,i&&this.updateObservers()}constructor(s){this.subscriptions=new Map,this.updateObservers=()=>{for(const[s,{disposer:t}]of this.subscriptions)s(this.o,t)},void 0!==s&&(this.value=s)}addCallback(s,t,i){if(!i)return void s(this.value);this.subscriptions.has(s)||this.subscriptions.set(s,{disposer:()=>{this.subscriptions.delete(s)},consumerHost:t});const{disposer:h}=this.subscriptions.get(s);s(this.value,h)}clearCallbacks(){this.subscriptions.clear()}}export{s as ValueNotifier};\n//# sourceMappingURL=value-notifier.js.map\n","import{ContextRequestEvent as t}from\"../context-request-event.js\";import{ValueNotifier as s}from\"../value-notifier.js\";\n/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */class e extends Event{constructor(t,s){super(\"context-provider\",{bubbles:!0,composed:!0}),this.context=t,this.contextTarget=s}}class i extends s{constructor(s,e,i){super(void 0!==e.context?e.initialValue:i),this.onContextRequest=t=>{if(t.context!==this.context)return;const s=t.contextTarget??t.composedPath()[0];s!==this.host&&(t.stopPropagation(),this.addCallback(t.callback,s,t.subscribe))},this.onProviderRequest=s=>{if(s.context!==this.context)return;if((s.contextTarget??s.composedPath()[0])===this.host)return;const e=new Set;for(const[s,{consumerHost:i}]of this.subscriptions)e.has(s)||(e.add(s),i.dispatchEvent(new t(this.context,i,s,!0)));s.stopPropagation()},this.host=s,void 0!==e.context?this.context=e.context:this.context=e,this.attachListeners(),this.host.addController?.(this)}attachListeners(){this.host.addEventListener(\"context-request\",this.onContextRequest),this.host.addEventListener(\"context-provider\",this.onProviderRequest)}hostConnected(){this.host.dispatchEvent(new e(this.context,this.host))}}export{i as ContextProvider,e as ContextProviderEvent};\n//# sourceMappingURL=context-provider.js.map\n","import type { AnyPlayerStore, PlayerStore } from '@videojs/core/dom';\nimport { type Context, createContext } from '@videojs/element/context';\n\nexport const PLAYER_CONTEXT_KEY = Symbol('@videojs/player');\n\nexport type PlayerContextValue<Store extends PlayerStore = AnyPlayerStore> = Store;\n\nexport type PlayerContext<Store extends PlayerStore = AnyPlayerStore> = Context<\n typeof PLAYER_CONTEXT_KEY,\n PlayerContextValue<Store>\n>;\n\n/**\n * The default player context instance for consuming the player store in controllers.\n *\n * @public\n */\nexport const playerContext = createContext<PlayerContextValue, typeof PLAYER_CONTEXT_KEY>(PLAYER_CONTEXT_KEY);\n","import type { MediaContainer, PlayerStore, PlayerTarget } from '@videojs/core/dom';\nimport { ContextConsumer } from '@videojs/element/context';\nimport { noop } from '@videojs/utils/function';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerConsumer, PlayerConsumerConstructor } from './types';\n\nexport type ContainerMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerConsumerConstructor<Store>;\n\n/**\n * Create a mixin that consumes player context and auto-attaches media elements.\n *\n * @param context - Player context to consume from an ancestor provider.\n */\nexport function createContainerMixin<Store extends PlayerStore>(context: PlayerContext<Store>): ContainerMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerContainerElement extends BaseClass implements PlayerConsumer<Store>, MediaContainer {\n #detach = noop;\n #observer: MutationObserver | null = null;\n #contextStore: Store | null = null;\n\n constructor(...args: any[]) {\n super(...args);\n\n // Created in the constructor body (after all field initializers) so\n // that #contextStore's private slot exists if the callback fires\n // synchronously — which happens when the element is already connected.\n // The host's controller list keeps the consumer alive; no field needed.\n new ContextConsumer(this, {\n context,\n callback: (value) => {\n this.#contextStore = value ?? null;\n this.#attachMedia();\n },\n subscribe: true,\n });\n }\n\n get store(): Store | null {\n return this.#contextStore;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n\n this.#observer = new MutationObserver((records) => {\n if (records.some(hasMediaNode)) this.#attachMedia();\n });\n\n this.#observer.observe(this, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['data-media-element'],\n });\n\n // Slotted media elements don't appear in the container's subtree,\n // so listen for slot reassignments to pick them up.\n this.addEventListener('slotchange', this.#onSlotChange);\n\n this.#attachMedia();\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.#observer?.disconnect();\n this.#observer = null;\n this.removeEventListener('slotchange', this.#onSlotChange);\n this.#detach();\n }\n\n #onSlotChange = () => {\n this.#attachMedia();\n };\n\n #getSlottedMedia(): HTMLMediaElement | null {\n const slot = this.querySelector<HTMLSlotElement>('slot[name=\"media\"]');\n if (!slot) return null;\n\n for (const el of slot.assignedElements({ flatten: true })) {\n if (el instanceof HTMLMediaElement) return el;\n }\n\n return null;\n }\n\n #attachMedia() {\n // Prefer the cached context value; fall back to `this.store` which\n // ProviderMixin overrides when both mixins are applied to one element.\n const store = this.#contextStore ?? this.store;\n if (!store) return;\n\n const media =\n this.querySelector<HTMLMediaElement>('video, audio, [data-media-element]') ?? this.#getSlottedMedia();\n\n if (!media) {\n this.#detach();\n this.#detach = noop;\n return;\n }\n\n const target: PlayerTarget = {\n media,\n container: this,\n };\n\n const hasMediaChanged = store.target?.media !== target.media,\n hasContainerChanged = store.target?.container !== target.container;\n\n if (hasMediaChanged || hasContainerChanged) {\n this.#detach();\n this.#detach = store.attach(target);\n }\n }\n }\n\n return PlayerContainerElement;\n };\n}\n\nfunction isMediaNode(node: Node): boolean {\n return node instanceof HTMLMediaElement || (node instanceof Element && node.hasAttribute('data-media-element'));\n}\n\nfunction hasMediaNode(record: MutationRecord): boolean {\n // Attribute mutation: data-media-element was added to a descendant\n if (record.type === 'attributes' && record.target instanceof Element) {\n return record.target.hasAttribute('data-media-element');\n }\n\n for (const node of record.addedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n for (const node of record.removedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n return false;\n}\n","//#region src/destroy-mixin.ts\n/**\n* Mixin that adds a deferred destruction lifecycle to a `ReactiveElement`.\n*\n* On disconnect, schedules destruction after two animation frames.\n* If the element reconnects before the frames fire (e.g. DOM shuffling,\n* framework reconciliation), the `isConnected` check prevents destruction.\n*\n* The `keep-alive` attribute prevents automatic destruction entirely —\n* call `destroy()` manually when done.\n*\n* Subclasses override `destroyCallback()` (calling `super.destroyCallback()`)\n* to release heavy resources like stores or imperative APIs.\n*\n* Mirrors `addController`/`removeController` to track controllers\n* (needed because `ReactiveElement.#controllers` is hard-private),\n* calls `hostDestroyed()` on all tracked controllers in `destroyCallback`,\n* and guards `performUpdate()` so no updates run after destruction.\n*/\nfunction DestroyMixin(SuperClass) {\n\tclass DestroyableElement extends SuperClass {\n\t\t#destroyed = false;\n\t\t#trackedControllers = /* @__PURE__ */ new Set();\n\t\tget destroyed() {\n\t\t\treturn this.#destroyed;\n\t\t}\n\t\tdestroy() {\n\t\t\tif (this.#destroyed) return;\n\t\t\tthis.#destroyed = true;\n\t\t\tthis.destroyCallback();\n\t\t}\n\t\tdestroyCallback() {\n\t\t\tfor (const c of this.#trackedControllers) c.hostDestroyed?.();\n\t\t}\n\t\taddController(controller) {\n\t\t\tsuper.addController(controller);\n\t\t\tthis.#trackedControllers.add(controller);\n\t\t}\n\t\tremoveController(controller) {\n\t\t\tsuper.removeController(controller);\n\t\t\tthis.#trackedControllers.delete(controller);\n\t\t}\n\t\tconnectedCallback() {\n\t\t\tif (this.#destroyed) return;\n\t\t\tsuper.connectedCallback();\n\t\t}\n\t\tdisconnectedCallback() {\n\t\t\tsuper.disconnectedCallback();\n\t\t\tif (!this.#destroyed && !this.hasAttribute(\"keep-alive\")) requestAnimationFrame(() => {\n\t\t\t\trequestAnimationFrame(() => {\n\t\t\t\t\tif (!this.isConnected) this.destroy();\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\t\tperformUpdate() {\n\t\t\tif (this.#destroyed) return;\n\t\t\tsuper.performUpdate();\n\t\t}\n\t}\n\treturn DestroyableElement;\n}\n\n//#endregion\nexport { DestroyMixin };\n//# sourceMappingURL=destroy-mixin.js.map","//#region src/reactive-element.ts\nconst cache = /* @__PURE__ */ new WeakMap();\nconst propertyKeys = /* @__PURE__ */ new Map();\n/**\n* Lightweight reactive custom element base class.\n*\n* Drop-in subset of Lit's `ReactiveElement` — supports `static properties`,\n* attribute reflection, batched async updates, and reactive controllers.\n* No Shadow DOM, no `static styles`, no decorators.\n*\n* Updates are batched using the same Promise-based scheduling as Lit:\n* property changes enqueue a microtask, and the update is gated behind\n* `connectedCallback` so the first update only runs once the element\n* is in the document.\n*\n* Subclasses that extend another element with properties must spread them:\n*\n* @example\n* ```ts\n* class MyButton extends ReactiveElement {\n* static override properties = {\n* label: { type: String },\n* disabled: { type: Boolean },\n* };\n*\n* label = 'Click me';\n* disabled = false;\n*\n* protected override update(changed: PropertyValues): void {\n* super.update(changed);\n* this.textContent = this.label;\n* }\n* }\n*\n* // Inheritance — spread parent properties\n* class FancyButton extends MyButton {\n* static override properties = {\n* ...MyButton.properties,\n* variant: { type: String },\n* };\n*\n* variant = 'primary';\n* }\n* ```\n*/\nvar ReactiveElement = class extends HTMLElement {\n\tstatic {\n\t\tthis.properties = {};\n\t}\n\t/**\n\t* Returns a list of attributes corresponding to the registered properties.\n\t*/\n\tstatic get observedAttributes() {\n\t\treturn [...resolve(this).attrToProp.keys()];\n\t}\n\t#controllers = /* @__PURE__ */ new Set();\n\t#changedProperties = /* @__PURE__ */ new Map();\n\t#instanceProperties;\n\t/**\n\t* Promise that gates the first update until `connectedCallback`. Also\n\t* used to serialize updates — each `#enqueueUpdate` awaits the previous\n\t* `#updatePromise`, so property changes are batched and updates never\n\t* overlap. Matches Lit's scheduling model.\n\t*/\n\t#updatePromise;\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isUpdatePending = false;\n\t\tthis.hasUpdated = false;\n\t\tthis.#updatePromise = new Promise((res) => this.enableUpdating = res);\n\t\tconst { props } = resolve(this.constructor);\n\t\tfor (const name of props.keys()) if (Object.hasOwn(this, name)) {\n\t\t\t(this.#instanceProperties ??= /* @__PURE__ */ new Map()).set(name, this[name]);\n\t\t\tdelete this[name];\n\t\t}\n\t\tthis.requestUpdate();\n\t}\n\t/**\n\t* Note, this method should be considered final and not overridden. It is\n\t* overridden on the element instance with a function that triggers the\n\t* first update.\n\t*/\n\tenableUpdating(_requestedUpdate) {}\n\t/**\n\t* Registers a {@linkcode ReactiveController} to participate in the\n\t* element's reactive update cycle. The element automatically calls into\n\t* any registered controllers during its lifecycle callbacks.\n\t*\n\t* If the element is connected when `addController()` is called, the\n\t* controller's `hostConnected()` callback will be immediately called.\n\t*/\n\taddController(controller) {\n\t\tthis.#controllers.add(controller);\n\t\tif (this.isConnected) controller.hostConnected?.();\n\t}\n\t/** Removes a {@linkcode ReactiveController} from the element. */\n\tremoveController(controller) {\n\t\tthis.#controllers.delete(controller);\n\t}\n\t/**\n\t* On first connection, enables updating and notifies controllers.\n\t*/\n\tconnectedCallback() {\n\t\tthis.enableUpdating(true);\n\t\tfor (const c of this.#controllers) c.hostConnected?.();\n\t}\n\tdisconnectedCallback() {\n\t\tfor (const c of this.#controllers) c.hostDisconnected?.();\n\t}\n\t/**\n\t* Synchronizes property values when attributes change.\n\t*\n\t* Specifically, when an attribute is set, the corresponding property is\n\t* set. You should rarely need to implement this callback. If this method\n\t* is overridden, `super.attributeChangedCallback(name, _old, value)` must\n\t* be called.\n\t*/\n\tattributeChangedCallback(attr, oldValue, newValue) {\n\t\tif (oldValue === newValue) return;\n\t\tconst { props, attrToProp } = resolve(this.constructor);\n\t\tconst propName = attrToProp.get(attr);\n\t\tif (!propName) return;\n\t\tconst decl = props.get(propName);\n\t\tif (!decl) return;\n\t\tlet value = newValue;\n\t\tif (decl.type === Boolean) value = newValue !== null;\n\t\telse if (decl.type === Number) value = newValue === null ? null : Number(newValue);\n\t\tthis[propName] = value;\n\t}\n\t/**\n\t* Requests an update which is processed asynchronously. This should be\n\t* called when an element should update based on some state not triggered\n\t* by setting a reactive property. In this case, pass no arguments. It\n\t* should also be called when manually implementing a property setter. In\n\t* this case, pass the property `name` and `oldValue` to ensure that any\n\t* configured property options are honored.\n\t*/\n\trequestUpdate(name, oldValue) {\n\t\tif (name !== void 0) this.#changedProperties.set(name, oldValue);\n\t\tif (this.isUpdatePending) return;\n\t\tthis.#updatePromise = this.#enqueueUpdate();\n\t}\n\t/**\n\t* Sets up the element to asynchronously update. Awaits the previous\n\t* `#updatePromise` which both serializes updates and (on first update)\n\t* waits for `connectedCallback` to resolve the gate.\n\t*/\n\tasync #enqueueUpdate() {\n\t\tthis.isUpdatePending = true;\n\t\ttry {\n\t\t\tawait this.#updatePromise;\n\t\t} catch (e) {\n\t\t\tPromise.reject(e);\n\t\t}\n\t\tconst result = this.scheduleUpdate();\n\t\tif (result != null) await result;\n\t\treturn !this.isUpdatePending;\n\t}\n\t/**\n\t* Schedules an element update. You can override this method to change the\n\t* timing of updates by returning a Promise. The update will await the\n\t* returned Promise, and you should resolve the Promise to allow the update\n\t* to proceed. If this method is overridden, `super.scheduleUpdate()` must\n\t* be called.\n\t*\n\t* For instance, to schedule updates to occur just before the next frame:\n\t*\n\t* ```ts\n\t* override protected async scheduleUpdate(): Promise<unknown> {\n\t* await new Promise((resolve) => requestAnimationFrame(() => resolve()));\n\t* super.scheduleUpdate();\n\t* }\n\t* ```\n\t*/\n\tscheduleUpdate() {\n\t\tthis.performUpdate();\n\t}\n\t/**\n\t* Performs an element update. Note, if an exception is thrown during the\n\t* update, `firstUpdated` and `updated` will not be called.\n\t*\n\t* Call `performUpdate()` to immediately process a pending update. This\n\t* should generally not be needed, but it can be done in rare cases when\n\t* you need to update synchronously.\n\t*/\n\tperformUpdate() {\n\t\tif (!this.isUpdatePending) return;\n\t\tif (!this.hasUpdated && this.#instanceProperties) {\n\t\t\tfor (const [name, value] of this.#instanceProperties) this[name] = value;\n\t\t\tthis.#instanceProperties = void 0;\n\t\t}\n\t\tconst changed = this.#changedProperties;\n\t\tthis.willUpdate(changed);\n\t\tfor (const c of this.#controllers) c.hostUpdate?.();\n\t\tthis.update(changed);\n\t\tthis.#changedProperties = /* @__PURE__ */ new Map();\n\t\tthis.isUpdatePending = false;\n\t\tfor (const c of this.#controllers) c.hostUpdated?.();\n\t\tif (!this.hasUpdated) {\n\t\t\tthis.hasUpdated = true;\n\t\t\tthis.firstUpdated(changed);\n\t\t}\n\t\tthis.updated(changed);\n\t}\n\t/**\n\t* Invoked before `update()` to compute values needed during the update.\n\t*\n\t* Implement `willUpdate` to compute property values that depend on other\n\t* properties and are used in the rest of the update process.\n\t*\n\t* ```ts\n\t* willUpdate(changed) {\n\t* if (changed.has('firstName') || changed.has('lastName')) {\n\t* this.sha = computeSHA(`${this.firstName} ${this.lastName}`);\n\t* }\n\t* }\n\t* ```\n\t*/\n\twillUpdate(_changed) {}\n\t/**\n\t* Updates the element. This method reflects property values to attributes\n\t* and can be overridden to render and keep updated element DOM. Setting\n\t* properties inside this method will *not* trigger another update.\n\t*/\n\tupdate(_changed) {}\n\t/**\n\t* Invoked when the element is first updated. Implement to perform one\n\t* time work on the element after update.\n\t*\n\t* Setting properties inside this method will trigger the element to\n\t* update again after this update cycle completes.\n\t*/\n\tfirstUpdated(_changed) {}\n\t/**\n\t* Invoked whenever the element is updated. Implement to perform\n\t* post-updating tasks via DOM APIs, for example, focusing an element.\n\t*\n\t* Setting properties inside this method will trigger the element to\n\t* update again after this update cycle completes.\n\t*/\n\tupdated(_changed) {}\n\t/**\n\t* Returns a Promise that resolves when the element has completed updating.\n\t* The Promise value is a boolean that is `true` if the element completed\n\t* the update without triggering another update. The Promise result is\n\t* `false` if a property was set inside `updated()`.\n\t*/\n\tget updateComplete() {\n\t\treturn this.#updatePromise;\n\t}\n};\n/**\n* Resolve `ctor.properties` into lookup Maps and install reactive accessors\n* on the prototype. Runs once per class, result is cached.\n*\n* Subclasses that need parent properties must spread them:\n* `static override properties = { ...Parent.properties, ... }`.\n*/\nfunction resolve(ctor) {\n\tconst existing = cache.get(ctor);\n\tif (existing) return existing;\n\tconst props = /* @__PURE__ */ new Map();\n\tconst attrToProp = /* @__PURE__ */ new Map();\n\tfor (const [name, decl] of Object.entries(ctor.properties)) {\n\t\tprops.set(name, decl);\n\t\tattrToProp.set(decl.attribute ?? name, name);\n\t\tif (!Object.getOwnPropertyDescriptor(ctor.prototype, name)?.get) {\n\t\t\tlet key = propertyKeys.get(name);\n\t\t\tif (!key) {\n\t\t\t\tkey = Symbol(name);\n\t\t\t\tpropertyKeys.set(name, key);\n\t\t\t}\n\t\t\tObject.defineProperty(ctor.prototype, name, {\n\t\t\t\tget() {\n\t\t\t\t\treturn this[key];\n\t\t\t\t},\n\t\t\t\tset(value) {\n\t\t\t\t\tconst old = this[key];\n\t\t\t\t\tthis[key] = value;\n\t\t\t\t\tif (!Object.is(old, value)) this.requestUpdate(name, old);\n\t\t\t\t},\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true\n\t\t\t});\n\t\t}\n\t}\n\tconst meta = {\n\t\tprops,\n\t\tattrToProp\n\t};\n\tcache.set(ctor, meta);\n\treturn meta;\n}\n\n//#endregion\nexport { ReactiveElement };\n//# sourceMappingURL=reactive-element.js.map","import { DestroyMixin, ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\n\n/** Base class for interactive media UI elements. */\nexport class MediaElement extends DestroyMixin(ReactiveElement) {}\n\nexport interface MediaElementConstructor extends Constructor<MediaElement> {}\n","import { playerContext } from '../player/context';\nimport { createContainerMixin } from '../store/container-mixin';\nimport { MediaElement } from '../ui/media-element';\n\nconst ContainerMixin = createContainerMixin(playerContext);\n\nexport class MediaContainerElement extends ContainerMixin(MediaElement) {\n static readonly tagName = 'media-container';\n}\n","import type { PlayerStore } from '@videojs/core/dom';\nimport { ContextProvider } from '@videojs/element/context';\nimport { isNull } from '@videojs/utils/predicate';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerProvider, PlayerProviderConstructor } from './types';\n\nexport type ProviderMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerProviderConstructor<Store>;\n\n/**\n * Create a mixin that provides player context to descendant elements.\n *\n * @param context - Player context to provide to descendants.\n * @param factory - Factory function that creates a store instance.\n */\nexport function createProviderMixin<Store extends PlayerStore>(\n context: PlayerContext<Store>,\n factory: () => Store\n): ProviderMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerProviderElement extends BaseClass implements PlayerProvider<Store> {\n #store: Store | null = factory();\n\n #provider = new ContextProvider(this, {\n context,\n initialValue: this.store,\n });\n\n get store(): Store {\n if (isNull(this.#store)) {\n this.#store = factory();\n }\n\n return this.#store;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n this.#provider.setValue(this.store);\n }\n\n override destroyCallback() {\n this.#store?.destroy();\n this.#store = null;\n super.destroyCallback();\n }\n }\n\n return PlayerProviderElement;\n };\n}\n","import { shallowEqual } from \"../../core/shallow-equal.js\";\nimport { noop } from \"@videojs/utils/function\";\n\n//#region src/html/controllers/snapshot-controller.ts\n/**\n* Subscribe to a `State<T>` container with optional selector.\n*\n* Without selector: returns full state, re-renders on any state change.\n* With selector: returns selected slice, re-renders only when the slice changes (shallowEqual).\n*\n* @example\n* ```ts\n* #state = new SnapshotController(this, sliderState, (s) => s.value);\n* ```\n*/\nvar SnapshotController = class {\n\t#host;\n\t#selector;\n\t#state;\n\t#cached;\n\t#unsubscribe = noop;\n\tconstructor(host, state, selector) {\n\t\tthis.#host = host;\n\t\tthis.#state = state;\n\t\tthis.#selector = selector;\n\t\thost.addController(this);\n\t}\n\tget value() {\n\t\tif (!this.#selector) return this.#state.current;\n\t\tthis.#cached ??= this.#selector(this.#state.current);\n\t\treturn this.#cached;\n\t}\n\t/** Switch to tracking a different state container. */\n\ttrack(state) {\n\t\tthis.#state = state;\n\t\tthis.#subscribe();\n\t}\n\thostConnected() {\n\t\tthis.#subscribe();\n\t}\n\thostDisconnected() {\n\t\tthis.#unsubscribe();\n\t\tthis.#unsubscribe = noop;\n\t\tthis.#cached = void 0;\n\t}\n\t#subscribe() {\n\t\tthis.#unsubscribe();\n\t\tif (!this.#selector) {\n\t\t\tthis.#unsubscribe = this.#state.subscribe(() => this.#host.requestUpdate());\n\t\t\treturn;\n\t\t}\n\t\tconst selector = this.#selector;\n\t\tthis.#cached = selector(this.#state.current);\n\t\tthis.#unsubscribe = this.#state.subscribe(() => {\n\t\t\tconst next = selector(this.#state.current);\n\t\t\tif (!shallowEqual(this.#cached, next)) {\n\t\t\t\tthis.#cached = next;\n\t\t\t\tthis.#host.requestUpdate();\n\t\t\t}\n\t\t});\n\t}\n};\n\n//#endregion\nexport { SnapshotController };\n//# sourceMappingURL=snapshot-controller.js.map","import { isStore } from \"../core/store.js\";\nimport { noop } from \"@videojs/utils/function\";\nimport { ContextConsumer } from \"@videojs/element/context\";\n\n//#region src/html/store-accessor.ts\n/**\n* Resolves a store from either a direct instance or context.\n*\n* When given a direct store, provides immediate access.\n* When given a context, sets up a ContextConsumer to receive the store.\n*\n* @example Direct store\n* ```ts\n* const accessor = new StoreAccessor(host, store, (s) => console.log('available', s));\n* accessor.value; // Store (immediately available)\n* ```\n*\n* @example Context source\n* ```ts\n* const accessor = new StoreAccessor(host, context, (s) => console.log('available', s));\n* accessor.value; // null until context provides store\n* ```\n*/\nvar StoreAccessor = class {\n\t#onAvailable;\n\t#consumer;\n\t#directStore;\n\tconstructor(host, source, onAvailable) {\n\t\tthis.#onAvailable = onAvailable ?? noop;\n\t\tif (isStore(source)) {\n\t\t\tthis.#directStore = source;\n\t\t\tthis.#consumer = null;\n\t\t} else {\n\t\t\tthis.#directStore = null;\n\t\t\tthis.#consumer = new ContextConsumer(host, {\n\t\t\t\tcontext: source,\n\t\t\t\tcallback: (store) => this.#onAvailable(store),\n\t\t\t\tsubscribe: false\n\t\t\t});\n\t\t}\n\t\thost.addController(this);\n\t}\n\t/** Returns the store, or null if not yet available from context. */\n\tget value() {\n\t\tif (this.#consumer) return this.#consumer.value ?? null;\n\t\treturn this.#directStore;\n\t}\n\thostConnected() {\n\t\tif (this.#directStore) this.#onAvailable(this.#directStore);\n\t}\n};\n\n//#endregion\nexport { StoreAccessor };\n//# sourceMappingURL=store-accessor.js.map","import { SnapshotController } from \"./snapshot-controller.js\";\nimport { StoreAccessor } from \"../store-accessor.js\";\nimport { isNull, isUndefined } from \"@videojs/utils/predicate\";\n\n//#region src/html/controllers/store-controller.ts\n/**\n* Access store state and actions.\n*\n* Without selector: Returns the store, does NOT subscribe to changes.\n* With selector: Returns selected state, triggers update when selected state changes (shallowEqual).\n*\n* @example\n* ```ts\n* // Store access (no subscription) - access actions\n* class Controls extends LitElement {\n* #store = new StoreController(this, storeSource);\n*\n* handleClick() {\n* this.#store.value.setVolume(0.5);\n* }\n* }\n*\n* // Selector-based subscription - re-renders when playback changes\n* class PlayButton extends LitElement {\n* #playback = new StoreController(this, storeSource, selectPlayback);\n*\n* render() {\n* const playback = this.#playback.value;\n* if (!playback) return nothing;\n* return html`<button @click=${playback.toggle}>\n* ${playback.paused ? 'Play' : 'Pause'}\n* </button>`;\n* }\n* }\n* ```\n*/\nvar StoreController = class {\n\t#host;\n\t#selector;\n\t#accessor;\n\t#snapshot = null;\n\tconstructor(host, source, selector) {\n\t\tthis.#host = host;\n\t\tthis.#selector = selector;\n\t\tthis.#accessor = new StoreAccessor(host, source, (store) => this.#connect(store));\n\t\thost.addController(this);\n\t}\n\tget value() {\n\t\tconst store = this.#accessor.value;\n\t\tif (isNull(store)) throw new Error(\"Store not available\");\n\t\tif (isUndefined(this.#selector)) return store;\n\t\treturn this.#snapshot.value;\n\t}\n\thostConnected() {}\n\t#connect(store) {\n\t\tif (isUndefined(this.#selector)) return;\n\t\tif (!this.#snapshot) this.#snapshot = new SnapshotController(this.#host, store.$state, this.#selector);\n\t\telse this.#snapshot.track(store.$state);\n\t}\n};\n\n//#endregion\nexport { StoreController };\n//# sourceMappingURL=store-controller.js.map","import type { PlayerStore } from '@videojs/core/dom';\nimport type { ReactiveController, ReactiveControllerHost } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\nimport type { InferStoreState, Selector } from '@videojs/store';\nimport { StoreController } from '@videojs/store/html';\n\nimport type { PlayerContext } from './context';\n\nexport type PlayerControllerHost = ReactiveControllerHost & HTMLElement;\n\n/**\n * Reactive controller for accessing player store state.\n *\n * Without selector: Returns the store, does NOT subscribe to changes.\n * With selector: Returns selected state, subscribes with shallowEqual comparison.\n *\n * @example\n * ```ts\n * // Store access (no subscription)\n * class Controls extends MediaElement {\n * #player = new PlayerController(this, playerContext);\n *\n * handleClick() {\n * this.#player.value.setVolume(0.5);\n * }\n * }\n *\n * // Selector-based subscription\n * class PlayButton extends MediaElement {\n * #playback = new PlayerController(this, playerContext, selectPlayback);\n * }\n * ```\n */\nexport class PlayerController<Store extends PlayerStore, Result = Store> implements ReactiveController {\n readonly #host: PlayerControllerHost;\n readonly #selector: Selector<InferStoreState<Store>, Result> | undefined;\n\n #consumer: ContextConsumer<PlayerContext<Store>, PlayerControllerHost>;\n #store: StoreController<Store, Result> | null = null;\n\n /**\n * @label Without Selector\n * @param host - The host element that owns this controller.\n * @param context - Player context to resolve the store from.\n */\n constructor(host: PlayerControllerHost, context: PlayerContext<Store>);\n /**\n * @label With Selector\n * @param host - The host element that owns this controller.\n * @param context - Player context to resolve the store from.\n * @param selector - Derives a value from the player store state.\n */\n constructor(\n host: PlayerControllerHost,\n context: PlayerContext<Store>,\n selector: Selector<InferStoreState<Store>, Result>\n );\n constructor(\n host: PlayerControllerHost,\n context: PlayerContext<Store>,\n selector?: Selector<InferStoreState<Store>, Result>\n ) {\n this.#host = host;\n this.#selector = selector;\n\n this.#consumer = new ContextConsumer(host, {\n context,\n callback: (ctx) => this.#connect(ctx),\n subscribe: true,\n });\n\n host.addController(this);\n }\n\n get value(): Result | undefined {\n const store = this.#consumer.value;\n if (!store) return undefined;\n\n // Without selector: return store directly\n if (!this.#selector) return store as unknown as Result;\n\n // With selector: use StoreController\n return this.#store?.value;\n }\n\n get displayName(): string | undefined {\n return this.#selector?.displayName;\n }\n\n hostConnected(): void {\n const store = this.#consumer.value;\n if (store) this.#connect(store);\n }\n\n hostDisconnected(): void {\n this.#store = null;\n }\n\n #connect(store: Store): void {\n if (!this.#store && this.#selector) {\n this.#store = new StoreController(this.#host, store, this.#selector);\n }\n }\n}\n\nexport namespace PlayerController {\n export type Host = PlayerControllerHost;\n\n export type Constructor<Store extends PlayerStore = PlayerStore, Result = Store> = typeof PlayerController<\n Store,\n Result\n >;\n}\n","import type {\n AnyPlayerFeature,\n AudioFeatures,\n AudioPlayerStore,\n PlayerStore,\n PlayerTarget,\n VideoFeatures,\n VideoPlayerStore,\n} from '@videojs/core/dom';\nimport { combine, createStore } from '@videojs/store';\n\nimport { type ContainerMixin, createContainerMixin } from '../store/container-mixin';\nimport { createProviderMixin, type ProviderMixin } from '../store/provider-mixin';\nimport { type PlayerContext, playerContext } from './context';\nimport { PlayerController } from './player-controller';\n\nexport interface CreatePlayerConfig<Features extends AnyPlayerFeature[]> {\n features: Features;\n}\n\nexport interface CreatePlayerResult<Store extends PlayerStore> {\n /** Context for consuming player in controllers. */\n context: PlayerContext<Store>;\n\n /** Creates a store instance for imperative access. */\n create: () => Store;\n\n /** Player controller bound to this player's context. */\n PlayerController: PlayerController.Constructor<Store>;\n\n /** Mixin that provides player context to descendants. */\n ProviderMixin: ProviderMixin<Store>;\n\n /** Mixin that consumes player context and auto-attaches media elements. */\n ContainerMixin: ContainerMixin<Store>;\n}\n\n/**\n * Creates a player factory with typed store, mixins, and controller.\n *\n * @example\n * ```ts\n * import { createPlayer, MediaElement, selectPlayback } from '@videojs/html';\n * import { videoFeatures } from '@videojs/html/video';\n *\n * const { ProviderMixin, ContainerMixin, PlayerController, context } = createPlayer({\n * features: videoFeatures,\n * });\n *\n * // Provider element: owns the store, provides context to descendants\n * class VideoPlayer extends ProviderMixin(MediaElement) {}\n * customElements.define('video-player', VideoPlayer);\n *\n * // Control element with selector\n * class PlayButton extends MediaElement {\n * #playback = new PlayerController(this, context, selectPlayback);\n * }\n * ```\n *\n * @label Video\n * @param config - Player configuration with features.\n */\nexport function createPlayer(config: CreatePlayerConfig<VideoFeatures>): CreatePlayerResult<VideoPlayerStore>;\n\n/**\n * Creates a player factory for audio media.\n *\n * @label Audio\n * @param config - Player configuration with features.\n */\nexport function createPlayer(config: CreatePlayerConfig<AudioFeatures>): CreatePlayerResult<AudioPlayerStore>;\n\n/**\n * Creates a player factory with custom features.\n *\n * @label Generic\n * @param config - Player configuration with features.\n */\nexport function createPlayer<const Features extends AnyPlayerFeature[]>(\n config: CreatePlayerConfig<Features>\n): CreatePlayerResult<PlayerStore<Features>>;\n\nexport function createPlayer(config: CreatePlayerConfig<AnyPlayerFeature[]>): CreatePlayerResult<PlayerStore> {\n const slice = combine<PlayerTarget, AnyPlayerFeature[]>(...config.features);\n\n function create(): PlayerStore {\n return createStore<PlayerTarget>()(slice);\n }\n\n const ProviderMixin = createProviderMixin<PlayerStore>(playerContext, create);\n const ContainerMixin = createContainerMixin<PlayerStore>(playerContext);\n\n return {\n context: playerContext,\n create,\n PlayerController,\n ProviderMixin,\n ContainerMixin,\n };\n}\n","type DefinableElement = CustomElementConstructor & { tagName: string };\n\n/** Define a custom element only if not already registered. */\nexport function safeDefine(element: DefinableElement): void {\n if (!customElements.get(element.tagName)) {\n customElements.define(element.tagName, element);\n }\n}\n","import { backgroundFeatures } from '@videojs/core/dom';\nimport { MediaContainerElement } from '../../media/container-element';\nimport { createPlayer } from '../../player/create-player';\nimport { MediaElement } from '../../ui/media-element';\nimport { safeDefine } from '../safe-define';\n\nconst { ProviderMixin } = createPlayer({\n features: backgroundFeatures,\n});\n\nexport class BackgroundVideoPlayerElement extends ProviderMixin(MediaElement) {\n static readonly tagName = 'background-video-player';\n}\n\n// Provider must be defined before consumer for context handshake during upgrade.\nsafeDefine(BackgroundVideoPlayerElement);\nsafeDefine(MediaContainerElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [BackgroundVideoPlayerElement.tagName]: BackgroundVideoPlayerElement;\n }\n}\n","import { ReactiveElement } from '@videojs/element';\nimport { namedNodeMapToObject } from '@videojs/utils/dom';\nimport { safeDefine } from '../safe-define';\n\nfunction getTemplateHTML(_attrs: Record<string, string>) {\n return /*html*/ `\n <media-container>\n <slot name=\"media\" slot=\"media\"></slot>\n </media-container>\n `;\n}\n\nexport class BackgroundVideoSkinElement extends ReactiveElement {\n static readonly tagName = 'background-video-skin';\n static shadowRootOptions = { mode: 'open' as ShadowRootMode };\n static getTemplateHTML = getTemplateHTML;\n\n constructor() {\n super();\n\n if (!this.shadowRoot) {\n this.attachShadow((this.constructor as typeof BackgroundVideoSkinElement).shadowRootOptions);\n this.shadowRoot!.innerHTML = getTemplateHTML(namedNodeMapToObject(this.attributes));\n }\n }\n}\n\nsafeDefine(BackgroundVideoSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [BackgroundVideoSkinElement.tagName]: BackgroundVideoSkinElement;\n }\n}\n"],"x_google_ignoreList":[34,35,36,37,38],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"background.js","names":["#base","#keys","#current","#markPending","#listeners","#pending","s","s","t","t","createContext","ContextConsumer","#contextStore","#attachMedia","#observer","#onSlotChange","#detach","#getSlottedMedia","#destroyed","#trackedControllers","#updatePromise","#instanceProperties","#controllers","#changedProperties","#enqueueUpdate","ContextProvider","#store","#provider","#host","#state","#selector","#cached","#subscribe","#unsubscribe","#onAvailable","#directStore","#consumer","ContextConsumer","#host","#selector","#accessor","#connect","#snapshot","#host","#selector","#consumer","ContextConsumer","#connect","#store"],"sources":["../../store/dist/default/core/abort-controller-registry.js","../../store/dist/default/core/combine.js","../../store/dist/default/core/errors.js","../../utils/dist/predicate/predicate.js","../../utils/dist/object/pick.js","../../store/dist/default/core/selector.js","../../store/dist/default/core/shallow-equal.js","../../store/dist/default/core/slice.js","../../utils/dist/function/noop.js","../../store/dist/default/core/state.js","../../store/dist/default/core/store.js","../../core/dist/default/dom/feature.js","../../utils/dist/dom/attributes.js","../../utils/dist/dom/event.js","../../utils/dist/dom/listen.js","../../utils/dist/dom/text-track.js","../../utils/dist/dom/time-ranges.js","../../core/dist/default/dom/store/features/buffer.js","../../core/dist/default/dom/store/features/controls.js","../../core/dist/default/dom/store/features/error.js","../../core/dist/default/dom/presentation/fullscreen.js","../../core/dist/default/dom/presentation/pip.js","../../core/dist/default/dom/store/features/fullscreen.js","../../core/dist/default/dom/store/features/pip.js","../../core/dist/default/dom/store/features/playback.js","../../core/dist/default/dom/store/features/playback-rate.js","../../core/dist/default/dom/store/features/source.js","../../core/dist/default/dom/store/features/text-track.js","../../core/dist/default/dom/media/predicate.js","../../core/dist/default/dom/store/signal-keys.js","../../core/dist/default/dom/store/features/time.js","../../core/dist/default/dom/store/features/volume.js","../../core/dist/default/dom/store/features/presets.js","../../core/dist/default/dom/store/selectors.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/context-request-event.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/create-context.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/controllers/context-consumer.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/value-notifier.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/lib/controllers/context-provider.js","../src/player/context.ts","../src/store/container-mixin.ts","../../element/dist/default/destroy-mixin.js","../../element/dist/default/reactive-element.js","../src/ui/media-element.ts","../src/media/container-element.ts","../src/store/provider-mixin.ts","../../store/dist/default/html/controllers/snapshot-controller.js","../../store/dist/default/html/store-accessor.js","../../store/dist/default/html/controllers/store-controller.js","../src/player/player-controller.ts","../src/player/create-player.ts","../src/define/safe-define.ts","../src/define/background/player.ts","../src/define/background/skin.ts"],"sourcesContent":["//#region src/core/abort-controller-registry.ts\nvar AbortControllerRegistry = class {\n\t#base = new AbortController();\n\t#keys = /* @__PURE__ */ new Map();\n\t/** The attach-scoped signal. Aborts on detach or reattach. */\n\tget base() {\n\t\treturn this.#base.signal;\n\t}\n\t/** Clears all keyed signals, leaving base intact. */\n\tclear() {\n\t\tfor (const controller of this.#keys.values()) controller.abort();\n\t\tthis.#keys.clear();\n\t}\n\t/** Resets base and clears all keyed signals. */\n\treset() {\n\t\tthis.clear();\n\t\tthis.#base.abort();\n\t\tthis.#base = new AbortController();\n\t}\n\t/** Creates a new signal for the key, superseding any previous signal. */\n\tsupersede(key) {\n\t\tthis.#keys.get(key)?.abort();\n\t\tconst controller = new AbortController();\n\t\tthis.#keys.set(key, controller);\n\t\treturn AbortSignal.any([this.#base.signal, controller.signal]);\n\t}\n};\n\n//#endregion\nexport { AbortControllerRegistry };\n//# sourceMappingURL=abort-controller-registry.js.map","//#region src/core/combine.ts\n/**\n* Combines multiple slices into a single slice.\n*\n* @param slices - The slices to combine.\n* @returns A new slice that represents the combination of the input slices.\n*/\nfunction combine(...slices) {\n\treturn {\n\t\tstate: (ctx) => {\n\t\t\tconst states = slices.map((slice) => slice.state(ctx));\n\t\t\treturn Object.assign({}, ...states);\n\t\t},\n\t\tattach: (ctx) => {\n\t\t\tfor (const slice of slices) try {\n\t\t\t\tslice.attach?.(ctx);\n\t\t\t} catch (err) {\n\t\t\t\tctx.reportError(err);\n\t\t\t}\n\t\t}\n\t};\n}\n\n//#endregion\nexport { combine };\n//# sourceMappingURL=combine.js.map","//#region src/core/errors.ts\nvar StoreError = class extends Error {\n\tcode;\n\tcause;\n\tconstructor(code, options) {\n\t\tsuper(options?.message ?? code);\n\t\tthis.name = \"StoreError\";\n\t\tthis.code = code;\n\t\tthis.cause = options?.cause;\n\t}\n};\nfunction isStoreError(error) {\n\treturn error instanceof StoreError;\n}\nfunction throwNoTargetError() {\n\tthrow new StoreError(\"NO_TARGET\");\n}\nfunction throwDestroyedError() {\n\tthrow new StoreError(\"DESTROYED\");\n}\n\n//#endregion\nexport { StoreError, isStoreError, throwDestroyedError, throwNoTargetError };\n//# sourceMappingURL=errors.js.map","//#region src/predicate/predicate.ts\nfunction isString(value) {\n\treturn typeof value === \"string\";\n}\nfunction isNumber(value) {\n\treturn typeof value === \"number\";\n}\nfunction isBoolean(value) {\n\treturn typeof value === \"boolean\";\n}\nfunction isFunction(value) {\n\treturn typeof value === \"function\";\n}\nfunction isNull(value) {\n\treturn value === null;\n}\nfunction isUndefined(value) {\n\treturn typeof value === \"undefined\";\n}\nfunction isNil(value) {\n\treturn value == null;\n}\nfunction isPromise(value) {\n\treturn value instanceof Promise;\n}\n/**\n* Check if a value is an object, excluding null.\n*/\nfunction isObject(value) {\n\treturn value !== null && typeof value === \"object\";\n}\n/**\n* Check if a value is a plain object (not a class instance like Date, Map, etc).\n*/\nfunction isPlainObject(value) {\n\tif (!isObject(value)) return false;\n\tconst proto = Object.getPrototypeOf(value);\n\treturn proto === null || proto === Object.prototype;\n}\n/**\n* Check if a value is an AbortError.\n*/\nfunction isAbortError(value) {\n\treturn value instanceof Error && value.name === \"AbortError\";\n}\n\n//#endregion\nexport { isAbortError, isBoolean, isFunction, isNil, isNull, isNumber, isObject, isPlainObject, isPromise, isString, isUndefined };\n//# sourceMappingURL=predicate.js.map","//#region src/object/pick.ts\n/**\n* Creates a new object with only the specified keys.\n*\n* @example\n* const obj = { a: 1, b: 2, c: 3 };\n* pick(obj, ['a', 'c']); // { a: 1, c: 3 }\n*/\nfunction pick(obj, keys) {\n\tconst result = {};\n\tfor (const key of keys) result[key] = obj[key];\n\treturn result;\n}\n\n//#endregion\nexport { pick };\n//# sourceMappingURL=pick.js.map","import { AbortControllerRegistry } from \"./abort-controller-registry.js\";\nimport { throwNoTargetError } from \"./errors.js\";\nimport { pick } from \"@videojs/utils/object\";\n\n//#region src/core/selector.ts\nconst stateContext = {\n\ttarget: throwNoTargetError,\n\tsignals: new AbortControllerRegistry(),\n\tset: throwNoTargetError\n};\n/**\n* Create a type-safe selector for a slice's state.\n*\n* The selector returns the slice's state, or `undefined` if the slice\n* is not configured in the store.\n*\n* @example\n* ```ts\n* const selectPlayback = createSelector(playbackSlice);\n* selectPlayback(store.state); // { paused, play, pause, ... } | undefined\n* selectPlayback.displayName; // 'playback' (from slice name)\n* ```\n*\n* @param slice - The slice to create a selector for.\n*/\nfunction createSelector(slice) {\n\tconst initialState = slice.state(stateContext);\n\tconst keys = Object.keys(initialState);\n\tconst firstKey = keys[0];\n\tif (!firstKey) return Object.assign(() => void 0, { displayName: slice.name });\n\treturn Object.assign((state) => {\n\t\tif (!(firstKey in state)) return void 0;\n\t\treturn pick(state, keys);\n\t}, { displayName: slice.name });\n}\n\n//#endregion\nexport { createSelector };\n//# sourceMappingURL=selector.js.map","//#region src/core/shallow-equal.ts\nconst hasOwn = Object.prototype.hasOwnProperty;\nfunction shallowEqual(a, b) {\n\tif (Object.is(a, b)) return true;\n\tif (typeof a !== \"object\" || a === null || typeof b !== \"object\" || b === null) return false;\n\tconst keysA = Object.keys(a);\n\tconst keysB = Object.keys(b);\n\tif (keysA.length !== keysB.length) return false;\n\tfor (const key of keysA) if (!hasOwn.call(b, key) || !Object.is(a[key], b[key])) return false;\n\treturn true;\n}\n\n//#endregion\nexport { shallowEqual };\n//# sourceMappingURL=shallow-equal.js.map","//#region src/core/slice.ts\nfunction defineSlice() {\n\treturn (config) => config;\n}\n\n//#endregion\nexport { defineSlice };\n//# sourceMappingURL=slice.js.map","//#region src/function/noop.ts\nfunction noop(..._args) {}\n\n//#endregion\nexport { noop };\n//# sourceMappingURL=noop.js.map","import { noop } from \"@videojs/utils/function\";\n\n//#region src/core/state.ts\nlet isFlushScheduled = false;\nfunction scheduleFlush() {\n\tif (isFlushScheduled) return;\n\tisFlushScheduled = true;\n\tqueueMicrotask(flush);\n}\nconst pendingContainers = /* @__PURE__ */ new Set();\nfunction flush() {\n\tisFlushScheduled = false;\n\tfor (const container of pendingContainers) container.flush();\n\tpendingContainers.clear();\n}\nconst hasOwnProp = Object.prototype.hasOwnProperty;\nvar StateContainer = class {\n\t#current;\n\t#listeners = /* @__PURE__ */ new Set();\n\t#pending = false;\n\tconstructor(initial) {\n\t\tthis.#current = Object.freeze({ ...initial });\n\t}\n\tget current() {\n\t\treturn this.#current;\n\t}\n\tpatch(partial) {\n\t\tconst next = { ...this.#current };\n\t\tlet changed = false;\n\t\tfor (const key in partial) {\n\t\t\tif (!hasOwnProp.call(partial, key)) continue;\n\t\t\tconst value = partial[key];\n\t\t\tif (!Object.is(this.#current[key], value)) {\n\t\t\t\tnext[key] = value;\n\t\t\t\tchanged = true;\n\t\t\t}\n\t\t}\n\t\tif (changed) {\n\t\t\tthis.#current = Object.freeze(next);\n\t\t\tthis.#markPending();\n\t\t}\n\t}\n\tsubscribe(callback, options) {\n\t\tconst signal = options?.signal;\n\t\tif (signal?.aborted) return noop;\n\t\tthis.#listeners.add(callback);\n\t\tif (!signal) return () => this.#listeners.delete(callback);\n\t\tconst onAbort = () => this.#listeners.delete(callback);\n\t\tsignal.addEventListener(\"abort\", onAbort, { once: true });\n\t\treturn () => {\n\t\t\tsignal.removeEventListener(\"abort\", onAbort);\n\t\t\tthis.#listeners.delete(callback);\n\t\t};\n\t}\n\tflush() {\n\t\tif (!this.#pending) return;\n\t\tthis.#pending = false;\n\t\tfor (const fn of this.#listeners) fn();\n\t}\n\t#markPending() {\n\t\tthis.#pending = true;\n\t\tpendingContainers.add(this);\n\t\tscheduleFlush();\n\t}\n};\nfunction createState(initial) {\n\treturn new StateContainer(initial);\n}\nfunction isState(value) {\n\treturn value instanceof StateContainer;\n}\n\n//#endregion\nexport { createState, flush, isState };\n//# sourceMappingURL=state.js.map","import { AbortControllerRegistry } from \"./abort-controller-registry.js\";\nimport { throwDestroyedError, throwNoTargetError } from \"./errors.js\";\nimport { createState } from \"./state.js\";\nimport { isNull, isObject } from \"@videojs/utils/predicate\";\n\n//#region src/core/store.ts\nconst STORE_SYMBOL = Symbol(\"@videojs/store\");\nfunction createStore() {\n\treturn (slice, options = {}) => {\n\t\tlet target = null;\n\t\tlet destroyed = false;\n\t\tconst setupAbort = new AbortController();\n\t\tconst signals = new AbortControllerRegistry();\n\t\tlet state;\n\t\tfunction validate() {\n\t\t\tif (destroyed) throwDestroyedError();\n\t\t\tif (!target) throwNoTargetError();\n\t\t}\n\t\tconst initialState = slice.state({\n\t\t\ttarget: () => {\n\t\t\t\tvalidate();\n\t\t\t\treturn target;\n\t\t\t},\n\t\t\tsignals,\n\t\t\tset: (partial) => state.patch(partial)\n\t\t});\n\t\tstate = createState(initialState);\n\t\tconst store = {\n\t\t\t[STORE_SYMBOL]: true,\n\t\t\tget $state() {\n\t\t\t\treturn state;\n\t\t\t},\n\t\t\tget target() {\n\t\t\t\treturn target;\n\t\t\t},\n\t\t\tget destroyed() {\n\t\t\t\treturn destroyed;\n\t\t\t},\n\t\t\tget state() {\n\t\t\t\treturn state.current;\n\t\t\t},\n\t\t\tattach,\n\t\t\tdestroy,\n\t\t\tsubscribe\n\t\t};\n\t\tfor (const key of Object.keys(initialState)) Object.defineProperty(store, key, {\n\t\t\tget: () => state.current[key],\n\t\t\tenumerable: true\n\t\t});\n\t\ttry {\n\t\t\toptions.onSetup?.({\n\t\t\t\tstore,\n\t\t\t\tsignal: setupAbort.signal\n\t\t\t});\n\t\t} catch (error) {\n\t\t\treportError(error);\n\t\t}\n\t\treturn store;\n\t\tfunction attach(newTarget) {\n\t\t\tif (destroyed) throwDestroyedError();\n\t\t\tsignals.reset();\n\t\t\ttarget = newTarget;\n\t\t\tconst attachContext = {\n\t\t\t\ttarget: newTarget,\n\t\t\t\tsignal: signals.base,\n\t\t\t\tget: () => state.current,\n\t\t\t\tset: (partial) => state.patch(partial),\n\t\t\t\treportError,\n\t\t\t\tstore: {\n\t\t\t\t\tget state() {\n\t\t\t\t\t\treturn state.current;\n\t\t\t\t\t},\n\t\t\t\t\tsubscribe\n\t\t\t\t}\n\t\t\t};\n\t\t\ttry {\n\t\t\t\tslice.attach?.(attachContext);\n\t\t\t} catch (error) {\n\t\t\t\treportError(error);\n\t\t\t}\n\t\t\ttry {\n\t\t\t\toptions.onAttach?.({\n\t\t\t\t\tstore,\n\t\t\t\t\ttarget: newTarget,\n\t\t\t\t\tsignal: signals.base\n\t\t\t\t});\n\t\t\t} catch (error) {\n\t\t\t\treportError(error);\n\t\t\t}\n\t\t\treturn detach;\n\t\t}\n\t\tfunction detach() {\n\t\t\tif (isNull(target)) return;\n\t\t\tsignals.reset();\n\t\t\ttarget = null;\n\t\t\tstate.patch(initialState);\n\t\t}\n\t\tfunction destroy() {\n\t\t\tif (destroyed) return;\n\t\t\tdestroyed = true;\n\t\t\tdetach();\n\t\t\tsetupAbort.abort();\n\t\t}\n\t\tfunction subscribe(callback, options) {\n\t\t\treturn state.subscribe(callback, options);\n\t\t}\n\t\tfunction reportError(error) {\n\t\t\tif (options.onError) options.onError({\n\t\t\t\tstore,\n\t\t\t\terror\n\t\t\t});\n\t\t\telse console.error(\"[vjs-store]\", error);\n\t\t}\n\t};\n}\nfunction isStore(value) {\n\treturn isObject(value) && STORE_SYMBOL in value;\n}\n\n//#endregion\nexport { createStore, isStore };\n//# sourceMappingURL=store.js.map","import { defineSlice } from \"@videojs/store\";\n\n//#region src/dom/feature.ts\nconst definePlayerFeature = defineSlice();\n\n//#endregion\nexport { definePlayerFeature };\n//# sourceMappingURL=feature.js.map","//#region src/dom/attributes.ts\nfunction namedNodeMapToObject(namedNodeMap) {\n\tconst obj = {};\n\tfor (const attr of namedNodeMap) obj[attr.name] = attr.value;\n\treturn obj;\n}\n\n//#endregion\nexport { namedNodeMapToObject };\n//# sourceMappingURL=attributes.js.map","//#region src/dom/event.ts\nfunction onEvent(target, type, options) {\n\treturn new Promise((resolve, reject) => {\n\t\tconst handleAbort = () => {\n\t\t\treject(options?.signal?.reason ?? \"Aborted\");\n\t\t};\n\t\tif (options?.signal?.aborted) {\n\t\t\thandleAbort();\n\t\t\treturn;\n\t\t}\n\t\toptions?.signal?.addEventListener(\"abort\", handleAbort, { once: true });\n\t\ttarget.addEventListener(type, (event) => {\n\t\t\toptions?.signal?.removeEventListener(\"abort\", handleAbort);\n\t\t\tresolve(event);\n\t\t}, {\n\t\t\t...options,\n\t\t\tonce: true\n\t\t});\n\t});\n}\n\n//#endregion\nexport { onEvent };\n//# sourceMappingURL=event.js.map","//#region src/dom/listen.ts\nfunction listen(target, type, listener, options) {\n\ttarget.addEventListener(type, listener, options);\n\treturn () => target.removeEventListener(type, listener, options);\n}\n\n//#endregion\nexport { listen };\n//# sourceMappingURL=listen.js.map","//#region src/dom/text-track.ts\n/** Find the `<track>` element that owns the given `TextTrack`. */\nfunction findTrackElement(media, track) {\n\tfor (const el of media.querySelectorAll(\"track\")) if (el.track === track) return el;\n\treturn null;\n}\nfunction getTextTrackList(media, filterPred) {\n\tif (!media?.textTracks) return [];\n\treturn Array.from(media.textTracks).filter(filterPred).sort(sortByTextTrackKind);\n}\nfunction sortByTextTrackKind(a, b) {\n\treturn a.kind >= b.kind ? 1 : -1;\n}\n\n//#endregion\nexport { findTrackElement, getTextTrackList };\n//# sourceMappingURL=text-track.js.map","//#region src/dom/time-ranges.ts\n/** Converts a TimeRanges object to an array of [start, end] tuples. */\nfunction serializeTimeRanges(ranges) {\n\tconst result = [];\n\tfor (let i = 0; i < ranges.length; i++) result.push([ranges.start(i), ranges.end(i)]);\n\treturn result;\n}\n\n//#endregion\nexport { serializeTimeRanges };\n//# sourceMappingURL=time-ranges.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen, serializeTimeRanges } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/buffer.ts\nconst bufferFeature = definePlayerFeature({\n\tname: \"buffer\",\n\tstate: () => ({\n\t\tbuffered: [],\n\t\tseekable: []\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({\n\t\t\tbuffered: serializeTimeRanges(media.buffered),\n\t\t\tseekable: serializeTimeRanges(media.seekable)\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"progress\", sync, { signal });\n\t\tlisten(media, \"emptied\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { bufferFeature };\n//# sourceMappingURL=buffer.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { isNull } from \"@videojs/utils/predicate\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/controls.ts\nconst IDLE_DELAY = 2e3;\nconst TAP_THRESHOLD = 250;\nconst controlsFeature = definePlayerFeature({\n\tname: \"controls\",\n\tstate: () => ({\n\t\tuserActive: true,\n\t\tcontrolsVisible: true\n\t}),\n\tattach({ target, signal, get, set }) {\n\t\tconst { media, container } = target;\n\t\tif (isNull(container)) return;\n\t\tfunction computeVisible(userActive) {\n\t\t\treturn userActive || media.paused;\n\t\t}\n\t\tlet idleTimer;\n\t\tfunction clearIdle() {\n\t\t\tclearTimeout(idleTimer);\n\t\t\tidleTimer = void 0;\n\t\t}\n\t\tfunction scheduleIdle() {\n\t\t\tclearIdle();\n\t\t\tidleTimer = setTimeout(setInactive, IDLE_DELAY);\n\t\t}\n\t\tfunction setActive() {\n\t\t\tif (!get().userActive) set({\n\t\t\t\tuserActive: true,\n\t\t\t\tcontrolsVisible: true\n\t\t\t});\n\t\t\tscheduleIdle();\n\t\t}\n\t\tfunction setInactive() {\n\t\t\tclearIdle();\n\t\t\tset({\n\t\t\t\tuserActive: false,\n\t\t\t\tcontrolsVisible: computeVisible(false)\n\t\t\t});\n\t\t}\n\t\tlet pointerDownTime = 0;\n\t\tfunction onPointerDown() {\n\t\t\tpointerDownTime = Date.now();\n\t\t}\n\t\tfunction onPointerUp(event) {\n\t\t\tif (event.pointerType === \"touch\" && Date.now() - pointerDownTime < TAP_THRESHOLD) if (get().controlsVisible) {\n\t\t\t\tclearIdle();\n\t\t\t\tset({\n\t\t\t\t\tuserActive: false,\n\t\t\t\t\tcontrolsVisible: computeVisible(false)\n\t\t\t\t});\n\t\t\t} else setActive();\n\t\t\telse setActive();\n\t\t}\n\t\tfunction onPlaybackChange() {\n\t\t\tconst { userActive } = get();\n\t\t\tset({ controlsVisible: computeVisible(userActive) });\n\t\t\tif (!media.paused && userActive) scheduleIdle();\n\t\t}\n\t\tlisten(container, \"pointermove\", setActive, { signal });\n\t\tlisten(container, \"pointerdown\", onPointerDown, { signal });\n\t\tlisten(container, \"pointerup\", onPointerUp, { signal });\n\t\tlisten(container, \"keyup\", setActive, { signal });\n\t\tlisten(container, \"focusin\", setActive, { signal });\n\t\tlisten(container, \"pointerleave\", setInactive, { signal });\n\t\tlisten(media, \"play\", onPlaybackChange, { signal });\n\t\tlisten(media, \"pause\", onPlaybackChange, { signal });\n\t\tlisten(media, \"ended\", onPlaybackChange, { signal });\n\t\tsignal.addEventListener(\"abort\", clearIdle, { once: true });\n\t\tscheduleIdle();\n\t}\n});\n\n//#endregion\nexport { controlsFeature };\n//# sourceMappingURL=controls.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/error.ts\nconst errorFeature = definePlayerFeature({\n\tname: \"error\",\n\tstate: ({ set }) => ({\n\t\terror: null,\n\t\tdismissError() {\n\t\t\tset({ error: null });\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst syncError = () => set({ error: media.error });\n\t\tlisten(media, \"error\", syncError, { signal });\n\t\tlisten(media, \"emptied\", () => set({ error: null }), { signal });\n\t}\n});\n\n//#endregion\nexport { errorFeature };\n//# sourceMappingURL=error.js.map","import { isFunction } from \"@videojs/utils/predicate\";\n\n//#region src/dom/presentation/fullscreen.ts\n/** Check if the Fullscreen API is supported on this platform. */\nfunction isFullscreenEnabled() {\n\tconst doc = document;\n\tif (doc.fullscreenEnabled || doc.webkitFullscreenEnabled) return true;\n\treturn document.createElement(\"video\").webkitSupportsFullscreen === true;\n}\n/** Get the current fullscreen element from the document. */\nfunction getFullscreenElement() {\n\tconst doc = document;\n\treturn doc.fullscreenElement ?? doc.webkitFullscreenElement ?? null;\n}\n/**\n* Check if a specific element (or its media) is currently in fullscreen.\n*\n* Uses `:fullscreen` pseudo-class which works across Shadow DOM boundaries.\n*/\nfunction isFullscreenElement(container, media) {\n\tconst video = media;\n\tif (video.webkitDisplayingFullscreen && video.webkitPresentationMode === \"fullscreen\") return true;\n\tconst target = container ?? media;\n\tif (getFullscreenElement() === target) return true;\n\ttry {\n\t\treturn target.matches(\":fullscreen\");\n\t} catch {\n\t\treturn false;\n\t}\n}\n/**\n* Request fullscreen mode.\n*\n* Tries container first (to show custom UI), falls back to media element\n* for platforms that only support video fullscreen (iOS Safari).\n*/\nasync function requestFullscreen(container, media) {\n\tconst video = media;\n\tif (container) {\n\t\tconst el = container;\n\t\tif (isFunction(el.requestFullscreen)) return el.requestFullscreen();\n\t\tif (isFunction(el.webkitRequestFullscreen)) return el.webkitRequestFullscreen();\n\t\tif (isFunction(el.webkitRequestFullScreen)) return el.webkitRequestFullScreen();\n\t}\n\tif (isFunction(video.webkitEnterFullscreen)) {\n\t\tvideo.webkitEnterFullscreen();\n\t\treturn;\n\t}\n\tif (isFunction(media.requestFullscreen)) return media.requestFullscreen();\n\tthrow new DOMException(\"Fullscreen not supported\", \"NotSupportedError\");\n}\n/** Exit fullscreen mode. */\nasync function exitFullscreen() {\n\tconst doc = document;\n\tconst video = getFullscreenElement();\n\tif (isFunction(doc.exitFullscreen)) return doc.exitFullscreen();\n\tif (isFunction(doc.webkitExitFullscreen)) return doc.webkitExitFullscreen();\n\tif (isFunction(doc.webkitCancelFullScreen)) return doc.webkitCancelFullScreen();\n\tif (video && isFunction(video.webkitExitFullscreen)) {\n\t\tvideo.webkitExitFullscreen();\n\t\treturn;\n\t}\n}\n\n//#endregion\nexport { exitFullscreen, isFullscreenElement, isFullscreenEnabled, requestFullscreen };\n//# sourceMappingURL=fullscreen.js.map","import { isFunction } from \"@videojs/utils/predicate\";\n\n//#region src/dom/presentation/pip.ts\nfunction resolveMediaTarget(media) {\n\tconst target = media.target;\n\treturn target instanceof HTMLMediaElement ? target : media;\n}\n/**\n* Check if Picture-in-Picture is supported on this platform.\n*\n* Note: Safari PWAs don't support PiP even though the API exists.\n*/\nfunction isPictureInPictureEnabled() {\n\tif (document.pictureInPictureEnabled) {\n\t\tconst isSafari = /.*Version\\/.*Safari\\/.*/.test(navigator.userAgent);\n\t\tconst isPWA = typeof matchMedia === \"function\" && matchMedia(\"(display-mode: standalone)\").matches;\n\t\treturn !isSafari || !isPWA;\n\t}\n\treturn isFunction(document.createElement(\"video\").webkitSetPresentationMode);\n}\n/**\n* Check if Picture-in-Picture is currently active for a media element.\n*/\nfunction isPictureInPictureElement(media) {\n\tconst target = resolveMediaTarget(media);\n\tif (document.pictureInPictureElement === target) return true;\n\treturn target.webkitPresentationMode === \"picture-in-picture\";\n}\n/**\n* Request Picture-in-Picture mode.\n*\n* Uses standard API where available, falls back to iOS Safari's\n* WebKit presentation mode.\n*/\nasync function requestPictureInPicture(media) {\n\tconst video = resolveMediaTarget(media);\n\tif (isFunction(video.requestPictureInPicture)) {\n\t\tawait video.requestPictureInPicture();\n\t\treturn;\n\t}\n\tif (isFunction(video.webkitSetPresentationMode)) {\n\t\tvideo.webkitSetPresentationMode(\"picture-in-picture\");\n\t\treturn;\n\t}\n\tthrow new DOMException(\"Picture-in-Picture not supported\", \"NotSupportedError\");\n}\n/**\n* Exit Picture-in-Picture mode.\n*\n* Uses standard API where available, falls back to iOS Safari's\n* WebKit presentation mode.\n*/\nasync function exitPictureInPicture(media) {\n\tif (isFunction(document.exitPictureInPicture)) try {\n\t\tawait document.exitPictureInPicture();\n\t\treturn;\n\t} catch {}\n\tif (media) {\n\t\tconst video = resolveMediaTarget(media);\n\t\tconst mode = video.webkitPresentationMode;\n\t\tif (isFunction(video.webkitSetPresentationMode) && (!mode || mode === \"picture-in-picture\")) {\n\t\t\tvideo.webkitSetPresentationMode(\"inline\");\n\t\t\treturn;\n\t\t}\n\t}\n}\n\n//#endregion\nexport { exitPictureInPicture, isPictureInPictureElement, isPictureInPictureEnabled, requestPictureInPicture };\n//# sourceMappingURL=pip.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { exitFullscreen, isFullscreenElement, isFullscreenEnabled, requestFullscreen } from \"../../presentation/fullscreen.js\";\nimport { exitPictureInPicture, isPictureInPictureElement } from \"../../presentation/pip.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/fullscreen.ts\nconst fullscreenFeature = definePlayerFeature({\n\tname: \"fullscreen\",\n\tstate: ({ target }) => ({\n\t\tfullscreen: false,\n\t\tfullscreenAvailability: \"unavailable\",\n\t\tasync requestFullscreen() {\n\t\t\tconst { media, container } = target();\n\t\t\tif (isPictureInPictureElement(media)) await exitPictureInPicture(media);\n\t\t\treturn requestFullscreen(container, media);\n\t\t},\n\t\tasync exitFullscreen() {\n\t\t\treturn exitFullscreen();\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media, container } = target;\n\t\tset({ fullscreenAvailability: isFullscreenEnabled() ? \"available\" : \"unsupported\" });\n\t\tconst sync = () => set({ fullscreen: isFullscreenElement(container, media) });\n\t\tsync();\n\t\tlisten(document, \"fullscreenchange\", sync, { signal });\n\t\tlisten(document, \"webkitfullscreenchange\", sync, { signal });\n\t\tif (\"webkitPresentationMode\" in media) listen(media, \"webkitpresentationmodechanged\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { fullscreenFeature };\n//# sourceMappingURL=fullscreen.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { exitFullscreen, isFullscreenElement } from \"../../presentation/fullscreen.js\";\nimport { exitPictureInPicture, isPictureInPictureElement, isPictureInPictureEnabled, requestPictureInPicture } from \"../../presentation/pip.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/pip.ts\nconst pipFeature = definePlayerFeature({\n\tname: \"pip\",\n\tstate: ({ target }) => ({\n\t\tpip: false,\n\t\tpipAvailability: \"unavailable\",\n\t\tasync requestPictureInPicture() {\n\t\t\tconst { media, container } = target();\n\t\t\tif (isFullscreenElement(container, media)) await exitFullscreen();\n\t\t\treturn requestPictureInPicture(media);\n\t\t},\n\t\tasync exitPictureInPicture() {\n\t\t\tconst { media } = target();\n\t\t\treturn exitPictureInPicture(media);\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tset({ pipAvailability: isPictureInPictureEnabled() ? \"available\" : \"unsupported\" });\n\t\tconst sync = () => set({ pip: isPictureInPictureElement(media) });\n\t\tsync();\n\t\tlisten(media, \"enterpictureinpicture\", sync, { signal });\n\t\tlisten(media, \"leavepictureinpicture\", sync, { signal });\n\t\tif (\"webkitPresentationMode\" in media) listen(media, \"webkitpresentationmodechanged\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { pipFeature };\n//# sourceMappingURL=pip.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/playback.ts\nconst playbackFeature = definePlayerFeature({\n\tname: \"playback\",\n\tstate: ({ target }) => ({\n\t\tpaused: true,\n\t\tended: false,\n\t\tstarted: false,\n\t\twaiting: false,\n\t\tplay() {\n\t\t\treturn target().media.play();\n\t\t},\n\t\tpause() {\n\t\t\ttarget().media.pause();\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({\n\t\t\tpaused: media.paused,\n\t\t\tended: media.ended,\n\t\t\tstarted: !media.paused || media.currentTime > 0,\n\t\t\twaiting: media.readyState < HTMLMediaElement.HAVE_FUTURE_DATA && !media.paused\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"emptied\", sync, { signal });\n\t\tlisten(media, \"play\", sync, { signal });\n\t\tlisten(media, \"pause\", sync, { signal });\n\t\tlisten(media, \"ended\", sync, { signal });\n\t\tlisten(media, \"playing\", sync, { signal });\n\t\tlisten(media, \"waiting\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { playbackFeature };\n//# sourceMappingURL=playback.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/playback-rate.ts\nconst DEFAULT_RATES = [\n\t1,\n\t1.2,\n\t1.5,\n\t1.7,\n\t2\n];\nconst playbackRateFeature = definePlayerFeature({\n\tname: \"playbackRate\",\n\tstate: ({ target }) => ({\n\t\tplaybackRates: DEFAULT_RATES,\n\t\tplaybackRate: 1,\n\t\tsetPlaybackRate(rate) {\n\t\t\ttarget().media.playbackRate = rate;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({ playbackRate: media.playbackRate });\n\t\tsync();\n\t\tlisten(media, \"ratechange\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { playbackRateFeature };\n//# sourceMappingURL=playback-rate.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/source.ts\nconst sourceFeature = definePlayerFeature({\n\tname: \"source\",\n\tstate: ({ target, signals }) => ({\n\t\tsource: null,\n\t\tcanPlay: false,\n\t\tloadSource(src) {\n\t\t\tsignals.clear();\n\t\t\tconst { media } = target();\n\t\t\tmedia.src = src;\n\t\t\tmedia.load();\n\t\t\treturn src;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({\n\t\t\tsource: media.currentSrc || media.src || null,\n\t\t\tcanPlay: media.readyState >= HTMLMediaElement.HAVE_ENOUGH_DATA\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"canplay\", sync, { signal });\n\t\tlisten(media, \"canplaythrough\", sync, { signal });\n\t\tlisten(media, \"loadstart\", sync, { signal });\n\t\tlisten(media, \"emptied\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { sourceFeature };\n//# sourceMappingURL=source.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { findTrackElement, getTextTrackList, listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/text-track.ts\nconst textTrackFeature = definePlayerFeature({\n\tname: \"textTrack\",\n\tstate: ({ target }) => ({\n\t\tchaptersCues: [],\n\t\tthumbnailCues: [],\n\t\tthumbnailTrackSrc: null,\n\t\ttextTrackList: [],\n\t\tsubtitlesShowing: false,\n\t\ttoggleSubtitles(forceShow) {\n\t\t\tconst subtitlesTracks = getTextTrackList(target().media, (track) => track.kind === \"subtitles\" || track.kind === \"captions\");\n\t\t\tif (!subtitlesTracks.length) return false;\n\t\t\tconst showing = subtitlesTracks.some((track) => track.mode === \"showing\");\n\t\t\tconst nextShowing = forceShow ?? !showing;\n\t\t\tfor (const track of subtitlesTracks) track.mode = nextShowing ? \"showing\" : \"disabled\";\n\t\t\treturn nextShowing;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tlet trackCleanup = null;\n\t\tfunction sync() {\n\t\t\ttrackCleanup?.abort();\n\t\t\ttrackCleanup = new AbortController();\n\t\t\tlet chaptersTrack = null;\n\t\t\tlet thumbnailTrack = null;\n\t\t\tconst textTrackList = [];\n\t\t\tlet subtitlesShowing = false;\n\t\t\tfor (let i = 0; i < media.textTracks.length; i++) {\n\t\t\t\tconst track = media.textTracks[i];\n\t\t\t\tif (!chaptersTrack && track.kind === \"chapters\") chaptersTrack = track;\n\t\t\t\tif (!thumbnailTrack && track.kind === \"metadata\" && track.label === \"thumbnails\") thumbnailTrack = track;\n\t\t\t\ttextTrackList.push({\n\t\t\t\t\tkind: track.kind,\n\t\t\t\t\tlabel: track.label,\n\t\t\t\t\tlanguage: track.language,\n\t\t\t\t\tmode: track.mode\n\t\t\t\t});\n\t\t\t\tif ((track.kind === \"captions\" || track.kind === \"subtitles\") && track.mode === \"showing\") subtitlesShowing = true;\n\t\t\t}\n\t\t\tconst chaptersCues = chaptersTrack?.cues ? Array.from(chaptersTrack.cues) : [];\n\t\t\tconst thumbnailCues = thumbnailTrack?.cues ? Array.from(thumbnailTrack.cues) : [];\n\t\t\tlet thumbnailTrackSrc = null;\n\t\t\tif (thumbnailTrack) thumbnailTrackSrc = findTrackElement(media, thumbnailTrack)?.src ?? null;\n\t\t\tfor (const trackEl of media.querySelectorAll?.(\"track\") ?? []) if (!trackEl.track?.cues?.length) listen(trackEl, \"load\", sync, { signal: trackCleanup.signal });\n\t\t\tset({\n\t\t\t\tchaptersCues,\n\t\t\t\tthumbnailCues,\n\t\t\t\tthumbnailTrackSrc,\n\t\t\t\ttextTrackList,\n\t\t\t\tsubtitlesShowing\n\t\t\t});\n\t\t}\n\t\tsync();\n\t\tlisten(media.textTracks, \"addtrack\", sync, { signal });\n\t\tlisten(media.textTracks, \"removetrack\", sync, { signal });\n\t\tlisten(media.textTracks, \"change\", sync, { signal });\n\t\tlisten(media, \"loadstart\", sync, { signal });\n\t\tsignal.addEventListener(\"abort\", () => trackCleanup?.abort(), { once: true });\n\t}\n});\n\n//#endregion\nexport { textTrackFeature };\n//# sourceMappingURL=text-track.js.map","//#region src/dom/media/predicate.ts\nfunction hasMetadata(media) {\n\treturn media.readyState >= HTMLMediaElement.HAVE_METADATA;\n}\n\n//#endregion\nexport { hasMetadata };\n//# sourceMappingURL=predicate.js.map","//#region src/dom/store/signal-keys.ts\nconst signalKeys = { seek: Symbol.for(\"@videojs/seek\") };\n\n//#endregion\nexport { signalKeys };\n//# sourceMappingURL=signal-keys.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { hasMetadata } from \"../../media/predicate.js\";\nimport { signalKeys } from \"../signal-keys.js\";\nimport { listen, onEvent } from \"@videojs/utils/dom\";\nimport { noop } from \"@videojs/utils/function\";\n\n//#region src/dom/store/features/time.ts\nconst timeFeature = definePlayerFeature({\n\tname: \"time\",\n\tstate: ({ target, signals, set }) => ({\n\t\tcurrentTime: 0,\n\t\tduration: 0,\n\t\tseeking: false,\n\t\tasync seek(time) {\n\t\t\tconst { media } = target(), signal = signals.supersede(signalKeys.seek);\n\t\t\tif (!hasMetadata(media)) {\n\t\t\t\tif (!await onEvent(media, \"loadedmetadata\", { signal }).catch(() => false)) return media.currentTime;\n\t\t\t}\n\t\t\tconst clampedTime = Math.max(0, Math.min(time, media.duration || Infinity));\n\t\t\tset({\n\t\t\t\tcurrentTime: clampedTime,\n\t\t\t\tseeking: true\n\t\t\t});\n\t\t\tmedia.currentTime = clampedTime;\n\t\t\tawait onEvent(media, \"seeked\", { signal }).catch(noop);\n\t\t\treturn media.currentTime;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tconst sync = () => set({\n\t\t\tcurrentTime: media.currentTime,\n\t\t\tduration: Number.isFinite(media.duration) ? media.duration : 0,\n\t\t\tseeking: media.seeking\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"timeupdate\", sync, { signal });\n\t\tlisten(media, \"durationchange\", sync, { signal });\n\t\tlisten(media, \"seeking\", sync, { signal });\n\t\tlisten(media, \"seeked\", sync, { signal });\n\t\tlisten(media, \"loadedmetadata\", sync, { signal });\n\t\tlisten(media, \"emptied\", sync, { signal });\n\t}\n});\n\n//#endregion\nexport { timeFeature };\n//# sourceMappingURL=time.js.map","import { definePlayerFeature } from \"../../feature.js\";\nimport { listen } from \"@videojs/utils/dom\";\n\n//#region src/dom/store/features/volume.ts\n/** Volume to restore when unmuting at zero. */\nconst UNMUTE_VOLUME = .25;\nconst volumeFeature = definePlayerFeature({\n\tname: \"volume\",\n\tstate: ({ target }) => ({\n\t\tvolume: 1,\n\t\tmuted: false,\n\t\tvolumeAvailability: \"unavailable\",\n\t\tsetVolume(volume) {\n\t\t\tconst { media } = target();\n\t\t\tconst clamped = Math.max(0, Math.min(1, volume));\n\t\t\tif (clamped > 0 && media.muted) media.muted = false;\n\t\t\tmedia.volume = clamped;\n\t\t\treturn media.volume;\n\t\t},\n\t\ttoggleMuted() {\n\t\t\tconst { media } = target();\n\t\t\tif (media.muted || media.volume === 0) {\n\t\t\t\tmedia.muted = false;\n\t\t\t\tif (media.volume === 0) media.volume = UNMUTE_VOLUME;\n\t\t\t} else media.muted = true;\n\t\t\treturn media.muted;\n\t\t}\n\t}),\n\tattach({ target, signal, set }) {\n\t\tconst { media } = target;\n\t\tset({ volumeAvailability: canSetVolume() });\n\t\tconst sync = () => set({\n\t\t\tvolume: media.volume,\n\t\t\tmuted: media.muted\n\t\t});\n\t\tsync();\n\t\tlisten(media, \"volumechange\", sync, { signal });\n\t}\n});\n/** Check if volume can be programmatically set (fails on iOS Safari). */\nfunction canSetVolume() {\n\tconst video = document.createElement(\"video\");\n\ttry {\n\t\tvideo.volume = .5;\n\t\treturn video.volume === .5 ? \"available\" : \"unsupported\";\n\t} catch {\n\t\treturn \"unsupported\";\n\t}\n}\n\n//#endregion\nexport { volumeFeature };\n//# sourceMappingURL=volume.js.map","import { bufferFeature } from \"./buffer.js\";\nimport { controlsFeature } from \"./controls.js\";\nimport { errorFeature } from \"./error.js\";\nimport { fullscreenFeature } from \"./fullscreen.js\";\nimport { pipFeature } from \"./pip.js\";\nimport { playbackFeature } from \"./playback.js\";\nimport { playbackRateFeature } from \"./playback-rate.js\";\nimport { sourceFeature } from \"./source.js\";\nimport { textTrackFeature } from \"./text-track.js\";\nimport { timeFeature } from \"./time.js\";\nimport { volumeFeature } from \"./volume.js\";\n\n//#region src/dom/store/features/presets.ts\nconst videoFeatures = [\n\tplaybackFeature,\n\tplaybackRateFeature,\n\tvolumeFeature,\n\ttimeFeature,\n\tsourceFeature,\n\tbufferFeature,\n\tfullscreenFeature,\n\tpipFeature,\n\tcontrolsFeature,\n\ttextTrackFeature,\n\terrorFeature\n];\nconst audioFeatures = [\n\tplaybackFeature,\n\tplaybackRateFeature,\n\tvolumeFeature,\n\ttimeFeature,\n\tsourceFeature,\n\tbufferFeature\n];\nconst backgroundFeatures = [];\n\n//#endregion\nexport { audioFeatures, backgroundFeatures, videoFeatures };\n//# sourceMappingURL=presets.js.map","import { bufferFeature } from \"./features/buffer.js\";\nimport { controlsFeature } from \"./features/controls.js\";\nimport { errorFeature } from \"./features/error.js\";\nimport { fullscreenFeature } from \"./features/fullscreen.js\";\nimport { pipFeature } from \"./features/pip.js\";\nimport { playbackFeature } from \"./features/playback.js\";\nimport { playbackRateFeature } from \"./features/playback-rate.js\";\nimport { sourceFeature } from \"./features/source.js\";\nimport { textTrackFeature } from \"./features/text-track.js\";\nimport { timeFeature } from \"./features/time.js\";\nimport { volumeFeature } from \"./features/volume.js\";\nimport { createSelector } from \"@videojs/store\";\n\n//#region src/dom/store/selectors.ts\n/** Select the buffer state (buffered ranges, percent buffered). */\nconst selectBuffer = createSelector(bufferFeature);\n/** Select the controls state (controls visible, user-active). */\nconst selectControls = createSelector(controlsFeature);\n/** Select the error state (error, dismissed, dismissError). */\nconst selectError = createSelector(errorFeature);\n/** Select the fullscreen state (fullscreen active, availability). */\nconst selectFullscreen = createSelector(fullscreenFeature);\n/** Select the PiP state (picture-in-picture active, availability). */\nconst selectPiP = createSelector(pipFeature);\n/** Select the playback state (paused, ended, play, pause, toggle). */\nconst selectPlayback = createSelector(playbackFeature);\n/** Select the playback rate state (playbackRate, playbackRates, setPlaybackRate). */\nconst selectPlaybackRate = createSelector(playbackRateFeature);\n/** Select the source state (src, type). */\nconst selectSource = createSelector(sourceFeature);\n/** Select the text track state (chapters cues, thumbnail cues). */\nconst selectTextTrack = createSelector(textTrackFeature);\n/** Select the time state (currentTime, duration, seek). */\nconst selectTime = createSelector(timeFeature);\n/** Select the volume state (volume, muted, setVolume, setMuted). */\nconst selectVolume = createSelector(volumeFeature);\n\n//#endregion\nexport { selectBuffer, selectControls, selectError, selectFullscreen, selectPiP, selectPlayback, selectPlaybackRate, selectSource, selectTextTrack, selectTime, selectVolume };\n//# sourceMappingURL=selectors.js.map","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nclass s extends Event{constructor(s,t,e,o){super(\"context-request\",{bubbles:!0,composed:!0}),this.context=s,this.contextTarget=t,this.callback=e,this.subscribe=o??!1}}export{s as ContextRequestEvent};\n//# sourceMappingURL=context-request-event.js.map\n","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nfunction n(n){return n}export{n as createContext};\n//# sourceMappingURL=create-context.js.map\n","import{ContextRequestEvent as t}from\"../context-request-event.js\";\n/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */class s{constructor(t,s,i,h){if(this.subscribe=!1,this.provided=!1,this.value=void 0,this.t=(t,s)=>{this.unsubscribe&&(this.unsubscribe!==s&&(this.provided=!1,this.unsubscribe()),this.subscribe||this.unsubscribe()),this.value=t,this.host.requestUpdate(),this.provided&&!this.subscribe||(this.provided=!0,this.callback&&this.callback(t,s)),this.unsubscribe=s},this.host=t,void 0!==s.context){const t=s;this.context=t.context,this.callback=t.callback,this.subscribe=t.subscribe??!1}else this.context=s,this.callback=i,this.subscribe=h??!1;this.host.addController(this)}hostConnected(){this.dispatchRequest()}hostDisconnected(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=void 0)}dispatchRequest(){this.host.dispatchEvent(new t(this.context,this.host,this.t,this.subscribe))}}export{s as ContextConsumer};\n//# sourceMappingURL=context-consumer.js.map\n","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nclass s{get value(){return this.o}set value(s){this.setValue(s)}setValue(s,t=!1){const i=t||!Object.is(s,this.o);this.o=s,i&&this.updateObservers()}constructor(s){this.subscriptions=new Map,this.updateObservers=()=>{for(const[s,{disposer:t}]of this.subscriptions)s(this.o,t)},void 0!==s&&(this.value=s)}addCallback(s,t,i){if(!i)return void s(this.value);this.subscriptions.has(s)||this.subscriptions.set(s,{disposer:()=>{this.subscriptions.delete(s)},consumerHost:t});const{disposer:h}=this.subscriptions.get(s);s(this.value,h)}clearCallbacks(){this.subscriptions.clear()}}export{s as ValueNotifier};\n//# sourceMappingURL=value-notifier.js.map\n","import{ContextRequestEvent as t}from\"../context-request-event.js\";import{ValueNotifier as s}from\"../value-notifier.js\";\n/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */class e extends Event{constructor(t,s){super(\"context-provider\",{bubbles:!0,composed:!0}),this.context=t,this.contextTarget=s}}class i extends s{constructor(s,e,i){super(void 0!==e.context?e.initialValue:i),this.onContextRequest=t=>{if(t.context!==this.context)return;const s=t.contextTarget??t.composedPath()[0];s!==this.host&&(t.stopPropagation(),this.addCallback(t.callback,s,t.subscribe))},this.onProviderRequest=s=>{if(s.context!==this.context)return;if((s.contextTarget??s.composedPath()[0])===this.host)return;const e=new Set;for(const[s,{consumerHost:i}]of this.subscriptions)e.has(s)||(e.add(s),i.dispatchEvent(new t(this.context,i,s,!0)));s.stopPropagation()},this.host=s,void 0!==e.context?this.context=e.context:this.context=e,this.attachListeners(),this.host.addController?.(this)}attachListeners(){this.host.addEventListener(\"context-request\",this.onContextRequest),this.host.addEventListener(\"context-provider\",this.onProviderRequest)}hostConnected(){this.host.dispatchEvent(new e(this.context,this.host))}}export{i as ContextProvider,e as ContextProviderEvent};\n//# sourceMappingURL=context-provider.js.map\n","import type { AnyPlayerStore, PlayerStore } from '@videojs/core/dom';\nimport { type Context, createContext } from '@videojs/element/context';\n\nexport const PLAYER_CONTEXT_KEY = Symbol('@videojs/player');\n\nexport type PlayerContextValue<Store extends PlayerStore = AnyPlayerStore> = Store;\n\nexport type PlayerContext<Store extends PlayerStore = AnyPlayerStore> = Context<\n typeof PLAYER_CONTEXT_KEY,\n PlayerContextValue<Store>\n>;\n\n/**\n * The default player context instance for consuming the player store in controllers.\n *\n * @public\n */\nexport const playerContext = createContext<PlayerContextValue, typeof PLAYER_CONTEXT_KEY>(PLAYER_CONTEXT_KEY);\n","import type { MediaContainer, PlayerStore, PlayerTarget } from '@videojs/core/dom';\nimport { ContextConsumer } from '@videojs/element/context';\nimport { noop } from '@videojs/utils/function';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerConsumer, PlayerConsumerConstructor } from './types';\n\nexport type ContainerMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerConsumerConstructor<Store>;\n\n/**\n * Create a mixin that consumes player context and auto-attaches media elements.\n *\n * @param context - Player context to consume from an ancestor provider.\n */\nexport function createContainerMixin<Store extends PlayerStore>(context: PlayerContext<Store>): ContainerMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerContainerElement extends BaseClass implements PlayerConsumer<Store>, MediaContainer {\n #detach = noop;\n #observer: MutationObserver | null = null;\n #contextStore: Store | null = null;\n\n constructor(...args: any[]) {\n super(...args);\n\n // Created in the constructor body (after all field initializers) so\n // that #contextStore's private slot exists if the callback fires\n // synchronously — which happens when the element is already connected.\n // The host's controller list keeps the consumer alive; no field needed.\n new ContextConsumer(this, {\n context,\n callback: (value) => {\n this.#contextStore = value ?? null;\n this.#attachMedia();\n },\n subscribe: true,\n });\n }\n\n get store(): Store | null {\n return this.#contextStore;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n\n this.#observer = new MutationObserver((records) => {\n if (records.some(hasMediaNode)) this.#attachMedia();\n });\n\n this.#observer.observe(this, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['data-media-element'],\n });\n\n // Slotted media elements don't appear in the container's subtree,\n // so listen for slot reassignments to pick them up.\n this.addEventListener('slotchange', this.#onSlotChange);\n\n this.#attachMedia();\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.#observer?.disconnect();\n this.#observer = null;\n this.removeEventListener('slotchange', this.#onSlotChange);\n this.#detach();\n }\n\n #onSlotChange = () => {\n this.#attachMedia();\n };\n\n #getSlottedMedia(): HTMLMediaElement | null {\n const slot = this.querySelector<HTMLSlotElement>('slot[name=\"media\"]');\n if (!slot) return null;\n\n for (const el of slot.assignedElements({ flatten: true })) {\n if (el instanceof HTMLMediaElement) return el;\n }\n\n return null;\n }\n\n #attachMedia() {\n // Prefer the cached context value; fall back to `this.store` which\n // ProviderMixin overrides when both mixins are applied to one element.\n const store = this.#contextStore ?? this.store;\n if (!store) return;\n\n const media =\n this.querySelector<HTMLMediaElement>('video, audio, [data-media-element]') ?? this.#getSlottedMedia();\n\n if (!media) {\n this.#detach();\n this.#detach = noop;\n return;\n }\n\n const target: PlayerTarget = {\n media,\n container: this,\n };\n\n const hasMediaChanged = store.target?.media !== target.media,\n hasContainerChanged = store.target?.container !== target.container;\n\n if (hasMediaChanged || hasContainerChanged) {\n this.#detach();\n this.#detach = store.attach(target);\n }\n }\n }\n\n return PlayerContainerElement;\n };\n}\n\nfunction isMediaNode(node: Node): boolean {\n return node instanceof HTMLMediaElement || (node instanceof Element && node.hasAttribute('data-media-element'));\n}\n\nfunction hasMediaNode(record: MutationRecord): boolean {\n // Attribute mutation: data-media-element was added to a descendant\n if (record.type === 'attributes' && record.target instanceof Element) {\n return record.target.hasAttribute('data-media-element');\n }\n\n for (const node of record.addedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n for (const node of record.removedNodes) {\n if (isMediaNode(node)) return true;\n }\n\n return false;\n}\n","//#region src/destroy-mixin.ts\n/**\n* Mixin that adds a deferred destruction lifecycle to a `ReactiveElement`.\n*\n* On disconnect, schedules destruction after two animation frames.\n* If the element reconnects before the frames fire (e.g. DOM shuffling,\n* framework reconciliation), the `isConnected` check prevents destruction.\n*\n* The `keep-alive` attribute prevents automatic destruction entirely —\n* call `destroy()` manually when done.\n*\n* Subclasses override `destroyCallback()` (calling `super.destroyCallback()`)\n* to release heavy resources like stores or imperative APIs.\n*\n* Mirrors `addController`/`removeController` to track controllers\n* (needed because `ReactiveElement.#controllers` is hard-private),\n* calls `hostDestroyed()` on all tracked controllers in `destroyCallback`,\n* and guards `performUpdate()` so no updates run after destruction.\n*/\nfunction DestroyMixin(SuperClass) {\n\tclass DestroyableElement extends SuperClass {\n\t\t#destroyed = false;\n\t\t#trackedControllers = /* @__PURE__ */ new Set();\n\t\tget destroyed() {\n\t\t\treturn this.#destroyed;\n\t\t}\n\t\tdestroy() {\n\t\t\tif (this.#destroyed) return;\n\t\t\tthis.#destroyed = true;\n\t\t\tthis.destroyCallback();\n\t\t}\n\t\tdestroyCallback() {\n\t\t\tfor (const c of this.#trackedControllers) c.hostDestroyed?.();\n\t\t}\n\t\taddController(controller) {\n\t\t\tsuper.addController(controller);\n\t\t\tthis.#trackedControllers.add(controller);\n\t\t}\n\t\tremoveController(controller) {\n\t\t\tsuper.removeController(controller);\n\t\t\tthis.#trackedControllers.delete(controller);\n\t\t}\n\t\tconnectedCallback() {\n\t\t\tif (this.#destroyed) return;\n\t\t\tsuper.connectedCallback();\n\t\t}\n\t\tdisconnectedCallback() {\n\t\t\tsuper.disconnectedCallback();\n\t\t\tif (!this.#destroyed && !this.hasAttribute(\"keep-alive\")) requestAnimationFrame(() => {\n\t\t\t\trequestAnimationFrame(() => {\n\t\t\t\t\tif (!this.isConnected) this.destroy();\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\t\tperformUpdate() {\n\t\t\tif (this.#destroyed) return;\n\t\t\tsuper.performUpdate();\n\t\t}\n\t}\n\treturn DestroyableElement;\n}\n\n//#endregion\nexport { DestroyMixin };\n//# sourceMappingURL=destroy-mixin.js.map","//#region src/reactive-element.ts\nconst cache = /* @__PURE__ */ new WeakMap();\nconst propertyKeys = /* @__PURE__ */ new Map();\n/**\n* Lightweight reactive custom element base class.\n*\n* Drop-in subset of Lit's `ReactiveElement` — supports `static properties`,\n* attribute reflection, batched async updates, and reactive controllers.\n* No Shadow DOM, no `static styles`, no decorators.\n*\n* Updates are batched using the same Promise-based scheduling as Lit:\n* property changes enqueue a microtask, and the update is gated behind\n* `connectedCallback` so the first update only runs once the element\n* is in the document.\n*\n* Subclasses that extend another element with properties must spread them:\n*\n* @example\n* ```ts\n* class MyButton extends ReactiveElement {\n* static override properties = {\n* label: { type: String },\n* disabled: { type: Boolean },\n* };\n*\n* label = 'Click me';\n* disabled = false;\n*\n* protected override update(changed: PropertyValues): void {\n* super.update(changed);\n* this.textContent = this.label;\n* }\n* }\n*\n* // Inheritance — spread parent properties\n* class FancyButton extends MyButton {\n* static override properties = {\n* ...MyButton.properties,\n* variant: { type: String },\n* };\n*\n* variant = 'primary';\n* }\n* ```\n*/\nvar ReactiveElement = class extends HTMLElement {\n\tstatic {\n\t\tthis.properties = {};\n\t}\n\t/**\n\t* Returns a list of attributes corresponding to the registered properties.\n\t*/\n\tstatic get observedAttributes() {\n\t\treturn [...resolve(this).attrToProp.keys()];\n\t}\n\t#controllers = /* @__PURE__ */ new Set();\n\t#changedProperties = /* @__PURE__ */ new Map();\n\t#instanceProperties;\n\t/**\n\t* Promise that gates the first update until `connectedCallback`. Also\n\t* used to serialize updates — each `#enqueueUpdate` awaits the previous\n\t* `#updatePromise`, so property changes are batched and updates never\n\t* overlap. Matches Lit's scheduling model.\n\t*/\n\t#updatePromise;\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isUpdatePending = false;\n\t\tthis.hasUpdated = false;\n\t\tthis.#updatePromise = new Promise((res) => this.enableUpdating = res);\n\t\tconst { props } = resolve(this.constructor);\n\t\tfor (const name of props.keys()) if (Object.hasOwn(this, name)) {\n\t\t\t(this.#instanceProperties ??= /* @__PURE__ */ new Map()).set(name, this[name]);\n\t\t\tdelete this[name];\n\t\t}\n\t\tthis.requestUpdate();\n\t}\n\t/**\n\t* Note, this method should be considered final and not overridden. It is\n\t* overridden on the element instance with a function that triggers the\n\t* first update.\n\t*/\n\tenableUpdating(_requestedUpdate) {}\n\t/**\n\t* Registers a {@linkcode ReactiveController} to participate in the\n\t* element's reactive update cycle. The element automatically calls into\n\t* any registered controllers during its lifecycle callbacks.\n\t*\n\t* If the element is connected when `addController()` is called, the\n\t* controller's `hostConnected()` callback will be immediately called.\n\t*/\n\taddController(controller) {\n\t\tthis.#controllers.add(controller);\n\t\tif (this.isConnected) controller.hostConnected?.();\n\t}\n\t/** Removes a {@linkcode ReactiveController} from the element. */\n\tremoveController(controller) {\n\t\tthis.#controllers.delete(controller);\n\t}\n\t/**\n\t* On first connection, enables updating and notifies controllers.\n\t*/\n\tconnectedCallback() {\n\t\tthis.enableUpdating(true);\n\t\tfor (const c of this.#controllers) c.hostConnected?.();\n\t}\n\tdisconnectedCallback() {\n\t\tfor (const c of this.#controllers) c.hostDisconnected?.();\n\t}\n\t/**\n\t* Synchronizes property values when attributes change.\n\t*\n\t* Specifically, when an attribute is set, the corresponding property is\n\t* set. You should rarely need to implement this callback. If this method\n\t* is overridden, `super.attributeChangedCallback(name, _old, value)` must\n\t* be called.\n\t*/\n\tattributeChangedCallback(attr, oldValue, newValue) {\n\t\tif (oldValue === newValue) return;\n\t\tconst { props, attrToProp } = resolve(this.constructor);\n\t\tconst propName = attrToProp.get(attr);\n\t\tif (!propName) return;\n\t\tconst decl = props.get(propName);\n\t\tif (!decl) return;\n\t\tlet value = newValue;\n\t\tif (decl.type === Boolean) value = newValue !== null;\n\t\telse if (decl.type === Number) value = newValue === null ? null : Number(newValue);\n\t\tthis[propName] = value;\n\t}\n\t/**\n\t* Requests an update which is processed asynchronously. This should be\n\t* called when an element should update based on some state not triggered\n\t* by setting a reactive property. In this case, pass no arguments. It\n\t* should also be called when manually implementing a property setter. In\n\t* this case, pass the property `name` and `oldValue` to ensure that any\n\t* configured property options are honored.\n\t*/\n\trequestUpdate(name, oldValue) {\n\t\tif (name !== void 0) this.#changedProperties.set(name, oldValue);\n\t\tif (this.isUpdatePending) return;\n\t\tthis.#updatePromise = this.#enqueueUpdate();\n\t}\n\t/**\n\t* Sets up the element to asynchronously update. Awaits the previous\n\t* `#updatePromise` which both serializes updates and (on first update)\n\t* waits for `connectedCallback` to resolve the gate.\n\t*/\n\tasync #enqueueUpdate() {\n\t\tthis.isUpdatePending = true;\n\t\ttry {\n\t\t\tawait this.#updatePromise;\n\t\t} catch (e) {\n\t\t\tPromise.reject(e);\n\t\t}\n\t\tconst result = this.scheduleUpdate();\n\t\tif (result != null) await result;\n\t\treturn !this.isUpdatePending;\n\t}\n\t/**\n\t* Schedules an element update. You can override this method to change the\n\t* timing of updates by returning a Promise. The update will await the\n\t* returned Promise, and you should resolve the Promise to allow the update\n\t* to proceed. If this method is overridden, `super.scheduleUpdate()` must\n\t* be called.\n\t*\n\t* For instance, to schedule updates to occur just before the next frame:\n\t*\n\t* ```ts\n\t* override protected async scheduleUpdate(): Promise<unknown> {\n\t* await new Promise((resolve) => requestAnimationFrame(() => resolve()));\n\t* super.scheduleUpdate();\n\t* }\n\t* ```\n\t*/\n\tscheduleUpdate() {\n\t\tthis.performUpdate();\n\t}\n\t/**\n\t* Performs an element update. Note, if an exception is thrown during the\n\t* update, `firstUpdated` and `updated` will not be called.\n\t*\n\t* Call `performUpdate()` to immediately process a pending update. This\n\t* should generally not be needed, but it can be done in rare cases when\n\t* you need to update synchronously.\n\t*/\n\tperformUpdate() {\n\t\tif (!this.isUpdatePending) return;\n\t\tif (!this.hasUpdated && this.#instanceProperties) {\n\t\t\tfor (const [name, value] of this.#instanceProperties) this[name] = value;\n\t\t\tthis.#instanceProperties = void 0;\n\t\t}\n\t\tconst changed = this.#changedProperties;\n\t\tthis.willUpdate(changed);\n\t\tfor (const c of this.#controllers) c.hostUpdate?.();\n\t\tthis.update(changed);\n\t\tthis.#changedProperties = /* @__PURE__ */ new Map();\n\t\tthis.isUpdatePending = false;\n\t\tfor (const c of this.#controllers) c.hostUpdated?.();\n\t\tif (!this.hasUpdated) {\n\t\t\tthis.hasUpdated = true;\n\t\t\tthis.firstUpdated(changed);\n\t\t}\n\t\tthis.updated(changed);\n\t}\n\t/**\n\t* Invoked before `update()` to compute values needed during the update.\n\t*\n\t* Implement `willUpdate` to compute property values that depend on other\n\t* properties and are used in the rest of the update process.\n\t*\n\t* ```ts\n\t* willUpdate(changed) {\n\t* if (changed.has('firstName') || changed.has('lastName')) {\n\t* this.sha = computeSHA(`${this.firstName} ${this.lastName}`);\n\t* }\n\t* }\n\t* ```\n\t*/\n\twillUpdate(_changed) {}\n\t/**\n\t* Updates the element. This method reflects property values to attributes\n\t* and can be overridden to render and keep updated element DOM. Setting\n\t* properties inside this method will *not* trigger another update.\n\t*/\n\tupdate(_changed) {}\n\t/**\n\t* Invoked when the element is first updated. Implement to perform one\n\t* time work on the element after update.\n\t*\n\t* Setting properties inside this method will trigger the element to\n\t* update again after this update cycle completes.\n\t*/\n\tfirstUpdated(_changed) {}\n\t/**\n\t* Invoked whenever the element is updated. Implement to perform\n\t* post-updating tasks via DOM APIs, for example, focusing an element.\n\t*\n\t* Setting properties inside this method will trigger the element to\n\t* update again after this update cycle completes.\n\t*/\n\tupdated(_changed) {}\n\t/**\n\t* Returns a Promise that resolves when the element has completed updating.\n\t* The Promise value is a boolean that is `true` if the element completed\n\t* the update without triggering another update. The Promise result is\n\t* `false` if a property was set inside `updated()`.\n\t*/\n\tget updateComplete() {\n\t\treturn this.#updatePromise;\n\t}\n};\n/**\n* Resolve `ctor.properties` into lookup Maps and install reactive accessors\n* on the prototype. Runs once per class, result is cached.\n*\n* Subclasses that need parent properties must spread them:\n* `static override properties = { ...Parent.properties, ... }`.\n*/\nfunction resolve(ctor) {\n\tconst existing = cache.get(ctor);\n\tif (existing) return existing;\n\tconst props = /* @__PURE__ */ new Map();\n\tconst attrToProp = /* @__PURE__ */ new Map();\n\tfor (const [name, decl] of Object.entries(ctor.properties)) {\n\t\tprops.set(name, decl);\n\t\tattrToProp.set(decl.attribute ?? name, name);\n\t\tif (!Object.getOwnPropertyDescriptor(ctor.prototype, name)?.get) {\n\t\t\tlet key = propertyKeys.get(name);\n\t\t\tif (!key) {\n\t\t\t\tkey = Symbol(name);\n\t\t\t\tpropertyKeys.set(name, key);\n\t\t\t}\n\t\t\tObject.defineProperty(ctor.prototype, name, {\n\t\t\t\tget() {\n\t\t\t\t\treturn this[key];\n\t\t\t\t},\n\t\t\t\tset(value) {\n\t\t\t\t\tconst old = this[key];\n\t\t\t\t\tthis[key] = value;\n\t\t\t\t\tif (!Object.is(old, value)) this.requestUpdate(name, old);\n\t\t\t\t},\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true\n\t\t\t});\n\t\t}\n\t}\n\tconst meta = {\n\t\tprops,\n\t\tattrToProp\n\t};\n\tcache.set(ctor, meta);\n\treturn meta;\n}\n\n//#endregion\nexport { ReactiveElement };\n//# sourceMappingURL=reactive-element.js.map","import { DestroyMixin, ReactiveElement } from '@videojs/element';\nimport type { Constructor } from '@videojs/utils/types';\n\n/** Base class for interactive media UI elements. */\nexport class MediaElement extends DestroyMixin(ReactiveElement) {}\n\nexport interface MediaElementConstructor extends Constructor<MediaElement> {}\n","import { playerContext } from '../player/context';\nimport { createContainerMixin } from '../store/container-mixin';\nimport { MediaElement } from '../ui/media-element';\n\nconst ContainerMixin = createContainerMixin(playerContext);\n\nexport class MediaContainerElement extends ContainerMixin(MediaElement) {\n static readonly tagName = 'media-container';\n}\n","import type { PlayerStore } from '@videojs/core/dom';\nimport { ContextProvider } from '@videojs/element/context';\nimport { isNull } from '@videojs/utils/predicate';\nimport type { MediaElementConstructor } from '@/ui/media-element';\nimport type { PlayerContext } from '../player/context';\nimport type { PlayerProvider, PlayerProviderConstructor } from './types';\n\nexport type ProviderMixin<Store extends PlayerStore> = <Class extends MediaElementConstructor>(\n BaseClass: Class\n) => Class & PlayerProviderConstructor<Store>;\n\n/**\n * Create a mixin that provides player context to descendant elements.\n *\n * @param context - Player context to provide to descendants.\n * @param factory - Factory function that creates a store instance.\n */\nexport function createProviderMixin<Store extends PlayerStore>(\n context: PlayerContext<Store>,\n factory: () => Store\n): ProviderMixin<Store> {\n return <Class extends MediaElementConstructor>(BaseClass: Class) => {\n class PlayerProviderElement extends BaseClass implements PlayerProvider<Store> {\n #store: Store | null = factory();\n\n #provider = new ContextProvider(this, {\n context,\n initialValue: this.store,\n });\n\n get store(): Store {\n if (isNull(this.#store)) {\n this.#store = factory();\n }\n\n return this.#store;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n this.#provider.setValue(this.store);\n }\n\n override destroyCallback() {\n this.#store?.destroy();\n this.#store = null;\n super.destroyCallback();\n }\n }\n\n return PlayerProviderElement;\n };\n}\n","import { shallowEqual } from \"../../core/shallow-equal.js\";\nimport { noop } from \"@videojs/utils/function\";\n\n//#region src/html/controllers/snapshot-controller.ts\n/**\n* Subscribe to a `State<T>` container with optional selector.\n*\n* Without selector: returns full state, re-renders on any state change.\n* With selector: returns selected slice, re-renders only when the slice changes (shallowEqual).\n*\n* @example\n* ```ts\n* #state = new SnapshotController(this, sliderState, (s) => s.value);\n* ```\n*/\nvar SnapshotController = class {\n\t#host;\n\t#selector;\n\t#state;\n\t#cached;\n\t#unsubscribe = noop;\n\tconstructor(host, state, selector) {\n\t\tthis.#host = host;\n\t\tthis.#state = state;\n\t\tthis.#selector = selector;\n\t\thost.addController(this);\n\t}\n\tget value() {\n\t\tif (!this.#selector) return this.#state.current;\n\t\tthis.#cached ??= this.#selector(this.#state.current);\n\t\treturn this.#cached;\n\t}\n\t/** Switch to tracking a different state container. */\n\ttrack(state) {\n\t\tthis.#state = state;\n\t\tthis.#subscribe();\n\t}\n\thostConnected() {\n\t\tthis.#subscribe();\n\t}\n\thostDisconnected() {\n\t\tthis.#unsubscribe();\n\t\tthis.#unsubscribe = noop;\n\t\tthis.#cached = void 0;\n\t}\n\t#subscribe() {\n\t\tthis.#unsubscribe();\n\t\tif (!this.#selector) {\n\t\t\tthis.#unsubscribe = this.#state.subscribe(() => this.#host.requestUpdate());\n\t\t\treturn;\n\t\t}\n\t\tconst selector = this.#selector;\n\t\tthis.#cached = selector(this.#state.current);\n\t\tthis.#unsubscribe = this.#state.subscribe(() => {\n\t\t\tconst next = selector(this.#state.current);\n\t\t\tif (!shallowEqual(this.#cached, next)) {\n\t\t\t\tthis.#cached = next;\n\t\t\t\tthis.#host.requestUpdate();\n\t\t\t}\n\t\t});\n\t}\n};\n\n//#endregion\nexport { SnapshotController };\n//# sourceMappingURL=snapshot-controller.js.map","import { isStore } from \"../core/store.js\";\nimport { noop } from \"@videojs/utils/function\";\nimport { ContextConsumer } from \"@videojs/element/context\";\n\n//#region src/html/store-accessor.ts\n/**\n* Resolves a store from either a direct instance or context.\n*\n* When given a direct store, provides immediate access.\n* When given a context, sets up a ContextConsumer to receive the store.\n*\n* @example Direct store\n* ```ts\n* const accessor = new StoreAccessor(host, store, (s) => console.log('available', s));\n* accessor.value; // Store (immediately available)\n* ```\n*\n* @example Context source\n* ```ts\n* const accessor = new StoreAccessor(host, context, (s) => console.log('available', s));\n* accessor.value; // null until context provides store\n* ```\n*/\nvar StoreAccessor = class {\n\t#onAvailable;\n\t#consumer;\n\t#directStore;\n\tconstructor(host, source, onAvailable) {\n\t\tthis.#onAvailable = onAvailable ?? noop;\n\t\tif (isStore(source)) {\n\t\t\tthis.#directStore = source;\n\t\t\tthis.#consumer = null;\n\t\t} else {\n\t\t\tthis.#directStore = null;\n\t\t\tthis.#consumer = new ContextConsumer(host, {\n\t\t\t\tcontext: source,\n\t\t\t\tcallback: (store) => this.#onAvailable(store),\n\t\t\t\tsubscribe: false\n\t\t\t});\n\t\t}\n\t\thost.addController(this);\n\t}\n\t/** Returns the store, or null if not yet available from context. */\n\tget value() {\n\t\tif (this.#consumer) return this.#consumer.value ?? null;\n\t\treturn this.#directStore;\n\t}\n\thostConnected() {\n\t\tif (this.#directStore) this.#onAvailable(this.#directStore);\n\t}\n};\n\n//#endregion\nexport { StoreAccessor };\n//# sourceMappingURL=store-accessor.js.map","import { SnapshotController } from \"./snapshot-controller.js\";\nimport { StoreAccessor } from \"../store-accessor.js\";\nimport { isNull, isUndefined } from \"@videojs/utils/predicate\";\n\n//#region src/html/controllers/store-controller.ts\n/**\n* Access store state and actions.\n*\n* Without selector: Returns the store, does NOT subscribe to changes.\n* With selector: Returns selected state, triggers update when selected state changes (shallowEqual).\n*\n* @example\n* ```ts\n* // Store access (no subscription) - access actions\n* class Controls extends LitElement {\n* #store = new StoreController(this, storeSource);\n*\n* handleClick() {\n* this.#store.value.setVolume(0.5);\n* }\n* }\n*\n* // Selector-based subscription - re-renders when playback changes\n* class PlayButton extends LitElement {\n* #playback = new StoreController(this, storeSource, selectPlayback);\n*\n* render() {\n* const playback = this.#playback.value;\n* if (!playback) return nothing;\n* return html`<button @click=${playback.toggle}>\n* ${playback.paused ? 'Play' : 'Pause'}\n* </button>`;\n* }\n* }\n* ```\n*/\nvar StoreController = class {\n\t#host;\n\t#selector;\n\t#accessor;\n\t#snapshot = null;\n\tconstructor(host, source, selector) {\n\t\tthis.#host = host;\n\t\tthis.#selector = selector;\n\t\tthis.#accessor = new StoreAccessor(host, source, (store) => this.#connect(store));\n\t\thost.addController(this);\n\t}\n\tget value() {\n\t\tconst store = this.#accessor.value;\n\t\tif (isNull(store)) throw new Error(\"Store not available\");\n\t\tif (isUndefined(this.#selector)) return store;\n\t\treturn this.#snapshot.value;\n\t}\n\thostConnected() {}\n\t#connect(store) {\n\t\tif (isUndefined(this.#selector)) return;\n\t\tif (!this.#snapshot) this.#snapshot = new SnapshotController(this.#host, store.$state, this.#selector);\n\t\telse this.#snapshot.track(store.$state);\n\t}\n};\n\n//#endregion\nexport { StoreController };\n//# sourceMappingURL=store-controller.js.map","import type { PlayerStore } from '@videojs/core/dom';\nimport type { ReactiveController, ReactiveControllerHost } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\nimport type { InferStoreState, Selector } from '@videojs/store';\nimport { StoreController } from '@videojs/store/html';\n\nimport type { PlayerContext } from './context';\n\nexport type PlayerControllerHost = ReactiveControllerHost & HTMLElement;\n\n/**\n * Reactive controller for accessing player store state.\n *\n * Without selector: Returns the store, does NOT subscribe to changes.\n * With selector: Returns selected state, subscribes with shallowEqual comparison.\n *\n * @example\n * ```ts\n * // Store access (no subscription)\n * class Controls extends MediaElement {\n * #player = new PlayerController(this, playerContext);\n *\n * handleClick() {\n * this.#player.value.setVolume(0.5);\n * }\n * }\n *\n * // Selector-based subscription\n * class PlayButton extends MediaElement {\n * #playback = new PlayerController(this, playerContext, selectPlayback);\n * }\n * ```\n */\nexport class PlayerController<Store extends PlayerStore, Result = Store> implements ReactiveController {\n readonly #host: PlayerControllerHost;\n readonly #selector: Selector<InferStoreState<Store>, Result> | undefined;\n\n #consumer: ContextConsumer<PlayerContext<Store>, PlayerControllerHost>;\n #store: StoreController<Store, Result> | null = null;\n\n /**\n * @label Without Selector\n * @param host - The host element that owns this controller.\n * @param context - Player context to resolve the store from.\n */\n constructor(host: PlayerControllerHost, context: PlayerContext<Store>);\n /**\n * @label With Selector\n * @param host - The host element that owns this controller.\n * @param context - Player context to resolve the store from.\n * @param selector - Derives a value from the player store state.\n */\n constructor(\n host: PlayerControllerHost,\n context: PlayerContext<Store>,\n selector: Selector<InferStoreState<Store>, Result>\n );\n constructor(\n host: PlayerControllerHost,\n context: PlayerContext<Store>,\n selector?: Selector<InferStoreState<Store>, Result>\n ) {\n this.#host = host;\n this.#selector = selector;\n\n this.#consumer = new ContextConsumer(host, {\n context,\n callback: (ctx) => this.#connect(ctx),\n subscribe: true,\n });\n\n host.addController(this);\n }\n\n get value(): Result | undefined {\n const store = this.#consumer.value;\n if (!store) return undefined;\n\n // Without selector: return store directly\n if (!this.#selector) return store as unknown as Result;\n\n // With selector: use StoreController\n return this.#store?.value;\n }\n\n get displayName(): string | undefined {\n return this.#selector?.displayName;\n }\n\n hostConnected(): void {\n const store = this.#consumer.value;\n if (store) this.#connect(store);\n }\n\n hostDisconnected(): void {\n this.#store = null;\n }\n\n #connect(store: Store): void {\n if (!this.#store && this.#selector) {\n this.#store = new StoreController(this.#host, store, this.#selector);\n }\n }\n}\n\nexport namespace PlayerController {\n export type Host = PlayerControllerHost;\n\n export type Constructor<Store extends PlayerStore = PlayerStore, Result = Store> = typeof PlayerController<\n Store,\n Result\n >;\n}\n","import type {\n AnyPlayerFeature,\n AudioFeatures,\n AudioPlayerStore,\n PlayerStore,\n PlayerTarget,\n VideoFeatures,\n VideoPlayerStore,\n} from '@videojs/core/dom';\nimport { combine, createStore } from '@videojs/store';\n\nimport { type ContainerMixin, createContainerMixin } from '../store/container-mixin';\nimport { createProviderMixin, type ProviderMixin } from '../store/provider-mixin';\nimport { type PlayerContext, playerContext } from './context';\nimport { PlayerController } from './player-controller';\n\nexport interface CreatePlayerConfig<Features extends AnyPlayerFeature[]> {\n features: Features;\n}\n\nexport interface CreatePlayerResult<Store extends PlayerStore> {\n /** Context for consuming player in controllers. */\n context: PlayerContext<Store>;\n\n /** Creates a store instance for imperative access. */\n create: () => Store;\n\n /** Player controller bound to this player's context. */\n PlayerController: PlayerController.Constructor<Store>;\n\n /** Mixin that provides player context to descendants. */\n ProviderMixin: ProviderMixin<Store>;\n\n /** Mixin that consumes player context and auto-attaches media elements. */\n ContainerMixin: ContainerMixin<Store>;\n}\n\n/**\n * Creates a player factory with typed store, mixins, and controller.\n *\n * @example\n * ```ts\n * import { createPlayer, MediaElement, selectPlayback } from '@videojs/html';\n * import { videoFeatures } from '@videojs/html/video';\n *\n * const { ProviderMixin, ContainerMixin, PlayerController, context } = createPlayer({\n * features: videoFeatures,\n * });\n *\n * // Provider element: owns the store, provides context to descendants\n * class VideoPlayer extends ProviderMixin(MediaElement) {}\n * customElements.define('video-player', VideoPlayer);\n *\n * // Control element with selector\n * class PlayButton extends MediaElement {\n * #playback = new PlayerController(this, context, selectPlayback);\n * }\n * ```\n *\n * @label Video\n * @param config - Player configuration with features.\n */\nexport function createPlayer(config: CreatePlayerConfig<VideoFeatures>): CreatePlayerResult<VideoPlayerStore>;\n\n/**\n * Creates a player factory for audio media.\n *\n * @label Audio\n * @param config - Player configuration with features.\n */\nexport function createPlayer(config: CreatePlayerConfig<AudioFeatures>): CreatePlayerResult<AudioPlayerStore>;\n\n/**\n * Creates a player factory with custom features.\n *\n * @label Generic\n * @param config - Player configuration with features.\n */\nexport function createPlayer<const Features extends AnyPlayerFeature[]>(\n config: CreatePlayerConfig<Features>\n): CreatePlayerResult<PlayerStore<Features>>;\n\nexport function createPlayer(config: CreatePlayerConfig<AnyPlayerFeature[]>): CreatePlayerResult<PlayerStore> {\n const slice = combine<PlayerTarget, AnyPlayerFeature[]>(...config.features);\n\n function create(): PlayerStore {\n return createStore<PlayerTarget>()(slice);\n }\n\n const ProviderMixin = createProviderMixin<PlayerStore>(playerContext, create);\n const ContainerMixin = createContainerMixin<PlayerStore>(playerContext);\n\n return {\n context: playerContext,\n create,\n PlayerController,\n ProviderMixin,\n ContainerMixin,\n };\n}\n","type DefinableElement = CustomElementConstructor & { tagName: string };\n\n/** Define a custom element only if not already registered. */\nexport function safeDefine(element: DefinableElement): void {\n if (!customElements.get(element.tagName)) {\n customElements.define(element.tagName, element);\n }\n}\n","import { backgroundFeatures } from '@videojs/core/dom';\nimport { MediaContainerElement } from '../../media/container-element';\nimport { createPlayer } from '../../player/create-player';\nimport { MediaElement } from '../../ui/media-element';\nimport { safeDefine } from '../safe-define';\n\nconst { ProviderMixin } = createPlayer({\n features: backgroundFeatures,\n});\n\nexport class BackgroundVideoPlayerElement extends ProviderMixin(MediaElement) {\n static readonly tagName = 'background-video-player';\n}\n\n// Provider must be defined before consumer for context handshake during upgrade.\nsafeDefine(BackgroundVideoPlayerElement);\nsafeDefine(MediaContainerElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [BackgroundVideoPlayerElement.tagName]: BackgroundVideoPlayerElement;\n }\n}\n","import { ReactiveElement } from '@videojs/element';\nimport { namedNodeMapToObject } from '@videojs/utils/dom';\nimport { safeDefine } from '../safe-define';\n\nfunction getTemplateHTML(_attrs: Record<string, string>) {\n return /*html*/ `\n <media-container>\n <slot name=\"media\" slot=\"media\"></slot>\n </media-container>\n `;\n}\n\nexport class BackgroundVideoSkinElement extends ReactiveElement {\n static readonly tagName = 'background-video-skin';\n static shadowRootOptions = { mode: 'open' as ShadowRootMode };\n static getTemplateHTML = getTemplateHTML;\n\n constructor() {\n super();\n\n if (!this.shadowRoot) {\n this.attachShadow((this.constructor as typeof BackgroundVideoSkinElement).shadowRootOptions);\n this.shadowRoot!.innerHTML = getTemplateHTML(namedNodeMapToObject(this.attributes));\n }\n }\n}\n\nsafeDefine(BackgroundVideoSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [BackgroundVideoSkinElement.tagName]: BackgroundVideoSkinElement;\n }\n}\n"],"x_google_ignoreList":[34,35,36,37,38],"mappings":"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"}
|