@livepeer-frameworks/player-wc 0.1.0

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 (141) hide show
  1. package/dist/cjs/components/fw-context-menu.js +17 -0
  2. package/dist/cjs/components/fw-context-menu.js.map +1 -0
  3. package/dist/cjs/components/fw-dev-mode-panel.js +273 -0
  4. package/dist/cjs/components/fw-dev-mode-panel.js.map +1 -0
  5. package/dist/cjs/components/fw-error-overlay.js +101 -0
  6. package/dist/cjs/components/fw-error-overlay.js.map +1 -0
  7. package/dist/cjs/components/fw-idle-screen.js +182 -0
  8. package/dist/cjs/components/fw-idle-screen.js.map +1 -0
  9. package/dist/cjs/components/fw-loading-spinner.js +62 -0
  10. package/dist/cjs/components/fw-loading-spinner.js.map +1 -0
  11. package/dist/cjs/components/fw-player-controls.js +258 -0
  12. package/dist/cjs/components/fw-player-controls.js.map +1 -0
  13. package/dist/cjs/components/fw-player.js +570 -0
  14. package/dist/cjs/components/fw-player.js.map +1 -0
  15. package/dist/cjs/components/fw-seek-bar.js +233 -0
  16. package/dist/cjs/components/fw-seek-bar.js.map +1 -0
  17. package/dist/cjs/components/fw-settings-menu.js +126 -0
  18. package/dist/cjs/components/fw-settings-menu.js.map +1 -0
  19. package/dist/cjs/components/fw-skip-indicator.js +143 -0
  20. package/dist/cjs/components/fw-skip-indicator.js.map +1 -0
  21. package/dist/cjs/components/fw-speed-indicator.js +61 -0
  22. package/dist/cjs/components/fw-speed-indicator.js.map +1 -0
  23. package/dist/cjs/components/fw-stats-panel.js +141 -0
  24. package/dist/cjs/components/fw-stats-panel.js.map +1 -0
  25. package/dist/cjs/components/fw-subtitle-renderer.js +70 -0
  26. package/dist/cjs/components/fw-subtitle-renderer.js.map +1 -0
  27. package/dist/cjs/components/fw-title-overlay.js +72 -0
  28. package/dist/cjs/components/fw-title-overlay.js.map +1 -0
  29. package/dist/cjs/components/fw-toast.js +74 -0
  30. package/dist/cjs/components/fw-toast.js.map +1 -0
  31. package/dist/cjs/components/fw-volume-control.js +140 -0
  32. package/dist/cjs/components/fw-volume-control.js.map +1 -0
  33. package/dist/cjs/controllers/player-controller-host.js +315 -0
  34. package/dist/cjs/controllers/player-controller-host.js.map +1 -0
  35. package/dist/cjs/define.js +45 -0
  36. package/dist/cjs/define.js.map +1 -0
  37. package/dist/cjs/icons/index.js +153 -0
  38. package/dist/cjs/icons/index.js.map +1 -0
  39. package/dist/cjs/index.js +88 -0
  40. package/dist/cjs/index.js.map +1 -0
  41. 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 +33 -0
  42. 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 +1 -0
  43. package/dist/cjs/styles/shared-styles.js +1967 -0
  44. package/dist/cjs/styles/shared-styles.js.map +1 -0
  45. package/dist/cjs/styles/utility-styles.js +725 -0
  46. package/dist/cjs/styles/utility-styles.js.map +1 -0
  47. package/dist/esm/components/fw-context-menu.js +17 -0
  48. package/dist/esm/components/fw-context-menu.js.map +1 -0
  49. package/dist/esm/components/fw-dev-mode-panel.js +273 -0
  50. package/dist/esm/components/fw-dev-mode-panel.js.map +1 -0
  51. package/dist/esm/components/fw-error-overlay.js +101 -0
  52. package/dist/esm/components/fw-error-overlay.js.map +1 -0
  53. package/dist/esm/components/fw-idle-screen.js +182 -0
  54. package/dist/esm/components/fw-idle-screen.js.map +1 -0
  55. package/dist/esm/components/fw-loading-spinner.js +62 -0
  56. package/dist/esm/components/fw-loading-spinner.js.map +1 -0
  57. package/dist/esm/components/fw-player-controls.js +258 -0
  58. package/dist/esm/components/fw-player-controls.js.map +1 -0
  59. package/dist/esm/components/fw-player.js +570 -0
  60. package/dist/esm/components/fw-player.js.map +1 -0
  61. package/dist/esm/components/fw-seek-bar.js +233 -0
  62. package/dist/esm/components/fw-seek-bar.js.map +1 -0
  63. package/dist/esm/components/fw-settings-menu.js +126 -0
  64. package/dist/esm/components/fw-settings-menu.js.map +1 -0
  65. package/dist/esm/components/fw-skip-indicator.js +143 -0
  66. package/dist/esm/components/fw-skip-indicator.js.map +1 -0
  67. package/dist/esm/components/fw-speed-indicator.js +61 -0
  68. package/dist/esm/components/fw-speed-indicator.js.map +1 -0
  69. package/dist/esm/components/fw-stats-panel.js +141 -0
  70. package/dist/esm/components/fw-stats-panel.js.map +1 -0
  71. package/dist/esm/components/fw-subtitle-renderer.js +70 -0
  72. package/dist/esm/components/fw-subtitle-renderer.js.map +1 -0
  73. package/dist/esm/components/fw-title-overlay.js +72 -0
  74. package/dist/esm/components/fw-title-overlay.js.map +1 -0
  75. package/dist/esm/components/fw-toast.js +74 -0
  76. package/dist/esm/components/fw-toast.js.map +1 -0
  77. package/dist/esm/components/fw-volume-control.js +140 -0
  78. package/dist/esm/components/fw-volume-control.js.map +1 -0
  79. package/dist/esm/controllers/player-controller-host.js +313 -0
  80. package/dist/esm/controllers/player-controller-host.js.map +1 -0
  81. package/dist/esm/define.js +43 -0
  82. package/dist/esm/define.js.map +1 -0
  83. package/dist/esm/icons/index.js +141 -0
  84. package/dist/esm/icons/index.js.map +1 -0
  85. package/dist/esm/index.js +18 -0
  86. package/dist/esm/index.js.map +1 -0
  87. package/dist/esm/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 +31 -0
  88. package/dist/esm/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 +1 -0
  89. package/dist/esm/styles/shared-styles.js +1965 -0
  90. package/dist/esm/styles/shared-styles.js.map +1 -0
  91. package/dist/esm/styles/utility-styles.js +723 -0
  92. package/dist/esm/styles/utility-styles.js.map +1 -0
  93. package/dist/fw-player.iife.js +4362 -0
  94. package/dist/fw-player.iife.js.map +1 -0
  95. package/dist/types/components/fw-context-menu.d.ts +15 -0
  96. package/dist/types/components/fw-dev-mode-panel.d.ts +24 -0
  97. package/dist/types/components/fw-error-overlay.d.ts +14 -0
  98. package/dist/types/components/fw-idle-screen.d.ts +13 -0
  99. package/dist/types/components/fw-loading-spinner.d.ts +10 -0
  100. package/dist/types/components/fw-player-controls.d.ts +23 -0
  101. package/dist/types/components/fw-player.d.ts +74 -0
  102. package/dist/types/components/fw-seek-bar.d.ts +33 -0
  103. package/dist/types/components/fw-settings-menu.d.ts +16 -0
  104. package/dist/types/components/fw-skip-indicator.d.ts +18 -0
  105. package/dist/types/components/fw-speed-indicator.d.ts +11 -0
  106. package/dist/types/components/fw-stats-panel.d.ts +18 -0
  107. package/dist/types/components/fw-subtitle-renderer.d.ts +21 -0
  108. package/dist/types/components/fw-title-overlay.d.ts +12 -0
  109. package/dist/types/components/fw-toast.d.ts +12 -0
  110. package/dist/types/components/fw-volume-control.d.ts +18 -0
  111. package/dist/types/controllers/player-controller-host.d.ts +119 -0
  112. package/dist/types/define.d.ts +1 -0
  113. package/dist/types/icons/index.d.ts +23 -0
  114. package/dist/types/iife-entry.d.ts +11 -0
  115. package/dist/types/index.d.ts +25 -0
  116. package/dist/types/styles/shared-styles.d.ts +1 -0
  117. package/dist/types/styles/utility-styles.d.ts +1 -0
  118. package/package.json +65 -0
  119. package/src/components/fw-context-menu.ts +23 -0
  120. package/src/components/fw-dev-mode-panel.ts +285 -0
  121. package/src/components/fw-error-overlay.ts +96 -0
  122. package/src/components/fw-idle-screen.ts +182 -0
  123. package/src/components/fw-loading-spinner.ts +63 -0
  124. package/src/components/fw-player-controls.ts +256 -0
  125. package/src/components/fw-player.ts +557 -0
  126. package/src/components/fw-seek-bar.ts +219 -0
  127. package/src/components/fw-settings-menu.ts +128 -0
  128. package/src/components/fw-skip-indicator.ts +139 -0
  129. package/src/components/fw-speed-indicator.ts +57 -0
  130. package/src/components/fw-stats-panel.ts +154 -0
  131. package/src/components/fw-subtitle-renderer.ts +65 -0
  132. package/src/components/fw-title-overlay.ts +64 -0
  133. package/src/components/fw-toast.ts +70 -0
  134. package/src/components/fw-volume-control.ts +140 -0
  135. package/src/controllers/player-controller-host.ts +457 -0
  136. package/src/define.ts +43 -0
  137. package/src/icons/index.ts +209 -0
  138. package/src/iife-entry.ts +11 -0
  139. package/src/index.ts +31 -0
  140. package/src/styles/shared-styles.ts +1962 -0
  141. package/src/styles/utility-styles.ts +720 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fw-idle-screen.js","sources":["../../../../src/components/fw-idle-screen.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from \"lit\";\nimport { customElement, property } from \"lit/decorators.js\";\nimport { classMap } from \"lit/directives/class-map.js\";\nimport { sharedStyles } from \"../styles/shared-styles.js\";\nimport { utilityStyles } from \"../styles/utility-styles.js\";\n\n@customElement(\"fw-idle-screen\")\nexport class FwIdleScreen extends LitElement {\n @property({ type: String }) status?: string;\n @property({ type: String }) message?: string;\n @property({ type: Number }) percentage?: number;\n\n static styles = [\n sharedStyles,\n utilityStyles,\n css`\n :host {\n display: contents;\n }\n .idle {\n position: absolute;\n inset: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: 15;\n background: linear-gradient(135deg, rgb(15 23 42), rgb(2 6 23), rgb(15 23 42));\n overflow: hidden;\n }\n .card {\n position: relative;\n z-index: 10;\n max-width: 280px;\n width: 100%;\n text-align: center;\n }\n .status-icon {\n margin: 0 auto 0.75rem;\n width: 2.5rem;\n height: 2.5rem;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n .spinner {\n width: 1.5rem;\n height: 1.5rem;\n border: 2px solid rgb(255 255 255 / 0.2);\n border-top-color: hsl(var(--tn-blue, 217 89% 61%));\n border-radius: 50%;\n animation: _fw-spin 1s linear infinite;\n }\n @keyframes _fw-spin {\n to {\n transform: rotate(360deg);\n }\n }\n .offline-dot {\n width: 0.75rem;\n height: 0.75rem;\n border-radius: 50%;\n background: hsl(var(--tn-red, 348 74% 64%));\n animation: _fw-blink 2s ease-in-out infinite;\n }\n @keyframes _fw-blink {\n 0%,\n 100% {\n opacity: 1;\n }\n 50% {\n opacity: 0.3;\n }\n }\n .label {\n font-size: 0.6875rem;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n color: rgb(255 255 255 / 0.5);\n margin-bottom: 0.5rem;\n }\n .msg {\n font-size: 0.8125rem;\n color: rgb(255 255 255 / 0.7);\n margin-bottom: 0.75rem;\n }\n .progress-wrap {\n width: 100%;\n height: 0.25rem;\n background: rgb(255 255 255 / 0.1);\n border-radius: 2px;\n overflow: hidden;\n margin-bottom: 0.5rem;\n }\n .progress-bar {\n height: 100%;\n background: hsl(var(--tn-blue, 217 89% 61%));\n border-radius: 2px;\n transition: width 300ms ease;\n }\n .pct {\n font-size: 0.6875rem;\n color: rgb(255 255 255 / 0.4);\n font-variant-numeric: tabular-nums;\n }\n .particles {\n position: absolute;\n inset: 0;\n overflow: hidden;\n pointer-events: none;\n }\n .particle {\n position: absolute;\n width: 4px;\n height: 4px;\n border-radius: 50%;\n opacity: 0.3;\n animation: _fw-float var(--dur, 8s) ease-in-out infinite;\n }\n @keyframes _fw-float {\n 0%,\n 100% {\n transform: translateY(0) translateX(0);\n }\n 25% {\n transform: translateY(-20px) translateX(10px);\n }\n 50% {\n transform: translateY(-10px) translateX(-5px);\n }\n 75% {\n transform: translateY(-30px) translateX(15px);\n }\n }\n `,\n ];\n\n protected render() {\n const isOffline = this.status === \"OFFLINE\";\n const isInitializing = this.status === \"INITIALIZING\" || this.status === \"STARTING\";\n\n return html`\n <div class=\"idle\">\n <div class=\"particles\">\n ${[0, 1, 2, 3, 4, 5, 6, 7].map(\n (i) => html`\n <div\n class=\"particle\"\n style=\"left: ${10 + i * 11}%; top: ${20 + (i % 3) * 25}%; --dur: ${6 +\n i * 0.8}s; background: hsl(${217 + i * 15} 70% 60%); animation-delay: ${i * -1}s;\"\n ></div>\n `\n )}\n </div>\n <div class=\"card\">\n <div class=\"status-icon\">\n ${isOffline ? html`<div class=\"offline-dot\"></div>` : html`<div class=\"spinner\"></div>`}\n </div>\n ${this.status ? html`<div class=\"label\">${this.status}</div>` : nothing}\n ${this.message ? html`<div class=\"msg\">${this.message}</div>` : nothing}\n ${isInitializing && this.percentage != null\n ? html`\n <div class=\"progress-wrap\">\n <div\n class=\"progress-bar\"\n style=\"width: ${Math.min(100, Math.max(0, this.percentage))}%\"\n ></div>\n </div>\n <div class=\"pct\">${Math.round(this.percentage)}%</div>\n `\n : nothing}\n </div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"fw-idle-screen\": FwIdleScreen;\n }\n}\n"],"names":[],"mappings":";;;;;;AAOO,IAAM,YAAY,GAAlB,MAAM,YAAa,SAAQ,UAAU,CAAA;IAkIhC,MAAM,GAAA;AACd,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,KAAK,SAAS;AAC3C,QAAA,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,KAAK,cAAc,IAAI,IAAI,CAAC,MAAM,KAAK,UAAU;AAEnF,QAAA,OAAO,IAAI,CAAA;;;YAGH,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAC5B,CAAC,CAAC,KAAK,IAAI,CAAA;;;AAGQ,6BAAA,EAAA,EAAE,GAAG,CAAC,GAAG,EAAE,WAAW,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,aAAa,CAAC;AACpE,YAAA,CAAC,GAAG,GAAG,CAAA,mBAAA,EAAsB,GAAG,GAAG,CAAC,GAAG,EAAE,CAAA,4BAAA,EAA+B,CAAC,GAAG,EAAE,CAAA;;aAEjF,CACF;;;;cAIG,SAAS,GAAG,IAAI,CAAA,CAAA,+BAAA,CAAiC,GAAG,IAAI,CAAA,CAAA,2BAAA,CAA6B;;AAEvF,UAAA,EAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAA,CAAA,mBAAA,EAAsB,IAAI,CAAC,MAAM,CAAA,MAAA,CAAQ,GAAG,OAAO;AACrE,UAAA,EAAA,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA,CAAA,iBAAA,EAAoB,IAAI,CAAC,OAAO,CAAA,MAAA,CAAQ,GAAG,OAAO;AACrE,UAAA,EAAA,cAAc,IAAI,IAAI,CAAC,UAAU,IAAI;cACnC,IAAI,CAAA;;;;AAIkB,kCAAA,EAAA,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAA;;;AAG5C,iCAAA,EAAA,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;AAC/C,cAAA;AACH,cAAE,OAAO;;;KAGhB;IACH;;AAlKO,YAAA,CAAA,MAAM,GAAG;IACd,YAAY;IACZ,aAAa;AACb,IAAA,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuHF,IAAA,CAAA;AACF,CA3HY;AAJe,UAAA,CAAA;AAA3B,IAAA,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE;AAAkB,CAAA,EAAA,YAAA,CAAA,SAAA,EAAA,QAAA,EAAA,MAAA,CAAA;AAChB,UAAA,CAAA;AAA3B,IAAA,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE;AAAmB,CAAA,EAAA,YAAA,CAAA,SAAA,EAAA,SAAA,EAAA,MAAA,CAAA;AACjB,UAAA,CAAA;AAA3B,IAAA,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE;AAAsB,CAAA,EAAA,YAAA,CAAA,SAAA,EAAA,YAAA,EAAA,MAAA,CAAA;AAHrC,YAAY,GAAA,UAAA,CAAA;IADxB,aAAa,CAAC,gBAAgB;AAClB,CAAA,EAAA,YAAY,CAwKxB;;;;"}
@@ -0,0 +1,62 @@
1
+ import { __decorate } from '../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';
2
+ import { css, LitElement, html } from 'lit';
3
+ import { customElement } from 'lit/decorators.js';
4
+
5
+ let FwLoadingSpinner = class FwLoadingSpinner extends LitElement {
6
+ render() {
7
+ return html `
8
+ <div class="overlay" role="status" aria-live="polite">
9
+ <div class="pill">
10
+ <div class="spinner"></div>
11
+ <span>Buffering...</span>
12
+ </div>
13
+ </div>
14
+ `;
15
+ }
16
+ };
17
+ FwLoadingSpinner.styles = css `
18
+ :host {
19
+ display: contents;
20
+ }
21
+ .overlay {
22
+ position: absolute;
23
+ inset: 0;
24
+ display: flex;
25
+ align-items: center;
26
+ justify-content: center;
27
+ background: rgb(0 0 0 / 0.4);
28
+ backdrop-filter: blur(4px);
29
+ z-index: 20;
30
+ }
31
+ .pill {
32
+ display: flex;
33
+ align-items: center;
34
+ gap: 0.75rem;
35
+ border-radius: 0.5rem;
36
+ border: 1px solid rgb(255 255 255 / 0.1);
37
+ background: rgb(0 0 0 / 0.7);
38
+ padding: 0.75rem 1rem;
39
+ font-size: 0.875rem;
40
+ color: white;
41
+ box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1);
42
+ }
43
+ .spinner {
44
+ width: 1rem;
45
+ height: 1rem;
46
+ border: 2px solid rgb(255 255 255 / 0.3);
47
+ border-top-color: white;
48
+ border-radius: 50%;
49
+ animation: _fw-spin 1s linear infinite;
50
+ }
51
+ @keyframes _fw-spin {
52
+ to {
53
+ transform: rotate(360deg);
54
+ }
55
+ }
56
+ `;
57
+ FwLoadingSpinner = __decorate([
58
+ customElement("fw-loading-spinner")
59
+ ], FwLoadingSpinner);
60
+
61
+ export { FwLoadingSpinner };
62
+ //# sourceMappingURL=fw-loading-spinner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fw-loading-spinner.js","sources":["../../../../src/components/fw-loading-spinner.ts"],"sourcesContent":["import { LitElement, html, css } from \"lit\";\nimport { customElement } from \"lit/decorators.js\";\n\n@customElement(\"fw-loading-spinner\")\nexport class FwLoadingSpinner extends LitElement {\n static styles = css`\n :host {\n display: contents;\n }\n .overlay {\n position: absolute;\n inset: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background: rgb(0 0 0 / 0.4);\n backdrop-filter: blur(4px);\n z-index: 20;\n }\n .pill {\n display: flex;\n align-items: center;\n gap: 0.75rem;\n border-radius: 0.5rem;\n border: 1px solid rgb(255 255 255 / 0.1);\n background: rgb(0 0 0 / 0.7);\n padding: 0.75rem 1rem;\n font-size: 0.875rem;\n color: white;\n box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1);\n }\n .spinner {\n width: 1rem;\n height: 1rem;\n border: 2px solid rgb(255 255 255 / 0.3);\n border-top-color: white;\n border-radius: 50%;\n animation: _fw-spin 1s linear infinite;\n }\n @keyframes _fw-spin {\n to {\n transform: rotate(360deg);\n }\n }\n `;\n\n protected render() {\n return html`\n <div class=\"overlay\" role=\"status\" aria-live=\"polite\">\n <div class=\"pill\">\n <div class=\"spinner\"></div>\n <span>Buffering...</span>\n </div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"fw-loading-spinner\": FwLoadingSpinner;\n }\n}\n"],"names":[],"mappings":";;;;AAIO,IAAM,gBAAgB,GAAtB,MAAM,gBAAiB,SAAQ,UAAU,CAAA;IA0CpC,MAAM,GAAA;AACd,QAAA,OAAO,IAAI,CAAA;;;;;;;KAOV;IACH;;AAlDO,gBAAA,CAAA,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuClB,EAAA,CAvCY;AADF,gBAAgB,GAAA,UAAA,CAAA;IAD5B,aAAa,CAAC,oBAAoB;AACtB,CAAA,EAAA,gBAAgB,CAoD5B;;;;"}
@@ -0,0 +1,258 @@
1
+ import { __decorate } from '../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';
2
+ import { css, LitElement, nothing, html } from 'lit';
3
+ import { property, state, customElement } from 'lit/decorators.js';
4
+ import { classMap } from 'lit/directives/class-map.js';
5
+ import { sharedStyles } from '../styles/shared-styles.js';
6
+ import { utilityStyles } from '../styles/utility-styles.js';
7
+ import { pauseIcon, playIcon, settingsIcon, fullscreenExitIcon, fullscreenIcon } from '../icons/index.js';
8
+
9
+ let FwPlayerControls = class FwPlayerControls extends LitElement {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.playbackMode = "auto";
13
+ this.isContentLive = false;
14
+ this.isStatsOpen = false;
15
+ this._settingsOpen = false;
16
+ }
17
+ _formatTime(seconds) {
18
+ if (!isFinite(seconds) || isNaN(seconds))
19
+ return "0:00";
20
+ const abs = Math.abs(Math.floor(seconds));
21
+ const h = Math.floor(abs / 3600);
22
+ const m = Math.floor((abs % 3600) / 60);
23
+ const s = abs % 60;
24
+ if (h > 0)
25
+ return `${h}:${String(m).padStart(2, "0")}:${String(s).padStart(2, "0")}`;
26
+ return `${m}:${String(s).padStart(2, "0")}`;
27
+ }
28
+ get _isNearLive() {
29
+ if (!this.isContentLive)
30
+ return false;
31
+ const { currentTime, duration } = this.pc.s;
32
+ if (!isFinite(duration) || duration <= 0)
33
+ return true;
34
+ return duration - currentTime < 10;
35
+ }
36
+ render() {
37
+ const s = this.pc.s;
38
+ const disabled = !s.videoElement;
39
+ return html `
40
+ <div
41
+ class=${classMap({
42
+ "controls-wrapper": true,
43
+ "controls-wrapper--visible": s.shouldShowControls,
44
+ "fw-controls-wrapper": true,
45
+ })}
46
+ >
47
+ <div class="bar fw-control-bar">
48
+ <!-- Seek bar -->
49
+ <fw-seek-bar
50
+ .currentTime=${s.currentTime}
51
+ .duration=${s.duration}
52
+ .disabled=${disabled}
53
+ .isLive=${this.isContentLive}
54
+ @fw-seek=${(e) => this.pc.seek(e.detail.time)}
55
+ ></fw-seek-bar>
56
+
57
+ <!-- Button row -->
58
+ <div class="row">
59
+ <div class="group fw-control-group">
60
+ <!-- Play/Pause -->
61
+ <button
62
+ class="btn fw-btn-flush"
63
+ type="button"
64
+ ?disabled=${disabled}
65
+ @click=${() => this.pc.togglePlay()}
66
+ aria-label="${s.isPlaying ? "Pause" : "Play"}"
67
+ >
68
+ ${s.isPlaying ? pauseIcon(18) : playIcon(18)}
69
+ </button>
70
+
71
+ <!-- Volume -->
72
+ <fw-volume-control .pc=${this.pc}></fw-volume-control>
73
+
74
+ <!-- Time display -->
75
+ ${!this.isContentLive
76
+ ? html `
77
+ <span class="time fw-time-display">
78
+ ${this._formatTime(s.currentTime)} / ${this._formatTime(s.duration)}
79
+ </span>
80
+ `
81
+ : nothing}
82
+
83
+ <!-- Live badge -->
84
+ ${this.isContentLive
85
+ ? html `
86
+ <button
87
+ class=${classMap({
88
+ "live-badge": true,
89
+ "fw-live-badge": true,
90
+ "live-badge--active": this._isNearLive,
91
+ "fw-live-badge--active": this._isNearLive,
92
+ "live-badge--behind": !this._isNearLive,
93
+ "fw-live-badge--behind": !this._isNearLive,
94
+ })}
95
+ type="button"
96
+ @click=${() => this.pc.jumpToLive()}
97
+ aria-label="Jump to live"
98
+ >
99
+ <span class="live-dot"></span>
100
+ LIVE
101
+ </button>
102
+ `
103
+ : nothing}
104
+ </div>
105
+
106
+ <div class="group fw-control-group">
107
+ <!-- Settings -->
108
+ <div class="settings-anchor">
109
+ <button
110
+ class="btn fw-btn-flush"
111
+ type="button"
112
+ @click=${() => {
113
+ this._settingsOpen = !this._settingsOpen;
114
+ }}
115
+ aria-label="Settings"
116
+ >
117
+ ${settingsIcon(16)}
118
+ </button>
119
+ <fw-settings-menu .pc=${this.pc} .open=${this._settingsOpen}></fw-settings-menu>
120
+ </div>
121
+
122
+ <!-- Fullscreen -->
123
+ <button
124
+ class="btn fw-btn-flush"
125
+ type="button"
126
+ ?disabled=${disabled}
127
+ @click=${() => this.pc.toggleFullscreen()}
128
+ aria-label="${s.isFullscreen ? "Exit fullscreen" : "Fullscreen"}"
129
+ >
130
+ ${s.isFullscreen ? fullscreenExitIcon(16) : fullscreenIcon(16)}
131
+ </button>
132
+ </div>
133
+ </div>
134
+ </div>
135
+ </div>
136
+ `;
137
+ }
138
+ };
139
+ FwPlayerControls.styles = [
140
+ sharedStyles,
141
+ utilityStyles,
142
+ css `
143
+ :host {
144
+ display: contents;
145
+ }
146
+ .controls-wrapper {
147
+ position: absolute;
148
+ bottom: 0;
149
+ left: 0;
150
+ right: 0;
151
+ z-index: 20;
152
+ background: linear-gradient(to top, rgb(0 0 0 / 0.7), transparent);
153
+ padding: 2rem 0.75rem 0.5rem;
154
+ opacity: 0;
155
+ transition: opacity 200ms ease;
156
+ pointer-events: none;
157
+ }
158
+ .controls-wrapper--visible {
159
+ opacity: 1;
160
+ pointer-events: auto;
161
+ }
162
+ .bar {
163
+ display: flex;
164
+ flex-direction: column;
165
+ gap: 0.25rem;
166
+ }
167
+ .row {
168
+ display: flex;
169
+ align-items: center;
170
+ justify-content: space-between;
171
+ gap: 0.25rem;
172
+ }
173
+ .group {
174
+ display: flex;
175
+ align-items: center;
176
+ gap: 0.125rem;
177
+ }
178
+ .btn {
179
+ display: flex;
180
+ align-items: center;
181
+ justify-content: center;
182
+ width: 2rem;
183
+ height: 2rem;
184
+ background: none;
185
+ border: none;
186
+ color: rgb(255 255 255 / 0.8);
187
+ cursor: pointer;
188
+ padding: 0;
189
+ border-radius: 0.25rem;
190
+ transition: color 150ms;
191
+ }
192
+ .btn:hover {
193
+ color: white;
194
+ }
195
+ .btn:disabled {
196
+ opacity: 0.4;
197
+ cursor: not-allowed;
198
+ }
199
+ .time {
200
+ font-size: 0.6875rem;
201
+ color: rgb(255 255 255 / 0.7);
202
+ font-variant-numeric: tabular-nums;
203
+ padding: 0 0.375rem;
204
+ white-space: nowrap;
205
+ }
206
+ .live-badge {
207
+ display: inline-flex;
208
+ align-items: center;
209
+ gap: 0.375rem;
210
+ padding: 0.125rem 0.5rem;
211
+ border-radius: 0.25rem;
212
+ font-size: 0.6875rem;
213
+ font-weight: 600;
214
+ text-transform: uppercase;
215
+ letter-spacing: 0.025em;
216
+ cursor: pointer;
217
+ border: none;
218
+ background: none;
219
+ transition: color 150ms;
220
+ }
221
+ .live-badge--active {
222
+ color: hsl(var(--tn-red, 348 74% 64%));
223
+ }
224
+ .live-badge--behind {
225
+ color: rgb(255 255 255 / 0.5);
226
+ }
227
+ .live-dot {
228
+ width: 6px;
229
+ height: 6px;
230
+ border-radius: 50%;
231
+ background: currentColor;
232
+ }
233
+ .settings-anchor {
234
+ position: relative;
235
+ }
236
+ `,
237
+ ];
238
+ __decorate([
239
+ property({ attribute: false })
240
+ ], FwPlayerControls.prototype, "pc", void 0);
241
+ __decorate([
242
+ property({ type: String })
243
+ ], FwPlayerControls.prototype, "playbackMode", void 0);
244
+ __decorate([
245
+ property({ type: Boolean, attribute: "is-content-live" })
246
+ ], FwPlayerControls.prototype, "isContentLive", void 0);
247
+ __decorate([
248
+ property({ type: Boolean, attribute: "is-stats-open" })
249
+ ], FwPlayerControls.prototype, "isStatsOpen", void 0);
250
+ __decorate([
251
+ state()
252
+ ], FwPlayerControls.prototype, "_settingsOpen", void 0);
253
+ FwPlayerControls = __decorate([
254
+ customElement("fw-player-controls")
255
+ ], FwPlayerControls);
256
+
257
+ export { FwPlayerControls };
258
+ //# sourceMappingURL=fw-player-controls.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fw-player-controls.js","sources":["../../../../src/components/fw-player-controls.ts"],"sourcesContent":["/**\n * <fw-player-controls> — Control bar with play/pause, seek, volume, quality, fullscreen.\n * Port of PlayerControls.tsx from player-react.\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 { sharedStyles } from \"../styles/shared-styles.js\";\nimport { utilityStyles } from \"../styles/utility-styles.js\";\nimport {\n playIcon,\n pauseIcon,\n fullscreenIcon,\n fullscreenExitIcon,\n settingsIcon,\n seekToLiveIcon,\n} from \"../icons/index.js\";\nimport type { PlayerControllerHost } from \"../controllers/player-controller-host.js\";\nimport type { PlaybackMode } from \"@livepeer-frameworks/player-core\";\n\n@customElement(\"fw-player-controls\")\nexport class FwPlayerControls extends LitElement {\n @property({ attribute: false }) pc!: PlayerControllerHost;\n @property({ type: String }) playbackMode: PlaybackMode = \"auto\";\n @property({ type: Boolean, attribute: \"is-content-live\" }) isContentLive = false;\n @property({ type: Boolean, attribute: \"is-stats-open\" }) isStatsOpen = false;\n\n @state() private _settingsOpen = false;\n\n static styles = [\n sharedStyles,\n utilityStyles,\n css`\n :host {\n display: contents;\n }\n .controls-wrapper {\n position: absolute;\n bottom: 0;\n left: 0;\n right: 0;\n z-index: 20;\n background: linear-gradient(to top, rgb(0 0 0 / 0.7), transparent);\n padding: 2rem 0.75rem 0.5rem;\n opacity: 0;\n transition: opacity 200ms ease;\n pointer-events: none;\n }\n .controls-wrapper--visible {\n opacity: 1;\n pointer-events: auto;\n }\n .bar {\n display: flex;\n flex-direction: column;\n gap: 0.25rem;\n }\n .row {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: 0.25rem;\n }\n .group {\n display: flex;\n align-items: center;\n gap: 0.125rem;\n }\n .btn {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 2rem;\n height: 2rem;\n background: none;\n border: none;\n color: rgb(255 255 255 / 0.8);\n cursor: pointer;\n padding: 0;\n border-radius: 0.25rem;\n transition: color 150ms;\n }\n .btn:hover {\n color: white;\n }\n .btn:disabled {\n opacity: 0.4;\n cursor: not-allowed;\n }\n .time {\n font-size: 0.6875rem;\n color: rgb(255 255 255 / 0.7);\n font-variant-numeric: tabular-nums;\n padding: 0 0.375rem;\n white-space: nowrap;\n }\n .live-badge {\n display: inline-flex;\n align-items: center;\n gap: 0.375rem;\n padding: 0.125rem 0.5rem;\n border-radius: 0.25rem;\n font-size: 0.6875rem;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.025em;\n cursor: pointer;\n border: none;\n background: none;\n transition: color 150ms;\n }\n .live-badge--active {\n color: hsl(var(--tn-red, 348 74% 64%));\n }\n .live-badge--behind {\n color: rgb(255 255 255 / 0.5);\n }\n .live-dot {\n width: 6px;\n height: 6px;\n border-radius: 50%;\n background: currentColor;\n }\n .settings-anchor {\n position: relative;\n }\n `,\n ];\n\n private _formatTime(seconds: number): string {\n if (!isFinite(seconds) || isNaN(seconds)) return \"0:00\";\n const abs = Math.abs(Math.floor(seconds));\n const h = Math.floor(abs / 3600);\n const m = Math.floor((abs % 3600) / 60);\n const s = abs % 60;\n if (h > 0) return `${h}:${String(m).padStart(2, \"0\")}:${String(s).padStart(2, \"0\")}`;\n return `${m}:${String(s).padStart(2, \"0\")}`;\n }\n\n private get _isNearLive(): boolean {\n if (!this.isContentLive) return false;\n const { currentTime, duration } = this.pc.s;\n if (!isFinite(duration) || duration <= 0) return true;\n return duration - currentTime < 10;\n }\n\n protected render() {\n const s = this.pc.s;\n const disabled = !s.videoElement;\n\n return html`\n <div\n class=${classMap({\n \"controls-wrapper\": true,\n \"controls-wrapper--visible\": s.shouldShowControls,\n \"fw-controls-wrapper\": true,\n })}\n >\n <div class=\"bar fw-control-bar\">\n <!-- Seek bar -->\n <fw-seek-bar\n .currentTime=${s.currentTime}\n .duration=${s.duration}\n .disabled=${disabled}\n .isLive=${this.isContentLive}\n @fw-seek=${(e: CustomEvent) => this.pc.seek(e.detail.time)}\n ></fw-seek-bar>\n\n <!-- Button row -->\n <div class=\"row\">\n <div class=\"group fw-control-group\">\n <!-- Play/Pause -->\n <button\n class=\"btn fw-btn-flush\"\n type=\"button\"\n ?disabled=${disabled}\n @click=${() => this.pc.togglePlay()}\n aria-label=\"${s.isPlaying ? \"Pause\" : \"Play\"}\"\n >\n ${s.isPlaying ? pauseIcon(18) : playIcon(18)}\n </button>\n\n <!-- Volume -->\n <fw-volume-control .pc=${this.pc}></fw-volume-control>\n\n <!-- Time display -->\n ${!this.isContentLive\n ? html`\n <span class=\"time fw-time-display\">\n ${this._formatTime(s.currentTime)} / ${this._formatTime(s.duration)}\n </span>\n `\n : nothing}\n\n <!-- Live badge -->\n ${this.isContentLive\n ? html`\n <button\n class=${classMap({\n \"live-badge\": true,\n \"fw-live-badge\": true,\n \"live-badge--active\": this._isNearLive,\n \"fw-live-badge--active\": this._isNearLive,\n \"live-badge--behind\": !this._isNearLive,\n \"fw-live-badge--behind\": !this._isNearLive,\n })}\n type=\"button\"\n @click=${() => this.pc.jumpToLive()}\n aria-label=\"Jump to live\"\n >\n <span class=\"live-dot\"></span>\n LIVE\n </button>\n `\n : nothing}\n </div>\n\n <div class=\"group fw-control-group\">\n <!-- Settings -->\n <div class=\"settings-anchor\">\n <button\n class=\"btn fw-btn-flush\"\n type=\"button\"\n @click=${() => {\n this._settingsOpen = !this._settingsOpen;\n }}\n aria-label=\"Settings\"\n >\n ${settingsIcon(16)}\n </button>\n <fw-settings-menu .pc=${this.pc} .open=${this._settingsOpen}></fw-settings-menu>\n </div>\n\n <!-- Fullscreen -->\n <button\n class=\"btn fw-btn-flush\"\n type=\"button\"\n ?disabled=${disabled}\n @click=${() => this.pc.toggleFullscreen()}\n aria-label=\"${s.isFullscreen ? \"Exit fullscreen\" : \"Fullscreen\"}\"\n >\n ${s.isFullscreen ? fullscreenExitIcon(16) : fullscreenIcon(16)}\n </button>\n </div>\n </div>\n </div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"fw-player-controls\": FwPlayerControls;\n }\n}\n"],"names":[],"mappings":"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"}