@livepeer-frameworks/player-wc 0.1.9 → 0.2.1

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 (140) hide show
  1. package/dist/esm/components/controls/fw-fullscreen-button.js +76 -0
  2. package/dist/esm/components/controls/fw-fullscreen-button.js.map +1 -0
  3. package/dist/esm/components/controls/fw-live-badge.js +109 -0
  4. package/dist/esm/components/controls/fw-live-badge.js.map +1 -0
  5. package/dist/esm/components/controls/fw-play-button.js +76 -0
  6. package/dist/esm/components/controls/fw-play-button.js.map +1 -0
  7. package/dist/esm/components/controls/fw-skip-button.js +62 -0
  8. package/dist/esm/components/controls/fw-skip-button.js.map +1 -0
  9. package/dist/esm/components/controls/fw-time-display.js +77 -0
  10. package/dist/esm/components/controls/fw-time-display.js.map +1 -0
  11. package/dist/esm/components/controls/fw-volume-control.js +76 -0
  12. package/dist/esm/components/controls/fw-volume-control.js.map +1 -0
  13. package/dist/esm/components/fw-dev-mode-panel.js +11 -15
  14. package/dist/esm/components/fw-dev-mode-panel.js.map +1 -1
  15. package/dist/esm/components/fw-error-overlay.js +13 -5
  16. package/dist/esm/components/fw-error-overlay.js.map +1 -1
  17. package/dist/esm/components/fw-idle-screen.js +10 -2
  18. package/dist/esm/components/fw-idle-screen.js.map +1 -1
  19. package/dist/esm/components/fw-loading-screen.js +89 -42
  20. package/dist/esm/components/fw-loading-screen.js.map +1 -1
  21. package/dist/esm/components/fw-loading-spinner.js +20 -9
  22. package/dist/esm/components/fw-loading-spinner.js.map +1 -1
  23. package/dist/esm/components/fw-player-controls.js +18 -13
  24. package/dist/esm/components/fw-player-controls.js.map +1 -1
  25. package/dist/esm/components/fw-player.js +165 -59
  26. package/dist/esm/components/fw-player.js.map +1 -1
  27. package/dist/esm/components/fw-settings-menu.js +44 -9
  28. package/dist/esm/components/fw-settings-menu.js.map +1 -1
  29. package/dist/esm/components/fw-stream-state-overlay.js +13 -5
  30. package/dist/esm/components/fw-stream-state-overlay.js.map +1 -1
  31. package/dist/esm/components/fw-toast.js +11 -1
  32. package/dist/esm/components/fw-toast.js.map +1 -1
  33. package/dist/esm/components/fw-volume-control.js +13 -3
  34. package/dist/esm/components/fw-volume-control.js.map +1 -1
  35. package/dist/esm/controllers/player-controller-host.js +14 -1
  36. package/dist/esm/controllers/player-controller-host.js.map +1 -1
  37. package/dist/esm/index.js +6 -0
  38. package/dist/esm/index.js.map +1 -1
  39. package/dist/esm/styles/shared-styles.js +401 -304
  40. package/dist/esm/styles/shared-styles.js.map +1 -1
  41. package/dist/fw-player.iife.js +707 -488
  42. package/dist/types/components/controls/fw-fullscreen-button.d.ts +18 -0
  43. package/dist/types/components/controls/fw-live-badge.d.ts +19 -0
  44. package/dist/types/components/controls/fw-play-button.d.ts +18 -0
  45. package/dist/types/components/controls/fw-skip-button.d.ts +17 -0
  46. package/dist/types/components/controls/fw-time-display.d.ts +17 -0
  47. package/dist/types/components/controls/fw-volume-control.d.ts +18 -0
  48. package/dist/types/components/controls/index.d.ts +6 -0
  49. package/dist/types/components/fw-dev-mode-panel.d.ts +1 -1
  50. package/dist/types/components/fw-error-overlay.d.ts +4 -0
  51. package/dist/types/components/fw-idle-screen.d.ts +4 -0
  52. package/dist/types/components/fw-loading-screen.d.ts +5 -1
  53. package/dist/types/components/fw-loading-spinner.d.ts +4 -0
  54. package/dist/types/components/fw-player-controls.d.ts +2 -1
  55. package/dist/types/components/fw-player.d.ts +10 -1
  56. package/dist/types/components/fw-settings-menu.d.ts +3 -1
  57. package/dist/types/components/fw-stream-state-overlay.d.ts +4 -0
  58. package/dist/types/components/fw-toast.d.ts +4 -0
  59. package/dist/types/controllers/player-controller-host.d.ts +7 -1
  60. package/dist/types/index.d.ts +1 -0
  61. package/package.json +10 -13
  62. package/src/components/controls/fw-fullscreen-button.ts +75 -0
  63. package/src/components/controls/fw-live-badge.ts +109 -0
  64. package/src/components/controls/fw-play-button.ts +75 -0
  65. package/src/components/controls/fw-skip-button.ts +59 -0
  66. package/src/components/controls/fw-time-display.ts +74 -0
  67. package/src/components/controls/fw-volume-control.ts +75 -0
  68. package/src/components/controls/index.ts +6 -0
  69. package/src/components/fw-dev-mode-panel.ts +10 -17
  70. package/src/components/fw-error-overlay.ts +13 -5
  71. package/src/components/fw-idle-screen.ts +10 -2
  72. package/src/components/fw-loading-screen.ts +90 -46
  73. package/src/components/fw-loading-spinner.ts +18 -9
  74. package/src/components/fw-player-controls.ts +17 -13
  75. package/src/components/fw-player.ts +166 -64
  76. package/src/components/fw-settings-menu.ts +49 -9
  77. package/src/components/fw-stream-state-overlay.ts +13 -5
  78. package/src/components/fw-toast.ts +11 -1
  79. package/src/components/fw-volume-control.ts +14 -3
  80. package/src/controllers/player-controller-host.ts +18 -0
  81. package/src/index.ts +10 -0
  82. package/src/styles/shared-styles.ts +401 -304
  83. package/dist/cjs/components/fw-context-menu.js +0 -17
  84. package/dist/cjs/components/fw-context-menu.js.map +0 -1
  85. package/dist/cjs/components/fw-dev-mode-panel.js +0 -907
  86. package/dist/cjs/components/fw-dev-mode-panel.js.map +0 -1
  87. package/dist/cjs/components/fw-dvd-logo.js +0 -211
  88. package/dist/cjs/components/fw-dvd-logo.js.map +0 -1
  89. package/dist/cjs/components/fw-error-overlay.js +0 -101
  90. package/dist/cjs/components/fw-error-overlay.js.map +0 -1
  91. package/dist/cjs/components/fw-idle-screen.js +0 -726
  92. package/dist/cjs/components/fw-idle-screen.js.map +0 -1
  93. package/dist/cjs/components/fw-loading-screen.js +0 -513
  94. package/dist/cjs/components/fw-loading-screen.js.map +0 -1
  95. package/dist/cjs/components/fw-loading-spinner.js +0 -62
  96. package/dist/cjs/components/fw-loading-spinner.js.map +0 -1
  97. package/dist/cjs/components/fw-player-controls.js +0 -451
  98. package/dist/cjs/components/fw-player-controls.js.map +0 -1
  99. package/dist/cjs/components/fw-player.js +0 -832
  100. package/dist/cjs/components/fw-player.js.map +0 -1
  101. package/dist/cjs/components/fw-seek-bar.js +0 -383
  102. package/dist/cjs/components/fw-seek-bar.js.map +0 -1
  103. package/dist/cjs/components/fw-settings-menu.js +0 -253
  104. package/dist/cjs/components/fw-settings-menu.js.map +0 -1
  105. package/dist/cjs/components/fw-skip-indicator.js +0 -143
  106. package/dist/cjs/components/fw-skip-indicator.js.map +0 -1
  107. package/dist/cjs/components/fw-speed-indicator.js +0 -61
  108. package/dist/cjs/components/fw-speed-indicator.js.map +0 -1
  109. package/dist/cjs/components/fw-stats-panel.js +0 -205
  110. package/dist/cjs/components/fw-stats-panel.js.map +0 -1
  111. package/dist/cjs/components/fw-stream-state-overlay.js +0 -338
  112. package/dist/cjs/components/fw-stream-state-overlay.js.map +0 -1
  113. package/dist/cjs/components/fw-subtitle-renderer.js +0 -217
  114. package/dist/cjs/components/fw-subtitle-renderer.js.map +0 -1
  115. package/dist/cjs/components/fw-thumbnail-overlay.js +0 -161
  116. package/dist/cjs/components/fw-thumbnail-overlay.js.map +0 -1
  117. package/dist/cjs/components/fw-title-overlay.js +0 -72
  118. package/dist/cjs/components/fw-title-overlay.js.map +0 -1
  119. package/dist/cjs/components/fw-toast.js +0 -74
  120. package/dist/cjs/components/fw-toast.js.map +0 -1
  121. package/dist/cjs/components/fw-volume-control.js +0 -276
  122. package/dist/cjs/components/fw-volume-control.js.map +0 -1
  123. package/dist/cjs/components/shared/hitmarker-audio.js +0 -76
  124. package/dist/cjs/components/shared/hitmarker-audio.js.map +0 -1
  125. package/dist/cjs/constants/media-assets.js +0 -11
  126. package/dist/cjs/constants/media-assets.js.map +0 -1
  127. package/dist/cjs/controllers/player-controller-host.js +0 -364
  128. package/dist/cjs/controllers/player-controller-host.js.map +0 -1
  129. package/dist/cjs/define.js +0 -53
  130. package/dist/cjs/define.js.map +0 -1
  131. package/dist/cjs/icons/index.js +0 -180
  132. package/dist/cjs/icons/index.js.map +0 -1
  133. package/dist/cjs/index.js +0 -108
  134. package/dist/cjs/index.js.map +0 -1
  135. package/dist/cjs/node_modules/.pnpm/@rollup_plugin-typescript@12.3.0_rollup@4.57.1_tslib@2.8.1_typescript@5.9.3/node_modules/tslib/tslib.es6.js +0 -33
  136. package/dist/cjs/node_modules/.pnpm/@rollup_plugin-typescript@12.3.0_rollup@4.57.1_tslib@2.8.1_typescript@5.9.3/node_modules/tslib/tslib.es6.js.map +0 -1
  137. package/dist/cjs/styles/shared-styles.js +0 -1985
  138. package/dist/cjs/styles/shared-styles.js.map +0 -1
  139. package/dist/cjs/styles/utility-styles.js +0 -725
  140. package/dist/cjs/styles/utility-styles.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"fw-player.js","sources":["../../../../src/components/fw-player.ts"],"sourcesContent":["/**\n * <fw-player> — Main player web component.\n * Port of Player.tsx / PlayerInner from player-react.\n */\nimport { LitElement, html, css, nothing, type PropertyValues } from \"lit\";\nimport { customElement, property, state, query } from \"lit/decorators.js\";\nimport { classMap } from \"lit/directives/class-map.js\";\nimport { PlayerControllerHost } from \"../controllers/player-controller-host.js\";\nimport { sharedStyles } from \"../styles/shared-styles.js\";\nimport { utilityStyles } from \"../styles/utility-styles.js\";\nimport {\n closeIcon,\n statsIcon,\n settingsIcon,\n pictureInPictureIcon,\n loopIcon,\n} from \"../icons/index.js\";\nimport type { ContentEndpoints, PlaybackMode } from \"@livepeer-frameworks/player-core\";\n\n@customElement(\"fw-player\")\nexport class FwPlayer extends LitElement {\n // ---- Public attributes (reflected) ----\n @property({ attribute: \"content-id\" }) contentId = \"\";\n @property({ attribute: \"content-type\" }) contentType?: \"live\" | \"dvr\" | \"clip\" | \"vod\";\n @property({ attribute: \"gateway-url\" }) gatewayUrl?: string;\n @property({ attribute: \"mist-url\" }) mistUrl?: string;\n @property({ attribute: \"auth-token\" }) authToken?: string;\n @property({ type: Boolean }) autoplay = true;\n @property({ type: Boolean }) muted = true;\n // React/Svelte use `stockControls` for native controls. Keep `controls` as a\n // compatibility no-op so WC parity does not hide custom controls/seekbar.\n @property({ type: Boolean }) controls = false;\n @property({ type: Boolean, attribute: \"stock-controls\" }) stockControls = false;\n @property({ type: Boolean, attribute: \"native-controls\" }) nativeControls = false;\n @property({ type: Boolean }) debug = false;\n @property({ type: Boolean, attribute: \"dev-mode\" }) devMode = false;\n @property({ attribute: \"thumbnail-url\" }) thumbnailUrl?: string;\n @property({ attribute: \"playback-mode\" }) playbackMode: PlaybackMode = \"auto\";\n\n // ---- JS-only properties (not reflected) ----\n @property({ attribute: false }) endpoints?: ContentEndpoints;\n\n // ---- Internal state ----\n @state() private _isStatsOpen = false;\n @state() private _isDevPanelOpen = false;\n @state() private _skipDirection: \"back\" | \"forward\" | null = null;\n @state() private _contextMenuOpen = false;\n @state() private _contextMenuMounted = false;\n @state() private _contextMenuState: \"open\" | \"closed\" = \"closed\";\n @state() private _contextMenuSide: \"top\" | \"bottom\" | \"left\" | \"right\" = \"bottom\";\n @state() private _contextMenuX = 0;\n @state() private _contextMenuY = 0;\n\n // ---- Refs ----\n @query(\"#container\") private _containerEl!: HTMLDivElement;\n\n // ---- Controller ----\n pc = new PlayerControllerHost(this);\n\n static styles = [\n sharedStyles,\n utilityStyles,\n css`\n :host {\n display: block;\n position: relative;\n width: 100%;\n height: 100%;\n contain: layout style;\n }\n :host([hidden]) {\n display: none;\n }\n .player-area {\n position: relative;\n width: 100%;\n height: 100%;\n }\n .player-area--dev {\n flex: 1;\n min-width: 0;\n min-height: 0;\n }\n `,\n ];\n\n // ---- Lifecycle ----\n\n protected willUpdate(changed: PropertyValues) {\n if (\n changed.has(\"contentId\") ||\n changed.has(\"contentType\") ||\n changed.has(\"gatewayUrl\") ||\n changed.has(\"mistUrl\") ||\n changed.has(\"authToken\") ||\n changed.has(\"autoplay\") ||\n changed.has(\"muted\") ||\n changed.has(\"stockControls\") ||\n changed.has(\"nativeControls\") ||\n changed.has(\"debug\") ||\n changed.has(\"thumbnailUrl\") ||\n changed.has(\"endpoints\")\n ) {\n this.pc.configure({\n contentId: this.contentId,\n contentType: this.contentType,\n endpoints: this.endpoints,\n gatewayUrl: this.gatewayUrl,\n mistUrl: this.mistUrl,\n authToken: this.authToken,\n autoplay: this.autoplay,\n muted: this.muted,\n controls: this.stockControls || this.nativeControls,\n poster: this.thumbnailUrl,\n debug: this.debug,\n });\n }\n }\n\n protected firstUpdated() {\n this.pc.attach(this._containerEl);\n\n // Close context menu on outside click\n document.addEventListener(\"pointerdown\", this._handleDocumentPointerDown);\n document.addEventListener(\"contextmenu\", this._handleDocumentContextMenu);\n document.addEventListener(\"keydown\", this._handleDocumentKeyDown);\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n document.removeEventListener(\"pointerdown\", this._handleDocumentPointerDown);\n document.removeEventListener(\"contextmenu\", this._handleDocumentContextMenu);\n document.removeEventListener(\"keydown\", this._handleDocumentKeyDown);\n if (this._contextMenuCloseTimer) {\n clearTimeout(this._contextMenuCloseTimer);\n this._contextMenuCloseTimer = undefined;\n }\n this._resetContextMenuTypeahead();\n }\n\n // ---- Context Menu ----\n\n private _contextMenuCloseTimer?: ReturnType<typeof setTimeout>;\n private _contextMenuTypeahead = \"\";\n private _contextMenuTypeaheadTimer?: ReturnType<typeof setTimeout>;\n\n private _resetContextMenuTypeahead = () => {\n this._contextMenuTypeahead = \"\";\n if (this._contextMenuTypeaheadTimer) {\n clearTimeout(this._contextMenuTypeaheadTimer);\n this._contextMenuTypeaheadTimer = undefined;\n }\n };\n\n private _resolveContextMenuSide = (\n rawX: number,\n rawY: number,\n clampedX: number,\n clampedY: number\n ) => {\n const deltaX = Math.abs(rawX - clampedX);\n const deltaY = Math.abs(rawY - clampedY);\n\n if (deltaX === 0 && deltaY === 0) {\n return \"bottom\";\n }\n\n if (deltaY >= deltaX) {\n return rawY > clampedY ? \"top\" : \"bottom\";\n }\n\n return rawX > clampedX ? \"left\" : \"right\";\n };\n\n private _closeContextMenu = (restoreFocus = false) => {\n this._contextMenuOpen = false;\n this._contextMenuState = \"closed\";\n this._resetContextMenuTypeahead();\n if (this._contextMenuCloseTimer) {\n clearTimeout(this._contextMenuCloseTimer);\n }\n this._contextMenuCloseTimer = setTimeout(() => {\n if (!this._contextMenuOpen) {\n this._contextMenuMounted = false;\n }\n }, 170);\n\n if (restoreFocus) {\n const root = this.shadowRoot?.querySelector<HTMLElement>('[part=\"root\"]');\n root?.focus();\n }\n };\n\n private _getQueryRoot = (): ShadowRoot | null => {\n return (\n this.shadowRoot ?? (this as unknown as { renderRoot?: ShadowRoot | null }).renderRoot ?? null\n );\n };\n\n private _getContextMenuElement = () =>\n this._getQueryRoot()?.querySelector<HTMLElement>('[data-context-menu=\"true\"]') ?? null;\n\n private _getContextMenuBounds = () => {\n const root = this._getQueryRoot()?.querySelector<HTMLElement>('[part=\"root\"]');\n const rect = root?.getBoundingClientRect() ?? this.getBoundingClientRect();\n\n const width = rect.width > 0 ? rect.width : window.innerWidth;\n const height = rect.height > 0 ? rect.height : window.innerHeight;\n\n return {\n left: rect.left,\n top: rect.top,\n right: rect.left + width,\n bottom: rect.top + height,\n width,\n height,\n };\n };\n\n private _toLocalContextMenuPoint = (clientX: number, clientY: number) => {\n const bounds = this._getContextMenuBounds();\n return {\n x: clientX - bounds.left,\n y: clientY - bounds.top,\n };\n };\n\n private _getContextMenuItems = () =>\n Array.from(\n this._getQueryRoot()?.querySelectorAll<HTMLButtonElement>(\n '[data-context-menu-item=\"true\"][data-context-menu-level=\"root\"]:not([data-disabled=\"true\"])'\n ) ?? []\n );\n\n private _focusFirstContextMenuItem = () => {\n const [firstItem] = this._getContextMenuItems();\n firstItem?.focus();\n };\n\n private _clampContextMenuPosition = (x: number, y: number, width: number, height: number) => {\n const viewportPadding = 8;\n const bounds = this._getContextMenuBounds();\n const maxX = Math.max(viewportPadding, bounds.width - width - viewportPadding);\n const maxY = Math.max(viewportPadding, bounds.height - height - viewportPadding);\n\n return {\n x: Math.max(viewportPadding, Math.min(x, maxX)),\n y: Math.max(viewportPadding, Math.min(y, maxY)),\n };\n };\n\n private _syncContextMenuPosition = () => {\n if (!this._contextMenuMounted) return;\n const menu = this._getContextMenuElement();\n if (!menu) return;\n\n const rect = menu.getBoundingClientRect();\n const next = this._clampContextMenuPosition(\n this._contextMenuX,\n this._contextMenuY,\n rect.width,\n rect.height\n );\n this._contextMenuSide = this._resolveContextMenuSide(\n this._contextMenuX,\n this._contextMenuY,\n next.x,\n next.y\n );\n if (next.x !== this._contextMenuX || next.y !== this._contextMenuY) {\n this._contextMenuX = next.x;\n this._contextMenuY = next.y;\n }\n };\n\n private _openContextMenu = (clientX: number, clientY: number) => {\n const local = this._toLocalContextMenuPoint(clientX, clientY);\n const next = this._clampContextMenuPosition(local.x, local.y, 220, 200);\n this._contextMenuSide = this._resolveContextMenuSide(local.x, local.y, next.x, next.y);\n this._contextMenuX = next.x;\n this._contextMenuY = next.y;\n this._contextMenuMounted = true;\n this._contextMenuState = \"open\";\n if (this._contextMenuCloseTimer) {\n clearTimeout(this._contextMenuCloseTimer);\n this._contextMenuCloseTimer = undefined;\n }\n this._resetContextMenuTypeahead();\n this._contextMenuOpen = true;\n };\n\n private _handleContextMenu = (e: MouseEvent) => {\n const target = e.target as HTMLElement | null;\n if (target?.closest('[data-context-menu=\"true\"]')) {\n e.preventDefault();\n return;\n }\n\n e.preventDefault();\n this._openContextMenu(e.clientX, e.clientY);\n };\n\n private _handleContextMenuShortcut = (e: KeyboardEvent) => {\n const isContextMenuKey = e.key === \"ContextMenu\";\n const isShiftF10 = e.key === \"F10\" && e.shiftKey;\n if (!isContextMenuKey && !isShiftF10) return;\n\n e.preventDefault();\n const rect = this.getBoundingClientRect();\n const x = rect.left + rect.width / 2;\n const y = rect.top + rect.height / 2;\n this._openContextMenu(x, y);\n };\n\n private _handleDocumentPointerDown = (e: PointerEvent) => {\n if (!this._contextMenuOpen) return;\n const menu = this._getContextMenuElement();\n const composedPath = e.composedPath();\n if (menu && composedPath.includes(menu)) return;\n this._closeContextMenu();\n };\n\n private _handleDocumentContextMenu = (e: MouseEvent) => {\n if (!this._contextMenuOpen) return;\n if (!this.contains(e.target as Node)) {\n this._closeContextMenu();\n }\n };\n\n private _handleDocumentKeyDown = (e: KeyboardEvent) => {\n if (e.key === \"Escape\" && this._contextMenuOpen) {\n e.preventDefault();\n this._closeContextMenu(true);\n }\n };\n\n private _handleContextMenuKeyDown = (e: KeyboardEvent) => {\n if (!this._contextMenuOpen) return;\n const activeElement = this.shadowRoot?.activeElement as HTMLButtonElement | null;\n\n if (e.key === \"Escape\") {\n e.preventDefault();\n this._closeContextMenu(true);\n return;\n }\n\n if (e.key === \"Tab\") {\n this._closeContextMenu();\n return;\n }\n\n const items = this._getContextMenuItems();\n if (items.length === 0) return;\n const activeIndex = items.findIndex((item) => item === activeElement);\n\n if (e.key === \"Home\") {\n e.preventDefault();\n this._focusFirstContextMenuItem();\n return;\n }\n\n if (e.key === \"End\") {\n e.preventDefault();\n items[items.length - 1]?.focus();\n return;\n }\n\n if (e.key === \"ArrowDown\" || e.key === \"ArrowUp\") {\n e.preventDefault();\n const direction = e.key === \"ArrowDown\" ? 1 : -1;\n const startIndex =\n activeIndex === -1 ? (direction === 1 ? 0 : items.length - 1) : activeIndex;\n const nextIndex = (startIndex + direction + items.length) % items.length;\n items[nextIndex]?.focus();\n return;\n }\n\n if (e.key === \"Enter\" || e.key === \" \") {\n if (activeElement) {\n e.preventDefault();\n activeElement.click();\n }\n return;\n }\n\n if (e.key.length === 1 && !e.metaKey && !e.ctrlKey && !e.altKey) {\n e.preventDefault();\n this._contextMenuTypeahead += e.key.toLowerCase();\n if (this._contextMenuTypeaheadTimer) {\n clearTimeout(this._contextMenuTypeaheadTimer);\n }\n this._contextMenuTypeaheadTimer = setTimeout(() => {\n this._resetContextMenuTypeahead();\n }, 700);\n\n const startIndex = activeIndex === -1 ? 0 : activeIndex + 1;\n const orderedItems = [...items.slice(startIndex), ...items.slice(0, startIndex)];\n const match = orderedItems.find((item) =>\n item.textContent?.trim().toLowerCase().startsWith(this._contextMenuTypeahead)\n );\n match?.focus();\n }\n };\n\n // ---- Toast auto-dismiss ----\n\n private _toastTimer?: ReturnType<typeof setTimeout>;\n\n protected updated(changed: PropertyValues) {\n if (this.pc.s.toast) {\n clearTimeout(this._toastTimer);\n this._toastTimer = setTimeout(() => this.pc.dismissToast(), 3000);\n }\n\n if (\n (changed.has(\"_contextMenuOpen\") || changed.has(\"_contextMenuMounted\")) &&\n this._contextMenuOpen\n ) {\n queueMicrotask(() => {\n this._syncContextMenuPosition();\n this._focusFirstContextMenuItem();\n });\n }\n }\n\n // ---- Derived state ----\n\n private get _showTitleOverlay() {\n const s = this.pc.s;\n return (s.isHovering || s.isPaused) && !s.shouldShowIdleScreen && !s.isBuffering && !s.error;\n }\n\n private get _showBufferingSpinner() {\n const s = this.pc.s;\n return !s.shouldShowIdleScreen && s.isBuffering && !s.error && s.hasPlaybackStarted;\n }\n\n private get _showWaitingForEndpoint() {\n const s = this.pc.s;\n return !s.endpoints?.primary && s.state !== \"booting\";\n }\n\n private get _waitingMessage() {\n const s = this.pc.s;\n if (this.gatewayUrl && s.state === \"gateway_loading\") {\n return \"Resolving viewing endpoint...\";\n }\n return \"Waiting for endpoint...\";\n }\n\n private get _useStockControls() {\n return (\n this.stockControls ||\n this.nativeControls ||\n this.pc.s.currentPlayerInfo?.shortname === \"mist-legacy\"\n );\n }\n\n // ---- Public API methods ----\n\n async play() {\n await this.pc.play();\n }\n pause() {\n this.pc.pause();\n }\n togglePlay() {\n this.pc.togglePlay();\n }\n seek(time: number) {\n this.pc.seek(time);\n }\n seekBy(delta: number) {\n this.pc.seekBy(delta);\n }\n jumpToLive() {\n this.pc.jumpToLive();\n }\n setVolume(volume: number) {\n this.pc.setVolume(volume);\n }\n toggleMute() {\n this.pc.toggleMute();\n }\n toggleLoop() {\n this.pc.toggleLoop();\n }\n async toggleFullscreen() {\n await this.pc.toggleFullscreen();\n }\n async togglePiP() {\n await this.pc.togglePiP();\n }\n toggleSubtitles() {\n this.pc.toggleSubtitles();\n }\n async retry() {\n await this.pc.retry();\n }\n async reload() {\n await this.pc.reload();\n }\n getQualities() {\n return this.pc.getQualities();\n }\n selectQuality(id: string) {\n this.pc.selectQuality(id);\n }\n destroy() {\n this.pc.hostDisconnected();\n }\n\n // ---- Render ----\n\n protected render() {\n const s = this.pc.s;\n\n return html`\n <div\n part=\"root\"\n class=${classMap({\n \"fw-player-surface\": true,\n \"fw-player-root\": true,\n \"w-full\": true,\n \"h-full\": true,\n \"overflow-hidden\": true,\n flex: this.devMode,\n })}\n data-player-container=\"true\"\n tabindex=\"0\"\n @mouseenter=${() => this.pc.handleMouseEnter()}\n @mouseleave=${() => this.pc.handleMouseLeave()}\n @mousemove=${() => this.pc.handleMouseMove()}\n @touchstart=${() => this.pc.handleTouchStart()}\n @keydown=${this._handleContextMenuShortcut}\n @contextmenu=${this._handleContextMenu}\n >\n <!-- Player area -->\n <div\n class=${classMap({\n \"player-area\": true,\n \"player-area--dev\": this.devMode,\n })}\n >\n <!-- Video container -->\n <div id=\"container\" part=\"video-container\" class=\"fw-player-container\"></div>\n\n <!-- Subtitle renderer -->\n ${s.subtitlesEnabled\n ? html`\n <fw-subtitle-renderer\n .currentTime=${s.currentTime}\n .enabled=${s.subtitlesEnabled}\n ></fw-subtitle-renderer>\n `\n : nothing}\n\n <!-- Title overlay -->\n ${this._showTitleOverlay\n ? html`\n <fw-title-overlay\n .title=${s.metadata?.title ?? null}\n .description=${s.metadata?.description ?? null}\n ></fw-title-overlay>\n `\n : nothing}\n\n <!-- Stats panel -->\n ${this._isStatsOpen\n ? html`\n <fw-stats-panel\n part=\"stats-panel\"\n .pc=${this.pc}\n @fw-close=${() => {\n this._isStatsOpen = false;\n }}\n ></fw-stats-panel>\n `\n : nothing}\n\n <!-- Speed indicator -->\n ${s.isHoldingSpeed\n ? html` <fw-speed-indicator .speed=${s.holdSpeed}></fw-speed-indicator> `\n : nothing}\n\n <!-- Skip indicator -->\n <fw-skip-indicator\n .direction=${this._skipDirection}\n @fw-hide=${() => {\n this._skipDirection = null;\n }}\n ></fw-skip-indicator>\n\n <!-- Waiting for endpoint -->\n ${this._showWaitingForEndpoint\n ? html`\n <fw-idle-screen\n status=\"OFFLINE\"\n .message=${this._waitingMessage}\n @fw-retry=${() => {\n this.pc.clearError();\n this.pc.retry();\n }}\n ></fw-idle-screen>\n `\n : nothing}\n\n <!-- Idle screen -->\n ${!this._showWaitingForEndpoint && s.shouldShowIdleScreen\n ? html`\n <fw-idle-screen\n .status=${s.isEffectivelyLive ? s.streamState?.status : undefined}\n .message=${s.isEffectivelyLive ? s.streamState?.message : \"Loading video...\"}\n .percentage=${s.isEffectivelyLive ? s.streamState?.percentage : undefined}\n @fw-retry=${() => {\n this.pc.clearError();\n this.pc.retry();\n }}\n ></fw-idle-screen>\n `\n : nothing}\n\n <!-- Buffering spinner -->\n ${this._showBufferingSpinner\n ? html`\n <div\n role=\"status\"\n aria-live=\"polite\"\n class=\"fw-player-surface absolute inset-0 flex items-center justify-center bg-black/40 backdrop-blur-sm z-20\"\n >\n <div\n class=\"flex items-center gap-3 rounded-lg border border-white/10 bg-black/70 px-4 py-3 text-sm text-white shadow-lg\"\n >\n <div\n class=\"w-4 h-4 border-2 border-white/10 rounded-full animate-spin\"\n style=\"border-top-color: white;\"\n ></div>\n <span>Buffering...</span>\n </div>\n </div>\n `\n : nothing}\n\n <!-- Error overlay -->\n ${!s.shouldShowIdleScreen && s.error\n ? html`\n <div\n role=\"alert\"\n aria-live=\"assertive\"\n class=${classMap({\n \"fw-error-overlay\": true,\n \"fw-error-overlay--passive\": s.isPassiveError,\n \"fw-error-overlay--fullscreen\": !s.isPassiveError,\n })}\n >\n <div\n class=${classMap({\n \"fw-error-popup\": true,\n \"fw-error-popup--passive\": s.isPassiveError,\n \"fw-error-popup--fullscreen\": !s.isPassiveError,\n })}\n >\n <div\n class=${classMap({\n \"fw-error-header\": true,\n \"fw-error-header--warning\": s.isPassiveError,\n \"fw-error-header--error\": !s.isPassiveError,\n })}\n >\n <span\n class=${classMap({\n \"fw-error-title\": true,\n \"fw-error-title--warning\": s.isPassiveError,\n \"fw-error-title--error\": !s.isPassiveError,\n })}\n >${s.isPassiveError ? \"Warning\" : \"Error\"}</span\n >\n <button\n type=\"button\"\n class=\"fw-error-close\"\n @click=${() => this.pc.clearError()}\n aria-label=\"Dismiss\"\n >\n ${closeIcon()}\n </button>\n </div>\n <div class=\"fw-error-body\">\n <p class=\"fw-error-message\">Playback issue</p>\n </div>\n <div class=\"fw-error-actions\">\n <button\n type=\"button\"\n class=\"fw-error-btn\"\n aria-label=\"Retry playback\"\n @click=${() => {\n this.pc.clearError();\n this.pc.retry();\n }}\n >\n Retry\n </button>\n </div>\n </div>\n </div>\n `\n : nothing}\n\n <!-- Toast notification -->\n ${s.toast\n ? html`\n <div\n class=\"absolute bottom-20 left-1/2 -translate-x-1/2 z-30\"\n role=\"status\"\n aria-live=\"polite\"\n >\n <div\n class=\"flex items-center gap-2 rounded-lg border border-white/10 bg-black/80 px-4 py-2 text-sm text-white shadow-lg backdrop-blur-sm\"\n >\n <span>${s.toast.message}</span>\n <button\n type=\"button\"\n @click=${() => this.pc.dismissToast()}\n class=\"ml-0.5 text-white/60 hover\\\\:text-white cursor-pointer\"\n aria-label=\"Dismiss\"\n >\n ${closeIcon()}\n </button>\n </div>\n </div>\n `\n : nothing}\n\n <!-- Player controls -->\n ${!this._useStockControls\n ? html`\n <fw-player-controls\n part=\"controls\"\n .pc=${this.pc}\n .playbackMode=${this.playbackMode}\n .isContentLive=${s.isEffectivelyLive}\n .devMode=${this.devMode}\n .isStatsOpen=${this._isStatsOpen}\n @fw-stats-toggle=${() => {\n this._isStatsOpen = !this._isStatsOpen;\n }}\n @fw-mode-change=${(event: CustomEvent<{ mode: PlaybackMode }>) => {\n this.playbackMode = event.detail.mode;\n }}\n ></fw-player-controls>\n `\n : nothing}\n </div>\n\n <!-- Dev mode side panel -->\n ${this.devMode && this._isDevPanelOpen\n ? html`\n <fw-dev-mode-panel\n .pc=${this.pc}\n .playbackMode=${this.playbackMode}\n @fw-close=${() => {\n this._isDevPanelOpen = false;\n }}\n @fw-playback-mode-change=${(event: CustomEvent<{ mode: PlaybackMode }>) => {\n this.playbackMode = event.detail.mode;\n }}\n ></fw-dev-mode-panel>\n `\n : nothing}\n </div>\n\n <!-- Context menu -->\n <!-- Keep menu in-shadow (no document portal) to preserve host-scoped styling and avoid a global overlay manager. -->\n ${this._contextMenuMounted\n ? html`\n <div\n data-context-menu=\"true\"\n data-state=${this._contextMenuState}\n data-side=${this._contextMenuSide}\n class=\"fw-player-surface fw-context-menu\"\n role=\"menu\"\n aria-label=\"Player options\"\n tabindex=\"-1\"\n style=\"position: absolute; left: ${this._contextMenuX}px; top: ${this\n ._contextMenuY}px;\"\n @contextmenu=${(e: MouseEvent) => e.preventDefault()}\n @keydown=${this._handleContextMenuKeyDown}\n >\n <button\n type=\"button\"\n role=\"menuitem\"\n tabindex=\"-1\"\n data-context-menu-item=\"true\"\n data-context-menu-level=\"root\"\n class=\"fw-context-menu-item gap-2\"\n @click=${() => {\n this._isStatsOpen = !this._isStatsOpen;\n this._closeContextMenu();\n }}\n >\n <span class=\"opacity-70 shrink-0\">${statsIcon(14)}</span>\n <span>${this._isStatsOpen ? \"Hide Stats\" : \"Stats\"}</span>\n </button>\n ${this.devMode\n ? html`\n <div class=\"fw-context-menu-separator\"></div>\n <button\n type=\"button\"\n role=\"menuitem\"\n tabindex=\"-1\"\n data-context-menu-item=\"true\"\n data-context-menu-level=\"root\"\n class=\"fw-context-menu-item gap-2\"\n @click=${() => {\n this._isDevPanelOpen = !this._isDevPanelOpen;\n this._closeContextMenu();\n }}\n >\n <span class=\"opacity-70 shrink-0\">${settingsIcon(14)}</span>\n <span>${this._isDevPanelOpen ? \"Hide Settings\" : \"Settings\"}</span>\n </button>\n `\n : nothing}\n <div class=\"fw-context-menu-separator\"></div>\n <button\n type=\"button\"\n role=\"menuitemcheckbox\"\n aria-checked=${String(s.isPiPActive)}\n tabindex=\"-1\"\n data-context-menu-item=\"true\"\n data-context-menu-level=\"root\"\n class=\"fw-context-menu-item gap-2\"\n @click=${() => {\n this.pc.togglePiP();\n this._closeContextMenu();\n }}\n >\n <span class=\"opacity-70 shrink-0\">${pictureInPictureIcon(14)}</span>\n <span>Picture-in-Picture</span>\n </button>\n <button\n type=\"button\"\n role=\"menuitemcheckbox\"\n aria-checked=${String(s.isLoopEnabled)}\n tabindex=\"-1\"\n data-context-menu-item=\"true\"\n data-context-menu-level=\"root\"\n class=\"fw-context-menu-item gap-2\"\n @click=${() => {\n this.pc.toggleLoop();\n this._closeContextMenu();\n }}\n >\n <span class=\"opacity-70 shrink-0\">${loopIcon(14)}</span>\n <span>${s.isLoopEnabled ? \"Disable Loop\" : \"Enable Loop\"}</span>\n </button>\n </div>\n `\n : nothing}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"fw-player\": FwPlayer;\n }\n}\n"],"names":["FwPlayer","LitElement","PlayerControllerHost","html","classMap","nothing","closeIcon","statsIcon","settingsIcon","pictureInPictureIcon","loopIcon","sharedStyles","utilityStyles","css","__decorate","property","state","query","customElement"],"mappings":"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"}
@@ -1,383 +0,0 @@
1
- 'use strict';
2
-
3
- var tslib_es6 = require('../node_modules/.pnpm/@rollup_plugin-typescript@12.3.0_rollup@4.57.1_tslib@2.8.1_typescript@5.9.3/node_modules/tslib/tslib.es6.js');
4
- var lit = require('lit');
5
- var decorators_js = require('lit/decorators.js');
6
- var classMap_js = require('lit/directives/class-map.js');
7
- var styleMap_js = require('lit/directives/style-map.js');
8
- var sharedStyles = require('../styles/shared-styles.js');
9
-
10
- exports.FwSeekBar = class FwSeekBar extends lit.LitElement {
11
- constructor() {
12
- super(...arguments);
13
- this.currentTime = 0;
14
- this.duration = 0;
15
- this.buffered = null;
16
- this.disabled = false;
17
- this.isLive = false;
18
- this.seekableStart = 0;
19
- this.commitOnRelease = false;
20
- this._hovering = false;
21
- this._dragging = false;
22
- this._dragTime = null;
23
- this._hoverPosition = 0;
24
- this._hoverTime = 0;
25
- this._trackRect = null;
26
- this._activePointerId = null;
27
- this._onKeyDown = (event) => {
28
- if (this.disabled) {
29
- return;
30
- }
31
- const step = event.shiftKey ? 10 : 5;
32
- const rawRangeEnd = this.isLive ? this._effectiveLiveEdge : this.duration;
33
- const rangeEnd = Number.isFinite(rawRangeEnd) ? rawRangeEnd : this.currentTime + step;
34
- const rangeStart = this.isLive ? this.seekableStart : 0;
35
- let newTime = null;
36
- switch (event.key) {
37
- case "ArrowLeft":
38
- case "ArrowDown":
39
- newTime = Math.max(rangeStart, this.currentTime - step);
40
- break;
41
- case "ArrowRight":
42
- case "ArrowUp":
43
- newTime = Math.min(rangeEnd, this.currentTime + step);
44
- break;
45
- case "Home":
46
- newTime = rangeStart;
47
- break;
48
- case "End":
49
- newTime = rangeEnd;
50
- break;
51
- default:
52
- return;
53
- }
54
- if (newTime != null) {
55
- event.preventDefault();
56
- this._emitSeek(newTime);
57
- }
58
- };
59
- this._onPointerEnter = () => {
60
- if (this.disabled) {
61
- return;
62
- }
63
- this._hovering = true;
64
- };
65
- this._onPointerLeave = () => {
66
- this._hovering = false;
67
- this._trackRect = null;
68
- };
69
- this._onPointerMove = (event) => {
70
- if (this.disabled || (!this._hovering && !this._dragging)) {
71
- return;
72
- }
73
- this._updateHover(event.clientX);
74
- };
75
- this._onPointerDown = (event) => {
76
- if (this.disabled) {
77
- return;
78
- }
79
- if (!this.isLive && !Number.isFinite(this.duration)) {
80
- return;
81
- }
82
- event.preventDefault();
83
- this._activePointerId = event.pointerId;
84
- this._dragging = true;
85
- this._hovering = true;
86
- const initialTime = this._getTimeFromClientX(event.clientX);
87
- this._updateHover(event.clientX);
88
- if (this.commitOnRelease) {
89
- this._dragTime = initialTime;
90
- }
91
- else {
92
- this._emitSeek(initialTime);
93
- }
94
- this._attachDragListeners();
95
- };
96
- this._onGlobalPointerMove = (event) => {
97
- if (!this._dragging || this._activePointerId !== event.pointerId) {
98
- return;
99
- }
100
- const time = this._getTimeFromClientX(event.clientX);
101
- this._updateHover(event.clientX);
102
- if (this.commitOnRelease) {
103
- this._dragTime = time;
104
- }
105
- else {
106
- this._emitSeek(time);
107
- }
108
- };
109
- this._onGlobalPointerUp = (event) => {
110
- if (!this._dragging || this._activePointerId !== event.pointerId) {
111
- return;
112
- }
113
- if (this.commitOnRelease && this._dragTime != null) {
114
- this._emitSeek(this._dragTime);
115
- }
116
- this._dragging = false;
117
- this._dragTime = null;
118
- this._activePointerId = null;
119
- this._detachDragListeners();
120
- };
121
- }
122
- disconnectedCallback() {
123
- super.disconnectedCallback();
124
- this._detachDragListeners();
125
- }
126
- get _effectiveLiveEdge() {
127
- if (typeof this.liveEdge === "number" && Number.isFinite(this.liveEdge)) {
128
- return this.liveEdge;
129
- }
130
- return this.duration;
131
- }
132
- get _seekableWindow() {
133
- return this._effectiveLiveEdge - this.seekableStart;
134
- }
135
- get _displayTime() {
136
- return this._dragTime ?? this.currentTime;
137
- }
138
- get _progressPercent() {
139
- const displayTime = this._displayTime;
140
- if (this.isLive && this._seekableWindow > 0) {
141
- const positionInWindow = displayTime - this.seekableStart;
142
- return Math.min(100, Math.max(0, (positionInWindow / this._seekableWindow) * 100));
143
- }
144
- if (!Number.isFinite(this.duration) || this.duration <= 0) {
145
- return 0;
146
- }
147
- return Math.min(100, Math.max(0, (displayTime / this.duration) * 100));
148
- }
149
- get _bufferedSegments() {
150
- const buffered = this.buffered;
151
- if (!buffered || buffered.length === 0) {
152
- return [];
153
- }
154
- const rangeEnd = this.isLive ? this._effectiveLiveEdge : this.duration;
155
- const rangeStart = this.isLive ? this.seekableStart : 0;
156
- const rangeSize = rangeEnd - rangeStart;
157
- if (!Number.isFinite(rangeSize) || rangeSize <= 0) {
158
- return [];
159
- }
160
- const segments = [];
161
- for (let i = 0; i < buffered.length; i += 1) {
162
- const start = buffered.start(i);
163
- const end = buffered.end(i);
164
- const relativeStart = start - rangeStart;
165
- const relativeEnd = end - rangeStart;
166
- segments.push({
167
- startPercent: Math.min(100, Math.max(0, (relativeStart / rangeSize) * 100)),
168
- endPercent: Math.min(100, Math.max(0, (relativeEnd / rangeSize) * 100)),
169
- });
170
- }
171
- return segments;
172
- }
173
- _formatTime(seconds) {
174
- if (!Number.isFinite(seconds) || seconds < 0) {
175
- return "0:00";
176
- }
177
- const total = Math.floor(seconds);
178
- const hours = Math.floor(total / 3600);
179
- const minutes = Math.floor((total % 3600) / 60);
180
- const secs = total % 60;
181
- if (hours > 0) {
182
- return `${hours}:${String(minutes).padStart(2, "0")}:${String(secs).padStart(2, "0")}`;
183
- }
184
- return `${minutes}:${String(secs).padStart(2, "0")}`;
185
- }
186
- _formatLiveTime(seconds, edge) {
187
- const behindSeconds = edge - seconds;
188
- if (behindSeconds < 1) {
189
- return "LIVE";
190
- }
191
- const total = Math.floor(behindSeconds);
192
- const hours = Math.floor(total / 3600);
193
- const minutes = Math.floor((total % 3600) / 60);
194
- const secs = total % 60;
195
- if (hours > 0) {
196
- return `-${hours}:${String(minutes).padStart(2, "0")}:${String(secs).padStart(2, "0")}`;
197
- }
198
- return `-${minutes}:${String(secs).padStart(2, "0")}`;
199
- }
200
- _getTrackRect() {
201
- const track = this.renderRoot.querySelector(".seek-root");
202
- if (!track) {
203
- return null;
204
- }
205
- this._trackRect = track.getBoundingClientRect();
206
- return this._trackRect;
207
- }
208
- _getTimeFromClientX(clientX) {
209
- const rect = this._getTrackRect();
210
- if (!rect || rect.width <= 0) {
211
- return 0;
212
- }
213
- const x = clientX - rect.left;
214
- const percent = Math.min(1, Math.max(0, x / rect.width));
215
- if (this.isLive && Number.isFinite(this._seekableWindow) && this._seekableWindow > 0) {
216
- return this.seekableStart + percent * this._seekableWindow;
217
- }
218
- if (Number.isFinite(this.duration) && this.duration > 0) {
219
- return percent * this.duration;
220
- }
221
- if (Number.isFinite(this._effectiveLiveEdge) && this._effectiveLiveEdge > 0) {
222
- const start = Number.isFinite(this.seekableStart) ? this.seekableStart : 0;
223
- const window = this._effectiveLiveEdge - start;
224
- if (window > 0) {
225
- return start + percent * window;
226
- }
227
- }
228
- return percent * (this.currentTime || 1);
229
- }
230
- _updateHover(clientX) {
231
- const rect = this._getTrackRect();
232
- if (!rect || rect.width <= 0) {
233
- return;
234
- }
235
- const x = clientX - rect.left;
236
- const percent = Math.min(1, Math.max(0, x / rect.width));
237
- this._hoverPosition = percent * 100;
238
- this._hoverTime = this._getTimeFromClientX(clientX);
239
- }
240
- _emitSeek(time) {
241
- this.dispatchEvent(new CustomEvent("fw-seek", { detail: { time }, bubbles: true, composed: true }));
242
- }
243
- _attachDragListeners() {
244
- window.addEventListener("pointermove", this._onGlobalPointerMove);
245
- window.addEventListener("pointerup", this._onGlobalPointerUp);
246
- window.addEventListener("pointercancel", this._onGlobalPointerUp);
247
- }
248
- _detachDragListeners() {
249
- window.removeEventListener("pointermove", this._onGlobalPointerMove);
250
- window.removeEventListener("pointerup", this._onGlobalPointerUp);
251
- window.removeEventListener("pointercancel", this._onGlobalPointerUp);
252
- }
253
- render() {
254
- const progressPercent = this._progressPercent;
255
- const showThumb = this._hovering || this._dragging;
256
- const canShowTooltip = this.isLive ? this._seekableWindow > 0 : Number.isFinite(this.duration);
257
- return lit.html `
258
- <div
259
- class=${classMap_js.classMap({
260
- "seek-root": true,
261
- "seek-root--disabled": this.disabled,
262
- "fw-seek-root": true,
263
- })}
264
- @pointerenter=${this._onPointerEnter}
265
- @pointerleave=${this._onPointerLeave}
266
- @pointermove=${this._onPointerMove}
267
- @pointerdown=${this._onPointerDown}
268
- role="slider"
269
- aria-label="Seek"
270
- aria-valuemin=${this.isLive ? this.seekableStart : 0}
271
- aria-valuemax=${this.isLive
272
- ? this._effectiveLiveEdge
273
- : Number.isFinite(this.duration)
274
- ? this.duration
275
- : 100}
276
- aria-valuenow=${this._displayTime}
277
- aria-valuetext=${this.isLive
278
- ? this._formatLiveTime(this._displayTime, this._effectiveLiveEdge)
279
- : this._formatTime(this._displayTime)}
280
- tabindex=${this.disabled ? -1 : 0}
281
- @keydown=${this._onKeyDown}
282
- >
283
- <div class=${classMap_js.classMap({ "fw-seek-track": true, "fw-seek-track--active": this._dragging })}>
284
- ${this._bufferedSegments.map((segment) => lit.html `
285
- <div
286
- class="fw-seek-buffered"
287
- style=${styleMap_js.styleMap({
288
- left: `${segment.startPercent}%`,
289
- width: `${segment.endPercent - segment.startPercent}%`,
290
- })}
291
- ></div>
292
- `)}
293
- <div class="fw-seek-progress" style=${styleMap_js.styleMap({ width: `${progressPercent}%` })}></div>
294
- </div>
295
-
296
- <div
297
- class=${classMap_js.classMap({
298
- "fw-seek-thumb": true,
299
- "fw-seek-thumb--active": showThumb,
300
- "fw-seek-thumb--hidden": !showThumb,
301
- })}
302
- style=${styleMap_js.styleMap({ left: `${progressPercent}%` })}
303
- ></div>
304
-
305
- ${this._hovering && !this._dragging && canShowTooltip
306
- ? lit.html `
307
- <div class="fw-seek-tooltip" style=${styleMap_js.styleMap({ left: `${this._hoverPosition}%` })}>
308
- ${this.isLive
309
- ? this._formatLiveTime(this._hoverTime, this._effectiveLiveEdge)
310
- : this._formatTime(this._hoverTime)}
311
- </div>
312
- `
313
- : lit.nothing}
314
- </div>
315
- `;
316
- }
317
- };
318
- exports.FwSeekBar.styles = [
319
- sharedStyles.sharedStyles,
320
- lit.css `
321
- :host {
322
- display: block;
323
- width: 100%;
324
- }
325
-
326
- .seek-root {
327
- position: relative;
328
- width: 100%;
329
- height: 1.5rem;
330
- display: flex;
331
- align-items: center;
332
- cursor: pointer;
333
- }
334
-
335
- .seek-root--disabled {
336
- opacity: 0.5;
337
- cursor: not-allowed;
338
- }
339
- `,
340
- ];
341
- tslib_es6.__decorate([
342
- decorators_js.property({ type: Number })
343
- ], exports.FwSeekBar.prototype, "currentTime", void 0);
344
- tslib_es6.__decorate([
345
- decorators_js.property({ type: Number })
346
- ], exports.FwSeekBar.prototype, "duration", void 0);
347
- tslib_es6.__decorate([
348
- decorators_js.property({ attribute: false })
349
- ], exports.FwSeekBar.prototype, "buffered", void 0);
350
- tslib_es6.__decorate([
351
- decorators_js.property({ type: Boolean })
352
- ], exports.FwSeekBar.prototype, "disabled", void 0);
353
- tslib_es6.__decorate([
354
- decorators_js.property({ type: Boolean, attribute: "is-live" })
355
- ], exports.FwSeekBar.prototype, "isLive", void 0);
356
- tslib_es6.__decorate([
357
- decorators_js.property({ type: Number, attribute: "seekable-start" })
358
- ], exports.FwSeekBar.prototype, "seekableStart", void 0);
359
- tslib_es6.__decorate([
360
- decorators_js.property({ type: Number, attribute: "live-edge" })
361
- ], exports.FwSeekBar.prototype, "liveEdge", void 0);
362
- tslib_es6.__decorate([
363
- decorators_js.property({ type: Boolean, attribute: "commit-on-release" })
364
- ], exports.FwSeekBar.prototype, "commitOnRelease", void 0);
365
- tslib_es6.__decorate([
366
- decorators_js.state()
367
- ], exports.FwSeekBar.prototype, "_hovering", void 0);
368
- tslib_es6.__decorate([
369
- decorators_js.state()
370
- ], exports.FwSeekBar.prototype, "_dragging", void 0);
371
- tslib_es6.__decorate([
372
- decorators_js.state()
373
- ], exports.FwSeekBar.prototype, "_dragTime", void 0);
374
- tslib_es6.__decorate([
375
- decorators_js.state()
376
- ], exports.FwSeekBar.prototype, "_hoverPosition", void 0);
377
- tslib_es6.__decorate([
378
- decorators_js.state()
379
- ], exports.FwSeekBar.prototype, "_hoverTime", void 0);
380
- exports.FwSeekBar = tslib_es6.__decorate([
381
- decorators_js.customElement("fw-seek-bar")
382
- ], exports.FwSeekBar);
383
- //# sourceMappingURL=fw-seek-bar.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fw-seek-bar.js","sources":["../../../../src/components/fw-seek-bar.ts"],"sourcesContent":["/**\n * <fw-seek-bar> — Video seek bar with buffer visualization, drag, and live tooltips.\n * Behavioral parity with react/svelte SeekBar implementations.\n */\nimport { LitElement, html, css, nothing } from \"lit\";\nimport { customElement, property, state } from \"lit/decorators.js\";\nimport { classMap } from \"lit/directives/class-map.js\";\nimport { styleMap } from \"lit/directives/style-map.js\";\nimport { sharedStyles } from \"../styles/shared-styles.js\";\n\ninterface BufferedSegment {\n startPercent: number;\n endPercent: number;\n}\n\n@customElement(\"fw-seek-bar\")\nexport class FwSeekBar extends LitElement {\n @property({ type: Number }) currentTime = 0;\n @property({ type: Number }) duration = 0;\n @property({ attribute: false }) buffered: TimeRanges | null = null;\n @property({ type: Boolean }) disabled = false;\n @property({ type: Boolean, attribute: \"is-live\" }) isLive = false;\n @property({ type: Number, attribute: \"seekable-start\" }) seekableStart = 0;\n @property({ type: Number, attribute: \"live-edge\" }) liveEdge?: number;\n @property({ type: Boolean, attribute: \"commit-on-release\" }) commitOnRelease = false;\n\n @state() private _hovering = false;\n @state() private _dragging = false;\n @state() private _dragTime: number | null = null;\n @state() private _hoverPosition = 0;\n @state() private _hoverTime = 0;\n\n private _trackRect: DOMRect | null = null;\n private _activePointerId: number | null = null;\n\n static styles = [\n sharedStyles,\n css`\n :host {\n display: block;\n width: 100%;\n }\n\n .seek-root {\n position: relative;\n width: 100%;\n height: 1.5rem;\n display: flex;\n align-items: center;\n cursor: pointer;\n }\n\n .seek-root--disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n `,\n ];\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n this._detachDragListeners();\n }\n\n private get _effectiveLiveEdge(): number {\n if (typeof this.liveEdge === \"number\" && Number.isFinite(this.liveEdge)) {\n return this.liveEdge;\n }\n return this.duration;\n }\n\n private get _seekableWindow(): number {\n return this._effectiveLiveEdge - this.seekableStart;\n }\n\n private get _displayTime(): number {\n return this._dragTime ?? this.currentTime;\n }\n\n private get _progressPercent(): number {\n const displayTime = this._displayTime;\n\n if (this.isLive && this._seekableWindow > 0) {\n const positionInWindow = displayTime - this.seekableStart;\n return Math.min(100, Math.max(0, (positionInWindow / this._seekableWindow) * 100));\n }\n\n if (!Number.isFinite(this.duration) || this.duration <= 0) {\n return 0;\n }\n\n return Math.min(100, Math.max(0, (displayTime / this.duration) * 100));\n }\n\n private get _bufferedSegments(): BufferedSegment[] {\n const buffered = this.buffered;\n if (!buffered || buffered.length === 0) {\n return [];\n }\n\n const rangeEnd = this.isLive ? this._effectiveLiveEdge : this.duration;\n const rangeStart = this.isLive ? this.seekableStart : 0;\n const rangeSize = rangeEnd - rangeStart;\n\n if (!Number.isFinite(rangeSize) || rangeSize <= 0) {\n return [];\n }\n\n const segments: BufferedSegment[] = [];\n for (let i = 0; i < buffered.length; i += 1) {\n const start = buffered.start(i);\n const end = buffered.end(i);\n const relativeStart = start - rangeStart;\n const relativeEnd = end - rangeStart;\n\n segments.push({\n startPercent: Math.min(100, Math.max(0, (relativeStart / rangeSize) * 100)),\n endPercent: Math.min(100, Math.max(0, (relativeEnd / rangeSize) * 100)),\n });\n }\n\n return segments;\n }\n\n private _formatTime(seconds: number): string {\n if (!Number.isFinite(seconds) || seconds < 0) {\n return \"0:00\";\n }\n\n const total = Math.floor(seconds);\n const hours = Math.floor(total / 3600);\n const minutes = Math.floor((total % 3600) / 60);\n const secs = total % 60;\n\n if (hours > 0) {\n return `${hours}:${String(minutes).padStart(2, \"0\")}:${String(secs).padStart(2, \"0\")}`;\n }\n\n return `${minutes}:${String(secs).padStart(2, \"0\")}`;\n }\n\n private _formatLiveTime(seconds: number, edge: number): string {\n const behindSeconds = edge - seconds;\n if (behindSeconds < 1) {\n return \"LIVE\";\n }\n\n const total = Math.floor(behindSeconds);\n const hours = Math.floor(total / 3600);\n const minutes = Math.floor((total % 3600) / 60);\n const secs = total % 60;\n\n if (hours > 0) {\n return `-${hours}:${String(minutes).padStart(2, \"0\")}:${String(secs).padStart(2, \"0\")}`;\n }\n\n return `-${minutes}:${String(secs).padStart(2, \"0\")}`;\n }\n\n private _getTrackRect(): DOMRect | null {\n const track = this.renderRoot.querySelector(\".seek-root\") as HTMLDivElement | null;\n if (!track) {\n return null;\n }\n\n this._trackRect = track.getBoundingClientRect();\n return this._trackRect;\n }\n\n private _getTimeFromClientX(clientX: number): number {\n const rect = this._getTrackRect();\n if (!rect || rect.width <= 0) {\n return 0;\n }\n\n const x = clientX - rect.left;\n const percent = Math.min(1, Math.max(0, x / rect.width));\n\n if (this.isLive && Number.isFinite(this._seekableWindow) && this._seekableWindow > 0) {\n return this.seekableStart + percent * this._seekableWindow;\n }\n\n if (Number.isFinite(this.duration) && this.duration > 0) {\n return percent * this.duration;\n }\n\n if (Number.isFinite(this._effectiveLiveEdge) && this._effectiveLiveEdge > 0) {\n const start = Number.isFinite(this.seekableStart) ? this.seekableStart : 0;\n const window = this._effectiveLiveEdge - start;\n if (window > 0) {\n return start + percent * window;\n }\n }\n\n return percent * (this.currentTime || 1);\n }\n\n private _updateHover(clientX: number): void {\n const rect = this._getTrackRect();\n if (!rect || rect.width <= 0) {\n return;\n }\n\n const x = clientX - rect.left;\n const percent = Math.min(1, Math.max(0, x / rect.width));\n this._hoverPosition = percent * 100;\n this._hoverTime = this._getTimeFromClientX(clientX);\n }\n\n private _emitSeek(time: number): void {\n this.dispatchEvent(\n new CustomEvent(\"fw-seek\", { detail: { time }, bubbles: true, composed: true })\n );\n }\n\n private _onKeyDown = (event: KeyboardEvent) => {\n if (this.disabled) {\n return;\n }\n\n const step = event.shiftKey ? 10 : 5;\n const rawRangeEnd = this.isLive ? this._effectiveLiveEdge : this.duration;\n const rangeEnd = Number.isFinite(rawRangeEnd) ? rawRangeEnd : this.currentTime + step;\n const rangeStart = this.isLive ? this.seekableStart : 0;\n\n let newTime: number | null = null;\n switch (event.key) {\n case \"ArrowLeft\":\n case \"ArrowDown\":\n newTime = Math.max(rangeStart, this.currentTime - step);\n break;\n case \"ArrowRight\":\n case \"ArrowUp\":\n newTime = Math.min(rangeEnd, this.currentTime + step);\n break;\n case \"Home\":\n newTime = rangeStart;\n break;\n case \"End\":\n newTime = rangeEnd;\n break;\n default:\n return;\n }\n\n if (newTime != null) {\n event.preventDefault();\n this._emitSeek(newTime);\n }\n };\n\n private _onPointerEnter = () => {\n if (this.disabled) {\n return;\n }\n this._hovering = true;\n };\n\n private _onPointerLeave = () => {\n this._hovering = false;\n this._trackRect = null;\n };\n\n private _onPointerMove = (event: PointerEvent) => {\n if (this.disabled || (!this._hovering && !this._dragging)) {\n return;\n }\n this._updateHover(event.clientX);\n };\n\n private _onPointerDown = (event: PointerEvent) => {\n if (this.disabled) {\n return;\n }\n\n if (!this.isLive && !Number.isFinite(this.duration)) {\n return;\n }\n\n event.preventDefault();\n this._activePointerId = event.pointerId;\n this._dragging = true;\n this._hovering = true;\n\n const initialTime = this._getTimeFromClientX(event.clientX);\n this._updateHover(event.clientX);\n\n if (this.commitOnRelease) {\n this._dragTime = initialTime;\n } else {\n this._emitSeek(initialTime);\n }\n\n this._attachDragListeners();\n };\n\n private _onGlobalPointerMove = (event: PointerEvent) => {\n if (!this._dragging || this._activePointerId !== event.pointerId) {\n return;\n }\n\n const time = this._getTimeFromClientX(event.clientX);\n this._updateHover(event.clientX);\n\n if (this.commitOnRelease) {\n this._dragTime = time;\n } else {\n this._emitSeek(time);\n }\n };\n\n private _onGlobalPointerUp = (event: PointerEvent) => {\n if (!this._dragging || this._activePointerId !== event.pointerId) {\n return;\n }\n\n if (this.commitOnRelease && this._dragTime != null) {\n this._emitSeek(this._dragTime);\n }\n\n this._dragging = false;\n this._dragTime = null;\n this._activePointerId = null;\n this._detachDragListeners();\n };\n\n private _attachDragListeners(): void {\n window.addEventListener(\"pointermove\", this._onGlobalPointerMove);\n window.addEventListener(\"pointerup\", this._onGlobalPointerUp);\n window.addEventListener(\"pointercancel\", this._onGlobalPointerUp);\n }\n\n private _detachDragListeners(): void {\n window.removeEventListener(\"pointermove\", this._onGlobalPointerMove);\n window.removeEventListener(\"pointerup\", this._onGlobalPointerUp);\n window.removeEventListener(\"pointercancel\", this._onGlobalPointerUp);\n }\n\n protected render() {\n const progressPercent = this._progressPercent;\n const showThumb = this._hovering || this._dragging;\n const canShowTooltip = this.isLive ? this._seekableWindow > 0 : Number.isFinite(this.duration);\n\n return html`\n <div\n class=${classMap({\n \"seek-root\": true,\n \"seek-root--disabled\": this.disabled,\n \"fw-seek-root\": true,\n })}\n @pointerenter=${this._onPointerEnter}\n @pointerleave=${this._onPointerLeave}\n @pointermove=${this._onPointerMove}\n @pointerdown=${this._onPointerDown}\n role=\"slider\"\n aria-label=\"Seek\"\n aria-valuemin=${this.isLive ? this.seekableStart : 0}\n aria-valuemax=${this.isLive\n ? this._effectiveLiveEdge\n : Number.isFinite(this.duration)\n ? this.duration\n : 100}\n aria-valuenow=${this._displayTime}\n aria-valuetext=${this.isLive\n ? this._formatLiveTime(this._displayTime, this._effectiveLiveEdge)\n : this._formatTime(this._displayTime)}\n tabindex=${this.disabled ? -1 : 0}\n @keydown=${this._onKeyDown}\n >\n <div class=${classMap({ \"fw-seek-track\": true, \"fw-seek-track--active\": this._dragging })}>\n ${this._bufferedSegments.map(\n (segment) => html`\n <div\n class=\"fw-seek-buffered\"\n style=${styleMap({\n left: `${segment.startPercent}%`,\n width: `${segment.endPercent - segment.startPercent}%`,\n })}\n ></div>\n `\n )}\n <div class=\"fw-seek-progress\" style=${styleMap({ width: `${progressPercent}%` })}></div>\n </div>\n\n <div\n class=${classMap({\n \"fw-seek-thumb\": true,\n \"fw-seek-thumb--active\": showThumb,\n \"fw-seek-thumb--hidden\": !showThumb,\n })}\n style=${styleMap({ left: `${progressPercent}%` })}\n ></div>\n\n ${this._hovering && !this._dragging && canShowTooltip\n ? html`\n <div class=\"fw-seek-tooltip\" style=${styleMap({ left: `${this._hoverPosition}%` })}>\n ${this.isLive\n ? this._formatLiveTime(this._hoverTime, this._effectiveLiveEdge)\n : this._formatTime(this._hoverTime)}\n </div>\n `\n : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"fw-seek-bar\": FwSeekBar;\n }\n}\n"],"names":["FwSeekBar","LitElement","html","classMap","styleMap","nothing","sharedStyles","css","__decorate","property","state","customElement"],"mappings":"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"}