@videojs/html 10.0.0-beta.1 → 10.0.0-beta.2

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.
Files changed (64) hide show
  1. package/cdn/audio-minimal.css +1 -0
  2. package/cdn/audio-minimal.dev.js +5360 -0
  3. package/cdn/audio-minimal.dev.js.map +1 -0
  4. package/cdn/audio-minimal.js +25 -0
  5. package/cdn/audio-minimal.js.map +1 -0
  6. package/cdn/audio.css +1 -0
  7. package/cdn/audio.dev.js +5351 -0
  8. package/cdn/audio.dev.js.map +1 -0
  9. package/cdn/audio.js +25 -0
  10. package/cdn/audio.js.map +1 -0
  11. package/cdn/background.css +1 -0
  12. package/cdn/background.dev.js +2057 -0
  13. package/cdn/background.dev.js.map +1 -0
  14. package/cdn/background.js +19 -0
  15. package/cdn/background.js.map +1 -0
  16. package/cdn/media/hls-video.dev.js +28728 -0
  17. package/cdn/media/hls-video.dev.js.map +1 -0
  18. package/cdn/media/hls-video.js +83 -0
  19. package/cdn/media/hls-video.js.map +1 -0
  20. package/cdn/media/simple-hls-video.dev.js +3796 -0
  21. package/cdn/media/simple-hls-video.dev.js.map +1 -0
  22. package/cdn/media/simple-hls-video.js +44 -0
  23. package/cdn/media/simple-hls-video.js.map +1 -0
  24. package/cdn/video-minimal.css +1 -0
  25. package/cdn/video-minimal.dev.js +5714 -0
  26. package/cdn/video-minimal.dev.js.map +1 -0
  27. package/cdn/video-minimal.js +25 -0
  28. package/cdn/video-minimal.js.map +1 -0
  29. package/cdn/video.css +1 -0
  30. package/cdn/video.dev.js +5782 -0
  31. package/cdn/video.dev.js.map +1 -0
  32. package/cdn/video.js +25 -0
  33. package/cdn/video.js.map +1 -0
  34. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js +1 -1
  35. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -1
  36. package/dist/default/_virtual/inline-css_src/define/audio/skin.js +1 -1
  37. package/dist/default/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
  38. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
  39. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
  40. package/dist/default/_virtual/inline-css_src/define/video/skin.js +1 -1
  41. package/dist/default/_virtual/inline-css_src/define/video/skin.js.map +1 -1
  42. package/dist/default/define/audio/minimal-skin.js +1 -79
  43. package/dist/default/define/audio/minimal-skin.js.map +1 -1
  44. package/dist/default/define/audio/minimal-skin.tailwind.js +1 -81
  45. package/dist/default/define/audio/minimal-skin.tailwind.js.map +1 -1
  46. package/dist/default/define/audio/skin.js +1 -70
  47. package/dist/default/define/audio/skin.js.map +1 -1
  48. package/dist/default/define/audio/skin.tailwind.js +1 -72
  49. package/dist/default/define/audio/skin.tailwind.js.map +1 -1
  50. package/dist/default/define/background/skin.js +1 -5
  51. package/dist/default/define/background/skin.js.map +1 -1
  52. package/dist/default/define/skin-mixin.js +1 -15
  53. package/dist/default/define/skin-mixin.js.map +1 -1
  54. package/dist/default/define/video/minimal-skin.js +1 -121
  55. package/dist/default/define/video/minimal-skin.js.map +1 -1
  56. package/dist/default/define/video/minimal-skin.tailwind.js +1 -131
  57. package/dist/default/define/video/minimal-skin.tailwind.js.map +1 -1
  58. package/dist/default/define/video/skin.js +1 -116
  59. package/dist/default/define/video/skin.js.map +1 -1
  60. package/dist/default/define/video/skin.tailwind.js +1 -124
  61. package/dist/default/define/video/skin.tailwind.js.map +1 -1
  62. package/dist/default/media/background-video/index.js +1 -18
  63. package/dist/default/media/background-video/index.js.map +1 -1
  64. package/package.json +12 -10
@@ -0,0 +1 @@
1
+ {"version":3,"file":"background.dev.js","names":["#base","#keys","#current","#markPending","#listeners","#pending","#contextStore","#attachMedia","#observer","#onSlotChange","#detach","#getSlottedMedia","#destroyed","#trackedControllers","#updatePromise","#instanceProperties","#controllers","#changedProperties","#enqueueUpdate","#store","#provider","#host","#state","#selector","#cached","#subscribe","#unsubscribe","#onAvailable","#directStore","#consumer","#host","#selector","#accessor","#connect","#snapshot","#host","#selector","#consumer","#connect","#store"],"sources":["../../store/dist/dev/core/abort-controller-registry.js","../../store/dist/dev/core/combine.js","../../store/dist/dev/core/errors.js","../../utils/dist/predicate/predicate.js","../../utils/dist/object/pick.js","../../store/dist/dev/core/selector.js","../../store/dist/dev/core/shallow-equal.js","../../store/dist/dev/core/slice.js","../../utils/dist/function/noop.js","../../store/dist/dev/core/state.js","../../store/dist/dev/core/store.js","../../core/dist/dev/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/dev/dom/store/features/buffer.js","../../core/dist/dev/dom/store/features/controls.js","../../core/dist/dev/dom/store/features/error.js","../../core/dist/dev/dom/presentation/fullscreen.js","../../core/dist/dev/dom/presentation/pip.js","../../core/dist/dev/dom/store/features/fullscreen.js","../../core/dist/dev/dom/store/features/pip.js","../../core/dist/dev/dom/store/features/playback.js","../../core/dist/dev/dom/store/features/playback-rate.js","../../core/dist/dev/dom/store/features/source.js","../../core/dist/dev/dom/store/features/text-track.js","../../core/dist/dev/dom/media/predicate.js","../../core/dist/dev/dom/store/signal-keys.js","../../core/dist/dev/dom/store/features/time.js","../../core/dist/dev/dom/store/features/volume.js","../../core/dist/dev/dom/store/features/presets.js","../../core/dist/dev/dom/store/selectors.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/development/lib/context-request-event.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/development/lib/create-context.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/development/lib/controllers/context-consumer.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/development/lib/value-notifier.js","../../../node_modules/.pnpm/@lit+context@1.1.6/node_modules/@lit/context/development/lib/controllers/context-provider.js","../src/player/context.ts","../src/store/container-mixin.ts","../../element/dist/dev/destroy-mixin.js","../../element/dist/dev/reactive-element.js","../src/ui/media-element.ts","../src/media/container-element.ts","../src/store/provider-mixin.ts","../../store/dist/dev/html/controllers/snapshot-controller.js","../../store/dist/dev/html/store-accessor.js","../../store/dist/dev/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)) {\n\t\t\tconsole.warn(\"[vjs] controlsFeature requires a container element for activity tracking.\");\n\t\t\treturn;\n\t\t}\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 */\n/**\n * An event fired by a context requester to signal it desires a specified context with the given key.\n *\n * A provider should inspect the `context` property of the event to determine if it has a value that can\n * satisfy the request, calling the `callback` with the requested value if so.\n *\n * If the requested context event contains a truthy `subscribe` value, then a provider can call the callback\n * multiple times if the value is changed, if this is the case the provider should pass an `unsubscribe`\n * method to the callback which consumers can invoke to indicate they no longer wish to receive these updates.\n *\n * If no `subscribe` value is present in the event, then the provider can assume that this is a 'one time'\n * request for the context and can therefore not track the consumer.\n */\nexport class ContextRequestEvent extends Event {\n /**\n *\n * @param context the context key to request\n * @param contextTarget the original context target of the requester\n * @param callback the callback that should be invoked when the context with the specified key is available\n * @param subscribe when, true indicates we want to subscribe to future updates\n */\n constructor(context, contextTarget, callback, subscribe) {\n super('context-request', { bubbles: true, composed: true });\n this.context = context;\n this.contextTarget = contextTarget;\n this.callback = callback;\n this.subscribe = subscribe ?? false;\n }\n}\n//# sourceMappingURL=context-request-event.js.map","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n/**\n * Creates a typed Context.\n *\n * Contexts are compared with strict equality.\n *\n * If you want two separate `createContext()` calls to referer to the same\n * context, then use a key that will by equal under strict equality like a\n * string for `Symbol.for()`:\n *\n * ```ts\n * // true\n * createContext('my-context') === createContext('my-context')\n * // true\n * createContext(Symbol.for('my-context')) === createContext(Symbol.for('my-context'))\n * ```\n *\n * If you want a context to be unique so that it's guaranteed to not collide\n * with other contexts, use a key that's unique under strict equality, like\n * a `Symbol()` or object.:\n *\n * ```\n * // false\n * createContext({}) === createContext({})\n * // false\n * createContext(Symbol('my-context')) === createContext(Symbol('my-context'))\n * ```\n *\n * @param key a context key value\n * @template ValueType the type of value that can be provided by this context.\n * @returns the context key value cast to `Context<K, ValueType>`\n */\nexport function createContext(key) {\n return key;\n}\n//# sourceMappingURL=create-context.js.map","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nimport { ContextRequestEvent, } from '../context-request-event.js';\n/**\n * A ReactiveController which adds context consuming behavior to a custom\n * element by dispatching `context-request` events.\n *\n * When the host element is connected to the document it will emit a\n * `context-request` event with its context key. When the context request\n * is satisfied the controller will invoke the callback, if present, and\n * trigger a host update so it can respond to the new value.\n *\n * It will also call the dispose method given by the provider when the\n * host element is disconnected.\n */\nexport class ContextConsumer {\n constructor(host, contextOrOptions, callback, subscribe) {\n this.subscribe = false;\n this.provided = false;\n this.value = undefined;\n // This function must have stable identity to properly dedupe in ContextRoot\n // if this element connects multiple times.\n this._callback = (value, unsubscribe) => {\n // some providers will pass an unsubscribe function indicating they may provide future values\n if (this.unsubscribe) {\n // if the unsubscribe function changes this implies we have changed provider\n if (this.unsubscribe !== unsubscribe) {\n // cleanup the old provider\n this.provided = false;\n this.unsubscribe();\n }\n // if we don't support subscription, immediately unsubscribe\n if (!this.subscribe) {\n this.unsubscribe();\n }\n }\n // store the value so that it can be retrieved from the controller\n this.value = value;\n // schedule an update in case this value is used in a template\n this.host.requestUpdate();\n // only invoke callback if we are either expecting updates or have not yet\n // been provided a value\n if (!this.provided || this.subscribe) {\n this.provided = true;\n if (this.callback) {\n this.callback(value, unsubscribe);\n }\n }\n this.unsubscribe = unsubscribe;\n };\n this.host = host;\n // This is a potentially fragile duck-type. It means a context object can't\n // have a property name context and be used in positional argument form.\n if (contextOrOptions.context !== undefined) {\n const options = contextOrOptions;\n this.context = options.context;\n this.callback = options.callback;\n this.subscribe = options.subscribe ?? false;\n }\n else {\n this.context = contextOrOptions;\n this.callback = callback;\n this.subscribe = subscribe ?? false;\n }\n this.host.addController(this);\n }\n hostConnected() {\n this.dispatchRequest();\n }\n hostDisconnected() {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = undefined;\n }\n }\n dispatchRequest() {\n this.host.dispatchEvent(new ContextRequestEvent(this.context, this.host, this._callback, this.subscribe));\n }\n}\n//# sourceMappingURL=context-consumer.js.map","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n/**\n * A simple class which stores a value, and triggers registered callbacks when\n * the value is changed via its setter.\n *\n * An implementor might use other observable patterns such as MobX or Redux to\n * get behavior like this. But this is a pretty minimal approach that will\n * likely work for a number of use cases.\n */\nexport class ValueNotifier {\n get value() {\n return this._value;\n }\n set value(v) {\n this.setValue(v);\n }\n setValue(v, force = false) {\n const update = force || !Object.is(v, this._value);\n this._value = v;\n if (update) {\n this.updateObservers();\n }\n }\n constructor(defaultValue) {\n this.subscriptions = new Map();\n this.updateObservers = () => {\n for (const [callback, { disposer }] of this.subscriptions) {\n callback(this._value, disposer);\n }\n };\n if (defaultValue !== undefined) {\n this.value = defaultValue;\n }\n }\n addCallback(callback, consumerHost, subscribe) {\n if (!subscribe) {\n // just call the callback once and we're done\n callback(this.value);\n return;\n }\n if (!this.subscriptions.has(callback)) {\n this.subscriptions.set(callback, {\n disposer: () => {\n this.subscriptions.delete(callback);\n },\n consumerHost,\n });\n }\n const { disposer } = this.subscriptions.get(callback);\n callback(this.value, disposer);\n }\n clearCallbacks() {\n this.subscriptions.clear();\n }\n}\n//# sourceMappingURL=value-notifier.js.map","/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nimport { ContextRequestEvent } from '../context-request-event.js';\nimport { ValueNotifier } from '../value-notifier.js';\nexport class ContextProviderEvent extends Event {\n /**\n *\n * @param context the context which this provider can provide\n * @param contextTarget the original context target of the provider\n */\n constructor(context, contextTarget) {\n super('context-provider', { bubbles: true, composed: true });\n this.context = context;\n this.contextTarget = contextTarget;\n }\n}\n/**\n * A ReactiveController which adds context provider behavior to a\n * custom element.\n *\n * This controller simply listens to the `context-request` event when\n * the host is connected to the DOM and registers the received callbacks\n * against its observable Context implementation.\n *\n * The controller may also be attached to any HTML element in which case it's\n * up to the user to call hostConnected() when attached to the DOM. This is\n * done automatically for any custom elements implementing\n * ReactiveControllerHost.\n */\nexport class ContextProvider extends ValueNotifier {\n constructor(host, contextOrOptions, initialValue) {\n super(contextOrOptions.context !== undefined\n ? contextOrOptions.initialValue\n : initialValue);\n this.onContextRequest = (ev) => {\n // Only call the callback if the context matches.\n if (ev.context !== this.context) {\n return;\n }\n // Also, in case an element is a consumer AND a provider\n // of the same context, we want to avoid the element to self-register.\n const consumerHost = ev.contextTarget ?? ev.composedPath()[0];\n if (consumerHost === this.host) {\n return;\n }\n ev.stopPropagation();\n this.addCallback(ev.callback, consumerHost, ev.subscribe);\n };\n /**\n * When we get a provider request event, that means a child of this element\n * has just woken up. If it's a provider of our context, then we may need to\n * re-parent our subscriptions, because is a more specific provider than us\n * for its subtree.\n */\n this.onProviderRequest = (ev) => {\n // Ignore events when the context doesn't match.\n if (ev.context !== this.context) {\n return;\n }\n // Also, in case an element is a consumer AND a provider\n // of the same context it shouldn't provide to itself.\n const childProviderHost = ev.contextTarget ?? ev.composedPath()[0];\n if (childProviderHost === this.host) {\n return;\n }\n // Re-parent all of our subscriptions in case this new child provider\n // should take them over.\n const seen = new Set();\n for (const [callback, { consumerHost }] of this.subscriptions) {\n // Prevent infinite loops in the case where a one host element\n // is providing the same context multiple times.\n //\n // While normally it's a no-op to attempt to re-parent a subscription\n // that already has its proper parent, in the case where there's more\n // than one ValueProvider for the same context on the same hostElement,\n // they will each call the consumer, and since they will each have their\n // own dispose function, a well behaved consumer will notice the change\n // in dispose function and call their old one.\n //\n // This will cause the subscriptions to thrash, but worse, without this\n // set check here, we can end up in an infinite loop, as we add and remove\n // the same subscriptions onto the end of the map over and over.\n if (seen.has(callback)) {\n continue;\n }\n seen.add(callback);\n consumerHost.dispatchEvent(new ContextRequestEvent(this.context, consumerHost, callback, true));\n }\n ev.stopPropagation();\n };\n this.host = host;\n if (contextOrOptions.context !== undefined) {\n this.context = contextOrOptions.context;\n }\n else {\n this.context = contextOrOptions;\n }\n this.attachListeners();\n this.host.addController?.(this);\n }\n attachListeners() {\n this.host.addEventListener('context-request', this.onContextRequest);\n this.host.addEventListener('context-provider', this.onProviderRequest);\n }\n hostConnected() {\n // emit an event to signal a provider is available for this context\n this.host.dispatchEvent(new ContextProviderEvent(this.context, this.host));\n }\n}\n//# sourceMappingURL=context-provider.js.map","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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"}
@@ -0,0 +1,19 @@
1
+ var e=class{#e=new AbortController;#t=new Map;get base(){return this.#e.signal}clear(){for(let e of this.#t.values())e.abort();this.#t.clear()}reset(){this.clear(),this.#e.abort(),this.#e=new AbortController}supersede(e){this.#t.get(e)?.abort();let t=new AbortController;return this.#t.set(e,t),AbortSignal.any([this.#e.signal,t.signal])}};function t(...e){return{state:t=>{let n=e.map(e=>e.state(t));return Object.assign({},...n)},attach:t=>{for(let n of e)try{n.attach?.(t)}catch(e){t.reportError(e)}}}}var n=class extends Error{code;cause;constructor(e,t){super(t?.message??e),this.name=`StoreError`,this.code=e,this.cause=t?.cause}};function r(){throw new n(`NO_TARGET`)}function i(){throw new n(`DESTROYED`)}function a(e){return typeof e==`function`}function o(e){return e===null}function s(e){return e===void 0}function c(e){return typeof e==`object`&&!!e}function l(e,t){let n={};for(let r of t)n[r]=e[r];return n}const u={target:r,signals:new e,set:r};function d(e){let t=e.state(u),n=Object.keys(t),r=n[0];return r?Object.assign(e=>{if(r in e)return l(e,n)},{displayName:e.name}):Object.assign(()=>void 0,{displayName:e.name})}const f=Object.prototype.hasOwnProperty;function p(e,t){if(Object.is(e,t))return!0;if(typeof e!=`object`||!e||typeof t!=`object`||!t)return!1;let n=Object.keys(e),r=Object.keys(t);if(n.length!==r.length)return!1;for(let r of n)if(!f.call(t,r)||!Object.is(e[r],t[r]))return!1;return!0}function m(){return e=>e}function h(...e){}let g=!1;function _(){g||(g=!0,queueMicrotask(y))}const v=new Set;function y(){g=!1;for(let e of v)e.flush();v.clear()}const b=Object.prototype.hasOwnProperty;var ee=class{#e;#t=new Set;#n=!1;constructor(e){this.#e=Object.freeze({...e})}get current(){return this.#e}patch(e){let t={...this.#e},n=!1;for(let r in e){if(!b.call(e,r))continue;let i=e[r];Object.is(this.#e[r],i)||(t[r]=i,n=!0)}n&&(this.#e=Object.freeze(t),this.#r())}subscribe(e,t){let n=t?.signal;if(n?.aborted)return h;if(this.#t.add(e),!n)return()=>this.#t.delete(e);let r=()=>this.#t.delete(e);return n.addEventListener(`abort`,r,{once:!0}),()=>{n.removeEventListener(`abort`,r),this.#t.delete(e)}}flush(){if(this.#n){this.#n=!1;for(let e of this.#t)e()}}#r(){this.#n=!0,v.add(this),_()}};function te(e){return new ee(e)}const x=Symbol(`@videojs/store`);function ne(){return(t,n={})=>{let a=null,s=!1,c=new AbortController,l=new e,u;function d(){s&&i(),a||r()}let f=t.state({target:()=>(d(),a),signals:l,set:e=>u.patch(e)});u=te(f);let p={[x]:!0,get $state(){return u},get target(){return a},get destroyed(){return s},get state(){return u.current},attach:m,destroy:g,subscribe:_};for(let e of Object.keys(f))Object.defineProperty(p,e,{get:()=>u.current[e],enumerable:!0});try{n.onSetup?.({store:p,signal:c.signal})}catch(e){v(e)}return p;function m(e){s&&i(),l.reset(),a=e;let r={target:e,signal:l.base,get:()=>u.current,set:e=>u.patch(e),reportError:v,store:{get state(){return u.current},subscribe:_}};try{t.attach?.(r)}catch(e){v(e)}try{n.onAttach?.({store:p,target:e,signal:l.base})}catch(e){v(e)}return h}function h(){o(a)||(l.reset(),a=null,u.patch(f))}function g(){s||(s=!0,h(),c.abort())}function _(e,t){return u.subscribe(e,t)}function v(e){n.onError?n.onError({store:p,error:e}):console.error(`[vjs-store]`,e)}}}function re(e){return c(e)&&x in e}const S=m();function ie(e){let t={};for(let n of e)t[n.name]=n.value;return t}function C(e,t,n){return new Promise((r,i)=>{let a=()=>{i(n?.signal?.reason??`Aborted`)};if(n?.signal?.aborted){a();return}n?.signal?.addEventListener(`abort`,a,{once:!0}),e.addEventListener(t,e=>{n?.signal?.removeEventListener(`abort`,a),r(e)},{...n,once:!0})})}function w(e,t,n,r){return e.addEventListener(t,n,r),()=>e.removeEventListener(t,n,r)}function ae(e,t){for(let n of e.querySelectorAll(`track`))if(n.track===t)return n;return null}function oe(e,t){return e?.textTracks?Array.from(e.textTracks).filter(t).sort(se):[]}function se(e,t){return e.kind>=t.kind?1:-1}function T(e){let t=[];for(let n=0;n<e.length;n++)t.push([e.start(n),e.end(n)]);return t}const E=S({name:`buffer`,state:()=>({buffered:[],seekable:[]}),attach({target:e,signal:t,set:n}){let{media:r}=e,i=()=>n({buffered:T(r.buffered),seekable:T(r.seekable)});i(),w(r,`progress`,i,{signal:t}),w(r,`emptied`,i,{signal:t})}}),ce=S({name:`controls`,state:()=>({userActive:!0,controlsVisible:!0}),attach({target:e,signal:t,get:n,set:r}){let{media:i,container:a}=e;if(o(a))return;function s(e){return e||i.paused}let c;function l(){clearTimeout(c),c=void 0}function u(){l(),c=setTimeout(f,2e3)}function d(){n().userActive||r({userActive:!0,controlsVisible:!0}),u()}function f(){l(),r({userActive:!1,controlsVisible:s(!1)})}let p=0;function m(){p=Date.now()}function h(e){e.pointerType===`touch`&&Date.now()-p<250&&n().controlsVisible?(l(),r({userActive:!1,controlsVisible:s(!1)})):d()}function g(){let{userActive:e}=n();r({controlsVisible:s(e)}),!i.paused&&e&&u()}w(a,`pointermove`,d,{signal:t}),w(a,`pointerdown`,m,{signal:t}),w(a,`pointerup`,h,{signal:t}),w(a,`keyup`,d,{signal:t}),w(a,`focusin`,d,{signal:t}),w(a,`pointerleave`,f,{signal:t}),w(i,`play`,g,{signal:t}),w(i,`pause`,g,{signal:t}),w(i,`ended`,g,{signal:t}),t.addEventListener(`abort`,l,{once:!0}),u()}}),le=S({name:`error`,state:({set:e})=>({error:null,dismissError(){e({error:null})}}),attach({target:e,signal:t,set:n}){let{media:r}=e;w(r,`error`,()=>n({error:r.error}),{signal:t}),w(r,`emptied`,()=>n({error:null}),{signal:t})}});function ue(){let e=document;return e.fullscreenEnabled||e.webkitFullscreenEnabled?!0:document.createElement(`video`).webkitSupportsFullscreen===!0}function D(){let e=document;return e.fullscreenElement??e.webkitFullscreenElement??null}function O(e,t){let n=t;if(n.webkitDisplayingFullscreen&&n.webkitPresentationMode===`fullscreen`)return!0;let r=e??t;if(D()===r)return!0;try{return r.matches(`:fullscreen`)}catch{return!1}}async function de(e,t){let n=t;if(e){let t=e;if(a(t.requestFullscreen))return t.requestFullscreen();if(a(t.webkitRequestFullscreen))return t.webkitRequestFullscreen();if(a(t.webkitRequestFullScreen))return t.webkitRequestFullScreen()}if(a(n.webkitEnterFullscreen)){n.webkitEnterFullscreen();return}if(a(t.requestFullscreen))return t.requestFullscreen();throw new DOMException(`Fullscreen not supported`,`NotSupportedError`)}async function k(){let e=document,t=D();if(a(e.exitFullscreen))return e.exitFullscreen();if(a(e.webkitExitFullscreen))return e.webkitExitFullscreen();if(a(e.webkitCancelFullScreen))return e.webkitCancelFullScreen();if(t&&a(t.webkitExitFullscreen)){t.webkitExitFullscreen();return}}function fe(){if(document.pictureInPictureEnabled){let e=/.*Version\/.*Safari\/.*/.test(navigator.userAgent),t=typeof matchMedia==`function`&&matchMedia(`(display-mode: standalone)`).matches;return!e||!t}return a(document.createElement(`video`).webkitSetPresentationMode)}function A(e){return document.pictureInPictureElement===e?!0:e.webkitPresentationMode===`picture-in-picture`}async function j(e){let t=e;if(a(t.requestPictureInPicture)){await t.requestPictureInPicture();return}if(a(t.webkitSetPresentationMode)){t.webkitSetPresentationMode(`picture-in-picture`);return}throw new DOMException(`Picture-in-Picture not supported`,`NotSupportedError`)}async function M(e){if(document.pictureInPictureElement&&a(document.exitPictureInPicture)){await document.exitPictureInPicture();return}if(e){let t=e;if(t.webkitPresentationMode===`picture-in-picture`&&a(t.webkitSetPresentationMode)){t.webkitSetPresentationMode(`inline`);return}}}const N=S({name:`fullscreen`,state:({target:e})=>({fullscreen:!1,fullscreenAvailability:`unavailable`,async requestFullscreen(){let{media:t,container:n}=e();return A(t)&&await M(t),de(n,t)},async exitFullscreen(){return k()}}),attach({target:e,signal:t,set:n}){let{media:r,container:i}=e;n({fullscreenAvailability:ue()?`available`:`unsupported`});let a=()=>n({fullscreen:O(i,r)});a(),w(document,`fullscreenchange`,a,{signal:t}),w(document,`webkitfullscreenchange`,a,{signal:t}),`webkitPresentationMode`in r&&w(r,`webkitpresentationmodechanged`,a,{signal:t})}}),P=S({name:`pip`,state:({target:e})=>({pip:!1,pipAvailability:`unavailable`,async requestPictureInPicture(){let{media:t,container:n}=e();return O(n,t)&&await k(),j(t)},async exitPictureInPicture(){let{media:t}=e();return M(t)}}),attach({target:e,signal:t,set:n}){let{media:r}=e;n({pipAvailability:fe()?`available`:`unsupported`});let i=()=>n({pip:A(r)});i(),w(r,`enterpictureinpicture`,i,{signal:t}),w(r,`leavepictureinpicture`,i,{signal:t}),`webkitPresentationMode`in r&&w(r,`webkitpresentationmodechanged`,i,{signal:t})}}),F=S({name:`playback`,state:({target:e})=>({paused:!0,ended:!1,started:!1,waiting:!1,play(){return e().media.play()},pause(){e().media.pause()}}),attach({target:e,signal:t,set:n}){let{media:r}=e,i=()=>n({paused:r.paused,ended:r.ended,started:!r.paused||r.currentTime>0,waiting:r.readyState<HTMLMediaElement.HAVE_FUTURE_DATA&&!r.paused});i(),w(r,`emptied`,i,{signal:t}),w(r,`play`,i,{signal:t}),w(r,`pause`,i,{signal:t}),w(r,`ended`,i,{signal:t}),w(r,`playing`,i,{signal:t}),w(r,`waiting`,i,{signal:t})}}),I=[1,1.2,1.5,1.7,2],L=S({name:`playbackRate`,state:({target:e})=>({playbackRates:I,playbackRate:1,setPlaybackRate(t){e().media.playbackRate=t}}),attach({target:e,signal:t,set:n}){let{media:r}=e,i=()=>n({playbackRate:r.playbackRate});i(),w(r,`ratechange`,i,{signal:t})}}),R=S({name:`source`,state:({target:e,signals:t})=>({source:null,canPlay:!1,loadSource(n){t.clear();let{media:r}=e();return r.src=n,r.load(),n}}),attach({target:e,signal:t,set:n}){let{media:r}=e,i=()=>n({source:r.currentSrc||r.src||null,canPlay:r.readyState>=HTMLMediaElement.HAVE_ENOUGH_DATA});i(),w(r,`canplay`,i,{signal:t}),w(r,`canplaythrough`,i,{signal:t}),w(r,`loadstart`,i,{signal:t}),w(r,`emptied`,i,{signal:t})}}),z=S({name:`textTrack`,state:({target:e})=>({chaptersCues:[],thumbnailCues:[],thumbnailTrackSrc:null,textTrackList:[],subtitlesShowing:!1,toggleSubtitles(t){let n=oe(e().media,e=>e.kind===`subtitles`||e.kind===`captions`);if(!n.length)return!1;let r=n.some(e=>e.mode===`showing`),i=t??!r;for(let e of n)e.mode=i?`showing`:`disabled`;return i}}),attach({target:e,signal:t,set:n}){let{media:r}=e,i=null;function a(){i?.abort(),i=new AbortController;let e=null,t=null,o=[],s=!1;for(let n=0;n<r.textTracks.length;n++){let i=r.textTracks[n];!e&&i.kind===`chapters`&&(e=i),!t&&i.kind===`metadata`&&i.label===`thumbnails`&&(t=i),o.push({kind:i.kind,label:i.label,language:i.language,mode:i.mode}),(i.kind===`captions`||i.kind===`subtitles`)&&i.mode===`showing`&&(s=!0)}let c=e?.cues?Array.from(e.cues):[],l=t?.cues?Array.from(t.cues):[],u=null;t&&(u=ae(r,t)?.src??null);for(let e of r.querySelectorAll?.(`track`)??[])e.track?.cues?.length||w(e,`load`,a,{signal:i.signal});n({chaptersCues:c,thumbnailCues:l,thumbnailTrackSrc:u,textTrackList:o,subtitlesShowing:s})}a(),w(r.textTracks,`addtrack`,a,{signal:t}),w(r.textTracks,`removetrack`,a,{signal:t}),w(r.textTracks,`change`,a,{signal:t}),w(r,`loadstart`,a,{signal:t}),t.addEventListener(`abort`,()=>i?.abort(),{once:!0})}});function B(e){return e.readyState>=HTMLMediaElement.HAVE_METADATA}const V={seek:Symbol.for(`@videojs/seek`)},pe=S({name:`time`,state:({target:e,signals:t,set:n})=>({currentTime:0,duration:0,seeking:!1,async seek(r){let{media:i}=e(),a=t.supersede(V.seek);if(!B(i)&&!await C(i,`loadedmetadata`,{signal:a}).catch(()=>!1))return i.currentTime;let o=Math.max(0,Math.min(r,i.duration||1/0));return n({currentTime:o,seeking:!0}),i.currentTime=o,await C(i,`seeked`,{signal:a}).catch(h),i.currentTime}}),attach({target:e,signal:t,set:n}){let{media:r}=e,i=()=>n({currentTime:r.currentTime,duration:Number.isFinite(r.duration)?r.duration:0,seeking:r.seeking});i(),w(r,`timeupdate`,i,{signal:t}),w(r,`durationchange`,i,{signal:t}),w(r,`seeking`,i,{signal:t}),w(r,`seeked`,i,{signal:t}),w(r,`loadedmetadata`,i,{signal:t}),w(r,`emptied`,i,{signal:t})}}),me=S({name:`volume`,state:({target:e})=>({volume:1,muted:!1,volumeAvailability:`unavailable`,setVolume(t){let{media:n}=e(),r=Math.max(0,Math.min(1,t));return r>0&&n.muted&&(n.muted=!1),n.volume=r,n.volume},toggleMuted(){let{media:t}=e();return t.muted||t.volume===0?(t.muted=!1,t.volume===0&&(t.volume=.25)):t.muted=!0,t.muted}}),attach({target:e,signal:t,set:n}){let{media:r}=e;n({volumeAvailability:he()});let i=()=>n({volume:r.volume,muted:r.muted});i(),w(r,`volumechange`,i,{signal:t})}});function he(){let e=document.createElement(`video`);try{return e.volume=.5,e.volume===.5?`available`:`unsupported`}catch{return`unsupported`}}const ge=[];d(E),d(ce),d(le),d(N),d(P),d(F),d(L),d(R),d(z),d(pe),d(me);
2
+ /**
3
+ * @license
4
+ * Copyright 2021 Google LLC
5
+ * SPDX-License-Identifier: BSD-3-Clause
6
+ */
7
+ var H=class extends Event{constructor(e,t,n,r){super(`context-request`,{bubbles:!0,composed:!0}),this.context=e,this.contextTarget=t,this.callback=n,this.subscribe=r??!1}};
8
+ /**
9
+ * @license
10
+ * Copyright 2021 Google LLC
11
+ * SPDX-License-Identifier: BSD-3-Clause
12
+ */
13
+ function _e(e){return e}
14
+ /**
15
+ * @license
16
+ * Copyright 2021 Google LLC
17
+ * SPDX-License-Identifier: BSD-3-Clause
18
+ */var U=class{constructor(e,t,n,r){if(this.subscribe=!1,this.provided=!1,this.value=void 0,this.t=(e,t)=>{this.unsubscribe&&(this.unsubscribe!==t&&(this.provided=!1,this.unsubscribe()),this.subscribe||this.unsubscribe()),this.value=e,this.host.requestUpdate(),this.provided&&!this.subscribe||(this.provided=!0,this.callback&&this.callback(e,t)),this.unsubscribe=t},this.host=e,t.context!==void 0){let e=t;this.context=e.context,this.callback=e.callback,this.subscribe=e.subscribe??!1}else this.context=t,this.callback=n,this.subscribe=r??!1;this.host.addController(this)}hostConnected(){this.dispatchRequest()}hostDisconnected(){this.unsubscribe&&=(this.unsubscribe(),void 0)}dispatchRequest(){this.host.dispatchEvent(new H(this.context,this.host,this.t,this.subscribe))}},ve=class{get value(){return this.o}set value(e){this.setValue(e)}setValue(e,t=!1){let n=t||!Object.is(e,this.o);this.o=e,n&&this.updateObservers()}constructor(e){this.subscriptions=new Map,this.updateObservers=()=>{for(let[e,{disposer:t}]of this.subscriptions)e(this.o,t)},e!==void 0&&(this.value=e)}addCallback(e,t,n){if(!n)return void e(this.value);this.subscriptions.has(e)||this.subscriptions.set(e,{disposer:()=>{this.subscriptions.delete(e)},consumerHost:t});let{disposer:r}=this.subscriptions.get(e);e(this.value,r)}clearCallbacks(){this.subscriptions.clear()}},ye=class extends Event{constructor(e,t){super(`context-provider`,{bubbles:!0,composed:!0}),this.context=e,this.contextTarget=t}},be=class extends ve{constructor(e,t,n){super(t.context===void 0?n:t.initialValue),this.onContextRequest=e=>{if(e.context!==this.context)return;let t=e.contextTarget??e.composedPath()[0];t!==this.host&&(e.stopPropagation(),this.addCallback(e.callback,t,e.subscribe))},this.onProviderRequest=e=>{if(e.context!==this.context||(e.contextTarget??e.composedPath()[0])===this.host)return;let t=new Set;for(let[e,{consumerHost:n}]of this.subscriptions)t.has(e)||(t.add(e),n.dispatchEvent(new H(this.context,n,e,!0)));e.stopPropagation()},this.host=e,t.context===void 0?this.context=t:this.context=t.context,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 ye(this.context,this.host))}};const W=_e(Symbol(`@videojs/player`));function G(e){return t=>{class n extends t{#e=h;#t=null;#n=null;constructor(...t){super(...t),new U(this,{context:e,callback:e=>{this.#n=e??null,this.#a()},subscribe:!0})}get store(){return this.#n}connectedCallback(){super.connectedCallback(),this.#t=new MutationObserver(e=>{e.some(xe)&&this.#a()}),this.#t.observe(this,{childList:!0,subtree:!0,attributes:!0,attributeFilter:[`data-media-element`]}),this.addEventListener(`slotchange`,this.#r),this.#a()}disconnectedCallback(){super.disconnectedCallback(),this.#t?.disconnect(),this.#t=null,this.removeEventListener(`slotchange`,this.#r),this.#e()}#r=()=>{this.#a()};#i(){let e=this.querySelector(`slot[name="media"]`);if(!e)return null;for(let t of e.assignedElements({flatten:!0}))if(t instanceof HTMLMediaElement)return t;return null}#a(){let e=this.#n??this.store;if(!e)return;let t=this.querySelector(`video, audio, [data-media-element]`)??this.#i();if(!t){this.#e(),this.#e=h;return}let n={media:t,container:this},r=e.target?.media!==n.media,i=e.target?.container!==n.container;(r||i)&&(this.#e(),this.#e=e.attach(n))}}return n}}function K(e){return e instanceof HTMLMediaElement||e instanceof Element&&e.hasAttribute(`data-media-element`)}function xe(e){if(e.type===`attributes`&&e.target instanceof Element)return e.target.hasAttribute(`data-media-element`);for(let t of e.addedNodes)if(K(t))return!0;for(let t of e.removedNodes)if(K(t))return!0;return!1}function Se(e){class t extends e{#e=!1;#t=new Set;get destroyed(){return this.#e}destroy(){this.#e||(this.#e=!0,this.destroyCallback())}destroyCallback(){for(let e of this.#t)e.hostDestroyed?.()}addController(e){super.addController(e),this.#t.add(e)}removeController(e){super.removeController(e),this.#t.delete(e)}connectedCallback(){this.#e||super.connectedCallback()}disconnectedCallback(){super.disconnectedCallback(),!this.#e&&!this.hasAttribute(`keep-alive`)&&requestAnimationFrame(()=>{requestAnimationFrame(()=>{this.isConnected||this.destroy()})})}performUpdate(){this.#e||super.performUpdate()}}return t}const q=new WeakMap,J=new Map;var Y=class extends HTMLElement{static{this.properties={}}static get observedAttributes(){return[...X(this).attrToProp.keys()]}#e=new Set;#t=new Map;#n;#r;constructor(){super(),this.isUpdatePending=!1,this.hasUpdated=!1,this.#r=new Promise(e=>this.enableUpdating=e);let{props:e}=X(this.constructor);for(let t of e.keys())Object.hasOwn(this,t)&&((this.#n??=new Map).set(t,this[t]),delete this[t]);this.requestUpdate()}enableUpdating(e){}addController(e){this.#e.add(e),this.isConnected&&e.hostConnected?.()}removeController(e){this.#e.delete(e)}connectedCallback(){this.enableUpdating(!0);for(let e of this.#e)e.hostConnected?.()}disconnectedCallback(){for(let e of this.#e)e.hostDisconnected?.()}attributeChangedCallback(e,t,n){if(t===n)return;let{props:r,attrToProp:i}=X(this.constructor),a=i.get(e);if(!a)return;let o=r.get(a);if(!o)return;let s=n;o.type===Boolean?s=n!==null:o.type===Number&&(s=n===null?null:Number(n)),this[a]=s}requestUpdate(e,t){e!==void 0&&this.#t.set(e,t),!this.isUpdatePending&&(this.#r=this.#i())}async#i(){this.isUpdatePending=!0;try{await this.#r}catch(e){Promise.reject(e)}let e=this.scheduleUpdate();return e!=null&&await e,!this.isUpdatePending}scheduleUpdate(){this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated&&this.#n){for(let[e,t]of this.#n)this[e]=t;this.#n=void 0}let e=this.#t;this.willUpdate(e);for(let e of this.#e)e.hostUpdate?.();this.update(e),this.#t=new Map,this.isUpdatePending=!1;for(let e of this.#e)e.hostUpdated?.();this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}willUpdate(e){}update(e){}firstUpdated(e){}updated(e){}get updateComplete(){return this.#r}};function X(e){let t=q.get(e);if(t)return t;let n=new Map,r=new Map;for(let[t,i]of Object.entries(e.properties))if(n.set(t,i),r.set(i.attribute??t,t),!Object.getOwnPropertyDescriptor(e.prototype,t)?.get){let n=J.get(t);n||(n=Symbol(t),J.set(t,n)),Object.defineProperty(e.prototype,t,{get(){return this[n]},set(e){let r=this[n];this[n]=e,Object.is(r,e)||this.requestUpdate(t,r)},configurable:!0,enumerable:!0})}let i={props:n,attrToProp:r};return q.set(e,i),i}var Z=class extends Se(Y){};const Ce=G(W);var we=class extends Ce(Z){static{this.tagName=`media-container`}};function Te(e,t){return n=>{class r extends n{#e=t();#t=new be(this,{context:e,initialValue:this.store});get store(){return o(this.#e)&&(this.#e=t()),this.#e}connectedCallback(){super.connectedCallback(),this.#t.setValue(this.store)}destroyCallback(){this.#e?.destroy(),this.#e=null,super.destroyCallback()}}return r}}var Ee=class{#e;#t;#n;#r;#i=h;constructor(e,t,n){this.#e=e,this.#n=t,this.#t=n,e.addController(this)}get value(){return this.#t?(this.#r??=this.#t(this.#n.current),this.#r):this.#n.current}track(e){this.#n=e,this.#a()}hostConnected(){this.#a()}hostDisconnected(){this.#i(),this.#i=h,this.#r=void 0}#a(){if(this.#i(),!this.#t){this.#i=this.#n.subscribe(()=>this.#e.requestUpdate());return}let e=this.#t;this.#r=e(this.#n.current),this.#i=this.#n.subscribe(()=>{let t=e(this.#n.current);p(this.#r,t)||(this.#r=t,this.#e.requestUpdate())})}},De=class{#e;#t;#n;constructor(e,t,n){this.#e=n??h,re(t)?(this.#n=t,this.#t=null):(this.#n=null,this.#t=new U(e,{context:t,callback:e=>this.#e(e),subscribe:!1})),e.addController(this)}get value(){return this.#t?this.#t.value??null:this.#n}hostConnected(){this.#n&&this.#e(this.#n)}},Oe=class{#e;#t;#n;#r=null;constructor(e,t,n){this.#e=e,this.#t=n,this.#n=new De(e,t,e=>this.#i(e)),e.addController(this)}get value(){let e=this.#n.value;if(o(e))throw Error(`Store not available`);return s(this.#t)?e:this.#r.value}hostConnected(){}#i(e){s(this.#t)||(this.#r?this.#r.track(e.$state):this.#r=new Ee(this.#e,e.$state,this.#t))}},ke=class{#e;#t;#n;#r=null;constructor(e,t,n){this.#e=e,this.#t=n,this.#n=new U(e,{context:t,callback:e=>this.#i(e),subscribe:!0}),e.addController(this)}get value(){let e=this.#n.value;if(e)return this.#t?this.#r?.value:e}get displayName(){return this.#t?.displayName}hostConnected(){let e=this.#n.value;e&&this.#i(e)}hostDisconnected(){this.#r=null}#i(e){!this.#r&&this.#t&&(this.#r=new Oe(this.#e,e,this.#t))}};function Ae(e){let n=t(...e.features);function r(){return ne()(n)}return{context:W,create:r,PlayerController:ke,ProviderMixin:Te(W,r),ContainerMixin:G(W)}}function Q(e){customElements.get(e.tagName)||customElements.define(e.tagName,e)}const{ProviderMixin:je}=Ae({features:ge});Q(class extends je(Z){static{this.tagName=`background-video-player`}}),Q(we);function $(e){return`<media-container><slot name="media" slot="media"></slot></media-container>`}Q(class extends Y{static{this.tagName=`background-video-skin`}static{this.shadowRootOptions={mode:`open`}}static{this.getTemplateHTML=$}constructor(){super(),this.shadowRoot||(this.attachShadow(this.constructor.shadowRootOptions),this.shadowRoot.innerHTML=$(ie(this.attributes)))}});
19
+ //# sourceMappingURL=background.js.map