@aigne/afs-ui 1.11.0-beta.12

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 (196) hide show
  1. package/LICENSE.md +26 -0
  2. package/dist/_virtual/_@oxc-project_runtime@0.108.0/helpers/decorate.cjs +11 -0
  3. package/dist/_virtual/_@oxc-project_runtime@0.108.0/helpers/decorate.mjs +10 -0
  4. package/dist/aup-protocol.cjs +235 -0
  5. package/dist/aup-protocol.d.cts +78 -0
  6. package/dist/aup-protocol.d.cts.map +1 -0
  7. package/dist/aup-protocol.d.mts +78 -0
  8. package/dist/aup-protocol.d.mts.map +1 -0
  9. package/dist/aup-protocol.mjs +235 -0
  10. package/dist/aup-protocol.mjs.map +1 -0
  11. package/dist/aup-registry.cjs +2489 -0
  12. package/dist/aup-registry.mjs +2487 -0
  13. package/dist/aup-registry.mjs.map +1 -0
  14. package/dist/aup-spec.cjs +1467 -0
  15. package/dist/aup-spec.mjs +1466 -0
  16. package/dist/aup-spec.mjs.map +1 -0
  17. package/dist/aup-types.cjs +165 -0
  18. package/dist/aup-types.d.cts +157 -0
  19. package/dist/aup-types.d.cts.map +1 -0
  20. package/dist/aup-types.d.mts +157 -0
  21. package/dist/aup-types.d.mts.map +1 -0
  22. package/dist/aup-types.mjs +157 -0
  23. package/dist/aup-types.mjs.map +1 -0
  24. package/dist/backend.cjs +14 -0
  25. package/dist/backend.d.cts +104 -0
  26. package/dist/backend.d.cts.map +1 -0
  27. package/dist/backend.d.mts +104 -0
  28. package/dist/backend.d.mts.map +1 -0
  29. package/dist/backend.mjs +13 -0
  30. package/dist/backend.mjs.map +1 -0
  31. package/dist/degradation.cjs +85 -0
  32. package/dist/degradation.d.cts +17 -0
  33. package/dist/degradation.d.cts.map +1 -0
  34. package/dist/degradation.d.mts +17 -0
  35. package/dist/degradation.d.mts.map +1 -0
  36. package/dist/degradation.mjs +84 -0
  37. package/dist/degradation.mjs.map +1 -0
  38. package/dist/index.cjs +36 -0
  39. package/dist/index.d.cts +12 -0
  40. package/dist/index.d.mts +12 -0
  41. package/dist/index.mjs +13 -0
  42. package/dist/runtime.cjs +117 -0
  43. package/dist/runtime.d.cts +59 -0
  44. package/dist/runtime.d.cts.map +1 -0
  45. package/dist/runtime.d.mts +59 -0
  46. package/dist/runtime.d.mts.map +1 -0
  47. package/dist/runtime.mjs +118 -0
  48. package/dist/runtime.mjs.map +1 -0
  49. package/dist/session.cjs +159 -0
  50. package/dist/session.d.cts +80 -0
  51. package/dist/session.d.cts.map +1 -0
  52. package/dist/session.d.mts +80 -0
  53. package/dist/session.d.mts.map +1 -0
  54. package/dist/session.mjs +159 -0
  55. package/dist/session.mjs.map +1 -0
  56. package/dist/snapshot.cjs +162 -0
  57. package/dist/snapshot.mjs +163 -0
  58. package/dist/snapshot.mjs.map +1 -0
  59. package/dist/term-page.cjs +264 -0
  60. package/dist/term-page.mjs +264 -0
  61. package/dist/term-page.mjs.map +1 -0
  62. package/dist/term.cjs +295 -0
  63. package/dist/term.d.cts +84 -0
  64. package/dist/term.d.cts.map +1 -0
  65. package/dist/term.d.mts +84 -0
  66. package/dist/term.d.mts.map +1 -0
  67. package/dist/term.mjs +296 -0
  68. package/dist/term.mjs.map +1 -0
  69. package/dist/tty.cjs +136 -0
  70. package/dist/tty.d.cts +53 -0
  71. package/dist/tty.d.cts.map +1 -0
  72. package/dist/tty.d.mts +53 -0
  73. package/dist/tty.d.mts.map +1 -0
  74. package/dist/tty.mjs +135 -0
  75. package/dist/tty.mjs.map +1 -0
  76. package/dist/ui-provider.cjs +4615 -0
  77. package/dist/ui-provider.d.cts +307 -0
  78. package/dist/ui-provider.d.cts.map +1 -0
  79. package/dist/ui-provider.d.mts +307 -0
  80. package/dist/ui-provider.d.mts.map +1 -0
  81. package/dist/ui-provider.mjs +4616 -0
  82. package/dist/ui-provider.mjs.map +1 -0
  83. package/dist/web-page/core.cjs +1388 -0
  84. package/dist/web-page/core.mjs +1387 -0
  85. package/dist/web-page/core.mjs.map +1 -0
  86. package/dist/web-page/css.cjs +1699 -0
  87. package/dist/web-page/css.mjs +1698 -0
  88. package/dist/web-page/css.mjs.map +1 -0
  89. package/dist/web-page/icons.cjs +248 -0
  90. package/dist/web-page/icons.mjs +248 -0
  91. package/dist/web-page/icons.mjs.map +1 -0
  92. package/dist/web-page/overlay-themes.cjs +514 -0
  93. package/dist/web-page/overlay-themes.mjs +513 -0
  94. package/dist/web-page/overlay-themes.mjs.map +1 -0
  95. package/dist/web-page/renderers/action.cjs +72 -0
  96. package/dist/web-page/renderers/action.mjs +72 -0
  97. package/dist/web-page/renderers/action.mjs.map +1 -0
  98. package/dist/web-page/renderers/broadcast.cjs +160 -0
  99. package/dist/web-page/renderers/broadcast.mjs +160 -0
  100. package/dist/web-page/renderers/broadcast.mjs.map +1 -0
  101. package/dist/web-page/renderers/calendar.cjs +137 -0
  102. package/dist/web-page/renderers/calendar.mjs +137 -0
  103. package/dist/web-page/renderers/calendar.mjs.map +1 -0
  104. package/dist/web-page/renderers/canvas.cjs +173 -0
  105. package/dist/web-page/renderers/canvas.mjs +173 -0
  106. package/dist/web-page/renderers/canvas.mjs.map +1 -0
  107. package/dist/web-page/renderers/cdn-loader.cjs +25 -0
  108. package/dist/web-page/renderers/cdn-loader.mjs +25 -0
  109. package/dist/web-page/renderers/cdn-loader.mjs.map +1 -0
  110. package/dist/web-page/renderers/chart.cjs +101 -0
  111. package/dist/web-page/renderers/chart.mjs +101 -0
  112. package/dist/web-page/renderers/chart.mjs.map +1 -0
  113. package/dist/web-page/renderers/deck.cjs +390 -0
  114. package/dist/web-page/renderers/deck.mjs +390 -0
  115. package/dist/web-page/renderers/deck.mjs.map +1 -0
  116. package/dist/web-page/renderers/device.cjs +1015 -0
  117. package/dist/web-page/renderers/device.mjs +1015 -0
  118. package/dist/web-page/renderers/device.mjs.map +1 -0
  119. package/dist/web-page/renderers/editor.cjs +127 -0
  120. package/dist/web-page/renderers/editor.mjs +127 -0
  121. package/dist/web-page/renderers/editor.mjs.map +1 -0
  122. package/dist/web-page/renderers/finance-chart.cjs +178 -0
  123. package/dist/web-page/renderers/finance-chart.mjs +178 -0
  124. package/dist/web-page/renderers/finance-chart.mjs.map +1 -0
  125. package/dist/web-page/renderers/frame.cjs +274 -0
  126. package/dist/web-page/renderers/frame.mjs +274 -0
  127. package/dist/web-page/renderers/frame.mjs.map +1 -0
  128. package/dist/web-page/renderers/globe.cjs +119 -0
  129. package/dist/web-page/renderers/globe.mjs +119 -0
  130. package/dist/web-page/renderers/globe.mjs.map +1 -0
  131. package/dist/web-page/renderers/input.cjs +137 -0
  132. package/dist/web-page/renderers/input.mjs +137 -0
  133. package/dist/web-page/renderers/input.mjs.map +1 -0
  134. package/dist/web-page/renderers/list.cjs +1243 -0
  135. package/dist/web-page/renderers/list.mjs +1243 -0
  136. package/dist/web-page/renderers/list.mjs.map +1 -0
  137. package/dist/web-page/renderers/map.cjs +126 -0
  138. package/dist/web-page/renderers/map.mjs +126 -0
  139. package/dist/web-page/renderers/map.mjs.map +1 -0
  140. package/dist/web-page/renderers/media.cjs +106 -0
  141. package/dist/web-page/renderers/media.mjs +106 -0
  142. package/dist/web-page/renderers/media.mjs.map +1 -0
  143. package/dist/web-page/renderers/moonphase.cjs +105 -0
  144. package/dist/web-page/renderers/moonphase.mjs +105 -0
  145. package/dist/web-page/renderers/moonphase.mjs.map +1 -0
  146. package/dist/web-page/renderers/natal-chart.cjs +222 -0
  147. package/dist/web-page/renderers/natal-chart.mjs +222 -0
  148. package/dist/web-page/renderers/natal-chart.mjs.map +1 -0
  149. package/dist/web-page/renderers/overlay.cjs +531 -0
  150. package/dist/web-page/renderers/overlay.mjs +531 -0
  151. package/dist/web-page/renderers/overlay.mjs.map +1 -0
  152. package/dist/web-page/renderers/table.cjs +74 -0
  153. package/dist/web-page/renderers/table.mjs +74 -0
  154. package/dist/web-page/renderers/table.mjs.map +1 -0
  155. package/dist/web-page/renderers/terminal.cjs +30 -0
  156. package/dist/web-page/renderers/terminal.mjs +30 -0
  157. package/dist/web-page/renderers/terminal.mjs.map +1 -0
  158. package/dist/web-page/renderers/text.cjs +109 -0
  159. package/dist/web-page/renderers/text.mjs +109 -0
  160. package/dist/web-page/renderers/text.mjs.map +1 -0
  161. package/dist/web-page/renderers/ticker.cjs +133 -0
  162. package/dist/web-page/renderers/ticker.mjs +133 -0
  163. package/dist/web-page/renderers/ticker.mjs.map +1 -0
  164. package/dist/web-page/renderers/time.cjs +69 -0
  165. package/dist/web-page/renderers/time.mjs +69 -0
  166. package/dist/web-page/renderers/time.mjs.map +1 -0
  167. package/dist/web-page/renderers/unknown.cjs +20 -0
  168. package/dist/web-page/renderers/unknown.mjs +20 -0
  169. package/dist/web-page/renderers/unknown.mjs.map +1 -0
  170. package/dist/web-page/renderers/view.cjs +161 -0
  171. package/dist/web-page/renderers/view.mjs +161 -0
  172. package/dist/web-page/renderers/view.mjs.map +1 -0
  173. package/dist/web-page/renderers/wm.cjs +669 -0
  174. package/dist/web-page/renderers/wm.mjs +669 -0
  175. package/dist/web-page/renderers/wm.mjs.map +1 -0
  176. package/dist/web-page/skeleton.cjs +103 -0
  177. package/dist/web-page/skeleton.mjs +103 -0
  178. package/dist/web-page/skeleton.mjs.map +1 -0
  179. package/dist/web-page.cjs +114 -0
  180. package/dist/web-page.d.cts +19 -0
  181. package/dist/web-page.d.cts.map +1 -0
  182. package/dist/web-page.d.mts +19 -0
  183. package/dist/web-page.d.mts.map +1 -0
  184. package/dist/web-page.mjs +115 -0
  185. package/dist/web-page.mjs.map +1 -0
  186. package/dist/web.cjs +827 -0
  187. package/dist/web.d.cts +144 -0
  188. package/dist/web.d.cts.map +1 -0
  189. package/dist/web.d.mts +144 -0
  190. package/dist/web.d.mts.map +1 -0
  191. package/dist/web.mjs +828 -0
  192. package/dist/web.mjs.map +1 -0
  193. package/dist/wm-state.cjs +172 -0
  194. package/dist/wm-state.mjs +171 -0
  195. package/dist/wm-state.mjs.map +1 -0
  196. package/package.json +59 -0
@@ -0,0 +1,514 @@
1
+
2
+ //#region src/web-page/overlay-themes.ts
3
+ /**
4
+ * Overlay Theme System — broadcast "graphics packages" for overlay-grid.
5
+ *
6
+ * Three built-in themes: minimal (default), cnn (hard-edge news), apple (frosted glass).
7
+ * Theme CSS is injected on-demand when _applyOverlayTheme is called.
8
+ * Font loading is lazy — Google Fonts <link> injected only when a theme activates.
9
+ *
10
+ * 12 broadcast roles styled per theme:
11
+ * live-badge, clock, viewer-count, speaker-bar, hashtag, logo,
12
+ * data-widget, alert, featured-comment, score-bug, lower-third, ticker-item
13
+ *
14
+ * Specificity strategy:
15
+ * - Role selectors use [data-overlay-theme][data-overlay-theme] double-attr
16
+ * to reach (0,3,0), beating primitive defaults like .aup-text[data-mode] (0,2,0).
17
+ * - Color inheritance is forced on all children inside themed overlay-grid
18
+ * so primitive default `color: var(--text)` doesn't override theme colors.
19
+ * - Ticker gets a dedicated override for .aup-ticker color.
20
+ */
21
+ const OVERLAY_THEMES_CSS = `
22
+ /* ── Overlay Theme: minimal ── */
23
+ [data-overlay-theme="minimal"] {
24
+ --overlay-badge-bg: rgba(0,0,0,0.6);
25
+ --overlay-badge-color: #fff;
26
+ --overlay-badge-radius: 6px;
27
+ --overlay-badge-font: inherit;
28
+ --overlay-badge-size: 0.85rem;
29
+ --overlay-badge-weight: 600;
30
+ --overlay-card-bg: rgba(0,0,0,0.5);
31
+ --overlay-card-color: #fff;
32
+ --overlay-card-border: 1px solid rgba(255,255,255,0.1);
33
+ --overlay-card-radius: 8px;
34
+ --overlay-glass-blur: 8px;
35
+ --overlay-lower-bg: rgba(0,0,0,0.5);
36
+ --overlay-lower-color: #fff;
37
+ --overlay-lower-accent: rgba(255,255,255,0.3);
38
+ --overlay-lower-radius: 8px;
39
+ --overlay-lower-size: 1rem;
40
+ --overlay-ticker-bg: rgba(0,0,0,0.6);
41
+ --overlay-ticker-color: #fff;
42
+ --overlay-ticker-size: 0.85rem;
43
+ --overlay-alert-bg: rgba(220,38,38,0.85);
44
+ --overlay-alert-color: #fff;
45
+ --overlay-alert-size: 0.9rem;
46
+ --overlay-score-bg: rgba(0,0,0,0.7);
47
+ --overlay-score-color: #fff;
48
+ --overlay-score-radius: 6px;
49
+ --overlay-viewer-bg: rgba(0,0,0,0.4);
50
+ --overlay-viewer-color: #fff;
51
+ }
52
+
53
+ /* ── Overlay Theme: cnn ── */
54
+ [data-overlay-theme="cnn"] {
55
+ --overlay-badge-bg: #cc0000;
56
+ --overlay-badge-color: #fff;
57
+ --overlay-badge-radius: 2px;
58
+ --overlay-badge-font: "Barlow Condensed", "Arial Narrow", sans-serif;
59
+ --overlay-badge-size: 1rem;
60
+ --overlay-badge-weight: 700;
61
+ --overlay-card-bg: rgba(0,0,0,0.9);
62
+ --overlay-card-color: #fff;
63
+ --overlay-card-border: 4px solid #cc0000;
64
+ --overlay-card-radius: 0;
65
+ --overlay-glass-blur: 0;
66
+ --overlay-lower-bg: rgba(0,0,0,0.9);
67
+ --overlay-lower-color: #fff;
68
+ --overlay-lower-accent: #cc0000;
69
+ --overlay-lower-radius: 0;
70
+ --overlay-lower-size: 1.15rem;
71
+ --overlay-ticker-bg: #111;
72
+ --overlay-ticker-color: #fff;
73
+ --overlay-ticker-size: 0.95rem;
74
+ --overlay-alert-bg: #fbbf24;
75
+ --overlay-alert-color: #111;
76
+ --overlay-alert-size: 1.05rem;
77
+ --overlay-score-bg: #1a1a1a;
78
+ --overlay-score-color: #fff;
79
+ --overlay-score-radius: 0;
80
+ --overlay-viewer-bg: rgba(0,0,0,0.6);
81
+ --overlay-viewer-color: rgba(255,255,255,0.9);
82
+ }
83
+
84
+ /* ── Overlay Theme: apple ── */
85
+ [data-overlay-theme="apple"] {
86
+ --overlay-badge-bg: rgba(0,0,0,0.4);
87
+ --overlay-badge-color: #fff;
88
+ --overlay-badge-radius: 20px;
89
+ --overlay-badge-font: "Inter", -apple-system, sans-serif;
90
+ --overlay-badge-size: 0.78rem;
91
+ --overlay-badge-weight: 500;
92
+ --overlay-card-bg: rgba(0,0,0,0.3);
93
+ --overlay-card-color: #fff;
94
+ --overlay-card-border: 1px solid rgba(255,255,255,0.18);
95
+ --overlay-card-radius: 16px;
96
+ --overlay-glass-blur: 20px;
97
+ --overlay-lower-bg: rgba(0,0,0,0.3);
98
+ --overlay-lower-color: #fff;
99
+ --overlay-lower-accent: rgba(255,255,255,0.2);
100
+ --overlay-lower-radius: 16px;
101
+ --overlay-lower-size: 0.95rem;
102
+ --overlay-ticker-bg: rgba(0,0,0,0.25);
103
+ --overlay-ticker-color: rgba(255,255,255,0.95);
104
+ --overlay-ticker-size: 0.82rem;
105
+ --overlay-alert-bg: rgba(220,38,38,0.8);
106
+ --overlay-alert-color: #fff;
107
+ --overlay-alert-size: 0.88rem;
108
+ --overlay-score-bg: rgba(0,0,0,0.3);
109
+ --overlay-score-color: #fff;
110
+ --overlay-score-radius: 12px;
111
+ --overlay-viewer-bg: rgba(0,0,0,0.3);
112
+ --overlay-viewer-color: rgba(255,255,255,0.9);
113
+ }
114
+
115
+ /* ══════════════════════════════════════════════════════════
116
+ Force color inheritance inside themed overlay-grid.
117
+ Primitives (.aup-text, .aup-ticker etc.) normally set
118
+ color: var(--text) which overrides theme colors.
119
+ This resets all children to inherit from their role/region container.
120
+ Double-attr [data-overlay-theme][data-overlay-theme] => (0,3,0)
121
+ beats .aup-text[data-mode="badge"][data-intent="info"] (0,3,1) — close but
122
+ we use * to catch all children.
123
+ ══════════════════════════════════════════════════════════ */
124
+
125
+ [data-overlay-theme] [data-role] *,
126
+ [data-overlay-theme] [data-role] {
127
+ color: inherit;
128
+ font-family: inherit;
129
+ }
130
+
131
+ /* Ticker: the .aup-ticker inside [data-region="ticker"] sets its own color.
132
+ Force it and all its children to inherit the region's color. */
133
+ [data-overlay-theme] > [data-region="ticker"],
134
+ [data-overlay-theme] > [data-region="ticker"] *,
135
+ [data-overlay-theme] > [data-region="ticker"] .aup-ticker {
136
+ color: var(--overlay-ticker-color) !important;
137
+ }
138
+
139
+ /* ── Role styles — doubled attribute for (0,3,0) specificity ── */
140
+
141
+ /* live-badge */
142
+ [data-overlay-theme] [data-role="live-badge"][data-role] {
143
+ display: inline-flex; align-items: center; gap: 6px;
144
+ background: var(--overlay-badge-bg); color: var(--overlay-badge-color);
145
+ padding: 6px 14px; border-radius: var(--overlay-badge-radius);
146
+ font-family: var(--overlay-badge-font); font-weight: var(--overlay-badge-weight);
147
+ font-size: var(--overlay-badge-size);
148
+ text-transform: uppercase; letter-spacing: 0.05em;
149
+ backdrop-filter: blur(var(--overlay-glass-blur));
150
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
151
+ border: none; box-shadow: none;
152
+ }
153
+
154
+ /* clock */
155
+ [data-overlay-theme] [data-role="clock"][data-role] {
156
+ display: inline-flex; align-items: center;
157
+ background: var(--overlay-badge-bg); color: var(--overlay-badge-color);
158
+ padding: 6px 14px; border-radius: var(--overlay-badge-radius);
159
+ font-family: var(--overlay-badge-font); font-variant-numeric: tabular-nums;
160
+ font-size: var(--overlay-badge-size); font-weight: var(--overlay-badge-weight);
161
+ backdrop-filter: blur(var(--overlay-glass-blur));
162
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
163
+ border: none; box-shadow: none;
164
+ }
165
+
166
+ /* viewer-count — lighter than badge, not same color */
167
+ [data-overlay-theme] [data-role="viewer-count"][data-role] {
168
+ display: inline-flex; align-items: center; gap: 4px;
169
+ background: var(--overlay-viewer-bg); color: var(--overlay-viewer-color);
170
+ padding: 6px 14px; border-radius: var(--overlay-badge-radius);
171
+ font-family: var(--overlay-badge-font); font-size: var(--overlay-badge-size);
172
+ backdrop-filter: blur(var(--overlay-glass-blur));
173
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
174
+ border: none; box-shadow: none;
175
+ }
176
+
177
+ /* speaker-bar */
178
+ [data-overlay-theme] [data-role="speaker-bar"][data-role] {
179
+ display: flex; flex-direction: column; gap: 4px;
180
+ background: var(--overlay-card-bg); color: var(--overlay-card-color);
181
+ padding: 14px 24px; border-radius: var(--overlay-card-radius);
182
+ border-left: var(--overlay-card-border);
183
+ backdrop-filter: blur(var(--overlay-glass-blur));
184
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
185
+ box-shadow: none;
186
+ }
187
+
188
+ /* hashtag */
189
+ [data-overlay-theme] [data-role="hashtag"][data-role] {
190
+ display: inline-flex; align-items: center;
191
+ background: var(--overlay-badge-bg); color: var(--overlay-badge-color);
192
+ padding: 6px 14px; border-radius: var(--overlay-badge-radius);
193
+ font-family: var(--overlay-badge-font); font-size: var(--overlay-badge-size);
194
+ backdrop-filter: blur(var(--overlay-glass-blur));
195
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
196
+ border: none; box-shadow: none;
197
+ }
198
+
199
+ /* logo */
200
+ [data-overlay-theme] [data-role="logo"][data-role] {
201
+ display: flex; align-items: center; justify-content: center;
202
+ backdrop-filter: blur(var(--overlay-glass-blur));
203
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
204
+ }
205
+
206
+ /* data-widget */
207
+ [data-overlay-theme] [data-role="data-widget"][data-role] {
208
+ background: var(--overlay-card-bg); color: var(--overlay-card-color);
209
+ padding: 14px 20px; border-radius: var(--overlay-card-radius);
210
+ border: var(--overlay-card-border);
211
+ backdrop-filter: blur(var(--overlay-glass-blur));
212
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
213
+ box-shadow: none;
214
+ }
215
+
216
+ /* alert — prominent bar */
217
+ [data-overlay-theme] [data-role="alert"][data-role] {
218
+ display: flex; align-items: center; justify-content: center; gap: 10px;
219
+ background: var(--overlay-alert-bg); color: var(--overlay-alert-color);
220
+ padding: 12px 32px; border-radius: var(--overlay-badge-radius);
221
+ font-family: var(--overlay-badge-font); font-weight: 700;
222
+ font-size: var(--overlay-alert-size);
223
+ text-transform: uppercase; letter-spacing: 0.06em;
224
+ backdrop-filter: blur(var(--overlay-glass-blur));
225
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
226
+ border: none; box-shadow: none;
227
+ }
228
+
229
+ /* featured-comment */
230
+ [data-overlay-theme] [data-role="featured-comment"][data-role] {
231
+ background: var(--overlay-card-bg); color: var(--overlay-card-color);
232
+ padding: 14px 24px; border-radius: var(--overlay-card-radius);
233
+ border: var(--overlay-card-border);
234
+ backdrop-filter: blur(var(--overlay-glass-blur));
235
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
236
+ max-width: 420px; box-shadow: none;
237
+ }
238
+
239
+ /* score-bug */
240
+ [data-overlay-theme] [data-role="score-bug"][data-role] {
241
+ display: inline-flex; align-items: center; gap: 0;
242
+ background: var(--overlay-score-bg); color: var(--overlay-score-color);
243
+ border-radius: var(--overlay-score-radius);
244
+ overflow: hidden; font-family: var(--overlay-badge-font);
245
+ font-weight: 700; font-variant-numeric: tabular-nums;
246
+ backdrop-filter: blur(var(--overlay-glass-blur));
247
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
248
+ border: none; box-shadow: none;
249
+ }
250
+
251
+ /* lower-third — wide bar, prominent */
252
+ [data-overlay-theme] [data-role="lower-third"][data-role] {
253
+ display: flex; flex-direction: column; gap: 4px;
254
+ background: var(--overlay-lower-bg); color: var(--overlay-lower-color);
255
+ padding: 16px 28px; border-radius: var(--overlay-lower-radius);
256
+ border-left: 4px solid var(--overlay-lower-accent);
257
+ backdrop-filter: blur(var(--overlay-glass-blur));
258
+ -webkit-backdrop-filter: blur(var(--overlay-glass-blur));
259
+ font-size: var(--overlay-lower-size);
260
+ min-width: 340px;
261
+ border-top: none; border-right: none; border-bottom: none;
262
+ box-shadow: none;
263
+ }
264
+
265
+ /* ticker region — background on the grid region container */
266
+ [data-overlay-theme] > [data-region="ticker"] {
267
+ background: var(--overlay-ticker-bg);
268
+ font-size: var(--overlay-ticker-size);
269
+ padding: 8px 0;
270
+ }
271
+
272
+ /* ticker-item */
273
+ [data-overlay-theme] [data-role="ticker-item"][data-role] {
274
+ display: inline-flex; align-items: center;
275
+ font-family: var(--overlay-badge-font);
276
+ font-size: var(--overlay-ticker-size);
277
+ }
278
+
279
+ /* ══════════════════════════════════════════════════════════
280
+ CNN theme-specific overrides
281
+ Real CNN: full-width bars, 0 gap, 0 radius, condensed bold,
282
+ huge text (2-3rem headlines), white-bg black-text headline bar,
283
+ red BREAKING NEWS bar, black ticker.
284
+ ══════════════════════════════════════════════════════════ */
285
+
286
+ /* CNN: zero gap between lower regions & ticker — tight bar stacking */
287
+ [data-overlay-theme="cnn"] {
288
+ gap: 8px 8px;
289
+ }
290
+ /* CNN broadcast: full-width bars for lower/ticker/bottom rows — break out of title-safe padding */
291
+ [data-overlay-theme="cnn"] > [data-region^="lower"],
292
+ [data-overlay-theme="cnn"] > [data-region="ticker"],
293
+ [data-overlay-theme="cnn"] > [data-region^="bottom"] {
294
+ margin-top: -8px;
295
+ margin-left: calc(-1 * var(--overlay-pad));
296
+ margin-right: calc(-1 * var(--overlay-pad));
297
+ padding-left: var(--overlay-pad);
298
+ padding-right: var(--overlay-pad);
299
+ }
300
+
301
+ [data-overlay-theme="cnn"] [data-role="live-badge"][data-role] {
302
+ font-size: 1.1rem; letter-spacing: 0.15em; padding: 10px 22px;
303
+ font-weight: 700;
304
+ }
305
+ [data-overlay-theme="cnn"] [data-role="clock"][data-role] {
306
+ font-size: 1rem; padding: 8px 16px;
307
+ }
308
+
309
+ /* CNN lower-third: name bar — dark bg, red left accent, bold white text */
310
+ [data-overlay-theme="cnn"] [data-role="lower-third"][data-role] {
311
+ border-left: 5px solid #cc0000;
312
+ background: rgba(0,0,0,0.95);
313
+ padding: 14px 24px; min-width: 280px;
314
+ font-size: 1rem; border-radius: 0;
315
+ }
316
+ [data-overlay-theme="cnn"] [data-role="lower-third"][data-role] .aup-text:first-child {
317
+ font-size: 1.2rem; font-weight: 700; text-transform: uppercase;
318
+ }
319
+ [data-overlay-theme="cnn"] [data-role="lower-third"][data-role] .aup-text:nth-child(2) {
320
+ font-size: 0.85rem; opacity: 0.7; font-weight: 400;
321
+ }
322
+
323
+ /* CNN alert (BREAKING NEWS): red bg, huge bold white text */
324
+ [data-overlay-theme="cnn"] [data-role="alert"][data-role] {
325
+ background: #cc0000; color: #fff;
326
+ font-size: 1.4rem; letter-spacing: 0.12em; font-weight: 700;
327
+ padding: 12px 28px; border-radius: 0;
328
+ text-transform: uppercase;
329
+ }
330
+
331
+ /* CNN headline: WHITE bg, BLACK text, enormous condensed bold, full-width bar */
332
+ [data-overlay-theme="cnn"] [data-role="headline"][data-role] {
333
+ background: rgba(255,255,255,0.97); color: #111;
334
+ font-size: 2.2rem; font-weight: 700; line-height: 1.15;
335
+ padding: 18px 28px; border-radius: 0;
336
+ text-transform: uppercase; letter-spacing: 0.02em;
337
+ border: none; box-shadow: none;
338
+ backdrop-filter: none; -webkit-backdrop-filter: none;
339
+ }
340
+
341
+ /* CNN speaker-bar (name card in lower-start) */
342
+ [data-overlay-theme="cnn"] [data-role="speaker-bar"][data-role] {
343
+ border-left: 5px solid #cc0000; border-radius: 0;
344
+ background: rgba(0,0,0,0.95); padding: 14px 24px;
345
+ }
346
+ [data-overlay-theme="cnn"] [data-role="speaker-bar"][data-role] .aup-text:first-child {
347
+ font-size: 1.15rem; font-weight: 700; text-transform: uppercase;
348
+ }
349
+ [data-overlay-theme="cnn"] [data-role="speaker-bar"][data-role] .aup-text:nth-child(2) {
350
+ font-size: 0.85rem; opacity: 0.7;
351
+ }
352
+
353
+ /* CNN logo system (vertical stack in lower-end) */
354
+ [data-overlay-theme="cnn"] [data-role="logo"][data-role] {
355
+ background: #fff; padding: 8px 16px; border-radius: 0;
356
+ }
357
+
358
+ /* CNN data-widget / hashtag — compact, 0 radius */
359
+ [data-overlay-theme="cnn"] [data-role="data-widget"][data-role] {
360
+ border-radius: 0; border: none; border-left: 4px solid #cc0000;
361
+ }
362
+ [data-overlay-theme="cnn"] [data-role="hashtag"][data-role] {
363
+ border-radius: 0; font-size: 0.9rem; padding: 8px 16px;
364
+ background: rgba(0,0,0,0.8);
365
+ }
366
+
367
+ /* CNN ticker: solid black, bold white, wider padding */
368
+ [data-overlay-theme="cnn"] > [data-region="ticker"] {
369
+ background: #111; font-weight: 600; padding: 10px 16px;
370
+ }
371
+ [data-overlay-theme="cnn"] > [data-region="ticker"] .aup-ticker-separator {
372
+ opacity: 0.4; padding: 0 16px;
373
+ }
374
+
375
+ /* ══════════════════════════════════════════════════════════
376
+ Apple theme-specific overrides
377
+ ══════════════════════════════════════════════════════════ */
378
+ [data-overlay-theme="apple"] [data-role="live-badge"][data-role] {
379
+ font-weight: 500; font-size: 0.78rem; letter-spacing: 0.08em;
380
+ padding: 7px 18px;
381
+ }
382
+ [data-overlay-theme="apple"] [data-role="lower-third"][data-role] {
383
+ border-left: none; padding: 20px 32px; min-width: 320px;
384
+ background: rgba(0,0,0,0.35);
385
+ backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
386
+ border: 1px solid rgba(255,255,255,0.15);
387
+ font-size: 0.95rem; font-weight: 400;
388
+ border-radius: 16px;
389
+ }
390
+ [data-overlay-theme="apple"] [data-role="speaker-bar"][data-role] {
391
+ border-left: none; padding: 18px 28px;
392
+ background: rgba(0,0,0,0.35);
393
+ backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
394
+ border: 1px solid rgba(255,255,255,0.15);
395
+ border-radius: 16px;
396
+ }
397
+ [data-overlay-theme="apple"] [data-role="alert"][data-role] {
398
+ border-radius: 24px; font-weight: 500;
399
+ text-transform: none; letter-spacing: 0;
400
+ background: rgba(220,38,38,0.8);
401
+ backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
402
+ padding: 10px 28px;
403
+ }
404
+ [data-overlay-theme="apple"] > [data-region="ticker"] {
405
+ background: rgba(0,0,0,0.25);
406
+ backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
407
+ padding: 6px 0;
408
+ }
409
+ `;
410
+ const OVERLAY_THEMES_JS = `
411
+ // ── Overlay Theme Presets ──
412
+ var _OVERLAY_THEMES = {
413
+ minimal: {
414
+ fonts: []
415
+ },
416
+ cnn: {
417
+ fonts: ["Barlow+Condensed:wght@400;600;700"]
418
+ },
419
+ apple: {
420
+ fonts: ["Inter:wght@300;400;500;600"]
421
+ }
422
+ };
423
+
424
+ // ── Font loader (lazy, deduplicated) ──
425
+ var _overlayLoadedFonts = {};
426
+
427
+ function _isSafeOverlayFontURL(url) {
428
+ return /^https:\\/\\/fonts\\.googleapis\\.com\\/css2/.test(url);
429
+ }
430
+
431
+ function _loadOverlayFonts(fonts) {
432
+ if (!fonts || !fonts.length) return;
433
+ for (var i = 0; i < fonts.length; i++) {
434
+ var f = fonts[i];
435
+ if (_overlayLoadedFonts[f]) continue;
436
+ var url = "https://fonts.googleapis.com/css2?family=" + f + "&display=swap";
437
+ if (!_isSafeOverlayFontURL(url)) continue;
438
+ var link = document.createElement("link");
439
+ link.rel = "stylesheet";
440
+ link.href = url;
441
+ document.head.appendChild(link);
442
+ _overlayLoadedFonts[f] = true;
443
+ }
444
+ }
445
+
446
+ // ── CSS injection (once) ──
447
+ var _overlayThemeCSSInjected = false;
448
+
449
+ function _injectOverlayThemeCSS() {
450
+ if (_overlayThemeCSSInjected) return;
451
+ _overlayThemeCSSInjected = true;
452
+ var style = document.createElement("style");
453
+ style.textContent = _OVERLAY_THEMES_CSS;
454
+ document.head.appendChild(style);
455
+ }
456
+
457
+ // ── Apply overlay theme to an element ──
458
+ function _applyOverlayTheme(el, theme) {
459
+ if (!theme) return;
460
+ _injectOverlayThemeCSS();
461
+
462
+ if (typeof theme === "string") {
463
+ // Named preset
464
+ var preset = _OVERLAY_THEMES[theme];
465
+ if (!preset) return;
466
+ el.setAttribute("data-overlay-theme", theme);
467
+ _loadOverlayFonts(preset.fonts);
468
+ } else if (typeof theme === "object") {
469
+ // Custom inline theme — apply as CSS variables
470
+ el.setAttribute("data-overlay-theme", "custom");
471
+ var keyMap = {
472
+ badgeBg: "--overlay-badge-bg",
473
+ badgeColor: "--overlay-badge-color",
474
+ badgeRadius: "--overlay-badge-radius",
475
+ badgeFont: "--overlay-badge-font",
476
+ badgeSize: "--overlay-badge-size",
477
+ badgeWeight: "--overlay-badge-weight",
478
+ cardBg: "--overlay-card-bg",
479
+ cardColor: "--overlay-card-color",
480
+ cardBorder: "--overlay-card-border",
481
+ cardRadius: "--overlay-card-radius",
482
+ glassBlur: "--overlay-glass-blur",
483
+ lowerBg: "--overlay-lower-bg",
484
+ lowerColor: "--overlay-lower-color",
485
+ lowerAccent: "--overlay-lower-accent",
486
+ lowerRadius: "--overlay-lower-radius",
487
+ lowerSize: "--overlay-lower-size",
488
+ tickerBg: "--overlay-ticker-bg",
489
+ tickerColor: "--overlay-ticker-color",
490
+ tickerSize: "--overlay-ticker-size",
491
+ alertBg: "--overlay-alert-bg",
492
+ alertColor: "--overlay-alert-color",
493
+ alertSize: "--overlay-alert-size",
494
+ scoreBg: "--overlay-score-bg",
495
+ scoreColor: "--overlay-score-color",
496
+ scoreRadius: "--overlay-score-radius",
497
+ viewerBg: "--overlay-viewer-bg",
498
+ viewerColor: "--overlay-viewer-color"
499
+ };
500
+ for (var k in theme) {
501
+ if (theme.hasOwnProperty(k)) {
502
+ var cssVar = keyMap[k] || ("--overlay-" + k.replace(/([A-Z])/g, "-$1").toLowerCase());
503
+ el.style.setProperty(cssVar, theme[k]);
504
+ }
505
+ }
506
+ // Load custom fonts if provided
507
+ if (theme.fonts) _loadOverlayFonts(theme.fonts);
508
+ }
509
+ }
510
+ `;
511
+
512
+ //#endregion
513
+ exports.OVERLAY_THEMES_CSS = OVERLAY_THEMES_CSS;
514
+ exports.OVERLAY_THEMES_JS = OVERLAY_THEMES_JS;