@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,12 +1,12 @@
1
- import { css as p, LitElement as v, nothing as u, html as c } from "lit";
1
+ import { css as v, LitElement as p, nothing as u, html as c } from "lit";
2
2
  import { property as n, state as g, customElement as m } 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 f = Object.defineProperty, y = Object.getOwnPropertyDescriptor, a = (e, r, i, s) => {
5
5
  for (var o = s > 1 ? void 0 : s ? y(r, i) : r, d = e.length - 1, l; d >= 0; d--)
6
6
  (l = e[d]) && (o = (s ? l(r, i, o) : l(o)) || o);
7
7
  return s && o && f(r, i, o), o;
8
8
  };
9
- let t = class extends v {
9
+ let t = class extends p {
10
10
  constructor() {
11
11
  super(...arguments), this.variant = "default", this.rounded = "md", this.shortTerm = [], this.longTerm = [], this.searchable = !0, this._activeTab = "short", this._search = "";
12
12
  }
@@ -78,7 +78,7 @@ let t = class extends v {
78
78
  `;
79
79
  }
80
80
  };
81
- t.styles = [h, b, p`
81
+ t.styles = [h, b, v`
82
82
 
83
83
  /* ── Default variant — bordered panel ── */
84
84
  .panel {
@@ -124,7 +124,7 @@ t.styles = [h, b, p`
124
124
  .tab-count {
125
125
  font-size: var(--cg-font-size-xs);
126
126
  margin-left: var(--cg-spacing-4);
127
- opacity: 0.5;
127
+ opacity: var(--cg-opacity-50);
128
128
  }
129
129
 
130
130
  /* ── Search ── */
@@ -135,7 +135,7 @@ t.styles = [h, b, p`
135
135
  border-radius: var(--cg-border-radius-100);
136
136
  border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);
137
137
  background: transparent; color: var(--cg-color-surface-base-text);
138
- font: inherit; font-size: var(--cg-font-size-xs); outline: none;
138
+ font: inherit; font-size: var(--cg-font-size-sm); outline: none;
139
139
  }
140
140
  .search-input:focus { border-color: var(--cg-color-input-border-focus); }
141
141
  .search-input::placeholder { color: var(--cg-color-surface-container-outlined); }
@@ -193,7 +193,7 @@ t.styles = [h, b, p`
193
193
  }
194
194
  .mem-btn svg { width: var(--cg-spacing-12); height: var(--cg-spacing-12); }
195
195
  .mem-btn:hover { color: var(--cg-color-surface-base-text); }
196
- .mem-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong); opacity: 1; }
196
+ .mem-btn:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-focus-ring-width) var(--cg-overlay-accent-strong); opacity: 1; }
197
197
  .mem-btn.pinned-btn { color: var(--cg-color-action-primary-background-default); opacity: 1; }
198
198
 
199
199
  .empty {
@@ -1 +1 @@
1
- {"version":3,"file":"ai-memory-panel.js","sources":["../../../src/components/ai-memory-panel/ai-memory-panel.ts"],"sourcesContent":["/**\n * @element ai-memory-panel\n * Agent memory viewer. Three variants: default (full panel), compact (sidebar), inline (no container).\n *\n * @fires {CustomEvent<{id: string, type: string}>} ai-memory-delete\n * @fires {CustomEvent<{id: string, pinned: boolean}>} ai-memory-pin\n * @fires {CustomEvent<{query: string}>} ai-memory-search\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\nexport interface Memory {\n id: string;\n content: string;\n type: 'fact' | 'preference' | 'instruction' | 'context';\n timestamp: number;\n relevance?: number;\n pinned?: boolean;\n}\n\n@customElement('ai-memory-panel')\nexport class AiMemoryPanel extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n\n /* ── Default variant — bordered panel ── */\n .panel {\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-100);\n overflow: hidden;\n }\n\n /* ── Rounded ── */\n :host([rounded=\"none\"]) .panel { border-radius: 0; }\n :host([rounded=\"sm\"]) .panel { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .panel { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .panel { border-radius: var(--cg-border-radius-150); }\n\n /* ── Inline variant — no container ── */\n :host([variant=\"inline\"]) .panel {\n background: transparent;\n border: none;\n border-radius: 0;\n }\n\n /* ── Tabs ── */\n .tabs {\n display: flex;\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n .tab {\n flex: 1; padding: var(--cg-spacing-16) var(--cg-spacing-20); text-align: center;\n font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-container-outlined);\n background: none; border: none;\n border-bottom: var(--cg-border-width-100) solid transparent;\n cursor: pointer; font-family: inherit;\n transition: color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .tab:hover { color: var(--cg-color-surface-base-text); }\n .tab.active {\n color: var(--cg-color-action-primary-background-default);\n border-bottom-color: var(--cg-color-action-primary-background-default);\n font-weight: var(--cg-font-weight-semibold);\n }\n .tab-count {\n font-size: var(--cg-font-size-xs);\n margin-left: var(--cg-spacing-4);\n opacity: 0.5;\n }\n\n /* ── Search ── */\n .search-row { padding: var(--cg-spacing-16) var(--cg-spacing-20); }\n .search-input {\n width: 100%; box-sizing: border-box;\n padding: var(--cg-spacing-12) var(--cg-spacing-16);\n border-radius: var(--cg-border-radius-100);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n background: transparent; color: var(--cg-color-surface-base-text);\n font: inherit; font-size: var(--cg-font-size-xs); outline: none;\n }\n .search-input:focus { border-color: var(--cg-color-input-border-focus); }\n .search-input::placeholder { color: var(--cg-color-surface-container-outlined); }\n\n /* ── Memory list ── */\n .memories { max-height: 320px; overflow-y: auto; padding: var(--cg-spacing-12) 0; }\n\n .memory {\n display: flex; flex-direction: column; gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-16) var(--cg-spacing-20);\n border-radius: var(--cg-border-radius-50);\n margin: 0 var(--cg-spacing-8);\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n position: relative;\n }\n .memory:hover { background: var(--cg-overlay-dark-subtle); }\n .memory.pinned { background: var(--cg-overlay-accent-subtle); }\n\n .memory-row {\n display: flex; align-items: center; gap: var(--cg-spacing-12);\n }\n\n .memory-type {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-action-primary-background-default);\n font-weight: var(--cg-font-weight-medium);\n flex-shrink: 0;\n }\n\n .memory-meta {\n font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined);\n margin-left: auto; flex-shrink: 0;\n }\n\n .memory-content {\n font-size: var(--cg-font-size-sm); color: var(--cg-color-surface-base-text);\n line-height: var(--cg-line-height-snug);\n }\n\n /* ── Actions — show on hover ── */\n .memory-actions {\n position: absolute; top: var(--cg-spacing-8); right: var(--cg-spacing-16);\n display: flex; gap: var(--cg-spacing-2);\n opacity: 0; transition: opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .memory:hover .memory-actions { opacity: 1; }\n\n .mem-btn {\n width: var(--cg-spacing-20); height: var(--cg-spacing-20);\n background: transparent; border: none;\n color: var(--cg-color-surface-container-outlined); cursor: pointer;\n display: flex; align-items: center; justify-content: center; padding: 0;\n border-radius: var(--cg-border-radius-50);\n transition: color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .mem-btn svg { width: var(--cg-spacing-12); height: var(--cg-spacing-12); }\n .mem-btn:hover { color: var(--cg-color-surface-base-text); }\n .mem-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong); opacity: 1; }\n .mem-btn.pinned-btn { color: var(--cg-color-action-primary-background-default); opacity: 1; }\n\n .empty {\n padding: var(--cg-spacing-24) var(--cg-spacing-20);\n text-align: center; color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-xs);\n }\n\n /* ── Compact variant ── */\n :host([variant=\"compact\"]) .search-row { display: none; }\n :host([variant=\"compact\"]) .memory { padding: var(--cg-spacing-6) var(--cg-spacing-12); }\n :host([variant=\"compact\"]) .memory-content { font-size: var(--cg-font-size-xs); }\n :host([variant=\"compact\"]) .memory-type { display: none; }\n `];\n\n @property({ reflect: true }) variant: 'default' | 'compact' | 'inline' = 'default';\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' = 'md';\n @property({ type: Array }) shortTerm: Memory[] = [];\n @property({ type: Array }) longTerm: Memory[] = [];\n @property({ type: Boolean }) searchable = true;\n\n @state() private _activeTab: 'short' | 'long' = 'short';\n @state() private _search = '';\n private _searchTimer?: ReturnType<typeof setTimeout>;\n\n private get _activeMemories(): Memory[] {\n const list = this._activeTab === 'short' ? this.shortTerm : this.longTerm;\n if (!this._search) return list;\n const q = this._search.toLowerCase();\n return list.filter(m => m.content.toLowerCase().includes(q));\n }\n\n private _formatTime(ts: number): string {\n const diff = Date.now() - ts;\n if (diff < 60000) return 'just now';\n if (diff < 3600000) return `${Math.floor(diff / 60000)}m ago`;\n if (diff < 86400000) return `${Math.floor(diff / 3600000)}h ago`;\n return new Date(ts).toLocaleDateString('en-US', { month: 'short', day: 'numeric' });\n }\n\n override render() {\n const memories = this._activeMemories;\n\n return html`\n <div class=\"panel\" role=\"region\" aria-label=\"Agent memory\">\n <div class=\"tabs\">\n <button class=\"tab ${this._activeTab === 'short' ? 'active' : ''}\" @click=${() => { this._activeTab = 'short'; }}>\n Short-term<span class=\"tab-count\">${this.shortTerm.length}</span>\n </button>\n <button class=\"tab ${this._activeTab === 'long' ? 'active' : ''}\" @click=${() => { this._activeTab = 'long'; }}>\n Long-term<span class=\"tab-count\">${this.longTerm.length}</span>\n </button>\n </div>\n\n ${this.searchable && this.variant !== 'compact' ? html`\n <div class=\"search-row\">\n <input class=\"search-input\" type=\"text\" placeholder=\"Search...\"\n .value=${this._search}\n @input=${(e: Event) => {\n this._search = (e.target as HTMLInputElement).value;\n if (this._searchTimer) clearTimeout(this._searchTimer);\n this._searchTimer = setTimeout(() => {\n this.dispatchEvent(new CustomEvent('ai-memory-search', { bubbles: true, composed: true, detail: { query: this._search } }));\n }, 250);\n }} />\n </div>\n ` : nothing}\n\n <div class=\"memories\">\n ${memories.length === 0 ? html`\n <div class=\"empty\">${this._search ? 'No matches' : 'No memories yet'}</div>\n ` : memories.map(m => html`\n <div class=\"memory ${m.pinned ? 'pinned' : ''}\">\n <div class=\"memory-row\">\n <span class=\"memory-type\">${m.type}</span>\n <span class=\"memory-meta\">${this._formatTime(m.timestamp)}</span>\n </div>\n <div class=\"memory-content\">${m.content}</div>\n <div class=\"memory-actions\">\n <button class=\"mem-btn ${m.pinned ? 'pinned-btn' : ''}\"\n @click=${() => this.dispatchEvent(new CustomEvent('ai-memory-pin', { bubbles: true, composed: true, detail: { id: m.id, pinned: !m.pinned } }))}\n aria-label=\"${m.pinned ? 'Unpin' : 'Pin'}\">\n <svg viewBox=\"0 0 24 24\" fill=\"${m.pinned ? 'currentColor' : 'none'}\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"><path d=\"M12 17v5m-4-9.26a2 2 0 01.88-1.66L12 9l3.12 2.08a2 2 0 01.88 1.66V15H8v-2.26zM9 9V4a1 1 0 011-1h4a1 1 0 011 1v5\"/></svg>\n </button>\n <button class=\"mem-btn\"\n @click=${() => this.dispatchEvent(new CustomEvent('ai-memory-delete', { bubbles: true, composed: true, detail: { id: m.id, type: this._activeTab } }))}\n aria-label=\"Delete\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg>\n </button>\n </div>\n </div>\n `)}\n </div>\n </div>\n `;\n }\n}\n"],"names":["AiMemoryPanel","LitElement","list","q","m","ts","diff","memories","html","e","nothing","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":";;;;;;;;AAsBO,IAAMA,IAAN,cAA4BC,EAAW;AAAA,EAAvC,cAAA;AAAA,UAAA,GAAA,SAAA,GAoIwB,KAAA,UAA4C,WAC5C,KAAA,UAAuC,MACzC,KAAA,YAAsB,CAAA,GACtB,KAAA,WAAqB,CAAA,GACnB,KAAA,aAAa,IAEjC,KAAQ,aAA+B,SACvC,KAAQ,UAAU;AAAA,EAAA;AAAA,EAG3B,IAAY,kBAA4B;AACtC,UAAMC,IAAO,KAAK,eAAe,UAAU,KAAK,YAAY,KAAK;AACjE,QAAI,CAAC,KAAK,QAAS,QAAOA;AAC1B,UAAMC,IAAI,KAAK,QAAQ,YAAA;AACvB,WAAOD,EAAK,OAAO,CAAAE,MAAKA,EAAE,QAAQ,YAAA,EAAc,SAASD,CAAC,CAAC;AAAA,EAC7D;AAAA,EAEQ,YAAYE,GAAoB;AACtC,UAAMC,IAAO,KAAK,IAAA,IAAQD;AAC1B,WAAIC,IAAO,MAAc,aACrBA,IAAO,OAAgB,GAAG,KAAK,MAAMA,IAAO,GAAK,CAAC,UAClDA,IAAO,QAAiB,GAAG,KAAK,MAAMA,IAAO,IAAO,CAAC,UAClD,IAAI,KAAKD,CAAE,EAAE,mBAAmB,SAAS,EAAE,OAAO,SAAS,KAAK,WAAW;AAAA,EACpF;AAAA,EAES,SAAS;AAChB,UAAME,IAAW,KAAK;AAEtB,WAAOC;AAAA;AAAA;AAAA,+BAGoB,KAAK,eAAe,UAAU,WAAW,EAAE,YAAY,MAAM;AAAE,WAAK,aAAa;AAAA,IAAS,CAAC;AAAA,gDAC1E,KAAK,UAAU,MAAM;AAAA;AAAA,+BAEtC,KAAK,eAAe,SAAS,WAAW,EAAE,YAAY,MAAM;AAAE,WAAK,aAAa;AAAA,IAAQ,CAAC;AAAA,+CACzE,KAAK,SAAS,MAAM;AAAA;AAAA;AAAA;AAAA,UAIzD,KAAK,cAAc,KAAK,YAAY,YAAYA;AAAA;AAAA;AAAA,uBAGnC,KAAK,OAAO;AAAA,uBACZ,CAACC,MAAa;AACrB,WAAK,UAAWA,EAAE,OAA4B,OAC1C,KAAK,gBAAc,aAAa,KAAK,YAAY,GACrD,KAAK,eAAe,WAAW,MAAM;AACnC,aAAK,cAAc,IAAI,YAAY,oBAAoB,EAAE,SAAS,IAAM,UAAU,IAAM,QAAQ,EAAE,OAAO,KAAK,QAAA,EAAQ,CAAG,CAAC;AAAA,MAC5H,GAAG,GAAG;AAAA,IACR,CAAC;AAAA;AAAA,YAEHC,CAAO;AAAA;AAAA;AAAA,YAGPH,EAAS,WAAW,IAAIC;AAAA,iCACH,KAAK,UAAU,eAAe,iBAAiB;AAAA,cAClED,EAAS,IAAI,CAAAH,MAAKI;AAAA,iCACCJ,EAAE,SAAS,WAAW,EAAE;AAAA;AAAA,4CAEbA,EAAE,IAAI;AAAA,4CACN,KAAK,YAAYA,EAAE,SAAS,CAAC;AAAA;AAAA,4CAE7BA,EAAE,OAAO;AAAA;AAAA,yCAEZA,EAAE,SAAS,eAAe,EAAE;AAAA,2BAC1C,MAAM,KAAK,cAAc,IAAI,YAAY,iBAAiB,EAAE,SAAS,IAAM,UAAU,IAAM,QAAQ,EAAE,IAAIA,EAAE,IAAI,QAAQ,CAACA,EAAE,OAAA,EAAO,CAAG,CAAC,CAAC;AAAA,gCACjIA,EAAE,SAAS,UAAU,KAAK;AAAA,mDACPA,EAAE,SAAS,iBAAiB,MAAM;AAAA;AAAA;AAAA,2BAG1D,MAAM,KAAK,cAAc,IAAI,YAAY,oBAAoB,EAAE,SAAS,IAAM,UAAU,IAAM,QAAQ,EAAE,IAAIA,EAAE,IAAI,MAAM,KAAK,WAAA,EAAW,CAAG,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,WAM7J,CAAC;AAAA;AAAA;AAAA;AAAA,EAIV;AACF;AArNaJ,EACK,SAAS,CAACW,GAAWC,GAAeC;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;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAiInD;AAE4BC,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GApIhBf,EAoIkB,WAAA,WAAA,CAAA;AACAc,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GArIhBf,EAqIkB,WAAA,WAAA,CAAA;AACFc,EAAA;AAAA,EAA1BC,EAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GAtIdf,EAsIgB,WAAA,aAAA,CAAA;AACAc,EAAA;AAAA,EAA1BC,EAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GAvIdf,EAuIgB,WAAA,YAAA,CAAA;AACEc,EAAA;AAAA,EAA5BC,EAAS,EAAE,MAAM,QAAA,CAAS;AAAA,GAxIhBf,EAwIkB,WAAA,cAAA,CAAA;AAEZc,EAAA;AAAA,EAAhBE,EAAA;AAAM,GA1IIhB,EA0IM,WAAA,cAAA,CAAA;AACAc,EAAA;AAAA,EAAhBE,EAAA;AAAM,GA3IIhB,EA2IM,WAAA,WAAA,CAAA;AA3INA,IAANc,EAAA;AAAA,EADNG,EAAc,iBAAiB;AAAA,GACnBjB,CAAA;"}
1
+ {"version":3,"file":"ai-memory-panel.js","sources":["../../../src/components/ai-memory-panel/ai-memory-panel.ts"],"sourcesContent":["/**\n * @element ai-memory-panel\n * Agent memory viewer. Three variants: default (full panel), compact (sidebar), inline (no container).\n *\n * @fires {CustomEvent<{id: string, type: string}>} ai-memory-delete\n * @fires {CustomEvent<{id: string, pinned: boolean}>} ai-memory-pin\n * @fires {CustomEvent<{query: string}>} ai-memory-search\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\nexport interface Memory {\n id: string;\n content: string;\n type: 'fact' | 'preference' | 'instruction' | 'context';\n timestamp: number;\n relevance?: number;\n pinned?: boolean;\n}\n\n@customElement('ai-memory-panel')\nexport class AiMemoryPanel extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n\n /* ── Default variant — bordered panel ── */\n .panel {\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-100);\n overflow: hidden;\n }\n\n /* ── Rounded ── */\n :host([rounded=\"none\"]) .panel { border-radius: 0; }\n :host([rounded=\"sm\"]) .panel { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .panel { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .panel { border-radius: var(--cg-border-radius-150); }\n\n /* ── Inline variant — no container ── */\n :host([variant=\"inline\"]) .panel {\n background: transparent;\n border: none;\n border-radius: 0;\n }\n\n /* ── Tabs ── */\n .tabs {\n display: flex;\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n .tab {\n flex: 1; padding: var(--cg-spacing-16) var(--cg-spacing-20); text-align: center;\n font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-container-outlined);\n background: none; border: none;\n border-bottom: var(--cg-border-width-100) solid transparent;\n cursor: pointer; font-family: inherit;\n transition: color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .tab:hover { color: var(--cg-color-surface-base-text); }\n .tab.active {\n color: var(--cg-color-action-primary-background-default);\n border-bottom-color: var(--cg-color-action-primary-background-default);\n font-weight: var(--cg-font-weight-semibold);\n }\n .tab-count {\n font-size: var(--cg-font-size-xs);\n margin-left: var(--cg-spacing-4);\n opacity: var(--cg-opacity-50);\n }\n\n /* ── Search ── */\n .search-row { padding: var(--cg-spacing-16) var(--cg-spacing-20); }\n .search-input {\n width: 100%; box-sizing: border-box;\n padding: var(--cg-spacing-12) var(--cg-spacing-16);\n border-radius: var(--cg-border-radius-100);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n background: transparent; color: var(--cg-color-surface-base-text);\n font: inherit; font-size: var(--cg-font-size-sm); outline: none;\n }\n .search-input:focus { border-color: var(--cg-color-input-border-focus); }\n .search-input::placeholder { color: var(--cg-color-surface-container-outlined); }\n\n /* ── Memory list ── */\n .memories { max-height: 320px; overflow-y: auto; padding: var(--cg-spacing-12) 0; }\n\n .memory {\n display: flex; flex-direction: column; gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-16) var(--cg-spacing-20);\n border-radius: var(--cg-border-radius-50);\n margin: 0 var(--cg-spacing-8);\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n position: relative;\n }\n .memory:hover { background: var(--cg-overlay-dark-subtle); }\n .memory.pinned { background: var(--cg-overlay-accent-subtle); }\n\n .memory-row {\n display: flex; align-items: center; gap: var(--cg-spacing-12);\n }\n\n .memory-type {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-action-primary-background-default);\n font-weight: var(--cg-font-weight-medium);\n flex-shrink: 0;\n }\n\n .memory-meta {\n font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined);\n margin-left: auto; flex-shrink: 0;\n }\n\n .memory-content {\n font-size: var(--cg-font-size-sm); color: var(--cg-color-surface-base-text);\n line-height: var(--cg-line-height-snug);\n }\n\n /* ── Actions — show on hover ── */\n .memory-actions {\n position: absolute; top: var(--cg-spacing-8); right: var(--cg-spacing-16);\n display: flex; gap: var(--cg-spacing-2);\n opacity: 0; transition: opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .memory:hover .memory-actions { opacity: 1; }\n\n .mem-btn {\n width: var(--cg-spacing-20); height: var(--cg-spacing-20);\n background: transparent; border: none;\n color: var(--cg-color-surface-container-outlined); cursor: pointer;\n display: flex; align-items: center; justify-content: center; padding: 0;\n border-radius: var(--cg-border-radius-50);\n transition: color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .mem-btn svg { width: var(--cg-spacing-12); height: var(--cg-spacing-12); }\n .mem-btn:hover { color: var(--cg-color-surface-base-text); }\n .mem-btn:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-focus-ring-width) var(--cg-overlay-accent-strong); opacity: 1; }\n .mem-btn.pinned-btn { color: var(--cg-color-action-primary-background-default); opacity: 1; }\n\n .empty {\n padding: var(--cg-spacing-24) var(--cg-spacing-20);\n text-align: center; color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-xs);\n }\n\n /* ── Compact variant ── */\n :host([variant=\"compact\"]) .search-row { display: none; }\n :host([variant=\"compact\"]) .memory { padding: var(--cg-spacing-6) var(--cg-spacing-12); }\n :host([variant=\"compact\"]) .memory-content { font-size: var(--cg-font-size-xs); }\n :host([variant=\"compact\"]) .memory-type { display: none; }\n `];\n\n @property({ reflect: true }) variant: 'default' | 'compact' | 'inline' = 'default';\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' = 'md';\n @property({ type: Array }) shortTerm: Memory[] = [];\n @property({ type: Array }) longTerm: Memory[] = [];\n @property({ type: Boolean }) searchable = true;\n\n @state() private _activeTab: 'short' | 'long' = 'short';\n @state() private _search = '';\n private _searchTimer?: ReturnType<typeof setTimeout>;\n\n private get _activeMemories(): Memory[] {\n const list = this._activeTab === 'short' ? this.shortTerm : this.longTerm;\n if (!this._search) return list;\n const q = this._search.toLowerCase();\n return list.filter(m => m.content.toLowerCase().includes(q));\n }\n\n private _formatTime(ts: number): string {\n const diff = Date.now() - ts;\n if (diff < 60000) return 'just now';\n if (diff < 3600000) return `${Math.floor(diff / 60000)}m ago`;\n if (diff < 86400000) return `${Math.floor(diff / 3600000)}h ago`;\n return new Date(ts).toLocaleDateString('en-US', { month: 'short', day: 'numeric' });\n }\n\n override render() {\n const memories = this._activeMemories;\n\n return html`\n <div class=\"panel\" role=\"region\" aria-label=\"Agent memory\">\n <div class=\"tabs\">\n <button class=\"tab ${this._activeTab === 'short' ? 'active' : ''}\" @click=${() => { this._activeTab = 'short'; }}>\n Short-term<span class=\"tab-count\">${this.shortTerm.length}</span>\n </button>\n <button class=\"tab ${this._activeTab === 'long' ? 'active' : ''}\" @click=${() => { this._activeTab = 'long'; }}>\n Long-term<span class=\"tab-count\">${this.longTerm.length}</span>\n </button>\n </div>\n\n ${this.searchable && this.variant !== 'compact' ? html`\n <div class=\"search-row\">\n <input class=\"search-input\" type=\"text\" placeholder=\"Search...\"\n .value=${this._search}\n @input=${(e: Event) => {\n this._search = (e.target as HTMLInputElement).value;\n if (this._searchTimer) clearTimeout(this._searchTimer);\n this._searchTimer = setTimeout(() => {\n this.dispatchEvent(new CustomEvent('ai-memory-search', { bubbles: true, composed: true, detail: { query: this._search } }));\n }, 250);\n }} />\n </div>\n ` : nothing}\n\n <div class=\"memories\">\n ${memories.length === 0 ? html`\n <div class=\"empty\">${this._search ? 'No matches' : 'No memories yet'}</div>\n ` : memories.map(m => html`\n <div class=\"memory ${m.pinned ? 'pinned' : ''}\">\n <div class=\"memory-row\">\n <span class=\"memory-type\">${m.type}</span>\n <span class=\"memory-meta\">${this._formatTime(m.timestamp)}</span>\n </div>\n <div class=\"memory-content\">${m.content}</div>\n <div class=\"memory-actions\">\n <button class=\"mem-btn ${m.pinned ? 'pinned-btn' : ''}\"\n @click=${() => this.dispatchEvent(new CustomEvent('ai-memory-pin', { bubbles: true, composed: true, detail: { id: m.id, pinned: !m.pinned } }))}\n aria-label=\"${m.pinned ? 'Unpin' : 'Pin'}\">\n <svg viewBox=\"0 0 24 24\" fill=\"${m.pinned ? 'currentColor' : 'none'}\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"><path d=\"M12 17v5m-4-9.26a2 2 0 01.88-1.66L12 9l3.12 2.08a2 2 0 01.88 1.66V15H8v-2.26zM9 9V4a1 1 0 011-1h4a1 1 0 011 1v5\"/></svg>\n </button>\n <button class=\"mem-btn\"\n @click=${() => this.dispatchEvent(new CustomEvent('ai-memory-delete', { bubbles: true, composed: true, detail: { id: m.id, type: this._activeTab } }))}\n aria-label=\"Delete\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg>\n </button>\n </div>\n </div>\n `)}\n </div>\n </div>\n `;\n }\n}\n"],"names":["AiMemoryPanel","LitElement","list","q","m","ts","diff","memories","html","e","nothing","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as v, LitElement as b, nothing as n, html as t } from "lit";
2
2
  import { property as g, customElement as f } from "lit/decorators.js";
3
- import { h as p, r as h, f as m } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as p, r as h, f as m } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var w = Object.defineProperty, y = Object.getOwnPropertyDescriptor, l = (e, r, s, c) => {
5
5
  for (var a = c > 1 ? void 0 : c ? y(r, s) : r, o = e.length - 1, i; o >= 0; o--)
6
6
  (i = e[o]) && (a = (c ? i(r, s, a) : i(a)) || a);
@@ -250,7 +250,7 @@ d.styles = [p, h, m, v`
250
250
  padding: 0 var(--cg-spacing-6);
251
251
  height: var(--cg-spacing-16);
252
252
  border-radius: var(--cg-border-radius-full);
253
- font-size: 10px;
253
+ font-size: var(--cg-font-size-xs);
254
254
  font-weight: var(--cg-font-weight-bold);
255
255
  letter-spacing: var(--cg-letter-spacing-wide);
256
256
  text-transform: uppercase;
@@ -1 +1 @@
1
- {"version":3,"file":"ai-model-comparison.js","sources":["../../../src/components/ai-model-comparison/ai-model-comparison.ts"],"sourcesContent":["/**\n * @element ai-model-comparison\n * Side-by-side comparison table for AI models. Renders metrics as rows\n * with color-coded score bars, highlights the best score per metric with\n * a \"Best\" badge, sticky first column on overflow, and staggered fade-in.\n *\n * @example\n * ```html\n * <ai-model-comparison .models=${[\n * { name: 'GPT-4', provider: 'OpenAI', scores: { reasoning: 92, coding: 88 }, costTier: '$$$', contextWindow: 128000 },\n * { name: 'Claude 3', provider: 'Anthropic', scores: { reasoning: 95, coding: 91 }, costTier: '$$', contextWindow: 200000 }\n * ]}></ai-model-comparison>\n * ```\n *\n * @prop {ComparisonModel[]} models - Array of models with name, provider, scores, costTier, contextWindow\n *\n * @fires {CustomEvent<{model: ComparisonModel}>} ai-comparison-select - When a model's Select button is clicked\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\nexport interface ComparisonModel {\n name: string;\n provider: string;\n scores: Record<string, number>;\n costTier: string;\n contextWindow: number;\n}\n\n@customElement('ai-model-comparison')\nexport class AiModelComparison extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n animation: fadeSlideIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;\n }\n :host([hidden]) { display: none; }\n\n .wrapper {\n overflow-x: auto;\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n background: var(--cg-color-surface-cards-background);\n box-shadow: var(--cg-elevation-1);\n }\n\n /* ── Rounded variants ── */\n :host([rounded=\"none\"]) .wrapper { border-radius: 0; }\n :host([rounded=\"sm\"]) .wrapper { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .wrapper { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .wrapper { border-radius: var(--cg-border-radius-150); }\n :host([rounded=\"full\"]) .wrapper { border-radius: var(--cg-border-radius-full); }\n\n table {\n width: 100%;\n border-collapse: collapse;\n font-size: var(--cg-font-size-sm);\n }\n\n th, td {\n padding: var(--cg-spacing-12) var(--cg-spacing-16);\n text-align: left;\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n\n /* Hover scoped to data rows only (not header, not action row) */\n tbody tr.data-row:hover { background: var(--cg-overlay-dark-subtle); }\n\n th {\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 text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wide);\n position: sticky;\n top: 0;\n /* Slightly darker than the body — overlay token composited over the\n solid cards-background so the sticky header stays opaque on scroll. */\n background:\n linear-gradient(var(--cg-overlay-dark-subtle), var(--cg-overlay-dark-subtle)),\n var(--cg-color-surface-cards-background);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n z-index: 1;\n }\n\n /* Sticky first column — survives horizontal scroll on narrow viewports */\n th.sticky-col,\n td.sticky-col {\n position: sticky;\n left: 0;\n background: var(--cg-color-surface-cards-background);\n z-index: 2;\n }\n thead th.sticky-col {\n background:\n linear-gradient(var(--cg-overlay-dark-subtle), var(--cg-overlay-dark-subtle)),\n var(--cg-color-surface-cards-background);\n z-index: 3;\n }\n tbody tr.data-row:hover td.sticky-col {\n background: var(--cg-color-surface-cards-hover-background);\n }\n\n .model-header {\n text-align: center;\n min-width: var(--cg-spacing-128);\n }\n\n .model-name {\n color: var(--cg-color-surface-base-text);\n font-weight: var(--cg-font-weight-bold);\n font-size: var(--cg-font-size-sm);\n }\n\n .model-provider {\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-xs);\n }\n\n .metric-label {\n color: var(--cg-color-surface-base-text);\n font-weight: var(--cg-font-weight-semibold);\n white-space: nowrap;\n }\n\n .score-cell {\n text-align: center;\n font-variant-numeric: tabular-nums;\n }\n\n .score-bar-wrapper {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: var(--cg-spacing-4);\n }\n\n .score-row {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n }\n\n .score-bar-track {\n width: var(--cg-spacing-64);\n height: var(--cg-spacing-6);\n background: var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-50);\n overflow: hidden;\n }\n\n .score-bar-fill {\n height: 100%;\n width: 0;\n border-radius: var(--cg-border-radius-50);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n transition-delay: var(--bar-delay, 0ms);\n }\n .score-bar-fill.low { background: var(--cg-color-status-error-text-default); }\n .score-bar-fill.mid {\n background: linear-gradient(90deg,\n var(--cg-color-status-warning-text-default),\n var(--cg-color-status-success-text-default));\n }\n .score-bar-fill.high { background: var(--cg-color-status-success-text-default); }\n .score-bar-fill.best { background: var(--cg-color-action-primary-background-default); }\n\n .score-value {\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n\n /* Best-in-metric pill — color-blind-safe + scan-friendly */\n .best-pill {\n display: inline-flex;\n align-items: center;\n padding: 0 var(--cg-spacing-6);\n height: var(--cg-spacing-16);\n border-radius: var(--cg-border-radius-full);\n font-size: 10px;\n font-weight: var(--cg-font-weight-bold);\n letter-spacing: var(--cg-letter-spacing-wide);\n text-transform: uppercase;\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n }\n\n .meta-cell {\n text-align: center;\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-xs);\n }\n\n .cost-badge {\n display: inline-block;\n padding: var(--cg-spacing-2) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-50);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n background: var(--cg-color-surface-container-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n color: var(--cg-color-surface-base-text);\n }\n\n .select-btn {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n min-height: var(--cg-spacing-40);\n margin: var(--cg-spacing-4) auto 0;\n padding: var(--cg-spacing-8) var(--cg-spacing-16);\n border-radius: var(--cg-border-radius-100);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n background: transparent;\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n cursor: pointer;\n font-family: inherit;\n transition:\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .select-btn:hover {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n border-color: var(--cg-color-action-primary-background-default);\n }\n .select-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .select-btn:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n `];\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ type: Array }) models: ComparisonModel[] = [];\n\n private _getMetrics(): string[] {\n const set = new Set<string>();\n for (const m of this.models) {\n for (const k of Object.keys(m.scores)) set.add(k);\n }\n return Array.from(set);\n }\n\n private _bestScore(metric: string): number {\n return Math.max(...this.models.map(m => m.scores[metric] ?? 0));\n }\n\n private _scoreTier(score: number, best: number): string {\n if (score === best && this.models.length > 1) return 'best';\n if (score >= 80) return 'high';\n if (score >= 50) return 'mid';\n return 'low';\n }\n\n private _formatCtx(n: number): string {\n if (n >= 1000000) return `${(n / 1000000).toFixed(0)}M`;\n if (n >= 1000) return `${(n / 1000).toFixed(0)}K`;\n return `${n}`;\n }\n\n private _select(model: ComparisonModel) {\n this.dispatchEvent(new CustomEvent('ai-comparison-select', {\n detail: { model },\n bubbles: true, composed: true,\n }));\n }\n\n override render() {\n if (!this.models.length) return nothing;\n const metrics = this._getMetrics();\n\n return html`\n <div class=\"wrapper\" role=\"region\" aria-label=\"Model comparison table\">\n <table>\n <thead>\n <tr>\n <th class=\"sticky-col\"></th>\n ${this.models.map(m => html`\n <th class=\"model-header\" scope=\"col\">\n <div class=\"model-name\">${m.name}</div>\n <div class=\"model-provider\">${m.provider}</div>\n </th>\n `)}\n </tr>\n </thead>\n <tbody>\n ${metrics.map((metric, rowIdx) => {\n const best = this._bestScore(metric);\n return html`\n <tr class=\"data-row\">\n <td class=\"metric-label sticky-col\" scope=\"row\">${metric}</td>\n ${this.models.map(m => {\n const score = m.scores[metric] ?? 0;\n const tier = this._scoreTier(score, best);\n const delay = `${rowIdx * 60}ms`;\n return html`\n <td class=\"score-cell\">\n <div class=\"score-bar-wrapper\">\n <div class=\"score-row\">\n <span class=\"score-value\">${score}</span>\n ${tier === 'best' ? html`<span class=\"best-pill\" aria-label=\"Best in ${metric}\">Best</span>` : nothing}\n </div>\n <div class=\"score-bar-track\" role=\"progressbar\" aria-valuenow=${score} aria-valuemin=\"0\" aria-valuemax=\"100\" aria-label=\"${m.name} ${metric}\">\n <div class=\"score-bar-fill ${tier}\" style=\"width: ${score}%; --bar-delay: ${delay};\"></div>\n </div>\n </div>\n </td>\n `;\n })}\n </tr>\n `;\n })}\n <tr class=\"data-row\">\n <td class=\"metric-label sticky-col\">Cost Tier</td>\n ${this.models.map(m => html`\n <td class=\"meta-cell\"><span class=\"cost-badge\">${m.costTier}</span></td>\n `)}\n </tr>\n <tr class=\"data-row\">\n <td class=\"metric-label sticky-col\">Context Window</td>\n ${this.models.map(m => html`\n <td class=\"meta-cell\">${this._formatCtx(m.contextWindow)}</td>\n `)}\n </tr>\n <tr>\n <td class=\"sticky-col\"></td>\n ${this.models.map(m => html`\n <td class=\"meta-cell\">\n <button class=\"select-btn\" aria-label=\"Select ${m.name}\" @click=${() => this._select(m)}>\n Select\n </button>\n </td>\n `)}\n </tr>\n </tbody>\n </table>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-model-comparison': AiModelComparison;\n }\n}\n"],"names":["AiModelComparison","LitElement","set","m","k","metric","score","best","n","model","nothing","metrics","html","rowIdx","tier","delay","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-model-comparison.js","sources":["../../../src/components/ai-model-comparison/ai-model-comparison.ts"],"sourcesContent":["/**\n * @element ai-model-comparison\n * Side-by-side comparison table for AI models. Renders metrics as rows\n * with color-coded score bars, highlights the best score per metric with\n * a \"Best\" badge, sticky first column on overflow, and staggered fade-in.\n *\n * @example\n * ```html\n * <ai-model-comparison .models=${[\n * { name: 'GPT-4', provider: 'OpenAI', scores: { reasoning: 92, coding: 88 }, costTier: '$$$', contextWindow: 128000 },\n * { name: 'Claude 3', provider: 'Anthropic', scores: { reasoning: 95, coding: 91 }, costTier: '$$', contextWindow: 200000 }\n * ]}></ai-model-comparison>\n * ```\n *\n * @prop {ComparisonModel[]} models - Array of models with name, provider, scores, costTier, contextWindow\n *\n * @fires {CustomEvent<{model: ComparisonModel}>} ai-comparison-select - When a model's Select button is clicked\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\nexport interface ComparisonModel {\n name: string;\n provider: string;\n scores: Record<string, number>;\n costTier: string;\n contextWindow: number;\n}\n\n@customElement('ai-model-comparison')\nexport class AiModelComparison extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n animation: fadeSlideIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;\n }\n :host([hidden]) { display: none; }\n\n .wrapper {\n overflow-x: auto;\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n background: var(--cg-color-surface-cards-background);\n box-shadow: var(--cg-elevation-1);\n }\n\n /* ── Rounded variants ── */\n :host([rounded=\"none\"]) .wrapper { border-radius: 0; }\n :host([rounded=\"sm\"]) .wrapper { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .wrapper { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .wrapper { border-radius: var(--cg-border-radius-150); }\n :host([rounded=\"full\"]) .wrapper { border-radius: var(--cg-border-radius-full); }\n\n table {\n width: 100%;\n border-collapse: collapse;\n font-size: var(--cg-font-size-sm);\n }\n\n th, td {\n padding: var(--cg-spacing-12) var(--cg-spacing-16);\n text-align: left;\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n\n /* Hover scoped to data rows only (not header, not action row) */\n tbody tr.data-row:hover { background: var(--cg-overlay-dark-subtle); }\n\n th {\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 text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wide);\n position: sticky;\n top: 0;\n /* Slightly darker than the body — overlay token composited over the\n solid cards-background so the sticky header stays opaque on scroll. */\n background:\n linear-gradient(var(--cg-overlay-dark-subtle), var(--cg-overlay-dark-subtle)),\n var(--cg-color-surface-cards-background);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n z-index: 1;\n }\n\n /* Sticky first column — survives horizontal scroll on narrow viewports */\n th.sticky-col,\n td.sticky-col {\n position: sticky;\n left: 0;\n background: var(--cg-color-surface-cards-background);\n z-index: 2;\n }\n thead th.sticky-col {\n background:\n linear-gradient(var(--cg-overlay-dark-subtle), var(--cg-overlay-dark-subtle)),\n var(--cg-color-surface-cards-background);\n z-index: 3;\n }\n tbody tr.data-row:hover td.sticky-col {\n background: var(--cg-color-surface-cards-hover-background);\n }\n\n .model-header {\n text-align: center;\n min-width: var(--cg-spacing-128);\n }\n\n .model-name {\n color: var(--cg-color-surface-base-text);\n font-weight: var(--cg-font-weight-bold);\n font-size: var(--cg-font-size-sm);\n }\n\n .model-provider {\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-xs);\n }\n\n .metric-label {\n color: var(--cg-color-surface-base-text);\n font-weight: var(--cg-font-weight-semibold);\n white-space: nowrap;\n }\n\n .score-cell {\n text-align: center;\n font-variant-numeric: tabular-nums;\n }\n\n .score-bar-wrapper {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: var(--cg-spacing-4);\n }\n\n .score-row {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n }\n\n .score-bar-track {\n width: var(--cg-spacing-64);\n height: var(--cg-spacing-6);\n background: var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-50);\n overflow: hidden;\n }\n\n .score-bar-fill {\n height: 100%;\n width: 0;\n border-radius: var(--cg-border-radius-50);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n transition-delay: var(--bar-delay, 0ms);\n }\n .score-bar-fill.low { background: var(--cg-color-status-error-text-default); }\n .score-bar-fill.mid {\n background: linear-gradient(90deg,\n var(--cg-color-status-warning-text-default),\n var(--cg-color-status-success-text-default));\n }\n .score-bar-fill.high { background: var(--cg-color-status-success-text-default); }\n .score-bar-fill.best { background: var(--cg-color-action-primary-background-default); }\n\n .score-value {\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n\n /* Best-in-metric pill — color-blind-safe + scan-friendly */\n .best-pill {\n display: inline-flex;\n align-items: center;\n padding: 0 var(--cg-spacing-6);\n height: var(--cg-spacing-16);\n border-radius: var(--cg-border-radius-full);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n letter-spacing: var(--cg-letter-spacing-wide);\n text-transform: uppercase;\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n }\n\n .meta-cell {\n text-align: center;\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-xs);\n }\n\n .cost-badge {\n display: inline-block;\n padding: var(--cg-spacing-2) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-50);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n background: var(--cg-color-surface-container-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n color: var(--cg-color-surface-base-text);\n }\n\n .select-btn {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n min-height: var(--cg-spacing-40);\n margin: var(--cg-spacing-4) auto 0;\n padding: var(--cg-spacing-8) var(--cg-spacing-16);\n border-radius: var(--cg-border-radius-100);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n background: transparent;\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n cursor: pointer;\n font-family: inherit;\n transition:\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .select-btn:hover {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n border-color: var(--cg-color-action-primary-background-default);\n }\n .select-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .select-btn:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n `];\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ type: Array }) models: ComparisonModel[] = [];\n\n private _getMetrics(): string[] {\n const set = new Set<string>();\n for (const m of this.models) {\n for (const k of Object.keys(m.scores)) set.add(k);\n }\n return Array.from(set);\n }\n\n private _bestScore(metric: string): number {\n return Math.max(...this.models.map(m => m.scores[metric] ?? 0));\n }\n\n private _scoreTier(score: number, best: number): string {\n if (score === best && this.models.length > 1) return 'best';\n if (score >= 80) return 'high';\n if (score >= 50) return 'mid';\n return 'low';\n }\n\n private _formatCtx(n: number): string {\n if (n >= 1000000) return `${(n / 1000000).toFixed(0)}M`;\n if (n >= 1000) return `${(n / 1000).toFixed(0)}K`;\n return `${n}`;\n }\n\n private _select(model: ComparisonModel) {\n this.dispatchEvent(new CustomEvent('ai-comparison-select', {\n detail: { model },\n bubbles: true, composed: true,\n }));\n }\n\n override render() {\n if (!this.models.length) return nothing;\n const metrics = this._getMetrics();\n\n return html`\n <div class=\"wrapper\" role=\"region\" aria-label=\"Model comparison table\">\n <table>\n <thead>\n <tr>\n <th class=\"sticky-col\"></th>\n ${this.models.map(m => html`\n <th class=\"model-header\" scope=\"col\">\n <div class=\"model-name\">${m.name}</div>\n <div class=\"model-provider\">${m.provider}</div>\n </th>\n `)}\n </tr>\n </thead>\n <tbody>\n ${metrics.map((metric, rowIdx) => {\n const best = this._bestScore(metric);\n return html`\n <tr class=\"data-row\">\n <td class=\"metric-label sticky-col\" scope=\"row\">${metric}</td>\n ${this.models.map(m => {\n const score = m.scores[metric] ?? 0;\n const tier = this._scoreTier(score, best);\n const delay = `${rowIdx * 60}ms`;\n return html`\n <td class=\"score-cell\">\n <div class=\"score-bar-wrapper\">\n <div class=\"score-row\">\n <span class=\"score-value\">${score}</span>\n ${tier === 'best' ? html`<span class=\"best-pill\" aria-label=\"Best in ${metric}\">Best</span>` : nothing}\n </div>\n <div class=\"score-bar-track\" role=\"progressbar\" aria-valuenow=${score} aria-valuemin=\"0\" aria-valuemax=\"100\" aria-label=\"${m.name} ${metric}\">\n <div class=\"score-bar-fill ${tier}\" style=\"width: ${score}%; --bar-delay: ${delay};\"></div>\n </div>\n </div>\n </td>\n `;\n })}\n </tr>\n `;\n })}\n <tr class=\"data-row\">\n <td class=\"metric-label sticky-col\">Cost Tier</td>\n ${this.models.map(m => html`\n <td class=\"meta-cell\"><span class=\"cost-badge\">${m.costTier}</span></td>\n `)}\n </tr>\n <tr class=\"data-row\">\n <td class=\"metric-label sticky-col\">Context Window</td>\n ${this.models.map(m => html`\n <td class=\"meta-cell\">${this._formatCtx(m.contextWindow)}</td>\n `)}\n </tr>\n <tr>\n <td class=\"sticky-col\"></td>\n ${this.models.map(m => html`\n <td class=\"meta-cell\">\n <button class=\"select-btn\" aria-label=\"Select ${m.name}\" @click=${() => this._select(m)}>\n Select\n </button>\n </td>\n `)}\n </tr>\n </tbody>\n </table>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-model-comparison': AiModelComparison;\n }\n}\n"],"names":["AiModelComparison","LitElement","set","m","k","metric","score","best","n","model","nothing","metrics","html","rowIdx","tier","delay","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
@@ -1,12 +1,12 @@
1
- import { css as v, LitElement as h, html as i, nothing as d } from "lit";
2
- import { property as l, state as u, customElement as f } from "lit/decorators.js";
3
- import { h as p, r as b } from "../../chunks/premium.css-9I4kHrsl.js";
1
+ import { css as v, LitElement as f, html as i, nothing as d } from "lit";
2
+ import { property as l, state as u, customElement as h } from "lit/decorators.js";
3
+ import { h as p, r as b } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var m = Object.defineProperty, _ = Object.getOwnPropertyDescriptor, s = (e, t, r, c) => {
5
5
  for (var a = c > 1 ? void 0 : c ? _(t, r) : t, n = e.length - 1, g; n >= 0; n--)
6
6
  (g = e[n]) && (a = (c ? g(t, r, a) : g(a)) || a);
7
7
  return c && a && m(t, r, a), a;
8
8
  };
9
- let o = class extends h {
9
+ let o = class extends f {
10
10
  constructor() {
11
11
  super(...arguments), this.rounded = "lg", this.models = [], this.selected = "", this.multi = !1, this._selectedIds = /* @__PURE__ */ new Set(), this._activeFilter = "", this._focusedIndex = -1;
12
12
  }
@@ -107,7 +107,7 @@ o.styles = [p, b, v`
107
107
  transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
108
108
  }
109
109
  .filter-chip:hover { border-color: var(--cg-color-surface-cards-hover-border); color: var(--cg-color-surface-base-text); }
110
- .filter-chip:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong); }
110
+ .filter-chip:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-focus-ring-width) var(--cg-color-focus-ring); }
111
111
  .filter-chip.active { border-color: var(--cg-color-action-primary-background-default); color: var(--cg-color-action-primary-background-default); background: var(--cg-overlay-accent-subtle); }
112
112
 
113
113
  /* ── Grid ── */
@@ -129,7 +129,7 @@ o.styles = [p, b, v`
129
129
  }
130
130
  .model-card:hover { border-color: var(--cg-color-surface-cards-hover-border); background: var(--cg-color-surface-cards-hover-background); }
131
131
  .model-card:active { transform: scale(var(--cg-interaction-press-scale)); }
132
- .model-card:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong); }
132
+ .model-card:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-focus-ring-width) var(--cg-color-focus-ring); }
133
133
  .model-card.selected {
134
134
  border-color: var(--cg-color-action-primary-background-default);
135
135
  background: var(--cg-overlay-accent-subtle);
@@ -192,7 +192,7 @@ s([
192
192
  u()
193
193
  ], o.prototype, "_focusedIndex", 2);
194
194
  o = s([
195
- f("ai-model-selector")
195
+ h("ai-model-selector")
196
196
  ], o);
197
197
  export {
198
198
  o as AiModelSelector
@@ -1 +1 @@
1
- {"version":3,"file":"ai-model-selector.js","sources":["../../../src/components/ai-model-selector/ai-model-selector.ts"],"sourcesContent":["/**\n * @element ai-model-selector\n * Card grid for picking AI models. Single or multi-select with capability filters.\n *\n * @fires {CustomEvent<{selected: string[], model: AIModel}>} ai-model-select\n * @fires {CustomEvent<{models: AIModel[]}>} ai-model-compare - When 2 models selected in multi mode\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\nexport interface AIModel {\n id: string;\n name: string;\n provider: string;\n icon?: string;\n capabilities?: string[];\n costTier?: 'free' | 'low' | 'medium' | 'high';\n description?: string;\n}\n\n@customElement('ai-model-selector')\nexport class AiModelSelector extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host([hidden]) { display: none; }\n\n /* ── Filter chips ── */\n .filter-row {\n display: flex; gap: var(--cg-spacing-6);\n margin-bottom: var(--cg-spacing-12);\n padding-bottom: var(--cg-spacing-12);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n flex-wrap: wrap;\n }\n .filter-chip {\n padding: var(--cg-spacing-4) var(--cg-spacing-12);\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n background: transparent; color: var(--cg-color-surface-container-outlined);\n font: inherit; font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-medium);\n cursor: pointer; text-transform: capitalize;\n transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .filter-chip:hover { border-color: var(--cg-color-surface-cards-hover-border); color: var(--cg-color-surface-base-text); }\n .filter-chip:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong); }\n .filter-chip.active { border-color: var(--cg-color-action-primary-background-default); color: var(--cg-color-action-primary-background-default); background: var(--cg-overlay-accent-subtle); }\n\n /* ── Grid ── */\n .grid {\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));\n gap: var(--cg-spacing-12);\n }\n\n /* ── Model card ── */\n .model-card {\n padding: var(--cg-spacing-16);\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n cursor: pointer;\n transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default), transform var(--cg-transition-duration-fast) var(--cg-transition-easing-ease-out);\n position: relative;\n }\n .model-card:hover { border-color: var(--cg-color-surface-cards-hover-border); background: var(--cg-color-surface-cards-hover-background); }\n .model-card:active { transform: scale(var(--cg-interaction-press-scale)); }\n .model-card:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong); }\n .model-card.selected {\n border-color: var(--cg-color-action-primary-background-default);\n background: var(--cg-overlay-accent-subtle);\n }\n\n /* ── Check indicator ── */\n .check {\n position: absolute; top: var(--cg-spacing-8); right: var(--cg-spacing-8);\n width: var(--cg-spacing-20); height: var(--cg-spacing-20);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n display: flex; align-items: center; justify-content: center;\n }\n .check svg { width: var(--cg-spacing-12); height: var(--cg-spacing-12); }\n\n /* ── Card content ── */\n .model-header {\n display: flex; align-items: center; gap: var(--cg-spacing-8);\n margin-bottom: var(--cg-spacing-8);\n }\n .model-icon { font-size: var(--cg-font-size-lg); }\n .model-info { flex: 1; }\n .model-name { font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-semibold); color: var(--cg-color-surface-base-text); }\n .model-provider { font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined); }\n\n .model-desc { font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined); line-height: var(--cg-line-height-snug); margin-bottom: var(--cg-spacing-8); }\n\n .model-footer { display: flex; justify-content: space-between; align-items: center; }\n .caps { display: flex; gap: var(--cg-spacing-4); flex-wrap: wrap; }\n .model-footer cg-badge { --cg-badge-font-size: var(--cg-font-size-xs); }\n\n .empty { text-align: center; padding: var(--cg-spacing-48); color: var(--cg-color-surface-container-outlined); font-size: var(--cg-font-size-sm); }\n\n /* ── Rounded ── */\n :host([rounded=\"none\"]) .model-card { border-radius: 0; }\n :host([rounded=\"sm\"]) .model-card { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .model-card { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .model-card { border-radius: var(--cg-border-radius-150); }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' = 'lg';\n @property({ type: Array }) models: AIModel[] = [];\n @property() selected = '';\n @property({ type: Boolean }) multi = false;\n\n @state() private _selectedIds = new Set<string>();\n @state() private _activeFilter = '';\n @state() private _focusedIndex = -1;\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('selected') && this.selected) {\n this._selectedIds = new Set([this.selected]);\n }\n }\n\n private get _allCapabilities(): string[] {\n const caps = new Set<string>();\n for (const m of this.models) for (const c of m.capabilities || []) caps.add(c);\n return [...caps].sort();\n }\n\n private get _filteredModels(): AIModel[] {\n if (!this._activeFilter) return this.models;\n return this.models.filter(m => m.capabilities?.includes(this._activeFilter));\n }\n\n private _handleGridKeydown(e: KeyboardEvent) {\n const models = this._filteredModels;\n if (!models.length) return;\n if (e.key === 'ArrowDown' || e.key === 'ArrowRight') {\n e.preventDefault();\n this._focusedIndex = this._focusedIndex >= models.length - 1 ? 0 : this._focusedIndex + 1;\n this._focusCard();\n } else if (e.key === 'ArrowUp' || e.key === 'ArrowLeft') {\n e.preventDefault();\n this._focusedIndex = this._focusedIndex <= 0 ? models.length - 1 : this._focusedIndex - 1;\n this._focusCard();\n } else if ((e.key === 'Enter' || e.key === ' ') && this._focusedIndex >= 0) {\n e.preventDefault();\n const model = models[this._focusedIndex];\n if (model) this._handleSelect(model);\n }\n }\n\n private _focusCard() {\n this.updateComplete.then(() => {\n const cards = this.shadowRoot?.querySelectorAll('.model-card') as NodeListOf<HTMLElement>;\n cards?.[this._focusedIndex]?.focus();\n });\n }\n\n private _handleSelect(model: AIModel) {\n if (this.multi) {\n if (this._selectedIds.has(model.id)) this._selectedIds.delete(model.id);\n else this._selectedIds.add(model.id);\n this._selectedIds = new Set(this._selectedIds);\n } else {\n this._selectedIds = new Set([model.id]);\n }\n this.dispatchEvent(new CustomEvent('ai-model-select', { bubbles: true, composed: true, detail: { selected: [...this._selectedIds], model } }));\n if (this.multi && this._selectedIds.size === 2) {\n this.dispatchEvent(new CustomEvent('ai-model-compare', { bubbles: true, composed: true, detail: { models: [...this._selectedIds].map(id => this.models.find(m => m.id === id)) } }));\n }\n }\n\n private _getCostLabel(tier?: string): string {\n if (tier === 'free') return 'Free';\n if (tier === 'low') return '$';\n if (tier === 'medium') return '$$';\n if (tier === 'high') return '$$$';\n return '';\n }\n\n override render() {\n if (!this.models.length) return html`<div class=\"empty\">No models available</div>`;\n const caps = this._allCapabilities;\n const filtered = this._filteredModels;\n\n return html`\n ${caps.length > 0 ? html`\n <div class=\"filter-row\" role=\"group\" aria-label=\"Filter by capability\">\n <button class=\"filter-chip ${!this._activeFilter ? 'active' : ''}\" @click=${() => { this._activeFilter = ''; }}>All</button>\n ${caps.map(c => html`<button class=\"filter-chip ${this._activeFilter === c ? 'active' : ''}\" @click=${() => { this._activeFilter = this._activeFilter === c ? '' : c; }}>${c}</button>`)}\n </div>\n ` : nothing}\n\n <div class=\"grid\" role=\"listbox\" aria-label=\"Select a model\" aria-multiselectable=\"${this.multi}\" @keydown=${this._handleGridKeydown}>\n ${filtered.map(m => html`\n <div class=\"model-card ${this._selectedIds.has(m.id) ? 'selected' : ''}\"\n role=\"${this.multi ? 'checkbox' : 'radio'}\" tabindex=\"0\"\n aria-selected=\"${this._selectedIds.has(m.id)}\"\n @click=${() => this._handleSelect(m)}>\n ${this._selectedIds.has(m.id) ? html`<div class=\"check\"><cg-icon name=\"check\" size=\"sm\"></cg-icon></div>` : nothing}\n <div class=\"model-header\">\n ${m.icon ? html`<span class=\"model-icon\">${m.icon}</span>` : nothing}\n <div class=\"model-info\">\n <div class=\"model-name\">${m.name}</div>\n <div class=\"model-provider\">${m.provider}</div>\n </div>\n </div>\n ${m.description ? html`<div class=\"model-desc\">${m.description}</div>` : nothing}\n <div class=\"model-footer\">\n <div class=\"caps\">${(m.capabilities || []).slice(0, 3).map(c => html`<cg-badge label=\"${c}\" size=\"sm\"></cg-badge>`)}</div>\n ${m.costTier ? html`<cg-badge label=\"${this._getCostLabel(m.costTier)}\" variant=\"${m.costTier === 'high' ? 'error' : m.costTier === 'medium' ? 'warning' : 'success'}\" size=\"sm\"></cg-badge>` : nothing}\n </div>\n </div>\n `)}\n </div>\n `;\n }\n}\n"],"names":["AiModelSelector","LitElement","changed","caps","m","c","models","model","id","tier","html","filtered","nothing","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-model-selector.js","sources":["../../../src/components/ai-model-selector/ai-model-selector.ts"],"sourcesContent":["/**\n * @element ai-model-selector\n * Card grid for picking AI models. Single or multi-select with capability filters.\n *\n * @fires {CustomEvent<{selected: string[], model: AIModel}>} ai-model-select\n * @fires {CustomEvent<{models: AIModel[]}>} ai-model-compare - When 2 models selected in multi mode\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\nexport interface AIModel {\n id: string;\n name: string;\n provider: string;\n icon?: string;\n capabilities?: string[];\n costTier?: 'free' | 'low' | 'medium' | 'high';\n description?: string;\n}\n\n@customElement('ai-model-selector')\nexport class AiModelSelector extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host([hidden]) { display: none; }\n\n /* ── Filter chips ── */\n .filter-row {\n display: flex; gap: var(--cg-spacing-6);\n margin-bottom: var(--cg-spacing-12);\n padding-bottom: var(--cg-spacing-12);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n flex-wrap: wrap;\n }\n .filter-chip {\n padding: var(--cg-spacing-4) var(--cg-spacing-12);\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n background: transparent; color: var(--cg-color-surface-container-outlined);\n font: inherit; font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-medium);\n cursor: pointer; text-transform: capitalize;\n transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .filter-chip:hover { border-color: var(--cg-color-surface-cards-hover-border); color: var(--cg-color-surface-base-text); }\n .filter-chip:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-focus-ring-width) var(--cg-color-focus-ring); }\n .filter-chip.active { border-color: var(--cg-color-action-primary-background-default); color: var(--cg-color-action-primary-background-default); background: var(--cg-overlay-accent-subtle); }\n\n /* ── Grid ── */\n .grid {\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));\n gap: var(--cg-spacing-12);\n }\n\n /* ── Model card ── */\n .model-card {\n padding: var(--cg-spacing-16);\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n cursor: pointer;\n transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default), transform var(--cg-transition-duration-fast) var(--cg-transition-easing-ease-out);\n position: relative;\n }\n .model-card:hover { border-color: var(--cg-color-surface-cards-hover-border); background: var(--cg-color-surface-cards-hover-background); }\n .model-card:active { transform: scale(var(--cg-interaction-press-scale)); }\n .model-card:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-focus-ring-width) var(--cg-color-focus-ring); }\n .model-card.selected {\n border-color: var(--cg-color-action-primary-background-default);\n background: var(--cg-overlay-accent-subtle);\n }\n\n /* ── Check indicator ── */\n .check {\n position: absolute; top: var(--cg-spacing-8); right: var(--cg-spacing-8);\n width: var(--cg-spacing-20); height: var(--cg-spacing-20);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n display: flex; align-items: center; justify-content: center;\n }\n .check svg { width: var(--cg-spacing-12); height: var(--cg-spacing-12); }\n\n /* ── Card content ── */\n .model-header {\n display: flex; align-items: center; gap: var(--cg-spacing-8);\n margin-bottom: var(--cg-spacing-8);\n }\n .model-icon { font-size: var(--cg-font-size-lg); }\n .model-info { flex: 1; }\n .model-name { font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-semibold); color: var(--cg-color-surface-base-text); }\n .model-provider { font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined); }\n\n .model-desc { font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined); line-height: var(--cg-line-height-snug); margin-bottom: var(--cg-spacing-8); }\n\n .model-footer { display: flex; justify-content: space-between; align-items: center; }\n .caps { display: flex; gap: var(--cg-spacing-4); flex-wrap: wrap; }\n .model-footer cg-badge { --cg-badge-font-size: var(--cg-font-size-xs); }\n\n .empty { text-align: center; padding: var(--cg-spacing-48); color: var(--cg-color-surface-container-outlined); font-size: var(--cg-font-size-sm); }\n\n /* ── Rounded ── */\n :host([rounded=\"none\"]) .model-card { border-radius: 0; }\n :host([rounded=\"sm\"]) .model-card { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .model-card { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .model-card { border-radius: var(--cg-border-radius-150); }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' = 'lg';\n @property({ type: Array }) models: AIModel[] = [];\n @property() selected = '';\n @property({ type: Boolean }) multi = false;\n\n @state() private _selectedIds = new Set<string>();\n @state() private _activeFilter = '';\n @state() private _focusedIndex = -1;\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('selected') && this.selected) {\n this._selectedIds = new Set([this.selected]);\n }\n }\n\n private get _allCapabilities(): string[] {\n const caps = new Set<string>();\n for (const m of this.models) for (const c of m.capabilities || []) caps.add(c);\n return [...caps].sort();\n }\n\n private get _filteredModels(): AIModel[] {\n if (!this._activeFilter) return this.models;\n return this.models.filter(m => m.capabilities?.includes(this._activeFilter));\n }\n\n private _handleGridKeydown(e: KeyboardEvent) {\n const models = this._filteredModels;\n if (!models.length) return;\n if (e.key === 'ArrowDown' || e.key === 'ArrowRight') {\n e.preventDefault();\n this._focusedIndex = this._focusedIndex >= models.length - 1 ? 0 : this._focusedIndex + 1;\n this._focusCard();\n } else if (e.key === 'ArrowUp' || e.key === 'ArrowLeft') {\n e.preventDefault();\n this._focusedIndex = this._focusedIndex <= 0 ? models.length - 1 : this._focusedIndex - 1;\n this._focusCard();\n } else if ((e.key === 'Enter' || e.key === ' ') && this._focusedIndex >= 0) {\n e.preventDefault();\n const model = models[this._focusedIndex];\n if (model) this._handleSelect(model);\n }\n }\n\n private _focusCard() {\n this.updateComplete.then(() => {\n const cards = this.shadowRoot?.querySelectorAll('.model-card') as NodeListOf<HTMLElement>;\n cards?.[this._focusedIndex]?.focus();\n });\n }\n\n private _handleSelect(model: AIModel) {\n if (this.multi) {\n if (this._selectedIds.has(model.id)) this._selectedIds.delete(model.id);\n else this._selectedIds.add(model.id);\n this._selectedIds = new Set(this._selectedIds);\n } else {\n this._selectedIds = new Set([model.id]);\n }\n this.dispatchEvent(new CustomEvent('ai-model-select', { bubbles: true, composed: true, detail: { selected: [...this._selectedIds], model } }));\n if (this.multi && this._selectedIds.size === 2) {\n this.dispatchEvent(new CustomEvent('ai-model-compare', { bubbles: true, composed: true, detail: { models: [...this._selectedIds].map(id => this.models.find(m => m.id === id)) } }));\n }\n }\n\n private _getCostLabel(tier?: string): string {\n if (tier === 'free') return 'Free';\n if (tier === 'low') return '$';\n if (tier === 'medium') return '$$';\n if (tier === 'high') return '$$$';\n return '';\n }\n\n override render() {\n if (!this.models.length) return html`<div class=\"empty\">No models available</div>`;\n const caps = this._allCapabilities;\n const filtered = this._filteredModels;\n\n return html`\n ${caps.length > 0 ? html`\n <div class=\"filter-row\" role=\"group\" aria-label=\"Filter by capability\">\n <button class=\"filter-chip ${!this._activeFilter ? 'active' : ''}\" @click=${() => { this._activeFilter = ''; }}>All</button>\n ${caps.map(c => html`<button class=\"filter-chip ${this._activeFilter === c ? 'active' : ''}\" @click=${() => { this._activeFilter = this._activeFilter === c ? '' : c; }}>${c}</button>`)}\n </div>\n ` : nothing}\n\n <div class=\"grid\" role=\"listbox\" aria-label=\"Select a model\" aria-multiselectable=\"${this.multi}\" @keydown=${this._handleGridKeydown}>\n ${filtered.map(m => html`\n <div class=\"model-card ${this._selectedIds.has(m.id) ? 'selected' : ''}\"\n role=\"${this.multi ? 'checkbox' : 'radio'}\" tabindex=\"0\"\n aria-selected=\"${this._selectedIds.has(m.id)}\"\n @click=${() => this._handleSelect(m)}>\n ${this._selectedIds.has(m.id) ? html`<div class=\"check\"><cg-icon name=\"check\" size=\"sm\"></cg-icon></div>` : nothing}\n <div class=\"model-header\">\n ${m.icon ? html`<span class=\"model-icon\">${m.icon}</span>` : nothing}\n <div class=\"model-info\">\n <div class=\"model-name\">${m.name}</div>\n <div class=\"model-provider\">${m.provider}</div>\n </div>\n </div>\n ${m.description ? html`<div class=\"model-desc\">${m.description}</div>` : nothing}\n <div class=\"model-footer\">\n <div class=\"caps\">${(m.capabilities || []).slice(0, 3).map(c => html`<cg-badge label=\"${c}\" size=\"sm\"></cg-badge>`)}</div>\n ${m.costTier ? html`<cg-badge label=\"${this._getCostLabel(m.costTier)}\" variant=\"${m.costTier === 'high' ? 'error' : m.costTier === 'medium' ? 'warning' : 'success'}\" size=\"sm\"></cg-badge>` : nothing}\n </div>\n </div>\n `)}\n </div>\n `;\n }\n}\n"],"names":["AiModelSelector","LitElement","changed","caps","m","c","models","model","id","tier","html","filtered","nothing","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,13 +1,13 @@
1
1
  import { css as p, LitElement as f, nothing as l, html as n } from "lit";
2
- import { property as g, state as h, customElement as m } from "lit/decorators.js";
3
- import { h as v, r as b, f as w } from "../../chunks/premium.css-9I4kHrsl.js";
2
+ import { property as g, state as h, customElement as v } from "lit/decorators.js";
3
+ import { h as m, r as b, f as w } 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";
7
- var x = Object.defineProperty, y = Object.getOwnPropertyDescriptor, c = (e, t, a, r) => {
8
- for (var i = r > 1 ? void 0 : r ? y(t, a) : t, s = e.length - 1, d; s >= 0; s--)
9
- (d = e[s]) && (i = (r ? d(t, a, i) : d(i)) || i);
10
- return r && i && x(t, a, i), i;
7
+ var x = Object.defineProperty, y = Object.getOwnPropertyDescriptor, c = (e, t, r, a) => {
8
+ for (var i = a > 1 ? void 0 : a ? y(t, r) : t, s = e.length - 1, d; s >= 0; s--)
9
+ (d = e[s]) && (i = (a ? d(t, r, i) : d(i)) || i);
10
+ return a && i && x(t, r, i), i;
11
11
  };
12
12
  const u = 1440 * 60 * 1e3;
13
13
  let o = class extends f {
@@ -16,10 +16,10 @@ let o = class extends f {
16
16
  }
17
17
  updated(e) {
18
18
  if (e.has("notifications")) {
19
- const t = new Set(this.notifications.map((a) => a.id));
19
+ const t = new Set(this.notifications.map((r) => r.id));
20
20
  if (this._seenIds.size > 0) {
21
- for (const a of t)
22
- this._seenIds.has(a) || this._justArrivedIds.add(a);
21
+ for (const r of t)
22
+ this._seenIds.has(r) || this._justArrivedIds.add(r);
23
23
  this._justArrivedIds.size > 0 && window.setTimeout(() => {
24
24
  this._justArrivedIds.clear(), this.requestUpdate();
25
25
  }, 1300);
@@ -37,22 +37,22 @@ let o = class extends f {
37
37
  }
38
38
  _bucketFor(e) {
39
39
  if (!e) return "Earlier";
40
- const t = Date.now(), a = /* @__PURE__ */ new Date();
41
- return a.setHours(0, 0, 0, 0), e >= a.getTime() ? "Today" : e >= a.getTime() - u ? "Yesterday" : e >= t - 7 * u ? "This week" : "Earlier";
40
+ const t = Date.now(), r = /* @__PURE__ */ new Date();
41
+ return r.setHours(0, 0, 0, 0), e >= r.getTime() ? "Today" : e >= r.getTime() - u ? "Yesterday" : e >= t - 7 * u ? "This week" : "Earlier";
42
42
  }
43
43
  get _grouped() {
44
- const e = ["Today", "Yesterday", "This week", "Earlier"], t = /* @__PURE__ */ new Map(), a = [...this.notifications].sort((r, i) => this._toMs(i.timestamp) - this._toMs(r.timestamp)).slice(0, this.maxVisible);
45
- for (const r of a) {
46
- const i = this._bucketFor(this._toMs(r.timestamp));
47
- t.has(i) || t.set(i, []), t.get(i).push(r);
44
+ const e = ["Today", "Yesterday", "This week", "Earlier"], t = /* @__PURE__ */ new Map(), r = [...this.notifications].sort((a, i) => this._toMs(i.timestamp) - this._toMs(a.timestamp)).slice(0, this.maxVisible);
45
+ for (const a of r) {
46
+ const i = this._bucketFor(this._toMs(a.timestamp));
47
+ t.has(i) || t.set(i, []), t.get(i).push(a);
48
48
  }
49
- return e.filter((r) => t.has(r)).map((r) => [r, t.get(r)]);
49
+ return e.filter((a) => t.has(a)).map((a) => [a, t.get(a)]);
50
50
  }
51
51
  _formatTime(e) {
52
52
  const t = this._toMs(e);
53
53
  if (!t) return String(e);
54
- const a = Date.now() - t;
55
- return a < 6e4 ? "Just now" : a < 36e5 ? `${Math.floor(a / 6e4)}m ago` : a < 864e5 ? `${Math.floor(a / 36e5)}h ago` : new Date(t).toLocaleDateString(void 0, { month: "short", day: "numeric" });
54
+ const r = Date.now() - t;
55
+ return r < 6e4 ? "Just now" : r < 36e5 ? `${Math.floor(r / 6e4)}m ago` : r < 864e5 ? `${Math.floor(r / 36e5)}h ago` : new Date(t).toLocaleDateString(void 0, { month: "short", day: "numeric" });
56
56
  }
57
57
  _handleClick(e) {
58
58
  this.dispatchEvent(new CustomEvent("ai-notification-click", {
@@ -104,10 +104,10 @@ let o = class extends f {
104
104
  </slot>
105
105
  ` : l}
106
106
 
107
- ${e.map(([a, r]) => n`
108
- <cg-text class="group-label" size="xs" weight="bold" color="muted" role="heading" aria-level="3">${a}</cg-text>
109
- <div role="list" aria-label="${a} notifications">
110
- ${r.map((i) => n`
107
+ ${e.map(([r, a]) => n`
108
+ <cg-text class="group-label" size="xs" weight="bold" color="muted" role="heading" aria-level="3">${r}</cg-text>
109
+ <div role="list" aria-label="${r} notifications">
110
+ ${a.map((i) => n`
111
111
  <button
112
112
  class="notification ${i.read ? "" : "unread"}"
113
113
  role="listitem"
@@ -135,7 +135,7 @@ let o = class extends f {
135
135
  `;
136
136
  }
137
137
  };
138
- o.styles = [v, b, w, p`
138
+ o.styles = [m, b, w, p`
139
139
  :host {
140
140
  animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
141
141
  display: block;
@@ -221,7 +221,7 @@ o.styles = [v, b, w, p`
221
221
  .notification:active { transform: scale(var(--cg-interaction-press-scale)); }
222
222
  .notification:focus-visible {
223
223
  outline: none;
224
- box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
224
+ box-shadow: 0 0 0 var(--cg-border-width-300) var(--cg-color-focus-ring);
225
225
  }
226
226
 
227
227
  /* Left-accent unread indicator (replaces dot + bg) */
@@ -229,7 +229,7 @@ o.styles = [v, b, w, p`
229
229
  content: '';
230
230
  position: absolute;
231
231
  left: 0; top: var(--cg-spacing-12); bottom: var(--cg-spacing-12);
232
- width: 2px;
232
+ width: var(--cg-border-width-100);
233
233
  background: var(--cg-color-action-primary-background-default);
234
234
  border-radius: var(--cg-border-radius-full);
235
235
  }
@@ -295,7 +295,7 @@ o.styles = [v, b, w, p`
295
295
  .dismiss-btn:active { transform: scale(var(--cg-interaction-press-scale)); }
296
296
  .dismiss-btn:focus-visible {
297
297
  outline: none;
298
- box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
298
+ box-shadow: 0 0 0 var(--cg-border-width-300) var(--cg-color-focus-ring);
299
299
  }
300
300
 
301
301
  /* ── Empty state ── */
@@ -326,7 +326,7 @@ c([
326
326
  h()
327
327
  ], o.prototype, "_justArrivedIds", 2);
328
328
  o = c([
329
- m("ai-notification-center")
329
+ v("ai-notification-center")
330
330
  ], o);
331
331
  export {
332
332
  o as AiNotificationCenter
@@ -1 +1 @@
1
- {"version":3,"file":"ai-notification-center.js","sources":["../../../src/components/ai-notification-center/ai-notification-center.ts"],"sourcesContent":["/**\n * @element ai-notification-center\n * Notification inbox built from design-system primitives (cg-card, cg-text, cg-button).\n * Date-bucketed grouping (Today / Yesterday / This week / Earlier), left-accent unread style,\n * pulse on new arrivals, positive empty state, sr-live unread announcer.\n *\n * @example\n * ```html\n * <ai-notification-center .notifications=${[\n * { id: '1', title: 'Model updated', message: 'GPT-4 Turbo is now available',\n * type: 'system', timestamp: Date.now() - 2 * 60 * 1000 }\n * ]}></ai-notification-center>\n * ```\n *\n * @prop {Notification[]} notifications - Notification objects (timestamp = ms epoch or ISO/string)\n * @prop {number} maxVisible - Max notifications to render (default 50)\n *\n * @slot empty - Override the default \"You're all caught up\" empty state\n *\n * @fires {CustomEvent<{id: string, notification: object}>} ai-notification-click\n * @fires {CustomEvent<{id: string}>} ai-notification-dismiss\n * @fires ai-notification-read-all\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';\n\ninterface Notification {\n id: string;\n title: string;\n message: string;\n type: string;\n timestamp: string | number;\n read?: boolean;\n}\n\nconst DAY_MS = 24 * 60 * 60 * 1000;\n\n@customElement('ai-notification-center')\nexport class AiNotificationCenter 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 }\n :host([hidden]) { display: none; }\n\n cg-card { display: block; max-height: 480px; overflow-y: auto; }\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 /* ── Header ── */\n .header-row {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: var(--cg-spacing-12);\n width: 100%;\n }\n .header-left {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n }\n\n .unread-badge {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n min-width: var(--cg-spacing-16);\n padding: var(--cg-spacing-2) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n font-variant-numeric: tabular-nums;\n }\n\n /* ── Date group label ── */\n .group-label {\n padding: var(--cg-spacing-12) 0 var(--cg-spacing-4);\n text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wide);\n }\n .group-label:first-child { padding-top: 0; }\n\n /* ── Notification row ── */\n .notification {\n display: flex;\n align-items: flex-start;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-12);\n min-height: var(--cg-spacing-48);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n border: none;\n background: transparent;\n width: 100%;\n text-align: left;\n font-family: inherit;\n color: inherit;\n position: relative;\n transition:\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .notification + .notification {\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: 0;\n }\n .notification:hover {\n background: var(--cg-color-action-secondary-background-hover);\n }\n .notification:active { transform: scale(var(--cg-interaction-press-scale)); }\n .notification:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n /* Left-accent unread indicator (replaces dot + bg) */\n .notification.unread::before {\n content: '';\n position: absolute;\n left: 0; top: var(--cg-spacing-12); bottom: var(--cg-spacing-12);\n width: 2px;\n background: var(--cg-color-action-primary-background-default);\n border-radius: var(--cg-border-radius-full);\n }\n\n /* Just-arrived pulse */\n @keyframes arrivalPulse {\n 0% { background: var(--cg-color-action-primary-background-default); opacity: 0.12; }\n 100% { background: transparent; opacity: 0; }\n }\n .notification[data-just-arrived]::after {\n content: '';\n position: absolute;\n inset: 0;\n pointer-events: none;\n border-radius: inherit;\n animation: arrivalPulse 1.2s var(--cg-transition-easing-ease-out) both;\n }\n @media (prefers-reduced-motion: reduce) {\n .notification[data-just-arrived]::after { animation: none; }\n }\n\n .notif-body {\n flex: 1;\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-2);\n }\n .notification.unread .notif-body cg-text[data-role=\"title\"] {\n font-weight: var(--cg-font-weight-semibold);\n }\n\n .notif-message {\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n white-space: normal;\n }\n\n /* ── Dismiss icon button ── */\n .dismiss-btn {\n flex-shrink: 0;\n background: transparent;\n border: none;\n color: var(--cg-color-surface-container-outlined);\n cursor: pointer;\n padding: var(--cg-spacing-4);\n border-radius: var(--cg-border-radius-50);\n line-height: 1;\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-status-error-text-default);\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 /* ── Empty state ── */\n .empty {\n text-align: center;\n padding: var(--cg-spacing-32) var(--cg-spacing-16);\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: var(--cg-spacing-8);\n }\n .empty-icon {\n color: var(--cg-color-status-success-text-default);\n width: var(--cg-spacing-32);\n height: var(--cg-spacing-32);\n }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ type: Array }) notifications: Notification[] = [];\n @property({ type: Number, attribute: 'max-visible' }) maxVisible = 50;\n\n @state() private _justArrivedIds = new Set<string>();\n private _seenIds = new Set<string>();\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('notifications')) {\n const currentIds = new Set(this.notifications.map(n => n.id));\n // Only mark as \"just arrived\" if we've already initialized (not first render)\n if (this._seenIds.size > 0) {\n for (const id of currentIds) {\n if (!this._seenIds.has(id)) this._justArrivedIds.add(id);\n }\n if (this._justArrivedIds.size > 0) {\n // Clear pulse after animation\n window.setTimeout(() => {\n this._justArrivedIds.clear();\n this.requestUpdate();\n }, 1300);\n }\n }\n this._seenIds = currentIds;\n }\n }\n\n private get _unreadCount(): number {\n return this.notifications.filter(n => !n.read).length;\n }\n\n private _toMs(ts: string | number): number {\n if (typeof ts === 'number') return ts;\n const n = Date.parse(ts);\n return Number.isNaN(n) ? 0 : n;\n }\n\n private _bucketFor(ts: number): string {\n if (!ts) return 'Earlier';\n const now = Date.now();\n const startOfToday = new Date(); startOfToday.setHours(0, 0, 0, 0);\n if (ts >= startOfToday.getTime()) return 'Today';\n if (ts >= startOfToday.getTime() - DAY_MS) return 'Yesterday';\n if (ts >= now - 7 * DAY_MS) return 'This week';\n return 'Earlier';\n }\n\n private get _grouped(): Array<[string, Notification[]]> {\n const order = ['Today', 'Yesterday', 'This week', 'Earlier'];\n const map = new Map<string, Notification[]>();\n const visible = [...this.notifications]\n .sort((a, b) => this._toMs(b.timestamp) - this._toMs(a.timestamp))\n .slice(0, this.maxVisible);\n for (const n of visible) {\n const bucket = this._bucketFor(this._toMs(n.timestamp));\n if (!map.has(bucket)) map.set(bucket, []);\n map.get(bucket)!.push(n);\n }\n return order.filter(k => map.has(k)).map(k => [k, map.get(k)!]);\n }\n\n private _formatTime(ts: string | number): string {\n const ms = this._toMs(ts);\n if (!ms) return String(ts);\n const diff = Date.now() - ms;\n if (diff < 60_000) return 'Just now';\n if (diff < 3_600_000) return `${Math.floor(diff / 60_000)}m ago`;\n if (diff < 86_400_000) return `${Math.floor(diff / 3_600_000)}h ago`;\n return new Date(ms).toLocaleDateString(undefined, { month: 'short', day: 'numeric' });\n }\n\n private _handleClick(notification: Notification) {\n this.dispatchEvent(new CustomEvent('ai-notification-click', {\n detail: { id: notification.id, notification },\n bubbles: true, composed: true,\n }));\n }\n\n private _handleDismiss(e: Event, notification: Notification) {\n e.stopPropagation();\n this.dispatchEvent(new CustomEvent('ai-notification-dismiss', {\n detail: { id: notification.id },\n bubbles: true, composed: true,\n }));\n }\n\n private _handleReadAll() {\n this.dispatchEvent(new CustomEvent('ai-notification-read-all', {\n bubbles: true, composed: true,\n }));\n }\n\n override render() {\n const groups = this._grouped;\n const unread = this._unreadCount;\n\n return html`\n <cg-card variant=\"outlined\" padding=\"md\" rounded=${this.rounded} role=\"region\" aria-label=\"Notification center\">\n <div class=\"sr-only\" aria-live=\"polite\" aria-atomic=\"true\">\n ${unread > 0 ? `${unread} unread notifications` : 'No unread notifications'}\n </div>\n\n <div slot=\"header\" class=\"header-row\">\n <div class=\"header-left\">\n <cg-text size=\"sm\" weight=\"semibold\">Notifications</cg-text>\n ${unread > 0 ? html`<span class=\"unread-badge\" aria-label=\"${unread} unread\">${unread}</span>` : nothing}\n </div>\n ${unread > 0 ? html`\n <cg-button variant=\"tertiary\" size=\"sm\" @click=${this._handleReadAll}>Mark all read</cg-button>\n ` : nothing}\n </div>\n\n ${this.notifications.length === 0 ? html`\n <slot name=\"empty\">\n <div class=\"empty\">\n <svg class=\"empty-icon\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">\n <polyline points=\"20 6 9 17 4 12\"/>\n </svg>\n <cg-text size=\"sm\" weight=\"semibold\">You're all caught up</cg-text>\n <cg-text size=\"xs\" color=\"muted\">New notifications will appear here.</cg-text>\n </div>\n </slot>\n ` : nothing}\n\n ${groups.map(([bucket, items]) => html`\n <cg-text class=\"group-label\" size=\"xs\" weight=\"bold\" color=\"muted\" role=\"heading\" aria-level=\"3\">${bucket}</cg-text>\n <div role=\"list\" aria-label=\"${bucket} notifications\">\n ${items.map(n => html`\n <button\n class=\"notification ${n.read ? '' : 'unread'}\"\n role=\"listitem\"\n aria-label=\"${n.title}${n.read ? '' : ' (unread)'}\"\n ?data-just-arrived=${this._justArrivedIds.has(n.id)}\n @click=${() => this._handleClick(n)}\n >\n <div class=\"notif-body\">\n <cg-text data-role=\"title\" size=\"sm\" weight=\"medium\">${n.title}</cg-text>\n <cg-text class=\"notif-message\" size=\"xs\" color=\"muted\">${n.message}</cg-text>\n <cg-text size=\"xs\" color=\"muted\">${this._formatTime(n.timestamp)}</cg-text>\n </div>\n <button\n class=\"dismiss-btn\"\n aria-label=\"Dismiss: ${n.title}\"\n @click=${(e: Event) => this._handleDismiss(e, n)}\n >\n <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>\n </button>\n </button>\n `)}\n </div>\n `)}\n </cg-card>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-notification-center': AiNotificationCenter;\n }\n}\n"],"names":["DAY_MS","AiNotificationCenter","LitElement","changed","currentIds","n","id","ts","now","startOfToday","order","map","visible","a","b","bucket","k","ms","diff","notification","groups","unread","html","nothing","items","e","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-notification-center.js","sources":["../../../src/components/ai-notification-center/ai-notification-center.ts"],"sourcesContent":["/**\n * @element ai-notification-center\n * Notification inbox built from design-system primitives (cg-card, cg-text, cg-button).\n * Date-bucketed grouping (Today / Yesterday / This week / Earlier), left-accent unread style,\n * pulse on new arrivals, positive empty state, sr-live unread announcer.\n *\n * @example\n * ```html\n * <ai-notification-center .notifications=${[\n * { id: '1', title: 'Model updated', message: 'GPT-4 Turbo is now available',\n * type: 'system', timestamp: Date.now() - 2 * 60 * 1000 }\n * ]}></ai-notification-center>\n * ```\n *\n * @prop {Notification[]} notifications - Notification objects (timestamp = ms epoch or ISO/string)\n * @prop {number} maxVisible - Max notifications to render (default 50)\n *\n * @slot empty - Override the default \"You're all caught up\" empty state\n *\n * @fires {CustomEvent<{id: string, notification: object}>} ai-notification-click\n * @fires {CustomEvent<{id: string}>} ai-notification-dismiss\n * @fires ai-notification-read-all\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';\n\ninterface Notification {\n id: string;\n title: string;\n message: string;\n type: string;\n timestamp: string | number;\n read?: boolean;\n}\n\nconst DAY_MS = 24 * 60 * 60 * 1000;\n\n@customElement('ai-notification-center')\nexport class AiNotificationCenter 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 }\n :host([hidden]) { display: none; }\n\n cg-card { display: block; max-height: 480px; overflow-y: auto; }\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 /* ── Header ── */\n .header-row {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: var(--cg-spacing-12);\n width: 100%;\n }\n .header-left {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n }\n\n .unread-badge {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n min-width: var(--cg-spacing-16);\n padding: var(--cg-spacing-2) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-bold);\n font-variant-numeric: tabular-nums;\n }\n\n /* ── Date group label ── */\n .group-label {\n padding: var(--cg-spacing-12) 0 var(--cg-spacing-4);\n text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wide);\n }\n .group-label:first-child { padding-top: 0; }\n\n /* ── Notification row ── */\n .notification {\n display: flex;\n align-items: flex-start;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-12);\n min-height: var(--cg-spacing-48);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n border: none;\n background: transparent;\n width: 100%;\n text-align: left;\n font-family: inherit;\n color: inherit;\n position: relative;\n transition:\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .notification + .notification {\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: 0;\n }\n .notification:hover {\n background: var(--cg-color-action-secondary-background-hover);\n }\n .notification:active { transform: scale(var(--cg-interaction-press-scale)); }\n .notification:focus-visible {\n outline: none;\n box-shadow: 0 0 0 var(--cg-border-width-300) var(--cg-color-focus-ring);\n }\n\n /* Left-accent unread indicator (replaces dot + bg) */\n .notification.unread::before {\n content: '';\n position: absolute;\n left: 0; top: var(--cg-spacing-12); bottom: var(--cg-spacing-12);\n width: var(--cg-border-width-100);\n background: var(--cg-color-action-primary-background-default);\n border-radius: var(--cg-border-radius-full);\n }\n\n /* Just-arrived pulse */\n @keyframes arrivalPulse {\n 0% { background: var(--cg-color-action-primary-background-default); opacity: 0.12; }\n 100% { background: transparent; opacity: 0; }\n }\n .notification[data-just-arrived]::after {\n content: '';\n position: absolute;\n inset: 0;\n pointer-events: none;\n border-radius: inherit;\n animation: arrivalPulse 1.2s var(--cg-transition-easing-ease-out) both;\n }\n @media (prefers-reduced-motion: reduce) {\n .notification[data-just-arrived]::after { animation: none; }\n }\n\n .notif-body {\n flex: 1;\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-2);\n }\n .notification.unread .notif-body cg-text[data-role=\"title\"] {\n font-weight: var(--cg-font-weight-semibold);\n }\n\n .notif-message {\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n white-space: normal;\n }\n\n /* ── Dismiss icon button ── */\n .dismiss-btn {\n flex-shrink: 0;\n background: transparent;\n border: none;\n color: var(--cg-color-surface-container-outlined);\n cursor: pointer;\n padding: var(--cg-spacing-4);\n border-radius: var(--cg-border-radius-50);\n line-height: 1;\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-status-error-text-default);\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 var(--cg-border-width-300) var(--cg-color-focus-ring);\n }\n\n /* ── Empty state ── */\n .empty {\n text-align: center;\n padding: var(--cg-spacing-32) var(--cg-spacing-16);\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: var(--cg-spacing-8);\n }\n .empty-icon {\n color: var(--cg-color-status-success-text-default);\n width: var(--cg-spacing-32);\n height: var(--cg-spacing-32);\n }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ type: Array }) notifications: Notification[] = [];\n @property({ type: Number, attribute: 'max-visible' }) maxVisible = 50;\n\n @state() private _justArrivedIds = new Set<string>();\n private _seenIds = new Set<string>();\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('notifications')) {\n const currentIds = new Set(this.notifications.map(n => n.id));\n // Only mark as \"just arrived\" if we've already initialized (not first render)\n if (this._seenIds.size > 0) {\n for (const id of currentIds) {\n if (!this._seenIds.has(id)) this._justArrivedIds.add(id);\n }\n if (this._justArrivedIds.size > 0) {\n // Clear pulse after animation\n window.setTimeout(() => {\n this._justArrivedIds.clear();\n this.requestUpdate();\n }, 1300);\n }\n }\n this._seenIds = currentIds;\n }\n }\n\n private get _unreadCount(): number {\n return this.notifications.filter(n => !n.read).length;\n }\n\n private _toMs(ts: string | number): number {\n if (typeof ts === 'number') return ts;\n const n = Date.parse(ts);\n return Number.isNaN(n) ? 0 : n;\n }\n\n private _bucketFor(ts: number): string {\n if (!ts) return 'Earlier';\n const now = Date.now();\n const startOfToday = new Date(); startOfToday.setHours(0, 0, 0, 0);\n if (ts >= startOfToday.getTime()) return 'Today';\n if (ts >= startOfToday.getTime() - DAY_MS) return 'Yesterday';\n if (ts >= now - 7 * DAY_MS) return 'This week';\n return 'Earlier';\n }\n\n private get _grouped(): Array<[string, Notification[]]> {\n const order = ['Today', 'Yesterday', 'This week', 'Earlier'];\n const map = new Map<string, Notification[]>();\n const visible = [...this.notifications]\n .sort((a, b) => this._toMs(b.timestamp) - this._toMs(a.timestamp))\n .slice(0, this.maxVisible);\n for (const n of visible) {\n const bucket = this._bucketFor(this._toMs(n.timestamp));\n if (!map.has(bucket)) map.set(bucket, []);\n map.get(bucket)!.push(n);\n }\n return order.filter(k => map.has(k)).map(k => [k, map.get(k)!]);\n }\n\n private _formatTime(ts: string | number): string {\n const ms = this._toMs(ts);\n if (!ms) return String(ts);\n const diff = Date.now() - ms;\n if (diff < 60_000) return 'Just now';\n if (diff < 3_600_000) return `${Math.floor(diff / 60_000)}m ago`;\n if (diff < 86_400_000) return `${Math.floor(diff / 3_600_000)}h ago`;\n return new Date(ms).toLocaleDateString(undefined, { month: 'short', day: 'numeric' });\n }\n\n private _handleClick(notification: Notification) {\n this.dispatchEvent(new CustomEvent('ai-notification-click', {\n detail: { id: notification.id, notification },\n bubbles: true, composed: true,\n }));\n }\n\n private _handleDismiss(e: Event, notification: Notification) {\n e.stopPropagation();\n this.dispatchEvent(new CustomEvent('ai-notification-dismiss', {\n detail: { id: notification.id },\n bubbles: true, composed: true,\n }));\n }\n\n private _handleReadAll() {\n this.dispatchEvent(new CustomEvent('ai-notification-read-all', {\n bubbles: true, composed: true,\n }));\n }\n\n override render() {\n const groups = this._grouped;\n const unread = this._unreadCount;\n\n return html`\n <cg-card variant=\"outlined\" padding=\"md\" rounded=${this.rounded} role=\"region\" aria-label=\"Notification center\">\n <div class=\"sr-only\" aria-live=\"polite\" aria-atomic=\"true\">\n ${unread > 0 ? `${unread} unread notifications` : 'No unread notifications'}\n </div>\n\n <div slot=\"header\" class=\"header-row\">\n <div class=\"header-left\">\n <cg-text size=\"sm\" weight=\"semibold\">Notifications</cg-text>\n ${unread > 0 ? html`<span class=\"unread-badge\" aria-label=\"${unread} unread\">${unread}</span>` : nothing}\n </div>\n ${unread > 0 ? html`\n <cg-button variant=\"tertiary\" size=\"sm\" @click=${this._handleReadAll}>Mark all read</cg-button>\n ` : nothing}\n </div>\n\n ${this.notifications.length === 0 ? html`\n <slot name=\"empty\">\n <div class=\"empty\">\n <svg class=\"empty-icon\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">\n <polyline points=\"20 6 9 17 4 12\"/>\n </svg>\n <cg-text size=\"sm\" weight=\"semibold\">You're all caught up</cg-text>\n <cg-text size=\"xs\" color=\"muted\">New notifications will appear here.</cg-text>\n </div>\n </slot>\n ` : nothing}\n\n ${groups.map(([bucket, items]) => html`\n <cg-text class=\"group-label\" size=\"xs\" weight=\"bold\" color=\"muted\" role=\"heading\" aria-level=\"3\">${bucket}</cg-text>\n <div role=\"list\" aria-label=\"${bucket} notifications\">\n ${items.map(n => html`\n <button\n class=\"notification ${n.read ? '' : 'unread'}\"\n role=\"listitem\"\n aria-label=\"${n.title}${n.read ? '' : ' (unread)'}\"\n ?data-just-arrived=${this._justArrivedIds.has(n.id)}\n @click=${() => this._handleClick(n)}\n >\n <div class=\"notif-body\">\n <cg-text data-role=\"title\" size=\"sm\" weight=\"medium\">${n.title}</cg-text>\n <cg-text class=\"notif-message\" size=\"xs\" color=\"muted\">${n.message}</cg-text>\n <cg-text size=\"xs\" color=\"muted\">${this._formatTime(n.timestamp)}</cg-text>\n </div>\n <button\n class=\"dismiss-btn\"\n aria-label=\"Dismiss: ${n.title}\"\n @click=${(e: Event) => this._handleDismiss(e, n)}\n >\n <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>\n </button>\n </button>\n `)}\n </div>\n `)}\n </cg-card>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-notification-center': AiNotificationCenter;\n }\n}\n"],"names":["DAY_MS","AiNotificationCenter","LitElement","changed","currentIds","n","id","ts","now","startOfToday","order","map","visible","b","bucket","k","ms","diff","notification","groups","unread","html","nothing","items","e","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":"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"}