@cognivo/components 0.8.0 → 0.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (543) hide show
  1. package/dist/chunks/focus-trap-vlQwKK-3.js +82 -0
  2. package/dist/chunks/focus-trap-vlQwKK-3.js.map +1 -0
  3. package/dist/chunks/{premium.css-9I4kHrsl.js → premium.css-DHekUEUt.js} +25 -25
  4. package/dist/chunks/{premium.css-9I4kHrsl.js.map → premium.css-DHekUEUt.js.map} +1 -1
  5. package/dist/cognivo.min.js +3375 -5270
  6. package/dist/cognivo.min.js.map +1 -1
  7. package/dist/components/ai-ab-test/ai-ab-test.js +1 -1
  8. package/dist/components/ai-accessibility-report/ai-accessibility-report.d.ts.map +1 -1
  9. package/dist/components/ai-accessibility-report/ai-accessibility-report.js +14 -13
  10. package/dist/components/ai-accessibility-report/ai-accessibility-report.js.map +1 -1
  11. package/dist/components/ai-action-preview/ai-action-preview.d.ts.map +1 -1
  12. package/dist/components/ai-action-preview/ai-action-preview.js +15 -14
  13. package/dist/components/ai-action-preview/ai-action-preview.js.map +1 -1
  14. package/dist/components/ai-agent-card/ai-agent-card.js +1 -1
  15. package/dist/components/ai-agent-steps/ai-agent-steps.d.ts +8 -21
  16. package/dist/components/ai-agent-steps/ai-agent-steps.d.ts.map +1 -1
  17. package/dist/components/ai-agent-steps/ai-agent-steps.js +85 -139
  18. package/dist/components/ai-agent-steps/ai-agent-steps.js.map +1 -1
  19. package/dist/components/ai-alert-card/ai-alert-card.js +5 -5
  20. package/dist/components/ai-alert-card/ai-alert-card.js.map +1 -1
  21. package/dist/components/ai-analytics-chart/ai-analytics-chart.d.ts +0 -13
  22. package/dist/components/ai-analytics-chart/ai-analytics-chart.d.ts.map +1 -1
  23. package/dist/components/ai-analytics-chart/ai-analytics-chart.js +75 -125
  24. package/dist/components/ai-analytics-chart/ai-analytics-chart.js.map +1 -1
  25. package/dist/components/ai-annotation/ai-annotation.js +2 -2
  26. package/dist/components/ai-annotation/ai-annotation.js.map +1 -1
  27. package/dist/components/ai-api-key-manager/ai-api-key-manager.d.ts +0 -9
  28. package/dist/components/ai-api-key-manager/ai-api-key-manager.d.ts.map +1 -1
  29. package/dist/components/ai-api-key-manager/ai-api-key-manager.js +115 -276
  30. package/dist/components/ai-api-key-manager/ai-api-key-manager.js.map +1 -1
  31. package/dist/components/ai-app-sidebar/ai-app-sidebar.js +13 -13
  32. package/dist/components/ai-app-sidebar/ai-app-sidebar.js.map +1 -1
  33. package/dist/components/ai-assistant-widget/ai-assistant-widget.d.ts.map +1 -1
  34. package/dist/components/ai-assistant-widget/ai-assistant-widget.js +5 -2
  35. package/dist/components/ai-assistant-widget/ai-assistant-widget.js.map +1 -1
  36. package/dist/components/ai-audio-player/ai-audio-player.d.ts.map +1 -1
  37. package/dist/components/ai-audio-player/ai-audio-player.js +23 -19
  38. package/dist/components/ai-audio-player/ai-audio-player.js.map +1 -1
  39. package/dist/components/ai-avatar/ai-avatar.js +1 -1
  40. package/dist/components/ai-badge/ai-badge.js +1 -1
  41. package/dist/components/ai-batch-progress/ai-batch-progress.js +6 -6
  42. package/dist/components/ai-batch-progress/ai-batch-progress.js.map +1 -1
  43. package/dist/components/ai-cache-indicator/ai-cache-indicator.d.ts +0 -13
  44. package/dist/components/ai-cache-indicator/ai-cache-indicator.d.ts.map +1 -1
  45. package/dist/components/ai-cache-indicator/ai-cache-indicator.js +90 -185
  46. package/dist/components/ai-cache-indicator/ai-cache-indicator.js.map +1 -1
  47. package/dist/components/ai-capture-flow/ai-capture-flow.js +21 -21
  48. package/dist/components/ai-capture-flow/ai-capture-flow.js.map +1 -1
  49. package/dist/components/ai-changelog/ai-changelog.js +26 -26
  50. package/dist/components/ai-changelog/ai-changelog.js.map +1 -1
  51. package/dist/components/ai-chart-summary/ai-chart-summary.d.ts +0 -6
  52. package/dist/components/ai-chart-summary/ai-chart-summary.d.ts.map +1 -1
  53. package/dist/components/ai-chart-summary/ai-chart-summary.js +100 -103
  54. package/dist/components/ai-chart-summary/ai-chart-summary.js.map +1 -1
  55. package/dist/components/ai-chat/ai-chat.d.ts.map +1 -1
  56. package/dist/components/ai-chat/ai-chat.js +9 -3
  57. package/dist/components/ai-chat/ai-chat.js.map +1 -1
  58. package/dist/components/ai-citation/ai-citation.d.ts +0 -6
  59. package/dist/components/ai-citation/ai-citation.d.ts.map +1 -1
  60. package/dist/components/ai-citation/ai-citation.js +64 -90
  61. package/dist/components/ai-citation/ai-citation.js.map +1 -1
  62. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.d.ts +1 -27
  63. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.d.ts.map +1 -1
  64. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js +114 -260
  65. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js.map +1 -1
  66. package/dist/components/ai-command-palette/ai-command-palette.js +1 -1
  67. package/dist/components/ai-confidence-badge/ai-confidence-badge.d.ts +11 -9
  68. package/dist/components/ai-confidence-badge/ai-confidence-badge.d.ts.map +1 -1
  69. package/dist/components/ai-confidence-badge/ai-confidence-badge.js +183 -101
  70. package/dist/components/ai-confidence-badge/ai-confidence-badge.js.map +1 -1
  71. package/dist/components/ai-confidence-slider/ai-confidence-slider.js +27 -27
  72. package/dist/components/ai-confidence-slider/ai-confidence-slider.js.map +1 -1
  73. package/dist/components/ai-consent-manager/ai-consent-manager.js +2 -2
  74. package/dist/components/ai-consent-manager/ai-consent-manager.js.map +1 -1
  75. package/dist/components/ai-context-window/ai-context-window.js +19 -19
  76. package/dist/components/ai-context-window/ai-context-window.js.map +1 -1
  77. package/dist/components/ai-copy-button/ai-copy-button.js +4 -4
  78. package/dist/components/ai-copy-button/ai-copy-button.js.map +1 -1
  79. package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js +14 -14
  80. package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js.map +1 -1
  81. package/dist/components/ai-data-card/ai-data-card.js +2 -2
  82. package/dist/components/ai-data-card/ai-data-card.js.map +1 -1
  83. package/dist/components/ai-data-lineage/ai-data-lineage.js +6 -6
  84. package/dist/components/ai-data-lineage/ai-data-lineage.js.map +1 -1
  85. package/dist/components/ai-data-preview/ai-data-preview.d.ts +0 -7
  86. package/dist/components/ai-data-preview/ai-data-preview.d.ts.map +1 -1
  87. package/dist/components/ai-data-preview/ai-data-preview.js +130 -267
  88. package/dist/components/ai-data-preview/ai-data-preview.js.map +1 -1
  89. package/dist/components/ai-data-table/ai-data-table.js +9 -9
  90. package/dist/components/ai-data-table/ai-data-table.js.map +1 -1
  91. package/dist/components/ai-debug-console/ai-debug-console.d.ts +1 -13
  92. package/dist/components/ai-debug-console/ai-debug-console.d.ts.map +1 -1
  93. package/dist/components/ai-debug-console/ai-debug-console.js +134 -340
  94. package/dist/components/ai-debug-console/ai-debug-console.js.map +1 -1
  95. package/dist/components/ai-detection-canvas/ai-detection-canvas.js +2 -2
  96. package/dist/components/ai-detection-canvas/ai-detection-canvas.js.map +1 -1
  97. package/dist/components/ai-diff-panel/ai-diff-panel.js +1 -1
  98. package/dist/components/ai-embedding-viz/ai-embedding-viz.js +4 -4
  99. package/dist/components/ai-embedding-viz/ai-embedding-viz.js.map +1 -1
  100. package/dist/components/ai-empty-state/ai-empty-state.js +1 -1
  101. package/dist/components/ai-error-boundary/ai-error-boundary.d.ts.map +1 -1
  102. package/dist/components/ai-error-boundary/ai-error-boundary.js +26 -21
  103. package/dist/components/ai-error-boundary/ai-error-boundary.js.map +1 -1
  104. package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js +5 -5
  105. package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js.map +1 -1
  106. package/dist/components/ai-feature-flag/ai-feature-flag.d.ts +0 -14
  107. package/dist/components/ai-feature-flag/ai-feature-flag.d.ts.map +1 -1
  108. package/dist/components/ai-feature-flag/ai-feature-flag.js +181 -322
  109. package/dist/components/ai-feature-flag/ai-feature-flag.js.map +1 -1
  110. package/dist/components/ai-feedback/ai-feedback.d.ts.map +1 -1
  111. package/dist/components/ai-feedback/ai-feedback.js +10 -5
  112. package/dist/components/ai-feedback/ai-feedback.js.map +1 -1
  113. package/dist/components/ai-file-upload/ai-file-upload.js +1 -1
  114. package/dist/components/ai-form-generator/ai-form-generator.js +1 -1
  115. package/dist/components/ai-guardrail/ai-guardrail.js +2 -2
  116. package/dist/components/ai-guardrail/ai-guardrail.js.map +1 -1
  117. package/dist/components/ai-heatmap/ai-heatmap.js +1 -1
  118. package/dist/components/ai-insight-card/ai-insight-card.js +4 -4
  119. package/dist/components/ai-insight-card/ai-insight-card.js.map +1 -1
  120. package/dist/components/ai-json-viewer/ai-json-viewer.js +13 -13
  121. package/dist/components/ai-json-viewer/ai-json-viewer.js.map +1 -1
  122. package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js +24 -24
  123. package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js.map +1 -1
  124. package/dist/components/ai-kpi-grid/ai-kpi-grid.js +2 -2
  125. package/dist/components/ai-kpi-grid/ai-kpi-grid.js.map +1 -1
  126. package/dist/components/ai-labeling-board/ai-labeling-board.js +11 -11
  127. package/dist/components/ai-labeling-board/ai-labeling-board.js.map +1 -1
  128. package/dist/components/ai-memory-panel/ai-memory-panel.js +7 -7
  129. package/dist/components/ai-memory-panel/ai-memory-panel.js.map +1 -1
  130. package/dist/components/ai-model-comparison/ai-model-comparison.js +2 -2
  131. package/dist/components/ai-model-comparison/ai-model-comparison.js.map +1 -1
  132. package/dist/components/ai-model-selector/ai-model-selector.js +7 -7
  133. package/dist/components/ai-model-selector/ai-model-selector.js.map +1 -1
  134. package/dist/components/ai-notification-center/ai-notification-center.js +27 -27
  135. package/dist/components/ai-notification-center/ai-notification-center.js.map +1 -1
  136. package/dist/components/ai-onboarding/ai-onboarding.js +5 -5
  137. package/dist/components/ai-onboarding/ai-onboarding.js.map +1 -1
  138. package/dist/components/ai-permission-gate/ai-permission-gate.js +1 -1
  139. package/dist/components/ai-personalization-dash/ai-personalization-dash.js +1 -1
  140. package/dist/components/ai-presence/ai-presence.js +25 -25
  141. package/dist/components/ai-presence/ai-presence.js.map +1 -1
  142. package/dist/components/ai-progress-steps/ai-progress-steps.js +11 -11
  143. package/dist/components/ai-progress-steps/ai-progress-steps.js.map +1 -1
  144. package/dist/components/ai-prompt-editor/ai-prompt-editor.js +1 -1
  145. package/dist/components/ai-prompt-template/ai-prompt-template.js +29 -29
  146. package/dist/components/ai-prompt-template/ai-prompt-template.js.map +1 -1
  147. package/dist/components/ai-rag-panel/ai-rag-panel.js +4 -4
  148. package/dist/components/ai-rag-panel/ai-rag-panel.js.map +1 -1
  149. package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js +16 -16
  150. package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js.map +1 -1
  151. package/dist/components/ai-result-panel/ai-result-panel.js +1 -1
  152. package/dist/components/ai-reveal-animation/ai-reveal-animation.js +3 -3
  153. package/dist/components/ai-reveal-animation/ai-reveal-animation.js.map +1 -1
  154. package/dist/components/ai-reward-signal/ai-reward-signal.js +1 -1
  155. package/dist/components/ai-rich-message/ai-rich-message.d.ts.map +1 -1
  156. package/dist/components/ai-rich-message/ai-rich-message.js +37 -30
  157. package/dist/components/ai-rich-message/ai-rich-message.js.map +1 -1
  158. package/dist/components/ai-scenario-panel/ai-scenario-panel.js +10 -10
  159. package/dist/components/ai-scenario-panel/ai-scenario-panel.js.map +1 -1
  160. package/dist/components/ai-search/ai-search.js +1 -1
  161. package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js +3 -3
  162. package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js.map +1 -1
  163. package/dist/components/ai-sidebar/ai-sidebar.js +1 -1
  164. package/dist/components/ai-similarity-card/ai-similarity-card.js +1 -1
  165. package/dist/components/ai-source-graph/ai-source-graph.js +2 -2
  166. package/dist/components/ai-source-graph/ai-source-graph.js.map +1 -1
  167. package/dist/components/ai-status-page/ai-status-page.js +15 -15
  168. package/dist/components/ai-status-page/ai-status-page.js.map +1 -1
  169. package/dist/components/ai-streaming-text/ai-streaming-text.js +1 -1
  170. package/dist/components/ai-test-runner/ai-test-runner.d.ts +0 -8
  171. package/dist/components/ai-test-runner/ai-test-runner.d.ts.map +1 -1
  172. package/dist/components/ai-test-runner/ai-test-runner.js +100 -257
  173. package/dist/components/ai-test-runner/ai-test-runner.js.map +1 -1
  174. package/dist/components/ai-thinking/ai-thinking.js +1 -1
  175. package/dist/components/ai-timeline/ai-timeline.js +2 -2
  176. package/dist/components/ai-timeline/ai-timeline.js.map +1 -1
  177. package/dist/components/ai-token-tracker/ai-token-tracker.js +3 -3
  178. package/dist/components/ai-token-tracker/ai-token-tracker.js.map +1 -1
  179. package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js +23 -23
  180. package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js.map +1 -1
  181. package/dist/components/ai-tool-indicator/ai-tool-indicator.js +3 -3
  182. package/dist/components/ai-tool-indicator/ai-tool-indicator.js.map +1 -1
  183. package/dist/components/ai-transform-slider/ai-transform-slider.js +1 -1
  184. package/dist/components/ai-translation-panel/ai-translation-panel.js +2 -2
  185. package/dist/components/ai-translation-panel/ai-translation-panel.js.map +1 -1
  186. package/dist/components/ai-usage-meter/ai-usage-meter.js +1 -1
  187. package/dist/components/ai-validation-checklist/ai-validation-checklist.d.ts +1 -11
  188. package/dist/components/ai-validation-checklist/ai-validation-checklist.d.ts.map +1 -1
  189. package/dist/components/ai-validation-checklist/ai-validation-checklist.js +133 -187
  190. package/dist/components/ai-validation-checklist/ai-validation-checklist.js.map +1 -1
  191. package/dist/components/ai-version-selector/ai-version-selector.d.ts +0 -4
  192. package/dist/components/ai-version-selector/ai-version-selector.d.ts.map +1 -1
  193. package/dist/components/ai-version-selector/ai-version-selector.js +189 -210
  194. package/dist/components/ai-version-selector/ai-version-selector.js.map +1 -1
  195. package/dist/components/ai-voice-panel/ai-voice-panel.js +28 -28
  196. package/dist/components/ai-voice-panel/ai-voice-panel.js.map +1 -1
  197. package/dist/components/ai-webhook-config/ai-webhook-config.d.ts +0 -17
  198. package/dist/components/ai-webhook-config/ai-webhook-config.d.ts.map +1 -1
  199. package/dist/components/ai-webhook-config/ai-webhook-config.js +281 -221
  200. package/dist/components/ai-webhook-config/ai-webhook-config.js.map +1 -1
  201. package/dist/components/ai-workflow-builder/ai-workflow-builder.js +2 -2
  202. package/dist/components/ai-workflow-builder/ai-workflow-builder.js.map +1 -1
  203. package/dist/components/bias-anchoring/bias-anchoring.js +1 -1
  204. package/dist/components/bias-authority/bias-authority.js +1 -1
  205. package/dist/components/bias-commitment/bias-commitment.js +1 -1
  206. package/dist/components/bias-reciprocity/bias-reciprocity.js +1 -1
  207. package/dist/components/bias-scarcity/bias-scarcity.js +1 -1
  208. package/dist/components/bias-social-proof/bias-social-proof.js +1 -1
  209. package/dist/components/cg-accordion/cg-accordion.d.ts.map +1 -1
  210. package/dist/components/cg-accordion/cg-accordion.js +51 -43
  211. package/dist/components/cg-accordion/cg-accordion.js.map +1 -1
  212. package/dist/components/cg-alert-dialog/cg-alert-dialog.js +18 -18
  213. package/dist/components/cg-alert-dialog/cg-alert-dialog.js.map +1 -1
  214. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.d.ts.map +1 -1
  215. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js +25 -21
  216. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js.map +1 -1
  217. package/dist/components/cg-autocomplete/cg-autocomplete.d.ts +1 -0
  218. package/dist/components/cg-autocomplete/cg-autocomplete.d.ts.map +1 -1
  219. package/dist/components/cg-autocomplete/cg-autocomplete.js +59 -43
  220. package/dist/components/cg-autocomplete/cg-autocomplete.js.map +1 -1
  221. package/dist/components/cg-avatar/cg-avatar.d.ts.map +1 -1
  222. package/dist/components/cg-avatar/cg-avatar.js +24 -24
  223. package/dist/components/cg-avatar/cg-avatar.js.map +1 -1
  224. package/dist/components/cg-avatar-group/cg-avatar-group.d.ts.map +1 -1
  225. package/dist/components/cg-avatar-group/cg-avatar-group.js +18 -12
  226. package/dist/components/cg-avatar-group/cg-avatar-group.js.map +1 -1
  227. package/dist/components/cg-badge/cg-badge.d.ts.map +1 -1
  228. package/dist/components/cg-badge/cg-badge.js +26 -20
  229. package/dist/components/cg-badge/cg-badge.js.map +1 -1
  230. package/dist/components/cg-badge-group/cg-badge-group.d.ts +0 -1
  231. package/dist/components/cg-badge-group/cg-badge-group.d.ts.map +1 -1
  232. package/dist/components/cg-badge-group/cg-badge-group.js +31 -29
  233. package/dist/components/cg-badge-group/cg-badge-group.js.map +1 -1
  234. package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js +21 -21
  235. package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js.map +1 -1
  236. package/dist/components/cg-button/cg-button.d.ts +5 -71
  237. package/dist/components/cg-button/cg-button.d.ts.map +1 -1
  238. package/dist/components/cg-button/cg-button.js +63 -172
  239. package/dist/components/cg-button/cg-button.js.map +1 -1
  240. package/dist/components/cg-button-group/cg-button-group.d.ts +2 -0
  241. package/dist/components/cg-button-group/cg-button-group.d.ts.map +1 -1
  242. package/dist/components/cg-button-group/cg-button-group.js +43 -29
  243. package/dist/components/cg-button-group/cg-button-group.js.map +1 -1
  244. package/dist/components/cg-calendar/cg-calendar.d.ts +4 -0
  245. package/dist/components/cg-calendar/cg-calendar.d.ts.map +1 -1
  246. package/dist/components/cg-calendar/cg-calendar.js +28 -12
  247. package/dist/components/cg-calendar/cg-calendar.js.map +1 -1
  248. package/dist/components/cg-callout/cg-callout.d.ts.map +1 -1
  249. package/dist/components/cg-callout/cg-callout.js +49 -48
  250. package/dist/components/cg-callout/cg-callout.js.map +1 -1
  251. package/dist/components/cg-card/cg-card.d.ts +9 -22
  252. package/dist/components/cg-card/cg-card.d.ts.map +1 -1
  253. package/dist/components/cg-card/cg-card.js +28 -56
  254. package/dist/components/cg-card/cg-card.js.map +1 -1
  255. package/dist/components/cg-carousel/cg-carousel.d.ts.map +1 -1
  256. package/dist/components/cg-carousel/cg-carousel.js +19 -13
  257. package/dist/components/cg-carousel/cg-carousel.js.map +1 -1
  258. package/dist/components/cg-chart/cg-chart.d.ts.map +1 -1
  259. package/dist/components/cg-chart/cg-chart.js +63 -58
  260. package/dist/components/cg-chart/cg-chart.js.map +1 -1
  261. package/dist/components/cg-checkbox/cg-checkbox.d.ts +0 -6
  262. package/dist/components/cg-checkbox/cg-checkbox.d.ts.map +1 -1
  263. package/dist/components/cg-checkbox/cg-checkbox.js +51 -51
  264. package/dist/components/cg-checkbox/cg-checkbox.js.map +1 -1
  265. package/dist/components/cg-chip/cg-chip.js +31 -31
  266. package/dist/components/cg-chip/cg-chip.js.map +1 -1
  267. package/dist/components/cg-code-block/cg-code-block.d.ts.map +1 -1
  268. package/dist/components/cg-code-block/cg-code-block.js +36 -34
  269. package/dist/components/cg-code-block/cg-code-block.js.map +1 -1
  270. package/dist/components/cg-collapsible/cg-collapsible.d.ts.map +1 -1
  271. package/dist/components/cg-collapsible/cg-collapsible.js +23 -18
  272. package/dist/components/cg-collapsible/cg-collapsible.js.map +1 -1
  273. package/dist/components/cg-color-picker/cg-color-picker.d.ts +3 -0
  274. package/dist/components/cg-color-picker/cg-color-picker.d.ts.map +1 -1
  275. package/dist/components/cg-color-picker/cg-color-picker.js +189 -91
  276. package/dist/components/cg-color-picker/cg-color-picker.js.map +1 -1
  277. package/dist/components/cg-combobox/cg-combobox.d.ts.map +1 -1
  278. package/dist/components/cg-combobox/cg-combobox.js +13 -6
  279. package/dist/components/cg-combobox/cg-combobox.js.map +1 -1
  280. package/dist/components/cg-command/cg-command.d.ts.map +1 -1
  281. package/dist/components/cg-command/cg-command.js +52 -45
  282. package/dist/components/cg-command/cg-command.js.map +1 -1
  283. package/dist/components/cg-context-menu/cg-context-menu.js +1 -1
  284. package/dist/components/cg-date-picker/cg-date-picker.d.ts.map +1 -1
  285. package/dist/components/cg-date-picker/cg-date-picker.js +36 -34
  286. package/dist/components/cg-date-picker/cg-date-picker.js.map +1 -1
  287. package/dist/components/cg-date-range-picker/cg-date-range-picker.d.ts +2 -0
  288. package/dist/components/cg-date-range-picker/cg-date-range-picker.d.ts.map +1 -1
  289. package/dist/components/cg-date-range-picker/cg-date-range-picker.js +12 -8
  290. package/dist/components/cg-date-range-picker/cg-date-range-picker.js.map +1 -1
  291. package/dist/components/cg-date-time-picker/cg-date-time-picker.d.ts.map +1 -1
  292. package/dist/components/cg-date-time-picker/cg-date-time-picker.js +3 -1
  293. package/dist/components/cg-date-time-picker/cg-date-time-picker.js.map +1 -1
  294. package/dist/components/cg-drawer/cg-drawer.js +3 -3
  295. package/dist/components/cg-drawer/cg-drawer.js.map +1 -1
  296. package/dist/components/cg-dropdown/cg-dropdown.d.ts.map +1 -1
  297. package/dist/components/cg-dropdown/cg-dropdown.js +1 -2
  298. package/dist/components/cg-dropdown/cg-dropdown.js.map +1 -1
  299. package/dist/components/cg-empty-state/cg-empty-state.d.ts +3 -24
  300. package/dist/components/cg-empty-state/cg-empty-state.d.ts.map +1 -1
  301. package/dist/components/cg-empty-state/cg-empty-state.js +51 -74
  302. package/dist/components/cg-empty-state/cg-empty-state.js.map +1 -1
  303. package/dist/components/cg-file-input/cg-file-input.d.ts.map +1 -1
  304. package/dist/components/cg-file-input/cg-file-input.js +9 -10
  305. package/dist/components/cg-file-input/cg-file-input.js.map +1 -1
  306. package/dist/components/cg-focus-scope/cg-focus-scope.js +1 -1
  307. package/dist/components/cg-follow-up/cg-follow-up.d.ts.map +1 -1
  308. package/dist/components/cg-follow-up/cg-follow-up.js +6 -7
  309. package/dist/components/cg-follow-up/cg-follow-up.js.map +1 -1
  310. package/dist/components/cg-form/cg-form.js +17 -17
  311. package/dist/components/cg-form/cg-form.js.map +1 -1
  312. package/dist/components/cg-hover-card/cg-hover-card.d.ts +1 -0
  313. package/dist/components/cg-hover-card/cg-hover-card.d.ts.map +1 -1
  314. package/dist/components/cg-hover-card/cg-hover-card.js +37 -32
  315. package/dist/components/cg-hover-card/cg-hover-card.js.map +1 -1
  316. package/dist/components/cg-icon/cg-icon.d.ts.map +1 -1
  317. package/dist/components/cg-icon/cg-icon.js +44 -37
  318. package/dist/components/cg-icon/cg-icon.js.map +1 -1
  319. package/dist/components/cg-image/cg-image.js +2 -2
  320. package/dist/components/cg-image/cg-image.js.map +1 -1
  321. package/dist/components/cg-image-block/cg-image-block.js +3 -3
  322. package/dist/components/cg-image-block/cg-image-block.js.map +1 -1
  323. package/dist/components/cg-image-gallery/cg-image-gallery.js +20 -20
  324. package/dist/components/cg-image-gallery/cg-image-gallery.js.map +1 -1
  325. package/dist/components/cg-input/cg-input.js +3 -3
  326. package/dist/components/cg-input/cg-input.js.map +1 -1
  327. package/dist/components/cg-kbd/cg-kbd.d.ts.map +1 -1
  328. package/dist/components/cg-kbd/cg-kbd.js +26 -24
  329. package/dist/components/cg-kbd/cg-kbd.js.map +1 -1
  330. package/dist/components/cg-label/cg-label.d.ts +4 -1
  331. package/dist/components/cg-label/cg-label.d.ts.map +1 -1
  332. package/dist/components/cg-label/cg-label.js +44 -41
  333. package/dist/components/cg-label/cg-label.js.map +1 -1
  334. package/dist/components/cg-link/cg-link.js +23 -23
  335. package/dist/components/cg-link/cg-link.js.map +1 -1
  336. package/dist/components/cg-list/cg-list.js +5 -5
  337. package/dist/components/cg-list/cg-list.js.map +1 -1
  338. package/dist/components/cg-listbox/cg-listbox.d.ts.map +1 -1
  339. package/dist/components/cg-listbox/cg-listbox.js +46 -40
  340. package/dist/components/cg-listbox/cg-listbox.js.map +1 -1
  341. package/dist/components/cg-markdown/cg-markdown.d.ts +2 -0
  342. package/dist/components/cg-markdown/cg-markdown.d.ts.map +1 -1
  343. package/dist/components/cg-markdown/cg-markdown.js +171 -121
  344. package/dist/components/cg-markdown/cg-markdown.js.map +1 -1
  345. package/dist/components/cg-menubar/cg-menubar.d.ts +6 -0
  346. package/dist/components/cg-menubar/cg-menubar.d.ts.map +1 -1
  347. package/dist/components/cg-menubar/cg-menubar.js +59 -47
  348. package/dist/components/cg-menubar/cg-menubar.js.map +1 -1
  349. package/dist/components/cg-meter/cg-meter.d.ts.map +1 -1
  350. package/dist/components/cg-meter/cg-meter.js +76 -76
  351. package/dist/components/cg-meter/cg-meter.js.map +1 -1
  352. package/dist/components/cg-metric-card/cg-metric-card.d.ts.map +1 -1
  353. package/dist/components/cg-metric-card/cg-metric-card.js +65 -68
  354. package/dist/components/cg-metric-card/cg-metric-card.js.map +1 -1
  355. package/dist/components/cg-modal/cg-modal.d.ts +3 -0
  356. package/dist/components/cg-modal/cg-modal.d.ts.map +1 -1
  357. package/dist/components/cg-modal/cg-modal.js +82 -83
  358. package/dist/components/cg-modal/cg-modal.js.map +1 -1
  359. package/dist/components/cg-navbar/cg-navbar.d.ts +1 -1
  360. package/dist/components/cg-navbar/cg-navbar.d.ts.map +1 -1
  361. package/dist/components/cg-navbar/cg-navbar.js +64 -55
  362. package/dist/components/cg-navbar/cg-navbar.js.map +1 -1
  363. package/dist/components/cg-navigation-menu/cg-navigation-menu.d.ts +3 -0
  364. package/dist/components/cg-navigation-menu/cg-navigation-menu.d.ts.map +1 -1
  365. package/dist/components/cg-navigation-menu/cg-navigation-menu.js +38 -26
  366. package/dist/components/cg-navigation-menu/cg-navigation-menu.js.map +1 -1
  367. package/dist/components/cg-number-input/cg-number-input.d.ts +1 -0
  368. package/dist/components/cg-number-input/cg-number-input.d.ts.map +1 -1
  369. package/dist/components/cg-number-input/cg-number-input.js +90 -77
  370. package/dist/components/cg-number-input/cg-number-input.js.map +1 -1
  371. package/dist/components/cg-otp-input/cg-otp-input.d.ts.map +1 -1
  372. package/dist/components/cg-otp-input/cg-otp-input.js +70 -60
  373. package/dist/components/cg-otp-input/cg-otp-input.js.map +1 -1
  374. package/dist/components/cg-pagination/cg-pagination.d.ts +2 -0
  375. package/dist/components/cg-pagination/cg-pagination.d.ts.map +1 -1
  376. package/dist/components/cg-pagination/cg-pagination.js +50 -49
  377. package/dist/components/cg-pagination/cg-pagination.js.map +1 -1
  378. package/dist/components/cg-password-input/cg-password-input.d.ts.map +1 -1
  379. package/dist/components/cg-password-input/cg-password-input.js +42 -34
  380. package/dist/components/cg-password-input/cg-password-input.js.map +1 -1
  381. package/dist/components/cg-phone-input/cg-phone-input.d.ts.map +1 -1
  382. package/dist/components/cg-phone-input/cg-phone-input.js +18 -14
  383. package/dist/components/cg-phone-input/cg-phone-input.js.map +1 -1
  384. package/dist/components/cg-popover/cg-popover.d.ts +12 -2
  385. package/dist/components/cg-popover/cg-popover.d.ts.map +1 -1
  386. package/dist/components/cg-popover/cg-popover.js +90 -63
  387. package/dist/components/cg-popover/cg-popover.js.map +1 -1
  388. package/dist/components/cg-portal/cg-portal.d.ts.map +1 -1
  389. package/dist/components/cg-portal/cg-portal.js +42 -41
  390. package/dist/components/cg-portal/cg-portal.js.map +1 -1
  391. package/dist/components/cg-progress-bar/cg-progress-bar.d.ts.map +1 -1
  392. package/dist/components/cg-progress-bar/cg-progress-bar.js +25 -25
  393. package/dist/components/cg-progress-bar/cg-progress-bar.js.map +1 -1
  394. package/dist/components/cg-radio/cg-radio.d.ts +10 -0
  395. package/dist/components/cg-radio/cg-radio.d.ts.map +1 -1
  396. package/dist/components/cg-radio/cg-radio.js +59 -48
  397. package/dist/components/cg-radio/cg-radio.js.map +1 -1
  398. package/dist/components/cg-radio-group/cg-radio-group.d.ts +6 -0
  399. package/dist/components/cg-radio-group/cg-radio-group.d.ts.map +1 -1
  400. package/dist/components/cg-radio-group/cg-radio-group.js +50 -37
  401. package/dist/components/cg-radio-group/cg-radio-group.js.map +1 -1
  402. package/dist/components/cg-rating/cg-rating.d.ts.map +1 -1
  403. package/dist/components/cg-rating/cg-rating.js +56 -54
  404. package/dist/components/cg-rating/cg-rating.js.map +1 -1
  405. package/dist/components/cg-resizable/cg-resizable.d.ts +4 -1
  406. package/dist/components/cg-resizable/cg-resizable.d.ts.map +1 -1
  407. package/dist/components/cg-resizable/cg-resizable.js +45 -35
  408. package/dist/components/cg-resizable/cg-resizable.js.map +1 -1
  409. package/dist/components/cg-scroll-area/cg-scroll-area.d.ts +8 -0
  410. package/dist/components/cg-scroll-area/cg-scroll-area.d.ts.map +1 -1
  411. package/dist/components/cg-scroll-area/cg-scroll-area.js +64 -21
  412. package/dist/components/cg-scroll-area/cg-scroll-area.js.map +1 -1
  413. package/dist/components/cg-segmented-control/cg-segmented-control.d.ts +4 -0
  414. package/dist/components/cg-segmented-control/cg-segmented-control.d.ts.map +1 -1
  415. package/dist/components/cg-segmented-control/cg-segmented-control.js +75 -39
  416. package/dist/components/cg-segmented-control/cg-segmented-control.js.map +1 -1
  417. package/dist/components/cg-select/cg-select.d.ts +4 -2
  418. package/dist/components/cg-select/cg-select.d.ts.map +1 -1
  419. package/dist/components/cg-select/cg-select.js +96 -58
  420. package/dist/components/cg-select/cg-select.js.map +1 -1
  421. package/dist/components/cg-separator/cg-separator.d.ts +1 -2
  422. package/dist/components/cg-separator/cg-separator.d.ts.map +1 -1
  423. package/dist/components/cg-separator/cg-separator.js +5 -8
  424. package/dist/components/cg-separator/cg-separator.js.map +1 -1
  425. package/dist/components/cg-sheet/cg-sheet.d.ts +4 -0
  426. package/dist/components/cg-sheet/cg-sheet.d.ts.map +1 -1
  427. package/dist/components/cg-sheet/cg-sheet.js +80 -43
  428. package/dist/components/cg-sheet/cg-sheet.js.map +1 -1
  429. package/dist/components/cg-sidebar/cg-sidebar.d.ts.map +1 -1
  430. package/dist/components/cg-sidebar/cg-sidebar.js +82 -19
  431. package/dist/components/cg-sidebar/cg-sidebar.js.map +1 -1
  432. package/dist/components/cg-skeleton/cg-skeleton.d.ts +7 -1
  433. package/dist/components/cg-skeleton/cg-skeleton.d.ts.map +1 -1
  434. package/dist/components/cg-skeleton/cg-skeleton.js +61 -63
  435. package/dist/components/cg-skeleton/cg-skeleton.js.map +1 -1
  436. package/dist/components/cg-slider/cg-slider.d.ts.map +1 -1
  437. package/dist/components/cg-slider/cg-slider.js +80 -73
  438. package/dist/components/cg-slider/cg-slider.js.map +1 -1
  439. package/dist/components/cg-spinner/cg-spinner.d.ts.map +1 -1
  440. package/dist/components/cg-spinner/cg-spinner.js +10 -19
  441. package/dist/components/cg-spinner/cg-spinner.js.map +1 -1
  442. package/dist/components/cg-split-button/cg-split-button.d.ts.map +1 -1
  443. package/dist/components/cg-split-button/cg-split-button.js +64 -50
  444. package/dist/components/cg-split-button/cg-split-button.js.map +1 -1
  445. package/dist/components/cg-stack/cg-stack.js +1 -1
  446. package/dist/components/cg-steps/cg-steps.js +1 -1
  447. package/dist/components/cg-switch/cg-switch.d.ts +3 -0
  448. package/dist/components/cg-switch/cg-switch.d.ts.map +1 -1
  449. package/dist/components/cg-switch/cg-switch.js +39 -47
  450. package/dist/components/cg-switch/cg-switch.js.map +1 -1
  451. package/dist/components/cg-table/cg-table.d.ts +0 -7
  452. package/dist/components/cg-table/cg-table.d.ts.map +1 -1
  453. package/dist/components/cg-table/cg-table.js +50 -47
  454. package/dist/components/cg-table/cg-table.js.map +1 -1
  455. package/dist/components/cg-tabs/cg-tabs.js +1 -1
  456. package/dist/components/cg-tag-input/cg-tag-input.js +1 -1
  457. package/dist/components/cg-text/cg-text.js +1 -1
  458. package/dist/components/cg-textarea/cg-textarea.js +1 -1
  459. package/dist/components/cg-time-picker/cg-time-picker.js +1 -1
  460. package/dist/components/cg-toaster/cg-toaster.js +3 -3
  461. package/dist/components/cg-toaster/cg-toaster.js.map +1 -1
  462. package/dist/components/cg-toggle/cg-toggle.js +1 -1
  463. package/dist/components/cg-toggle-group/cg-toggle-group.js +1 -1
  464. package/dist/components/cg-tree-view/cg-tree-view.js +1 -1
  465. package/dist/foundation.d.ts +0 -16
  466. package/dist/foundation.d.ts.map +1 -1
  467. package/dist/foundation.js +174 -206
  468. package/dist/foundation.js.map +1 -1
  469. package/dist/index.d.ts +1 -17
  470. package/dist/index.d.ts.map +1 -1
  471. package/dist/index.js +100 -132
  472. package/dist/index.js.map +1 -1
  473. package/dist/utils/focus-trap.d.ts +19 -2
  474. package/dist/utils/focus-trap.d.ts.map +1 -1
  475. package/package.json +6 -810
  476. package/dist/chunks/focus-trap-BdRNhSPD.js +0 -53
  477. package/dist/chunks/focus-trap-BdRNhSPD.js.map +0 -1
  478. package/dist/components/cg-app-shell/cg-app-shell.d.ts +0 -54
  479. package/dist/components/cg-app-shell/cg-app-shell.d.ts.map +0 -1
  480. package/dist/components/cg-app-shell/cg-app-shell.js +0 -135
  481. package/dist/components/cg-app-shell/cg-app-shell.js.map +0 -1
  482. package/dist/components/cg-auth-shell/cg-auth-shell.d.ts +0 -61
  483. package/dist/components/cg-auth-shell/cg-auth-shell.d.ts.map +0 -1
  484. package/dist/components/cg-auth-shell/cg-auth-shell.js +0 -163
  485. package/dist/components/cg-auth-shell/cg-auth-shell.js.map +0 -1
  486. package/dist/components/cg-definition-list/cg-definition-list.d.ts +0 -99
  487. package/dist/components/cg-definition-list/cg-definition-list.d.ts.map +0 -1
  488. package/dist/components/cg-definition-list/cg-definition-list.js +0 -332
  489. package/dist/components/cg-definition-list/cg-definition-list.js.map +0 -1
  490. package/dist/components/cg-draggable/cg-draggable.d.ts +0 -53
  491. package/dist/components/cg-draggable/cg-draggable.d.ts.map +0 -1
  492. package/dist/components/cg-draggable/cg-draggable.js +0 -136
  493. package/dist/components/cg-draggable/cg-draggable.js.map +0 -1
  494. package/dist/components/cg-droppable/cg-droppable.d.ts +0 -57
  495. package/dist/components/cg-droppable/cg-droppable.d.ts.map +0 -1
  496. package/dist/components/cg-droppable/cg-droppable.js +0 -114
  497. package/dist/components/cg-droppable/cg-droppable.js.map +0 -1
  498. package/dist/components/cg-filter-bar/cg-filter-bar.d.ts +0 -50
  499. package/dist/components/cg-filter-bar/cg-filter-bar.d.ts.map +0 -1
  500. package/dist/components/cg-filter-bar/cg-filter-bar.js +0 -115
  501. package/dist/components/cg-filter-bar/cg-filter-bar.js.map +0 -1
  502. package/dist/components/cg-filter-chip/cg-filter-chip.d.ts +0 -55
  503. package/dist/components/cg-filter-chip/cg-filter-chip.d.ts.map +0 -1
  504. package/dist/components/cg-filter-chip/cg-filter-chip.js +0 -213
  505. package/dist/components/cg-filter-chip/cg-filter-chip.js.map +0 -1
  506. package/dist/components/cg-kanban/cg-kanban.d.ts +0 -44
  507. package/dist/components/cg-kanban/cg-kanban.d.ts.map +0 -1
  508. package/dist/components/cg-kanban/cg-kanban.js +0 -86
  509. package/dist/components/cg-kanban/cg-kanban.js.map +0 -1
  510. package/dist/components/cg-kanban-column/cg-kanban-column.d.ts +0 -58
  511. package/dist/components/cg-kanban-column/cg-kanban-column.d.ts.map +0 -1
  512. package/dist/components/cg-kanban-column/cg-kanban-column.js +0 -144
  513. package/dist/components/cg-kanban-column/cg-kanban-column.js.map +0 -1
  514. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.d.ts +0 -77
  515. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.d.ts.map +0 -1
  516. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.js +0 -245
  517. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.js.map +0 -1
  518. package/dist/components/cg-search-input/cg-search-input.d.ts +0 -62
  519. package/dist/components/cg-search-input/cg-search-input.d.ts.map +0 -1
  520. package/dist/components/cg-search-input/cg-search-input.js +0 -106
  521. package/dist/components/cg-search-input/cg-search-input.js.map +0 -1
  522. package/dist/components/cg-sortable/cg-sortable.d.ts +0 -72
  523. package/dist/components/cg-sortable/cg-sortable.d.ts.map +0 -1
  524. package/dist/components/cg-sortable/cg-sortable.js +0 -177
  525. package/dist/components/cg-sortable/cg-sortable.js.map +0 -1
  526. package/dist/components/cg-theme/cg-theme.d.ts +0 -82
  527. package/dist/components/cg-theme/cg-theme.d.ts.map +0 -1
  528. package/dist/components/cg-theme/cg-theme.js +0 -91
  529. package/dist/components/cg-theme/cg-theme.js.map +0 -1
  530. package/dist/components/cg-theme-editor/cg-theme-editor.d.ts +0 -98
  531. package/dist/components/cg-theme-editor/cg-theme-editor.d.ts.map +0 -1
  532. package/dist/components/cg-theme-editor/cg-theme-editor.js +0 -341
  533. package/dist/components/cg-theme-editor/cg-theme-editor.js.map +0 -1
  534. package/dist/components/cg-timeline/cg-timeline.d.ts +0 -70
  535. package/dist/components/cg-timeline/cg-timeline.d.ts.map +0 -1
  536. package/dist/components/cg-timeline/cg-timeline.js +0 -131
  537. package/dist/components/cg-timeline/cg-timeline.js.map +0 -1
  538. package/dist/components/cg-timeline-event/cg-timeline-event.d.ts +0 -59
  539. package/dist/components/cg-timeline-event/cg-timeline-event.d.ts.map +0 -1
  540. package/dist/components/cg-timeline-event/cg-timeline-event.js +0 -190
  541. package/dist/components/cg-timeline-event/cg-timeline-event.js.map +0 -1
  542. package/dist/utils/drag-manager.d.ts +0 -40
  543. package/dist/utils/drag-manager.d.ts.map +0 -1
@@ -1,6 +1,6 @@
1
1
  import { css as v, LitElement as h, html as s, nothing as g } from "lit";
2
2
  import { property as l, state as b, customElement as f } from "lit/decorators.js";
3
- import { h as m, r as y, f as k } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as m, r as y, f as k } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  import "../cg-card/cg-card.js";
5
5
  import "../cg-text/cg-text.js";
6
6
  import "../cg-button/cg-button.js";
@@ -180,7 +180,7 @@ c.styles = [m, y, k, v`
180
180
  .dismiss-btn:active { transform: scale(var(--cg-interaction-press-scale)); }
181
181
  .dismiss-btn:focus-visible {
182
182
  outline: none;
183
- box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
183
+ box-shadow: 0 0 0 3px var(--cg-color-focus-ring);
184
184
  }
185
185
 
186
186
  /* ── Progress: numbered ── */
@@ -210,7 +210,7 @@ c.styles = [m, y, k, v`
210
210
  }
211
211
  .dot.completed {
212
212
  background: var(--cg-color-action-primary-background-default);
213
- opacity: 0.5;
213
+ opacity: var(--cg-opacity-50);
214
214
  cursor: pointer;
215
215
  }
216
216
  .dot.completed:hover { opacity: 0.85; }
@@ -221,7 +221,7 @@ c.styles = [m, y, k, v`
221
221
  }
222
222
  .dot:focus-visible {
223
223
  outline: none;
224
- box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
224
+ box-shadow: 0 0 0 3px var(--cg-color-focus-ring);
225
225
  }
226
226
 
227
227
  /* ── Progress: bar ── */
@@ -284,7 +284,7 @@ c.styles = [m, y, k, v`
284
284
  }
285
285
  .stepper-node:focus-visible {
286
286
  outline: none;
287
- box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
287
+ box-shadow: 0 0 0 3px var(--cg-color-focus-ring);
288
288
  }
289
289
  .stepper-line {
290
290
  flex: 1;
@@ -1 +1 @@
1
- {"version":3,"file":"ai-onboarding.js","sources":["../../../src/components/ai-onboarding/ai-onboarding.ts"],"sourcesContent":["/**\n * @element ai-onboarding\n * Step-by-step onboarding card built entirely from design-system primitives\n * (cg-card, cg-text, cg-button, cg-stack). Progress affordance is configurable\n * via the `progress` attribute: numbered | dots | bar | stepper.\n *\n * @example\n * ```html\n * <ai-onboarding\n * progress=\"bar\"\n * .steps=${[\n * { title: 'Welcome', description: 'Let us show you around.' },\n * { title: 'Ask anything', description: 'Type a question to get started.' }\n * ]}\n * active=\"0\"\n * dismissible\n * ></ai-onboarding>\n * ```\n *\n * @prop {OnboardingStep[]} steps - Array of step objects with title and description\n * @prop {number} active - Index of the current step (default 0)\n * @prop {boolean} dismissible - Show dismiss button (default true)\n * @prop {'numbered'|'dots'|'bar'|'stepper'} progress - Progress style (default auto-picks by step count)\n *\n * @slot media - Optional media (illustration, Lottie, video) shown above the title\n * @slot step-action - Optional per-step CTA (e.g., \"Try it\") rendered below description\n *\n * @fires {CustomEvent<{step: number}>} ai-onboarding-next - When Next is clicked\n * @fires {CustomEvent<{step: number}>} ai-onboarding-prev - When Back is clicked\n * @fires {CustomEvent<{from: number, to: number}>} ai-onboarding-step-change - Any step change\n * @fires ai-onboarding-complete - When Done is clicked on the last step\n * @fires {CustomEvent<{step: number}>} ai-onboarding-dismiss - When dismissed\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\nimport '../cg-card/cg-card.js';\nimport '../cg-text/cg-text.js';\nimport '../cg-button/cg-button.js';\nimport '../cg-stack/cg-stack.js';\n\nexport interface OnboardingStep {\n title: string;\n description: string;\n target?: string;\n}\n\ntype ProgressVariant = 'numbered' | 'dots' | 'bar' | 'stepper';\n\n@customElement('ai-onboarding')\nexport class AiOnboarding extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n display: block;\n max-width: 440px;\n }\n :host([hidden]) { display: none; }\n\n cg-card { display: block; }\n\n /* ── Header row (progress + dismiss) ── */\n .header-row {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n width: 100%;\n }\n .header-progress { flex: 1; min-width: 0; }\n\n .dismiss-btn {\n flex-shrink: 0;\n background: none;\n border: none;\n color: var(--cg-color-surface-container-outlined);\n cursor: pointer;\n padding: var(--cg-spacing-4);\n line-height: 1;\n border-radius: var(--cg-border-radius-50);\n display: inline-flex;\n align-items: center;\n justify-content: center;\n transition:\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .dismiss-btn:hover {\n color: var(--cg-color-surface-base-text);\n background: var(--cg-color-action-secondary-background-hover);\n }\n .dismiss-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .dismiss-btn:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n /* ── Progress: numbered ── */\n .progress-numbered {\n text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wide);\n }\n\n /* ── Progress: dots ── */\n .progress-dots {\n display: flex;\n gap: var(--cg-spacing-6);\n align-items: center;\n }\n .dot {\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-surface-cards-border);\n border: none;\n padding: 0;\n cursor: not-allowed;\n transition:\n background var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n opacity var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .dot.completed {\n background: var(--cg-color-action-primary-background-default);\n opacity: 0.5;\n cursor: pointer;\n }\n .dot.completed:hover { opacity: 0.85; }\n .dot.active {\n background: var(--cg-color-action-primary-background-default);\n transform: scale(1.3);\n cursor: default;\n }\n .dot:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n /* ── Progress: bar ── */\n .progress-bar {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-6);\n width: 100%;\n }\n .progress-bar-track {\n width: 100%;\n height: var(--cg-spacing-4);\n background: var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-full);\n overflow: hidden;\n }\n .progress-bar-fill {\n height: 100%;\n background: var(--cg-color-action-primary-background-default);\n border-radius: var(--cg-border-radius-full);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);\n }\n\n /* ── Progress: stepper ── */\n .progress-stepper {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-4);\n flex-wrap: nowrap;\n overflow: hidden;\n }\n .stepper-node {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--cg-spacing-24);\n height: var(--cg-spacing-24);\n flex-shrink: 0;\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-surface-cards-border);\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n border: none;\n padding: 0;\n cursor: not-allowed;\n transition:\n background var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .stepper-node.completed {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n cursor: pointer;\n }\n .stepper-node.active {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n cursor: default;\n }\n .stepper-node:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n .stepper-line {\n flex: 1;\n min-width: var(--cg-spacing-8);\n height: var(--cg-border-width-100);\n background: var(--cg-color-surface-cards-border);\n transition: background var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .stepper-line.completed {\n background: var(--cg-color-action-primary-background-default);\n }\n\n /* ── Step content (animated on change) ── */\n .step-content {\n animation: stepIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;\n }\n @keyframes stepIn {\n from { opacity: 0; transform: translateX(8px); }\n to { opacity: 1; transform: translateX(0); }\n }\n .step-content[data-direction=\"back\"] { animation-name: stepInBack; }\n @keyframes stepInBack {\n from { opacity: 0; transform: translateX(-8px); }\n to { opacity: 1; transform: translateX(0); }\n }\n @media (prefers-reduced-motion: reduce) {\n .step-content { animation: none; }\n }\n\n .media-slot { margin-bottom: var(--cg-spacing-16); }\n .media-slot:empty { display: none; }\n\n .step-action-slot { margin-top: var(--cg-spacing-16); }\n .step-action-slot:empty { display: none; }\n\n /* ── Footer (actions) ── */\n .footer-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n gap: var(--cg-spacing-8);\n width: 100%;\n }\n .footer-right {\n display: inline-flex;\n gap: var(--cg-spacing-8);\n align-items: center;\n }\n\n /* sr-only live region */\n .sr-only {\n position: absolute;\n width: 1px; height: 1px;\n padding: 0; margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ type: Array }) steps: OnboardingStep[] = [];\n @property({ type: Number }) active = 0;\n @property({ type: Boolean }) dismissible = true;\n @property({ type: Boolean, attribute: 'show-skip' }) showSkip = true;\n @property({ reflect: true }) progress: ProgressVariant | 'auto' = 'auto';\n\n @state() private _direction: 'forward' | 'back' = 'forward';\n\n override connectedCallback() {\n super.connectedCallback();\n this.addEventListener('keydown', this._onKeydown);\n if (!this.hasAttribute('tabindex')) this.tabIndex = 0;\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.removeEventListener('keydown', this._onKeydown);\n }\n\n private _onKeydown = (e: KeyboardEvent) => {\n if (e.key === 'ArrowRight') { e.preventDefault(); this._next(); }\n else if (e.key === 'ArrowLeft') { e.preventDefault(); this._prev(); }\n else if (e.key === 'Escape' && this.dismissible) { e.preventDefault(); this._dismiss(); }\n };\n\n private _emit(name: string, detail: Record<string, unknown> = {}) {\n this.dispatchEvent(new CustomEvent(name, { detail, bubbles: true, composed: true }));\n }\n\n private _goTo(target: number) {\n if (target < 0 || target >= this.steps.length || target === this.active) return;\n const from = this.active;\n this._direction = target > from ? 'forward' : 'back';\n this.active = target;\n this._emit('ai-onboarding-step-change', { from, to: target });\n }\n\n private _next() {\n if (this.active < this.steps.length - 1) {\n this._direction = 'forward';\n this.active++;\n this._emit('ai-onboarding-next', { step: this.active });\n this._emit('ai-onboarding-step-change', { from: this.active - 1, to: this.active });\n } else {\n this._emit('ai-onboarding-complete');\n }\n }\n\n private _prev() {\n if (this.active > 0) {\n this._direction = 'back';\n this.active--;\n this._emit('ai-onboarding-prev', { step: this.active });\n this._emit('ai-onboarding-step-change', { from: this.active + 1, to: this.active });\n }\n }\n\n private _dismiss() {\n this._emit('ai-onboarding-dismiss', { step: this.active });\n }\n\n private _resolvedProgress(): ProgressVariant {\n if (this.progress !== 'auto') return this.progress;\n const n = this.steps.length;\n if (n <= 1) return 'numbered';\n if (n <= 4) return 'dots';\n return 'bar';\n }\n\n private _renderProgress() {\n const variant = this._resolvedProgress();\n const total = this.steps.length;\n const stepLabel = `Step ${this.active + 1} of ${total}`;\n\n if (variant === 'numbered') {\n return html`<cg-text class=\"progress-numbered\" size=\"xs\" weight=\"bold\" color=\"muted\">${stepLabel}</cg-text>`;\n }\n\n if (variant === 'dots') {\n return html`\n <div class=\"progress-dots\" role=\"tablist\" aria-label=\"Onboarding progress\">\n ${this.steps.map((s, i) => {\n const completed = i < this.active;\n const current = i === this.active;\n const cls = current ? 'active' : completed ? 'completed' : '';\n return html`<button\n class=\"dot ${cls}\"\n role=\"tab\"\n aria-selected=${current}\n aria-label=\"Go to step ${i + 1}: ${s.title}\"\n ?disabled=${!completed && !current}\n @click=${() => completed && this._goTo(i)}\n ></button>`;\n })}\n </div>\n `;\n }\n\n if (variant === 'bar') {\n const pct = total > 1 ? Math.round(((this.active + 1) / total) * 100) : 100;\n return html`\n <div class=\"progress-bar\">\n <div class=\"progress-bar-track\" role=\"progressbar\" aria-valuenow=${this.active + 1} aria-valuemin=\"1\" aria-valuemax=${total} aria-label=${stepLabel}>\n <div class=\"progress-bar-fill\" style=\"width: ${pct}%\"></div>\n </div>\n <cg-text size=\"xs\" weight=\"bold\" color=\"muted\">${stepLabel}</cg-text>\n </div>\n `;\n }\n\n // stepper\n return html`\n <div class=\"progress-stepper\" role=\"tablist\" aria-label=\"Onboarding progress\">\n ${this.steps.map((s, i) => {\n const completed = i < this.active;\n const current = i === this.active;\n const cls = current ? 'active' : completed ? 'completed' : '';\n const label = completed\n ? html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><polyline points=\"20 6 9 17 4 12\"/></svg>`\n : html`${i + 1}`;\n return html`\n ${i > 0 ? html`<span class=\"stepper-line ${i <= this.active ? 'completed' : ''}\"></span>` : nothing}\n <button\n class=\"stepper-node ${cls}\"\n role=\"tab\"\n aria-selected=${current}\n aria-label=\"Go to step ${i + 1}: ${s.title}\"\n ?disabled=${!completed && !current}\n @click=${() => completed && this._goTo(i)}\n >${label}</button>\n `;\n })}\n </div>\n `;\n }\n\n override render() {\n const step = this.steps[this.active];\n if (!step) return nothing;\n\n const isLast = this.active === this.steps.length - 1;\n const total = this.steps.length;\n\n return html`\n <cg-card variant=\"elevated\" padding=\"lg\" rounded=${this.rounded} role=\"dialog\" aria-modal=\"true\" aria-label=\"Onboarding step ${this.active + 1} of ${total}\">\n <div class=\"sr-only\" aria-live=\"polite\" aria-atomic=\"true\">Step ${this.active + 1} of ${total}: ${step.title}</div>\n\n <div slot=\"header\" class=\"header-row\">\n <div class=\"header-progress\">${this._renderProgress()}</div>\n ${this.dismissible\n ? html`<button class=\"dismiss-btn\" aria-label=\"Dismiss onboarding\" @click=${this._dismiss}><svg width=\"14\" height=\"14\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2.5\" stroke-linecap=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg></button>`\n : nothing}\n </div>\n\n <div class=\"step-content\" data-direction=${this._direction} .key=${this.active}>\n <div class=\"media-slot\"><slot name=\"media\"></slot></div>\n <cg-stack direction=\"column\" gap=\"sm\">\n <cg-text as=\"h3\" size=\"lg\" weight=\"bold\">${step.title}</cg-text>\n <cg-text size=\"sm\" color=\"muted\">${step.description}</cg-text>\n </cg-stack>\n <div class=\"step-action-slot\"><slot name=\"step-action\"></slot></div>\n </div>\n\n <div slot=\"footer\" class=\"footer-row\">\n <cg-button\n variant=\"secondary\"\n size=\"md\"\n ?disabled=${this.active === 0}\n label=\"Previous step\"\n @click=${this._prev}\n >Back</cg-button>\n <div class=\"footer-right\">\n ${this.showSkip && !isLast\n ? html`<cg-button variant=\"tertiary\" size=\"sm\" label=\"Skip onboarding\" @click=${this._dismiss}>Skip tour</cg-button>`\n : nothing}\n <cg-button\n variant=\"primary\"\n size=\"md\"\n label=${isLast ? 'Complete onboarding' : 'Next step'}\n @click=${this._next}\n >${isLast ? 'Done' : 'Next'}</cg-button>\n </div>\n </div>\n </cg-card>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-onboarding': AiOnboarding;\n }\n}\n"],"names":["AiOnboarding","LitElement","e","name","detail","target","from","n","variant","total","stepLabel","html","s","i","completed","current","pct","cls","label","nothing","step","isLast","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-onboarding.js","sources":["../../../src/components/ai-onboarding/ai-onboarding.ts"],"sourcesContent":["/**\n * @element ai-onboarding\n * Step-by-step onboarding card built entirely from design-system primitives\n * (cg-card, cg-text, cg-button, cg-stack). Progress affordance is configurable\n * via the `progress` attribute: numbered | dots | bar | stepper.\n *\n * @example\n * ```html\n * <ai-onboarding\n * progress=\"bar\"\n * .steps=${[\n * { title: 'Welcome', description: 'Let us show you around.' },\n * { title: 'Ask anything', description: 'Type a question to get started.' }\n * ]}\n * active=\"0\"\n * dismissible\n * ></ai-onboarding>\n * ```\n *\n * @prop {OnboardingStep[]} steps - Array of step objects with title and description\n * @prop {number} active - Index of the current step (default 0)\n * @prop {boolean} dismissible - Show dismiss button (default true)\n * @prop {'numbered'|'dots'|'bar'|'stepper'} progress - Progress style (default auto-picks by step count)\n *\n * @slot media - Optional media (illustration, Lottie, video) shown above the title\n * @slot step-action - Optional per-step CTA (e.g., \"Try it\") rendered below description\n *\n * @fires {CustomEvent<{step: number}>} ai-onboarding-next - When Next is clicked\n * @fires {CustomEvent<{step: number}>} ai-onboarding-prev - When Back is clicked\n * @fires {CustomEvent<{from: number, to: number}>} ai-onboarding-step-change - Any step change\n * @fires ai-onboarding-complete - When Done is clicked on the last step\n * @fires {CustomEvent<{step: number}>} ai-onboarding-dismiss - When dismissed\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\nimport '../cg-card/cg-card.js';\nimport '../cg-text/cg-text.js';\nimport '../cg-button/cg-button.js';\nimport '../cg-stack/cg-stack.js';\n\nexport interface OnboardingStep {\n title: string;\n description: string;\n target?: string;\n}\n\ntype ProgressVariant = 'numbered' | 'dots' | 'bar' | 'stepper';\n\n@customElement('ai-onboarding')\nexport class AiOnboarding extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n display: block;\n max-width: 440px;\n }\n :host([hidden]) { display: none; }\n\n cg-card { display: block; }\n\n /* ── Header row (progress + dismiss) ── */\n .header-row {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n width: 100%;\n }\n .header-progress { flex: 1; min-width: 0; }\n\n .dismiss-btn {\n flex-shrink: 0;\n background: none;\n border: none;\n color: var(--cg-color-surface-container-outlined);\n cursor: pointer;\n padding: var(--cg-spacing-4);\n line-height: 1;\n border-radius: var(--cg-border-radius-50);\n display: inline-flex;\n align-items: center;\n justify-content: center;\n transition:\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .dismiss-btn:hover {\n color: var(--cg-color-surface-base-text);\n background: var(--cg-color-action-secondary-background-hover);\n }\n .dismiss-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .dismiss-btn:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-color-focus-ring);\n }\n\n /* ── Progress: numbered ── */\n .progress-numbered {\n text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wide);\n }\n\n /* ── Progress: dots ── */\n .progress-dots {\n display: flex;\n gap: var(--cg-spacing-6);\n align-items: center;\n }\n .dot {\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-surface-cards-border);\n border: none;\n padding: 0;\n cursor: not-allowed;\n transition:\n background var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n opacity var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .dot.completed {\n background: var(--cg-color-action-primary-background-default);\n opacity: var(--cg-opacity-50);\n cursor: pointer;\n }\n .dot.completed:hover { opacity: 0.85; }\n .dot.active {\n background: var(--cg-color-action-primary-background-default);\n transform: scale(1.3);\n cursor: default;\n }\n .dot:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-color-focus-ring);\n }\n\n /* ── Progress: bar ── */\n .progress-bar {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-6);\n width: 100%;\n }\n .progress-bar-track {\n width: 100%;\n height: var(--cg-spacing-4);\n background: var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-full);\n overflow: hidden;\n }\n .progress-bar-fill {\n height: 100%;\n background: var(--cg-color-action-primary-background-default);\n border-radius: var(--cg-border-radius-full);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);\n }\n\n /* ── Progress: stepper ── */\n .progress-stepper {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-4);\n flex-wrap: nowrap;\n overflow: hidden;\n }\n .stepper-node {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--cg-spacing-24);\n height: var(--cg-spacing-24);\n flex-shrink: 0;\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-surface-cards-border);\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n border: none;\n padding: 0;\n cursor: not-allowed;\n transition:\n background var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .stepper-node.completed {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n cursor: pointer;\n }\n .stepper-node.active {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n cursor: default;\n }\n .stepper-node:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-color-focus-ring);\n }\n .stepper-line {\n flex: 1;\n min-width: var(--cg-spacing-8);\n height: var(--cg-border-width-100);\n background: var(--cg-color-surface-cards-border);\n transition: background var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .stepper-line.completed {\n background: var(--cg-color-action-primary-background-default);\n }\n\n /* ── Step content (animated on change) ── */\n .step-content {\n animation: stepIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;\n }\n @keyframes stepIn {\n from { opacity: 0; transform: translateX(8px); }\n to { opacity: 1; transform: translateX(0); }\n }\n .step-content[data-direction=\"back\"] { animation-name: stepInBack; }\n @keyframes stepInBack {\n from { opacity: 0; transform: translateX(-8px); }\n to { opacity: 1; transform: translateX(0); }\n }\n @media (prefers-reduced-motion: reduce) {\n .step-content { animation: none; }\n }\n\n .media-slot { margin-bottom: var(--cg-spacing-16); }\n .media-slot:empty { display: none; }\n\n .step-action-slot { margin-top: var(--cg-spacing-16); }\n .step-action-slot:empty { display: none; }\n\n /* ── Footer (actions) ── */\n .footer-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n gap: var(--cg-spacing-8);\n width: 100%;\n }\n .footer-right {\n display: inline-flex;\n gap: var(--cg-spacing-8);\n align-items: center;\n }\n\n /* sr-only live region */\n .sr-only {\n position: absolute;\n width: 1px; height: 1px;\n padding: 0; margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ type: Array }) steps: OnboardingStep[] = [];\n @property({ type: Number }) active = 0;\n @property({ type: Boolean }) dismissible = true;\n @property({ type: Boolean, attribute: 'show-skip' }) showSkip = true;\n @property({ reflect: true }) progress: ProgressVariant | 'auto' = 'auto';\n\n @state() private _direction: 'forward' | 'back' = 'forward';\n\n override connectedCallback() {\n super.connectedCallback();\n this.addEventListener('keydown', this._onKeydown);\n if (!this.hasAttribute('tabindex')) this.tabIndex = 0;\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.removeEventListener('keydown', this._onKeydown);\n }\n\n private _onKeydown = (e: KeyboardEvent) => {\n if (e.key === 'ArrowRight') { e.preventDefault(); this._next(); }\n else if (e.key === 'ArrowLeft') { e.preventDefault(); this._prev(); }\n else if (e.key === 'Escape' && this.dismissible) { e.preventDefault(); this._dismiss(); }\n };\n\n private _emit(name: string, detail: Record<string, unknown> = {}) {\n this.dispatchEvent(new CustomEvent(name, { detail, bubbles: true, composed: true }));\n }\n\n private _goTo(target: number) {\n if (target < 0 || target >= this.steps.length || target === this.active) return;\n const from = this.active;\n this._direction = target > from ? 'forward' : 'back';\n this.active = target;\n this._emit('ai-onboarding-step-change', { from, to: target });\n }\n\n private _next() {\n if (this.active < this.steps.length - 1) {\n this._direction = 'forward';\n this.active++;\n this._emit('ai-onboarding-next', { step: this.active });\n this._emit('ai-onboarding-step-change', { from: this.active - 1, to: this.active });\n } else {\n this._emit('ai-onboarding-complete');\n }\n }\n\n private _prev() {\n if (this.active > 0) {\n this._direction = 'back';\n this.active--;\n this._emit('ai-onboarding-prev', { step: this.active });\n this._emit('ai-onboarding-step-change', { from: this.active + 1, to: this.active });\n }\n }\n\n private _dismiss() {\n this._emit('ai-onboarding-dismiss', { step: this.active });\n }\n\n private _resolvedProgress(): ProgressVariant {\n if (this.progress !== 'auto') return this.progress;\n const n = this.steps.length;\n if (n <= 1) return 'numbered';\n if (n <= 4) return 'dots';\n return 'bar';\n }\n\n private _renderProgress() {\n const variant = this._resolvedProgress();\n const total = this.steps.length;\n const stepLabel = `Step ${this.active + 1} of ${total}`;\n\n if (variant === 'numbered') {\n return html`<cg-text class=\"progress-numbered\" size=\"xs\" weight=\"bold\" color=\"muted\">${stepLabel}</cg-text>`;\n }\n\n if (variant === 'dots') {\n return html`\n <div class=\"progress-dots\" role=\"tablist\" aria-label=\"Onboarding progress\">\n ${this.steps.map((s, i) => {\n const completed = i < this.active;\n const current = i === this.active;\n const cls = current ? 'active' : completed ? 'completed' : '';\n return html`<button\n class=\"dot ${cls}\"\n role=\"tab\"\n aria-selected=${current}\n aria-label=\"Go to step ${i + 1}: ${s.title}\"\n ?disabled=${!completed && !current}\n @click=${() => completed && this._goTo(i)}\n ></button>`;\n })}\n </div>\n `;\n }\n\n if (variant === 'bar') {\n const pct = total > 1 ? Math.round(((this.active + 1) / total) * 100) : 100;\n return html`\n <div class=\"progress-bar\">\n <div class=\"progress-bar-track\" role=\"progressbar\" aria-valuenow=${this.active + 1} aria-valuemin=\"1\" aria-valuemax=${total} aria-label=${stepLabel}>\n <div class=\"progress-bar-fill\" style=\"width: ${pct}%\"></div>\n </div>\n <cg-text size=\"xs\" weight=\"bold\" color=\"muted\">${stepLabel}</cg-text>\n </div>\n `;\n }\n\n // stepper\n return html`\n <div class=\"progress-stepper\" role=\"tablist\" aria-label=\"Onboarding progress\">\n ${this.steps.map((s, i) => {\n const completed = i < this.active;\n const current = i === this.active;\n const cls = current ? 'active' : completed ? 'completed' : '';\n const label = completed\n ? html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><polyline points=\"20 6 9 17 4 12\"/></svg>`\n : html`${i + 1}`;\n return html`\n ${i > 0 ? html`<span class=\"stepper-line ${i <= this.active ? 'completed' : ''}\"></span>` : nothing}\n <button\n class=\"stepper-node ${cls}\"\n role=\"tab\"\n aria-selected=${current}\n aria-label=\"Go to step ${i + 1}: ${s.title}\"\n ?disabled=${!completed && !current}\n @click=${() => completed && this._goTo(i)}\n >${label}</button>\n `;\n })}\n </div>\n `;\n }\n\n override render() {\n const step = this.steps[this.active];\n if (!step) return nothing;\n\n const isLast = this.active === this.steps.length - 1;\n const total = this.steps.length;\n\n return html`\n <cg-card variant=\"elevated\" padding=\"lg\" rounded=${this.rounded} role=\"dialog\" aria-modal=\"true\" aria-label=\"Onboarding step ${this.active + 1} of ${total}\">\n <div class=\"sr-only\" aria-live=\"polite\" aria-atomic=\"true\">Step ${this.active + 1} of ${total}: ${step.title}</div>\n\n <div slot=\"header\" class=\"header-row\">\n <div class=\"header-progress\">${this._renderProgress()}</div>\n ${this.dismissible\n ? html`<button class=\"dismiss-btn\" aria-label=\"Dismiss onboarding\" @click=${this._dismiss}><svg width=\"14\" height=\"14\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2.5\" stroke-linecap=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg></button>`\n : nothing}\n </div>\n\n <div class=\"step-content\" data-direction=${this._direction} .key=${this.active}>\n <div class=\"media-slot\"><slot name=\"media\"></slot></div>\n <cg-stack direction=\"column\" gap=\"sm\">\n <cg-text as=\"h3\" size=\"lg\" weight=\"bold\">${step.title}</cg-text>\n <cg-text size=\"sm\" color=\"muted\">${step.description}</cg-text>\n </cg-stack>\n <div class=\"step-action-slot\"><slot name=\"step-action\"></slot></div>\n </div>\n\n <div slot=\"footer\" class=\"footer-row\">\n <cg-button\n variant=\"secondary\"\n size=\"md\"\n ?disabled=${this.active === 0}\n label=\"Previous step\"\n @click=${this._prev}\n >Back</cg-button>\n <div class=\"footer-right\">\n ${this.showSkip && !isLast\n ? html`<cg-button variant=\"tertiary\" size=\"sm\" label=\"Skip onboarding\" @click=${this._dismiss}>Skip tour</cg-button>`\n : nothing}\n <cg-button\n variant=\"primary\"\n size=\"md\"\n label=${isLast ? 'Complete onboarding' : 'Next step'}\n @click=${this._next}\n >${isLast ? 'Done' : 'Next'}</cg-button>\n </div>\n </div>\n </cg-card>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-onboarding': AiOnboarding;\n }\n}\n"],"names":["AiOnboarding","LitElement","e","name","detail","target","from","n","variant","total","stepLabel","html","s","i","completed","current","pct","cls","label","nothing","step","isLast","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as m, svg as u, nothing as d, html as s } from "lit";
2
2
  import { property as g, customElement as v } from "lit/decorators.js";
3
- import { h as f, r as h, f as x } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as f, r as h, f as x } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  import "../cg-card/cg-card.js";
5
5
  import "../cg-text/cg-text.js";
6
6
  import "../cg-button/cg-button.js";
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as v, nothing as n, html as s } from "lit";
2
2
  import { property as c, customElement as f } from "lit/decorators.js";
3
- import { h as u, r as h } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as u, r as h } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var m = Object.defineProperty, b = Object.getOwnPropertyDescriptor, i = (e, a, o, l) => {
5
5
  for (var t = l > 1 ? void 0 : l ? b(a, o) : a, d = e.length - 1, g; d >= 0; d--)
6
6
  (g = e[d]) && (t = (l ? g(a, o, t) : g(t)) || t);
@@ -1,10 +1,10 @@
1
- import { css as g, LitElement as p, html as n, nothing as b } from "lit";
2
- import { property as c, customElement as u } from "lit/decorators.js";
3
- import { a as f, r as h, f as m } from "../../chunks/premium.css-9I4kHrsl.js";
1
+ import { css as g, LitElement as d, html as s, nothing as u } from "lit";
2
+ import { property as c, customElement as b } from "lit/decorators.js";
3
+ import { a as f, r as h, f as m } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  import "../cg-avatar/cg-avatar.js";
5
- var w = Object.defineProperty, y = Object.getOwnPropertyDescriptor, s = (r, t, e, a) => {
6
- for (var o = a > 1 ? void 0 : a ? y(t, e) : t, l = r.length - 1, d; l >= 0; l--)
7
- (d = r[l]) && (o = (a ? d(t, e, o) : d(o)) || o);
5
+ var w = Object.defineProperty, y = Object.getOwnPropertyDescriptor, n = (r, t, e, a) => {
6
+ for (var o = a > 1 ? void 0 : a ? y(t, e) : t, l = r.length - 1, p; l >= 0; l--)
7
+ (p = r[l]) && (o = (a ? p(t, e, o) : p(o)) || o);
8
8
  return a && o && w(t, e, o), o;
9
9
  };
10
10
  const v = {
@@ -13,7 +13,7 @@ const v = {
13
13
  busy: "Do not disturb",
14
14
  offline: "Offline"
15
15
  };
16
- let i = class extends p {
16
+ let i = class extends d {
17
17
  constructor() {
18
18
  super(...arguments), this.users = [], this.maxVisible = 5, this.loading = !1, this.size = "md";
19
19
  }
@@ -29,7 +29,7 @@ let i = class extends p {
29
29
  }
30
30
  _renderTooltip(r) {
31
31
  const t = v[r.status], e = r.lastSeen ? `${t} • ${r.lastSeen}` : t;
32
- return n`
32
+ return s`
33
33
  <span class="tooltip" role="tooltip">
34
34
  <span class="tooltip-name">${r.name}</span>
35
35
  <span class="tooltip-meta">${e}</span>
@@ -39,19 +39,19 @@ let i = class extends p {
39
39
  render() {
40
40
  if (this.loading) {
41
41
  const a = Math.min(this.maxVisible, 4);
42
- return n`
42
+ return s`
43
43
  <div class="container" aria-busy="true" aria-label="Loading presence">
44
44
  <div class="avatar-stack">
45
- ${Array.from({ length: a }).map(() => n`<span class="skeleton"></span>`)}
45
+ ${Array.from({ length: a }).map(() => s`<span class="skeleton"></span>`)}
46
46
  </div>
47
47
  </div>
48
48
  `;
49
49
  }
50
50
  const r = this.users.slice(0, this.maxVisible), t = this.users.length - this.maxVisible, e = this._avatarSize();
51
- return n`
51
+ return s`
52
52
  <div class="container" role="group" aria-label="Active users" aria-live="polite">
53
53
  <div class="avatar-stack">
54
- ${r.map((a) => n`
54
+ ${r.map((a) => s`
55
55
  <div class="avatar-wrapper">
56
56
  <button
57
57
  class="avatar-btn"
@@ -69,7 +69,7 @@ let i = class extends p {
69
69
  ${this._renderTooltip(a)}
70
70
  </div>
71
71
  `)}
72
- ${t > 0 ? n`<span class="overflow-badge" aria-label="${t} more users">+${t}</span>` : b}
72
+ ${t > 0 ? s`<span class="overflow-badge" aria-label="${t} more users">+${t}</span>` : u}
73
73
  </div>
74
74
  </div>
75
75
  `;
@@ -157,7 +157,7 @@ i.styles = [f, h, m, g`
157
157
  bottom: calc(100% + var(--cg-spacing-8));
158
158
  left: 50%;
159
159
  transform: translateX(-50%) translateY(var(--cg-spacing-2));
160
- background: var(--cg-color-modal-container-background);
160
+ background: var(--cg-color-surface-tooltip-background);
161
161
  color: var(--cg-color-surface-base-text);
162
162
  padding: var(--cg-spacing-6) var(--cg-spacing-12);
163
163
  border-radius: var(--cg-border-radius-100);
@@ -170,7 +170,7 @@ i.styles = [f, h, m, g`
170
170
  opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
171
171
  transform var(--cg-transition-duration-fast) var(--cg-transition-easing-ease-out);
172
172
  z-index: 20;
173
- border: var(--cg-border-width-50) solid var(--cg-color-modal-container-border);
173
+ border: var(--cg-border-width-50) solid var(--cg-color-surface-tooltip-border);
174
174
  box-shadow: var(--cg-elevation-2);
175
175
  white-space: nowrap;
176
176
  }
@@ -182,9 +182,9 @@ i.styles = [f, h, m, g`
182
182
  width: var(--cg-spacing-8);
183
183
  height: var(--cg-spacing-8);
184
184
  transform: translateX(-50%) translateY(-50%) rotate(45deg);
185
- background: var(--cg-color-modal-container-background);
186
- border-right: var(--cg-border-width-50) solid var(--cg-color-modal-container-border);
187
- border-bottom: var(--cg-border-width-50) solid var(--cg-color-modal-container-border);
185
+ background: var(--cg-color-surface-tooltip-background);
186
+ border-right: var(--cg-border-width-50) solid var(--cg-color-surface-tooltip-border);
187
+ border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-tooltip-border);
188
188
  }
189
189
  .tooltip-name {
190
190
  font-weight: var(--cg-font-weight-semibold);
@@ -195,7 +195,7 @@ i.styles = [f, h, m, g`
195
195
  .tooltip-meta {
196
196
  display: block;
197
197
  margin-top: var(--cg-spacing-2);
198
- color: var(--cg-color-surface-container-outlined);
198
+ color: var(--cg-color-surface-container-subtle);
199
199
  }
200
200
  .avatar-wrapper:hover .tooltip,
201
201
  .avatar-wrapper:focus-within .tooltip {
@@ -240,20 +240,20 @@ i.styles = [f, h, m, g`
240
240
  .skeleton { animation: none; }
241
241
  }
242
242
  `];
243
- s([
243
+ n([
244
244
  c({ type: Array })
245
245
  ], i.prototype, "users", 2);
246
- s([
246
+ n([
247
247
  c({ type: Number, attribute: "max-visible" })
248
248
  ], i.prototype, "maxVisible", 2);
249
- s([
249
+ n([
250
250
  c({ type: Boolean, reflect: !0 })
251
251
  ], i.prototype, "loading", 2);
252
- s([
252
+ n([
253
253
  c({ type: String, reflect: !0 })
254
254
  ], i.prototype, "size", 2);
255
- i = s([
256
- u("ai-presence")
255
+ i = n([
256
+ b("ai-presence")
257
257
  ], i);
258
258
  export {
259
259
  i as AiPresence
@@ -1 +1 @@
1
- {"version":3,"file":"ai-presence.js","sources":["../../../src/components/ai-presence/ai-presence.ts"],"sourcesContent":["/**\n * @element ai-presence\n * Overlapping avatar stack showing live user presence. Built on top of <cg-avatar>\n * (handles initials/image/status-dot/sizes) with bespoke overlap stack, hover-lift,\n * tooltip with status + last-seen, \"+N more\" overflow badge, and skeleton state.\n *\n * @example\n * ```html\n * <ai-presence\n * size=\"md\"\n * .users=${[\n * { name: 'Alice', status: 'online', avatar: '/avatars/alice.jpg' },\n * { name: 'Bob', status: 'away', lastSeen: '5m ago' },\n * { name: 'Carol', status: 'busy' }\n * ]}\n * max-visible=\"4\"\n * ></ai-presence>\n * ```\n *\n * @prop {PresenceUser[]} users - User objects (name, status, optional avatar + lastSeen)\n * @prop {number} maxVisible - Max avatars before overflow badge (default 5)\n * @prop {boolean} loading - Render skeleton placeholders\n * @prop {\"sm\" | \"md\" | \"lg\"} size - Avatar size (default md)\n *\n * @fires {CustomEvent<{user: PresenceUser}>} ai-presence-user-click - Avatar clicked\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, customElement } from 'lit/decorators.js';\nimport { hostBase, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\nimport '../cg-avatar/cg-avatar.js';\n\nexport type PresenceStatus = 'online' | 'away' | 'busy' | 'offline';\nexport type PresenceSize = 'sm' | 'md' | 'lg';\n\nexport interface PresenceUser {\n name: string;\n avatar?: string;\n status: PresenceStatus;\n /** Optional last-seen text shown in the tooltip (e.g. \"5m ago\") */\n lastSeen?: string;\n}\n\nconst STATUS_LABEL: Record<PresenceStatus, string> = {\n online: 'Active',\n away: 'Away',\n busy: 'Do not disturb',\n offline: 'Offline',\n};\n\n@customElement('ai-presence')\nexport class AiPresence extends LitElement {\n static override styles = [hostBase, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n align-items: center;\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n\n /* Per-size variables (defaults to md) */\n --_avatar-size: var(--cg-spacing-32);\n --_overlap: var(--cg-spacing-8);\n }\n :host([hidden]) { display: none; }\n :host([size=\"sm\"]) {\n --_avatar-size: var(--cg-spacing-24);\n --_overlap: var(--cg-spacing-6);\n }\n :host([size=\"lg\"]) {\n --_avatar-size: var(--cg-spacing-40);\n --_overlap: var(--cg-spacing-12);\n }\n\n .container {\n display: flex;\n align-items: center;\n }\n .avatar-stack {\n display: flex;\n align-items: center;\n }\n\n .avatar-wrapper {\n position: relative;\n margin-left: calc(-1 * var(--_overlap));\n z-index: 1;\n transition: transform var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n .avatar-wrapper:first-child { margin-left: 0; }\n .avatar-wrapper:hover,\n .avatar-wrapper:focus-within {\n z-index: 10;\n transform: translateY(calc(-1 * var(--cg-spacing-4)));\n }\n\n /* Outline ring around each avatar so they read as separate even when overlapping */\n .avatar-btn {\n display: inline-block;\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-base-background);\n background: transparent;\n padding: 0;\n cursor: pointer;\n transition: transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .avatar-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .avatar-btn:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 2px var(--cg-color-surface-base-background),\n 0 0 0 calc(2px + var(--cg-border-width-100)) var(--cg-color-focus-ring);\n }\n\n /* ── Overflow ── */\n .overflow-badge {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--_avatar-size);\n height: var(--_avatar-size);\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-base-background);\n background: var(--cg-color-action-tertiary-background-hover);\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n margin-left: calc(-1 * var(--_overlap));\n cursor: default;\n }\n\n /* ── Tooltip (bespoke — multi-line beats cg-tooltip's single-string content) ── */\n .tooltip {\n position: absolute;\n bottom: calc(100% + var(--cg-spacing-8));\n left: 50%;\n transform: translateX(-50%) translateY(var(--cg-spacing-2));\n background: var(--cg-color-modal-container-background);\n color: var(--cg-color-surface-base-text);\n padding: var(--cg-spacing-6) var(--cg-spacing-12);\n border-radius: var(--cg-border-radius-100);\n font-size: var(--cg-font-size-xs);\n line-height: var(--cg-line-height-snug);\n max-width: var(--cg-spacing-256);\n pointer-events: none;\n opacity: 0;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-ease-out);\n z-index: 20;\n border: var(--cg-border-width-50) solid var(--cg-color-modal-container-border);\n box-shadow: var(--cg-elevation-2);\n white-space: nowrap;\n }\n .tooltip::after {\n content: '';\n position: absolute;\n top: 100%;\n left: 50%;\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n transform: translateX(-50%) translateY(-50%) rotate(45deg);\n background: var(--cg-color-modal-container-background);\n border-right: var(--cg-border-width-50) solid var(--cg-color-modal-container-border);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-modal-container-border);\n }\n .tooltip-name {\n font-weight: var(--cg-font-weight-semibold);\n display: block;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n .tooltip-meta {\n display: block;\n margin-top: var(--cg-spacing-2);\n color: var(--cg-color-surface-container-outlined);\n }\n .avatar-wrapper:hover .tooltip,\n .avatar-wrapper:focus-within .tooltip {\n opacity: 1;\n transform: translateX(-50%) translateY(0);\n }\n\n /* ── Skeleton ── */\n @keyframes presence-shimmer {\n 0% { background-position: -100% 0, 0 0; }\n 100% { background-position: 200% 0, 0 0; }\n }\n .skeleton {\n display: inline-block;\n width: var(--_avatar-size);\n height: var(--_avatar-size);\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-base-background);\n margin-left: calc(-1 * var(--_overlap));\n flex-shrink: 0;\n background:\n linear-gradient(\n 90deg,\n transparent 0%,\n var(--cg-overlay-white-strong) 50%,\n transparent 100%\n ),\n var(--cg-color-action-tertiary-background-hover);\n background-size: 50% 100%, 100% 100%;\n background-repeat: no-repeat, no-repeat;\n animation: presence-shimmer 1.5s var(--cg-transition-easing-linear) infinite;\n }\n .skeleton:first-child { margin-left: 0; }\n\n @media (prefers-reduced-motion: reduce) {\n :host { animation: none; }\n .avatar-wrapper { transition: none; }\n .avatar-btn { transition: none; }\n .tooltip { transition: none; transform: translateX(-50%); }\n .avatar-wrapper:hover .tooltip,\n .avatar-wrapper:focus-within .tooltip { transform: translateX(-50%); }\n .skeleton { animation: none; }\n }\n `];\n\n @property({ type: Array }) users: PresenceUser[] = [];\n @property({ type: Number, attribute: 'max-visible' }) maxVisible = 5;\n @property({ type: Boolean, reflect: true }) loading = false;\n @property({ type: String, reflect: true }) size: PresenceSize = 'md';\n\n private _handleUserClick(user: PresenceUser) {\n this.dispatchEvent(new CustomEvent('ai-presence-user-click', {\n detail: { user },\n bubbles: true, composed: true,\n }));\n }\n\n private _avatarSize(): 'sm' | 'md' | 'lg' {\n return this.size; // matches cg-avatar's size scale\n }\n\n private _renderTooltip(user: PresenceUser) {\n const statusText = STATUS_LABEL[user.status];\n const meta = user.lastSeen ? `${statusText} • ${user.lastSeen}` : statusText;\n return html`\n <span class=\"tooltip\" role=\"tooltip\">\n <span class=\"tooltip-name\">${user.name}</span>\n <span class=\"tooltip-meta\">${meta}</span>\n </span>\n `;\n }\n\n override render() {\n if (this.loading) {\n const placeholders = Math.min(this.maxVisible, 4);\n return html`\n <div class=\"container\" aria-busy=\"true\" aria-label=\"Loading presence\">\n <div class=\"avatar-stack\">\n ${Array.from({ length: placeholders }).map(() => html`<span class=\"skeleton\"></span>`)}\n </div>\n </div>\n `;\n }\n\n const visible = this.users.slice(0, this.maxVisible);\n const overflow = this.users.length - this.maxVisible;\n const avSize = this._avatarSize();\n\n return html`\n <div class=\"container\" role=\"group\" aria-label=\"Active users\" aria-live=\"polite\">\n <div class=\"avatar-stack\">\n ${visible.map(user => html`\n <div class=\"avatar-wrapper\">\n <button\n class=\"avatar-btn\"\n aria-label=\"${user.name}, ${STATUS_LABEL[user.status]}${user.lastSeen ? `, last seen ${user.lastSeen}` : ''}\"\n @click=${() => this._handleUserClick(user)}\n >\n <cg-avatar\n size=${avSize}\n shape=\"circle\"\n name=${user.name}\n src=${user.avatar ?? ''}\n status=${user.status}\n ></cg-avatar>\n </button>\n ${this._renderTooltip(user)}\n </div>\n `)}\n ${overflow > 0\n ? html`<span class=\"overflow-badge\" aria-label=\"${overflow} more users\">+${overflow}</span>`\n : nothing}\n </div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-presence': AiPresence;\n }\n}\n"],"names":["STATUS_LABEL","AiPresence","LitElement","user","statusText","meta","html","placeholders","visible","overflow","avSize","nothing","hostBase","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-presence.js","sources":["../../../src/components/ai-presence/ai-presence.ts"],"sourcesContent":["/**\n * @element ai-presence\n * Overlapping avatar stack showing live user presence. Built on top of <cg-avatar>\n * (handles initials/image/status-dot/sizes) with bespoke overlap stack, hover-lift,\n * tooltip with status + last-seen, \"+N more\" overflow badge, and skeleton state.\n *\n * @example\n * ```html\n * <ai-presence\n * size=\"md\"\n * .users=${[\n * { name: 'Alice', status: 'online', avatar: '/avatars/alice.jpg' },\n * { name: 'Bob', status: 'away', lastSeen: '5m ago' },\n * { name: 'Carol', status: 'busy' }\n * ]}\n * max-visible=\"4\"\n * ></ai-presence>\n * ```\n *\n * @prop {PresenceUser[]} users - User objects (name, status, optional avatar + lastSeen)\n * @prop {number} maxVisible - Max avatars before overflow badge (default 5)\n * @prop {boolean} loading - Render skeleton placeholders\n * @prop {\"sm\" | \"md\" | \"lg\"} size - Avatar size (default md)\n *\n * @fires {CustomEvent<{user: PresenceUser}>} ai-presence-user-click - Avatar clicked\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, customElement } from 'lit/decorators.js';\nimport { hostBase, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\nimport '../cg-avatar/cg-avatar.js';\n\nexport type PresenceStatus = 'online' | 'away' | 'busy' | 'offline';\nexport type PresenceSize = 'sm' | 'md' | 'lg';\n\nexport interface PresenceUser {\n name: string;\n avatar?: string;\n status: PresenceStatus;\n /** Optional last-seen text shown in the tooltip (e.g. \"5m ago\") */\n lastSeen?: string;\n}\n\nconst STATUS_LABEL: Record<PresenceStatus, string> = {\n online: 'Active',\n away: 'Away',\n busy: 'Do not disturb',\n offline: 'Offline',\n};\n\n@customElement('ai-presence')\nexport class AiPresence extends LitElement {\n static override styles = [hostBase, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n align-items: center;\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n\n /* Per-size variables (defaults to md) */\n --_avatar-size: var(--cg-spacing-32);\n --_overlap: var(--cg-spacing-8);\n }\n :host([hidden]) { display: none; }\n :host([size=\"sm\"]) {\n --_avatar-size: var(--cg-spacing-24);\n --_overlap: var(--cg-spacing-6);\n }\n :host([size=\"lg\"]) {\n --_avatar-size: var(--cg-spacing-40);\n --_overlap: var(--cg-spacing-12);\n }\n\n .container {\n display: flex;\n align-items: center;\n }\n .avatar-stack {\n display: flex;\n align-items: center;\n }\n\n .avatar-wrapper {\n position: relative;\n margin-left: calc(-1 * var(--_overlap));\n z-index: 1;\n transition: transform var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n .avatar-wrapper:first-child { margin-left: 0; }\n .avatar-wrapper:hover,\n .avatar-wrapper:focus-within {\n z-index: 10;\n transform: translateY(calc(-1 * var(--cg-spacing-4)));\n }\n\n /* Outline ring around each avatar so they read as separate even when overlapping */\n .avatar-btn {\n display: inline-block;\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-base-background);\n background: transparent;\n padding: 0;\n cursor: pointer;\n transition: transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .avatar-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .avatar-btn:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 2px var(--cg-color-surface-base-background),\n 0 0 0 calc(2px + var(--cg-border-width-100)) var(--cg-color-focus-ring);\n }\n\n /* ── Overflow ── */\n .overflow-badge {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--_avatar-size);\n height: var(--_avatar-size);\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-base-background);\n background: var(--cg-color-action-tertiary-background-hover);\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n margin-left: calc(-1 * var(--_overlap));\n cursor: default;\n }\n\n /* ── Tooltip (bespoke — multi-line beats cg-tooltip's single-string content) ── */\n .tooltip {\n position: absolute;\n bottom: calc(100% + var(--cg-spacing-8));\n left: 50%;\n transform: translateX(-50%) translateY(var(--cg-spacing-2));\n background: var(--cg-color-surface-tooltip-background);\n color: var(--cg-color-surface-base-text);\n padding: var(--cg-spacing-6) var(--cg-spacing-12);\n border-radius: var(--cg-border-radius-100);\n font-size: var(--cg-font-size-xs);\n line-height: var(--cg-line-height-snug);\n max-width: var(--cg-spacing-256);\n pointer-events: none;\n opacity: 0;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-ease-out);\n z-index: 20;\n border: var(--cg-border-width-50) solid var(--cg-color-surface-tooltip-border);\n box-shadow: var(--cg-elevation-2);\n white-space: nowrap;\n }\n .tooltip::after {\n content: '';\n position: absolute;\n top: 100%;\n left: 50%;\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n transform: translateX(-50%) translateY(-50%) rotate(45deg);\n background: var(--cg-color-surface-tooltip-background);\n border-right: var(--cg-border-width-50) solid var(--cg-color-surface-tooltip-border);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-tooltip-border);\n }\n .tooltip-name {\n font-weight: var(--cg-font-weight-semibold);\n display: block;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n .tooltip-meta {\n display: block;\n margin-top: var(--cg-spacing-2);\n color: var(--cg-color-surface-container-subtle);\n }\n .avatar-wrapper:hover .tooltip,\n .avatar-wrapper:focus-within .tooltip {\n opacity: 1;\n transform: translateX(-50%) translateY(0);\n }\n\n /* ── Skeleton ── */\n @keyframes presence-shimmer {\n 0% { background-position: -100% 0, 0 0; }\n 100% { background-position: 200% 0, 0 0; }\n }\n .skeleton {\n display: inline-block;\n width: var(--_avatar-size);\n height: var(--_avatar-size);\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-base-background);\n margin-left: calc(-1 * var(--_overlap));\n flex-shrink: 0;\n background:\n linear-gradient(\n 90deg,\n transparent 0%,\n var(--cg-overlay-white-strong) 50%,\n transparent 100%\n ),\n var(--cg-color-action-tertiary-background-hover);\n background-size: 50% 100%, 100% 100%;\n background-repeat: no-repeat, no-repeat;\n animation: presence-shimmer 1.5s var(--cg-transition-easing-linear) infinite;\n }\n .skeleton:first-child { margin-left: 0; }\n\n @media (prefers-reduced-motion: reduce) {\n :host { animation: none; }\n .avatar-wrapper { transition: none; }\n .avatar-btn { transition: none; }\n .tooltip { transition: none; transform: translateX(-50%); }\n .avatar-wrapper:hover .tooltip,\n .avatar-wrapper:focus-within .tooltip { transform: translateX(-50%); }\n .skeleton { animation: none; }\n }\n `];\n\n @property({ type: Array }) users: PresenceUser[] = [];\n @property({ type: Number, attribute: 'max-visible' }) maxVisible = 5;\n @property({ type: Boolean, reflect: true }) loading = false;\n @property({ type: String, reflect: true }) size: PresenceSize = 'md';\n\n private _handleUserClick(user: PresenceUser) {\n this.dispatchEvent(new CustomEvent('ai-presence-user-click', {\n detail: { user },\n bubbles: true, composed: true,\n }));\n }\n\n private _avatarSize(): 'sm' | 'md' | 'lg' {\n return this.size; // matches cg-avatar's size scale\n }\n\n private _renderTooltip(user: PresenceUser) {\n const statusText = STATUS_LABEL[user.status];\n const meta = user.lastSeen ? `${statusText} • ${user.lastSeen}` : statusText;\n return html`\n <span class=\"tooltip\" role=\"tooltip\">\n <span class=\"tooltip-name\">${user.name}</span>\n <span class=\"tooltip-meta\">${meta}</span>\n </span>\n `;\n }\n\n override render() {\n if (this.loading) {\n const placeholders = Math.min(this.maxVisible, 4);\n return html`\n <div class=\"container\" aria-busy=\"true\" aria-label=\"Loading presence\">\n <div class=\"avatar-stack\">\n ${Array.from({ length: placeholders }).map(() => html`<span class=\"skeleton\"></span>`)}\n </div>\n </div>\n `;\n }\n\n const visible = this.users.slice(0, this.maxVisible);\n const overflow = this.users.length - this.maxVisible;\n const avSize = this._avatarSize();\n\n return html`\n <div class=\"container\" role=\"group\" aria-label=\"Active users\" aria-live=\"polite\">\n <div class=\"avatar-stack\">\n ${visible.map(user => html`\n <div class=\"avatar-wrapper\">\n <button\n class=\"avatar-btn\"\n aria-label=\"${user.name}, ${STATUS_LABEL[user.status]}${user.lastSeen ? `, last seen ${user.lastSeen}` : ''}\"\n @click=${() => this._handleUserClick(user)}\n >\n <cg-avatar\n size=${avSize}\n shape=\"circle\"\n name=${user.name}\n src=${user.avatar ?? ''}\n status=${user.status}\n ></cg-avatar>\n </button>\n ${this._renderTooltip(user)}\n </div>\n `)}\n ${overflow > 0\n ? html`<span class=\"overflow-badge\" aria-label=\"${overflow} more users\">+${overflow}</span>`\n : nothing}\n </div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-presence': AiPresence;\n }\n}\n"],"names":["STATUS_LABEL","AiPresence","LitElement","user","statusText","meta","html","placeholders","visible","overflow","avSize","nothing","hostBase","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
@@ -1,9 +1,9 @@
1
- import { css as u, LitElement as g, nothing as p, html as c } from "lit";
1
+ import { css as u, LitElement as g, nothing as p, html as i } from "lit";
2
2
  import { property as d, customElement as v } from "lit/decorators.js";
3
- import { h as f, r as b, f as h } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as f, r as b, f as h } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var m = Object.defineProperty, x = Object.getOwnPropertyDescriptor, l = (r, t, e, o) => {
5
- for (var a = o > 1 ? void 0 : o ? x(t, e) : t, i = r.length - 1, n; i >= 0; i--)
6
- (n = r[i]) && (a = (o ? n(t, e, a) : n(a)) || a);
5
+ for (var a = o > 1 ? void 0 : o ? x(t, e) : t, c = r.length - 1, n; c >= 0; c--)
6
+ (n = r[c]) && (a = (o ? n(t, e, a) : n(a)) || a);
7
7
  return o && a && m(t, e, a), a;
8
8
  };
9
9
  let s = class extends g {
@@ -31,11 +31,11 @@ let s = class extends g {
31
31
  }
32
32
  render() {
33
33
  const r = this.phases.length;
34
- return c`
34
+ return i`
35
35
  <div class="steps" role="list" aria-label="Progress steps">
36
36
  ${this.phases.map((t, e) => {
37
37
  const o = e > 0 && this.phases[e - 1].status === "complete";
38
- return c`
38
+ return i`
39
39
  <button
40
40
  class="step"
41
41
  role="listitem"
@@ -47,13 +47,13 @@ let s = class extends g {
47
47
  <div class="step-row">
48
48
  <div class="line ${e === 0 ? "hide" : ""} ${o ? "done" : ""}"></div>
49
49
  <div class="dot" data-status=${t.status}>
50
- ${this._statusIcon(t.status) || c`${e + 1}`}
50
+ ${this._statusIcon(t.status) || i`${e + 1}`}
51
51
  </div>
52
52
  <div class="line ${e === r - 1 ? "hide" : ""} ${t.status === "complete" ? "done" : ""}"></div>
53
53
  </div>
54
54
  <div class="info">
55
55
  <div class="label">${t.label}</div>
56
- ${t.duration ? c`<div class="duration">${t.duration}</div>` : p}
56
+ ${t.duration ? i`<div class="duration">${t.duration}</div>` : p}
57
57
  </div>
58
58
  </button>
59
59
  `;
@@ -95,7 +95,7 @@ s.styles = [f, b, h, u`
95
95
  transform: scale(var(--cg-interaction-press-scale));
96
96
  }
97
97
  .step:focus-visible {
98
- outline: 2px solid var(--cg-overlay-accent-strong);
98
+ outline: var(--cg-outline-width-default) solid var(--cg-color-focus-ring);
99
99
  outline-offset: var(--cg-outline-offset-default);
100
100
  border-radius: var(--cg-border-radius-50);
101
101
  }
@@ -108,7 +108,7 @@ s.styles = [f, b, h, u`
108
108
 
109
109
  .line {
110
110
  flex: 1;
111
- height: 2px;
111
+ height: var(--cg-border-width-100);
112
112
  background: var(--cg-color-surface-cards-border);
113
113
  transition: background var(--cg-transition-duration-default) var(--cg-transition-easing-default);
114
114
  }
@@ -160,7 +160,7 @@ s.styles = [f, b, h, u`
160
160
  }
161
161
 
162
162
  .label {
163
- font-size: var(--cg-font-size-xs);
163
+ font-size: var(--cg-font-size-sm);
164
164
  font-weight: var(--cg-font-weight-medium);
165
165
  color: var(--cg-color-input-text-placeholder);
166
166
  white-space: nowrap;
@@ -1 +1 @@
1
- {"version":3,"file":"ai-progress-steps.js","sources":["../../../src/components/ai-progress-steps/ai-progress-steps.ts"],"sourcesContent":["/**\n * @element ai-progress-steps\n * Horizontal step indicator for multi-phase AI pipelines. Shows connected\n * dots with status icons (pending/active/complete/error), pulse animation\n * on the active phase, and optional duration labels. Supports compact mode.\n *\n * @example\n * ```html\n * <ai-progress-steps .phases=${[\n * { label: 'Retrieve', status: 'complete', duration: '0.3s' },\n * { label: 'Analyze', status: 'active' },\n * { label: 'Generate', status: 'pending' }\n * ]}></ai-progress-steps>\n * ```\n *\n * @prop {ProgressPhase[]} phases - Array of phase objects with label, status, duration\n * @prop {boolean} compact - Hide labels and shrink dots\n *\n * @fires {CustomEvent<{label: string, status: string, index: number}>} ai-progress-phase-click - When a phase is clicked\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\nexport interface ProgressPhase {\n label: string;\n status: 'pending' | 'active' | 'complete' | 'error';\n duration?: string;\n}\n\n@customElement('ai-progress-steps')\nexport class AiProgressSteps extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n :host([hidden]) { display: none; }\n\n .steps {\n display: flex;\n align-items: flex-start;\n gap: 0;\n width: 100%;\n }\n\n .step {\n display: flex;\n flex-direction: column;\n align-items: center;\n flex: 1;\n position: relative;\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-family: inherit;\n color: inherit;\n }\n .step:hover .dot {\n border-color: var(--cg-color-input-border-hover);\n }\n .step:active {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .step:focus-visible {\n outline: 2px solid var(--cg-overlay-accent-strong);\n outline-offset: var(--cg-outline-offset-default);\n border-radius: var(--cg-border-radius-50);\n }\n\n .step-row {\n display: flex;\n align-items: center;\n width: 100%;\n }\n\n .line {\n flex: 1;\n height: 2px;\n background: var(--cg-color-surface-cards-border);\n transition: background var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .line.done {\n background: var(--cg-color-action-primary-background-default);\n }\n .line.hide { visibility: hidden; }\n\n .dot {\n flex-shrink: 0;\n width: var(--cg-spacing-24);\n height: var(--cg-spacing-24);\n border-radius: 50%;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n border: var(--cg-border-width-100) solid var(--cg-color-surface-cards-border);\n background: var(--cg-color-surface-container-background);\n color: var(--cg-color-input-text-placeholder);\n transition: opacity var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n\n .dot[data-status=\"complete\"] {\n border-color: var(--cg-color-surface-base-text);\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-surface-container-background);\n }\n .dot[data-status=\"active\"] {\n border-color: var(--cg-color-surface-base-text);\n color: var(--cg-color-surface-base-text);\n animation: pulse 1.5s ease-in-out infinite;\n }\n .dot[data-status=\"error\"] {\n border-color: var(--cg-color-status-error-text-default);\n background: var(--cg-color-status-error-background-default);\n color: var(--cg-color-status-error-text-default);\n }\n\n @keyframes pulse {\n 0%, 100% { opacity: 1; }\n 50% { opacity: 0.6; }\n }\n\n .info {\n margin-top: var(--cg-spacing-6);\n text-align: center;\n }\n\n .label {\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-input-text-placeholder);\n white-space: nowrap;\n }\n .step[data-status=\"active\"] .label {\n color: var(--cg-color-surface-base-text);\n }\n .step[data-status=\"complete\"] .label {\n color: var(--cg-color-surface-base-text);\n }\n .step[data-status=\"error\"] .label {\n color: var(--cg-color-status-error-text-default);\n }\n\n .duration {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n margin-top: var(--cg-spacing-2);\n }\n\n /* Compact mode */\n :host([compact]) .dot { width: var(--cg-spacing-20); height: var(--cg-spacing-20); font-size: var(--cg-font-size-xs); }\n :host([compact]) .info { display: none; }\n\n `];\n\n @property({ type: Array }) phases: ProgressPhase[] = [];\n @property({ type: Boolean, reflect: true }) compact = false;\n\n private _statusIcon(status: string): string {\n switch (status) {\n case 'complete': return '\\u2713';\n case 'error': return '\\u2717';\n case 'active': return '\\u25CF';\n default: return '';\n }\n }\n\n private _handlePhaseClick(phase: ProgressPhase, index: number): void {\n this.dispatchEvent(new CustomEvent('ai-progress-phase-click', {\n detail: { label: phase.label, status: phase.status, index },\n bubbles: true,\n composed: true,\n }));\n }\n\n override render() {\n const len = this.phases.length;\n return html`\n <div class=\"steps\" role=\"list\" aria-label=\"Progress steps\">\n ${this.phases.map((phase, i) => {\n const prevDone = i > 0 && (this.phases[i - 1]!.status === 'complete');\n return html`\n <button\n class=\"step\"\n role=\"listitem\"\n tabindex=\"0\"\n data-status=${phase.status}\n aria-label=${`${phase.label}: ${phase.status}`}\n @click=${() => this._handlePhaseClick(phase, i)}\n >\n <div class=\"step-row\">\n <div class=\"line ${i === 0 ? 'hide' : ''} ${prevDone ? 'done' : ''}\"></div>\n <div class=\"dot\" data-status=${phase.status}>\n ${this._statusIcon(phase.status) || html`${i + 1}`}\n </div>\n <div class=\"line ${i === len - 1 ? 'hide' : ''} ${phase.status === 'complete' ? 'done' : ''}\"></div>\n </div>\n <div class=\"info\">\n <div class=\"label\">${phase.label}</div>\n ${phase.duration ? html`<div class=\"duration\">${phase.duration}</div>` : nothing}\n </div>\n </button>\n `;\n })}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-progress-steps': AiProgressSteps;\n }\n}\n"],"names":["AiProgressSteps","LitElement","status","phase","index","len","html","i","prevDone","nothing","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-progress-steps.js","sources":["../../../src/components/ai-progress-steps/ai-progress-steps.ts"],"sourcesContent":["/**\n * @element ai-progress-steps\n * Horizontal step indicator for multi-phase AI pipelines. Shows connected\n * dots with status icons (pending/active/complete/error), pulse animation\n * on the active phase, and optional duration labels. Supports compact mode.\n *\n * @example\n * ```html\n * <ai-progress-steps .phases=${[\n * { label: 'Retrieve', status: 'complete', duration: '0.3s' },\n * { label: 'Analyze', status: 'active' },\n * { label: 'Generate', status: 'pending' }\n * ]}></ai-progress-steps>\n * ```\n *\n * @prop {ProgressPhase[]} phases - Array of phase objects with label, status, duration\n * @prop {boolean} compact - Hide labels and shrink dots\n *\n * @fires {CustomEvent<{label: string, status: string, index: number}>} ai-progress-phase-click - When a phase is clicked\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\nexport interface ProgressPhase {\n label: string;\n status: 'pending' | 'active' | 'complete' | 'error';\n duration?: string;\n}\n\n@customElement('ai-progress-steps')\nexport class AiProgressSteps extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n :host([hidden]) { display: none; }\n\n .steps {\n display: flex;\n align-items: flex-start;\n gap: 0;\n width: 100%;\n }\n\n .step {\n display: flex;\n flex-direction: column;\n align-items: center;\n flex: 1;\n position: relative;\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-family: inherit;\n color: inherit;\n }\n .step:hover .dot {\n border-color: var(--cg-color-input-border-hover);\n }\n .step:active {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .step:focus-visible {\n outline: var(--cg-outline-width-default) solid var(--cg-color-focus-ring);\n outline-offset: var(--cg-outline-offset-default);\n border-radius: var(--cg-border-radius-50);\n }\n\n .step-row {\n display: flex;\n align-items: center;\n width: 100%;\n }\n\n .line {\n flex: 1;\n height: var(--cg-border-width-100);\n background: var(--cg-color-surface-cards-border);\n transition: background var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .line.done {\n background: var(--cg-color-action-primary-background-default);\n }\n .line.hide { visibility: hidden; }\n\n .dot {\n flex-shrink: 0;\n width: var(--cg-spacing-24);\n height: var(--cg-spacing-24);\n border-radius: 50%;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n border: var(--cg-border-width-100) solid var(--cg-color-surface-cards-border);\n background: var(--cg-color-surface-container-background);\n color: var(--cg-color-input-text-placeholder);\n transition: opacity var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n\n .dot[data-status=\"complete\"] {\n border-color: var(--cg-color-surface-base-text);\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-surface-container-background);\n }\n .dot[data-status=\"active\"] {\n border-color: var(--cg-color-surface-base-text);\n color: var(--cg-color-surface-base-text);\n animation: pulse 1.5s ease-in-out infinite;\n }\n .dot[data-status=\"error\"] {\n border-color: var(--cg-color-status-error-text-default);\n background: var(--cg-color-status-error-background-default);\n color: var(--cg-color-status-error-text-default);\n }\n\n @keyframes pulse {\n 0%, 100% { opacity: 1; }\n 50% { opacity: 0.6; }\n }\n\n .info {\n margin-top: var(--cg-spacing-6);\n text-align: center;\n }\n\n .label {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-input-text-placeholder);\n white-space: nowrap;\n }\n .step[data-status=\"active\"] .label {\n color: var(--cg-color-surface-base-text);\n }\n .step[data-status=\"complete\"] .label {\n color: var(--cg-color-surface-base-text);\n }\n .step[data-status=\"error\"] .label {\n color: var(--cg-color-status-error-text-default);\n }\n\n .duration {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n margin-top: var(--cg-spacing-2);\n }\n\n /* Compact mode */\n :host([compact]) .dot { width: var(--cg-spacing-20); height: var(--cg-spacing-20); font-size: var(--cg-font-size-xs); }\n :host([compact]) .info { display: none; }\n\n `];\n\n @property({ type: Array }) phases: ProgressPhase[] = [];\n @property({ type: Boolean, reflect: true }) compact = false;\n\n private _statusIcon(status: string): string {\n switch (status) {\n case 'complete': return '\\u2713';\n case 'error': return '\\u2717';\n case 'active': return '\\u25CF';\n default: return '';\n }\n }\n\n private _handlePhaseClick(phase: ProgressPhase, index: number): void {\n this.dispatchEvent(new CustomEvent('ai-progress-phase-click', {\n detail: { label: phase.label, status: phase.status, index },\n bubbles: true,\n composed: true,\n }));\n }\n\n override render() {\n const len = this.phases.length;\n return html`\n <div class=\"steps\" role=\"list\" aria-label=\"Progress steps\">\n ${this.phases.map((phase, i) => {\n const prevDone = i > 0 && (this.phases[i - 1]!.status === 'complete');\n return html`\n <button\n class=\"step\"\n role=\"listitem\"\n tabindex=\"0\"\n data-status=${phase.status}\n aria-label=${`${phase.label}: ${phase.status}`}\n @click=${() => this._handlePhaseClick(phase, i)}\n >\n <div class=\"step-row\">\n <div class=\"line ${i === 0 ? 'hide' : ''} ${prevDone ? 'done' : ''}\"></div>\n <div class=\"dot\" data-status=${phase.status}>\n ${this._statusIcon(phase.status) || html`${i + 1}`}\n </div>\n <div class=\"line ${i === len - 1 ? 'hide' : ''} ${phase.status === 'complete' ? 'done' : ''}\"></div>\n </div>\n <div class=\"info\">\n <div class=\"label\">${phase.label}</div>\n ${phase.duration ? html`<div class=\"duration\">${phase.duration}</div>` : nothing}\n </div>\n </button>\n `;\n })}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-progress-steps': AiProgressSteps;\n }\n}\n"],"names":["AiProgressSteps","LitElement","status","phase","index","len","html","i","prevDone","nothing","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","customElement"],"mappings":";;;;;;;;AA+BO,IAAMA,IAAN,cAA8BC,EAAW;AAAA,EAAzC,cAAA;AAAA,UAAA,GAAA,SAAA,GA8HsB,KAAA,SAA0B,CAAA,GACT,KAAA,UAAU;AAAA,EAAA;AAAA,EAE9C,YAAYC,GAAwB;AAC1C,YAAQA,GAAA;AAAA,MACN,KAAK;AAAY,eAAO;AAAA,MACxB,KAAK;AAAS,eAAO;AAAA,MACrB,KAAK;AAAU,eAAO;AAAA,MACtB;AAAS,eAAO;AAAA,IAAA;AAAA,EAEpB;AAAA,EAEQ,kBAAkBC,GAAsBC,GAAqB;AACnE,SAAK,cAAc,IAAI,YAAY,2BAA2B;AAAA,MAC5D,QAAQ,EAAE,OAAOD,EAAM,OAAO,QAAQA,EAAM,QAAQ,OAAAC,EAAA;AAAA,MACpD,SAAS;AAAA,MACT,UAAU;AAAA,IAAA,CACX,CAAC;AAAA,EACJ;AAAA,EAES,SAAS;AAChB,UAAMC,IAAM,KAAK,OAAO;AACxB,WAAOC;AAAA;AAAA,UAED,KAAK,OAAO,IAAI,CAACH,GAAOI,MAAM;AAC9B,YAAMC,IAAWD,IAAI,KAAM,KAAK,OAAOA,IAAI,CAAC,EAAG,WAAW;AAC1D,aAAOD;AAAA;AAAA;AAAA;AAAA;AAAA,4BAKWH,EAAM,MAAM;AAAA,2BACb,GAAGA,EAAM,KAAK,KAAKA,EAAM,MAAM,EAAE;AAAA,uBACrC,MAAM,KAAK,kBAAkBA,GAAOI,CAAC,CAAC;AAAA;AAAA;AAAA,mCAG1BA,MAAM,IAAI,SAAS,EAAE,IAAIC,IAAW,SAAS,EAAE;AAAA,+CACnCL,EAAM,MAAM;AAAA,oBACvC,KAAK,YAAYA,EAAM,MAAM,KAAKG,IAAOC,IAAI,CAAC,EAAE;AAAA;AAAA,mCAEjCA,MAAMF,IAAM,IAAI,SAAS,EAAE,IAAIF,EAAM,WAAW,aAAa,SAAS,EAAE;AAAA;AAAA;AAAA,qCAGtEA,EAAM,KAAK;AAAA,kBAC9BA,EAAM,WAAWG,0BAA6BH,EAAM,QAAQ,WAAWM,CAAO;AAAA;AAAA;AAAA;AAAA,IAIxF,CAAC,CAAC;AAAA;AAAA;AAAA,EAGR;AACF;AAlLaT,EACK,SAAS,CAACU,GAAWC,GAAeC,GAAsBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GA2HzE;AAE0BC,EAAA;AAAA,EAA1BC,EAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GA9Hdf,EA8HgB,WAAA,UAAA,CAAA;AACiBc,EAAA;AAAA,EAA3CC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GA/H/Bf,EA+HiC,WAAA,WAAA,CAAA;AA/HjCA,IAANc,EAAA;AAAA,EADNE,EAAc,mBAAmB;AAAA,GACrBhB,CAAA;"}
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as u, nothing as c, html as r } from "lit";
2
2
  import { property as v, state as g, customElement as f } from "lit/decorators.js";
3
- import { h, r as b } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h, r as b } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var m = Object.defineProperty, w = Object.getOwnPropertyDescriptor, s = (e, t, i, n) => {
5
5
  for (var o = n > 1 ? void 0 : n ? w(t, i) : t, d = e.length - 1, l; d >= 0; d--)
6
6
  (l = e[d]) && (o = (n ? l(t, i, o) : l(o)) || o);