@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,10 +1,10 @@
1
- import { css as g, LitElement as v, html as i, nothing as p } from "lit";
2
- import { property as l, state as u, customElement as b } from "lit/decorators.js";
3
- import { h as m, r as h, f } from "../../chunks/premium.css-9I4kHrsl.js";
4
- var x = Object.defineProperty, w = Object.getOwnPropertyDescriptor, c = (e, a, n, t) => {
5
- for (var r = t > 1 ? void 0 : t ? w(a, n) : a, o = e.length - 1, d; o >= 0; o--)
6
- (d = e[o]) && (r = (t ? d(a, n, r) : d(r)) || r);
7
- return t && r && x(a, n, r), r;
1
+ import { css as g, LitElement as v, html as i, nothing as u } from "lit";
2
+ import { property as l, state as p, customElement as b } from "lit/decorators.js";
3
+ import { h, r as m, f } from "../../chunks/premium.css-DHekUEUt.js";
4
+ var w = Object.defineProperty, x = Object.getOwnPropertyDescriptor, n = (e, a, c, t) => {
5
+ for (var r = t > 1 ? void 0 : t ? x(a, c) : a, o = e.length - 1, d; o >= 0; o--)
6
+ (d = e[o]) && (r = (t ? d(a, c, r) : d(r)) || r);
7
+ return t && r && w(a, c, r), r;
8
8
  };
9
9
  let s = class extends v {
10
10
  constructor() {
@@ -17,10 +17,10 @@ let s = class extends v {
17
17
  _renderHighlightedTemplate() {
18
18
  const e = [];
19
19
  let a = this.template;
20
- const n = /\{\{(\w+)\}\}/g;
20
+ const c = /\{\{(\w+)\}\}/g;
21
21
  let t, r = 0;
22
- for (n.lastIndex = 0; (t = n.exec(a)) !== null; )
23
- t.index > r && e.push(a.slice(r, t.index)), e.push({ varName: t[1] }), r = n.lastIndex;
22
+ for (c.lastIndex = 0; (t = c.exec(a)) !== null; )
23
+ t.index > r && e.push(a.slice(r, t.index)), e.push({ varName: t[1] }), r = c.lastIndex;
24
24
  return r < a.length && e.push(a.slice(r)), e.map((o) => typeof o == "string" ? o : this._mode === "preview" && this.variables[o.varName] ? i`<span class="var-value">${this.variables[o.varName]}</span>` : i`<span class="var-highlight">{{${o.varName}}}</span>`);
25
25
  }
26
26
  _handleTemplateChange(e) {
@@ -97,12 +97,12 @@ let s = class extends v {
97
97
  </div>
98
98
  `)}
99
99
  </div>
100
- ` : p}
100
+ ` : u}
101
101
  </div>
102
102
  `;
103
103
  }
104
104
  };
105
- s.styles = [m, h, f, g`
105
+ s.styles = [h, m, f, g`
106
106
  :host {
107
107
  animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
108
108
  }
@@ -153,7 +153,7 @@ s.styles = [m, h, f, g`
153
153
  .mode-btn:hover:not(.active) { border-color: var(--cg-color-surface-cards-border); color: var(--cg-color-input-text-placeholder); }
154
154
  .mode-btn:focus-visible {
155
155
  outline: none;
156
- box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
156
+ box-shadow: 0 0 0 var(--cg-outline-width-thick) var(--cg-color-focus-ring);
157
157
  }
158
158
 
159
159
  /* ── Template editor area ── */
@@ -164,7 +164,7 @@ s.styles = [m, h, f, g`
164
164
  padding: var(--cg-spacing-16);
165
165
  min-height: 80px;
166
166
  font-size: var(--cg-font-size-sm);
167
- line-height: 1.7;
167
+ line-height: var(--cg-line-height-relaxed);
168
168
  color: var(--cg-color-input-text-placeholder);
169
169
  white-space: pre-wrap;
170
170
  word-break: break-word;
@@ -180,27 +180,27 @@ s.styles = [m, h, f, g`
180
180
  box-sizing: border-box;
181
181
  font-size: var(--cg-font-size-sm);
182
182
  font-family: var(--cg-font-family-mono);
183
- line-height: 1.7;
183
+ line-height: var(--cg-line-height-relaxed);
184
184
  color: var(--cg-color-input-text-placeholder);
185
185
  resize: vertical;
186
186
  }
187
187
  .template-textarea:focus-visible {
188
- outline: 2px solid var(--cg-overlay-accent-strong);
189
- outline-offset: -2px;
188
+ outline: var(--cg-outline-width-default) solid var(--cg-color-focus-ring);
189
+ outline-offset: calc(-1 * var(--cg-outline-offset-default));
190
190
  }
191
191
 
192
192
  .var-highlight {
193
193
  background: var(--cg-overlay-accent-subtle);
194
194
  color: var(--cg-color-surface-base-text);
195
195
  padding: var(--cg-spacing-1) var(--cg-spacing-4);
196
- border-radius: var(--cg-border-radius-25);
196
+ border-radius: var(--cg-border-radius-50);
197
197
  font-weight: var(--cg-font-weight-semibold);
198
198
  font-family: var(--cg-font-family-mono);
199
199
  font-size: var(--cg-font-size-xs);
200
200
  }
201
201
 
202
202
  .var-value {
203
- color: var(--cg-color-status-success-text);
203
+ color: var(--cg-color-status-success-text-default);
204
204
  font-weight: var(--cg-font-weight-semibold);
205
205
  }
206
206
 
@@ -242,11 +242,11 @@ s.styles = [m, h, f, g`
242
242
  font-family: inherit;
243
243
  }
244
244
  .var-input:focus-visible {
245
- outline: 2px solid var(--cg-overlay-accent-strong);
246
- outline-offset: -2px;
245
+ outline: var(--cg-outline-width-default) solid var(--cg-color-focus-ring);
246
+ outline-offset: calc(-1 * var(--cg-outline-offset-default));
247
247
  }
248
248
  .var-input:disabled {
249
- opacity: 0.5;
249
+ opacity: var(--cg-opacity-50);
250
250
  cursor: not-allowed;
251
251
  }
252
252
 
@@ -264,22 +264,22 @@ s.styles = [m, h, f, g`
264
264
  :host([rounded="lg"]) .container { border-radius: var(--cg-border-radius-150); }
265
265
  :host([rounded="full"]) .container { border-radius: var(--cg-border-radius-full); }
266
266
  `];
267
- c([
267
+ n([
268
268
  l({ reflect: !0 })
269
269
  ], s.prototype, "rounded", 2);
270
- c([
270
+ n([
271
271
  l({ type: String })
272
272
  ], s.prototype, "template", 2);
273
- c([
273
+ n([
274
274
  l({ type: Object })
275
275
  ], s.prototype, "variables", 2);
276
- c([
276
+ n([
277
277
  l({ type: Boolean })
278
278
  ], s.prototype, "editable", 2);
279
- c([
280
- u()
279
+ n([
280
+ p()
281
281
  ], s.prototype, "_mode", 2);
282
- s = c([
282
+ s = n([
283
283
  b("ai-prompt-template")
284
284
  ], s);
285
285
  export {
@@ -1 +1 @@
1
- {"version":3,"file":"ai-prompt-template.js","sources":["../../../src/components/ai-prompt-template/ai-prompt-template.ts"],"sourcesContent":["/**\n * @element ai-prompt-template\n * Prompt template editor with {{variable}} highlighting, inline variable\n * inputs, and edit/preview toggle. Variables are auto-detected from the\n * template string and rendered as editable fields.\n *\n * @example\n * ```html\n * <ai-prompt-template\n * template=\"Summarize {{topic}} for a {{audience}} audience.\"\n * .variables=${{ topic: 'quantum computing', audience: 'beginner' }}\n * editable\n * ></ai-prompt-template>\n * ```\n *\n * @prop {string} template - Template string with {{variable}} placeholders\n * @prop {Record<string, string>} variables - Variable name-to-value map\n * @prop {boolean} editable - Allow editing the template and variables (default true)\n *\n * @fires {CustomEvent<{template: string}>} ai-template-change - When the template text changes\n * @fires {CustomEvent<{variable: string, value: string}>} ai-template-variable-change - When a variable value changes\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\n@customElement('ai-prompt-template')\nexport class AiPromptTemplate extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n :host([hidden]) { display: none; }\n\n .container {\n background: var(--cg-color-surface-container-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n padding: var(--cg-spacing-16);\n color: var(--cg-color-surface-base-text);\n }\n\n .header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: var(--cg-spacing-12);\n }\n\n .title {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n }\n\n .mode-toggle {\n display: flex;\n gap: var(--cg-spacing-4);\n }\n\n .mode-btn {\n background: transparent;\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-xs);\n padding: var(--cg-spacing-4) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\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 .mode-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .mode-btn.active {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-surface-container-background);\n border-color: var(--cg-color-surface-base-text);\n font-weight: var(--cg-font-weight-semibold);\n }\n .mode-btn:hover:not(.active) { border-color: var(--cg-color-surface-cards-border); color: var(--cg-color-input-text-placeholder); }\n .mode-btn:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n /* ── Template editor area ── */\n .template-area {\n background: var(--cg-color-surface-base-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-100);\n padding: var(--cg-spacing-16);\n min-height: 80px;\n font-size: var(--cg-font-size-sm);\n line-height: 1.7;\n color: var(--cg-color-input-text-placeholder);\n white-space: pre-wrap;\n word-break: break-word;\n }\n\n .template-textarea {\n background: var(--cg-color-surface-base-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-100);\n padding: var(--cg-spacing-16);\n min-height: 80px;\n width: 100%;\n box-sizing: border-box;\n font-size: var(--cg-font-size-sm);\n font-family: var(--cg-font-family-mono);\n line-height: 1.7;\n color: var(--cg-color-input-text-placeholder);\n resize: vertical;\n }\n .template-textarea:focus-visible {\n outline: 2px solid var(--cg-overlay-accent-strong);\n outline-offset: -2px;\n }\n\n .var-highlight {\n background: var(--cg-overlay-accent-subtle);\n color: var(--cg-color-surface-base-text);\n padding: var(--cg-spacing-1) var(--cg-spacing-4);\n border-radius: var(--cg-border-radius-25);\n font-weight: var(--cg-font-weight-semibold);\n font-family: var(--cg-font-family-mono);\n font-size: var(--cg-font-size-xs);\n }\n\n .var-value {\n color: var(--cg-color-status-success-text);\n font-weight: var(--cg-font-weight-semibold);\n }\n\n /* ── Variables panel ── */\n .variables-section {\n margin-top: var(--cg-spacing-12);\n }\n\n .variables-title {\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-input-text-placeholder);\n margin-bottom: var(--cg-spacing-8);\n }\n\n .variable-row {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n margin-bottom: var(--cg-spacing-6);\n }\n\n .var-name {\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 font-family: var(--cg-font-family-mono);\n min-width: var(--cg-spacing-96);\n }\n\n .var-input {\n flex: 1;\n background: var(--cg-color-surface-base-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-xs);\n padding: var(--cg-spacing-6) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-100);\n font-family: inherit;\n }\n .var-input:focus-visible {\n outline: 2px solid var(--cg-overlay-accent-strong);\n outline-offset: -2px;\n }\n .var-input:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .empty-state {\n text-align: center;\n color: var(--cg-color-input-border-hover);\n font-size: var(--cg-font-size-sm);\n padding: var(--cg-spacing-16) 0;\n }\n\n /* ── Rounded variants ── */\n :host([rounded=\"none\"]) .container { border-radius: 0; }\n :host([rounded=\"sm\"]) .container { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .container { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .container { border-radius: var(--cg-border-radius-150); }\n :host([rounded=\"full\"]) .container { border-radius: var(--cg-border-radius-full); }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ type: String }) template = '';\n @property({ type: Object }) variables: Record<string, string> = {};\n @property({ type: Boolean }) editable = true;\n\n @state() private _mode: 'edit' | 'preview' = 'edit';\n\n private get _templateVars(): string[] {\n const matches = this.template.match(/\\{\\{(\\w+)\\}\\}/g) || [];\n return [...new Set(matches.map(m => m.replace(/\\{\\{|\\}\\}/g, '')))];\n }\n\n private _renderHighlightedTemplate() {\n const parts: (string | { varName: string })[] = [];\n let remaining = this.template;\n const regex = /\\{\\{(\\w+)\\}\\}/g;\n let match: RegExpExecArray | null;\n let lastIndex = 0;\n\n regex.lastIndex = 0;\n while ((match = regex.exec(remaining)) !== null) {\n if (match.index > lastIndex) {\n parts.push(remaining.slice(lastIndex, match.index));\n }\n parts.push({ varName: match[1]! });\n lastIndex = regex.lastIndex;\n }\n if (lastIndex < remaining.length) {\n parts.push(remaining.slice(lastIndex));\n }\n\n return parts.map(p => {\n if (typeof p === 'string') return p;\n if (this._mode === 'preview' && this.variables[p.varName]) {\n return html`<span class=\"var-value\">${this.variables[p.varName]}</span>`;\n }\n return html`<span class=\"var-highlight\">{{${p.varName}}}</span>`;\n });\n }\n\n private _handleTemplateChange(e: Event) {\n const value = (e.target as HTMLTextAreaElement).value;\n this.dispatchEvent(new CustomEvent('ai-template-change', {\n detail: { template: value },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _handleVariableChange(varName: string, value: string) {\n this.dispatchEvent(new CustomEvent('ai-template-variable-change', {\n detail: { variable: varName, value },\n bubbles: true,\n composed: true,\n }));\n }\n\n override render() {\n return html`\n <div class=\"container\" role=\"region\" aria-label=\"Prompt template editor\">\n <div class=\"header\">\n <span class=\"title\">Prompt Template</span>\n <div class=\"mode-toggle\" role=\"radiogroup\" aria-label=\"View mode\">\n <button\n class=\"mode-btn ${this._mode === 'edit' ? 'active' : ''}\"\n role=\"radio\"\n aria-checked=${this._mode === 'edit' ? 'true' : 'false'}\n @click=${() => { this._mode = 'edit'; }}\n tabindex=\"0\"\n >Edit</button>\n <button\n class=\"mode-btn ${this._mode === 'preview' ? 'active' : ''}\"\n role=\"radio\"\n aria-checked=${this._mode === 'preview' ? 'true' : 'false'}\n @click=${() => { this._mode = 'preview'; }}\n tabindex=\"0\"\n >Preview</button>\n </div>\n </div>\n\n ${this._mode === 'edit' && this.editable ? html`\n <textarea\n class=\"template-textarea\"\n .value=${this.template}\n @input=${this._handleTemplateChange}\n aria-label=\"Template content\"\n rows=\"4\"\n ></textarea>\n ` : html`\n <div class=\"template-area\" role=\"document\" aria-label=\"Template preview\">\n ${this.template ? this._renderHighlightedTemplate() : html`<span class=\"empty-state\">No template defined</span>`}\n </div>\n `}\n\n ${this._templateVars.length > 0 ? html`\n <div class=\"variables-section\">\n <div class=\"variables-title\">Variables (${this._templateVars.length})</div>\n ${this._templateVars.map(v => html`\n <div class=\"variable-row\">\n <span class=\"var-name\">{{${v}}}</span>\n <input\n class=\"var-input\"\n type=\"text\"\n .value=${this.variables[v] || ''}\n ?disabled=${!this.editable}\n placeholder=\"Enter value...\"\n aria-label=\"Value for variable ${v}\"\n @input=${(e: Event) => this._handleVariableChange(v, (e.target as HTMLInputElement).value)}\n />\n </div>\n `)}\n </div>\n ` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-prompt-template': AiPromptTemplate;\n }\n}\n"],"names":["AiPromptTemplate","LitElement","matches","m","parts","remaining","regex","match","lastIndex","p","html","value","varName","v","e","nothing","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-prompt-template.js","sources":["../../../src/components/ai-prompt-template/ai-prompt-template.ts"],"sourcesContent":["/**\n * @element ai-prompt-template\n * Prompt template editor with {{variable}} highlighting, inline variable\n * inputs, and edit/preview toggle. Variables are auto-detected from the\n * template string and rendered as editable fields.\n *\n * @example\n * ```html\n * <ai-prompt-template\n * template=\"Summarize {{topic}} for a {{audience}} audience.\"\n * .variables=${{ topic: 'quantum computing', audience: 'beginner' }}\n * editable\n * ></ai-prompt-template>\n * ```\n *\n * @prop {string} template - Template string with {{variable}} placeholders\n * @prop {Record<string, string>} variables - Variable name-to-value map\n * @prop {boolean} editable - Allow editing the template and variables (default true)\n *\n * @fires {CustomEvent<{template: string}>} ai-template-change - When the template text changes\n * @fires {CustomEvent<{variable: string, value: string}>} ai-template-variable-change - When a variable value changes\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\n@customElement('ai-prompt-template')\nexport class AiPromptTemplate extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n :host([hidden]) { display: none; }\n\n .container {\n background: var(--cg-color-surface-container-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n padding: var(--cg-spacing-16);\n color: var(--cg-color-surface-base-text);\n }\n\n .header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: var(--cg-spacing-12);\n }\n\n .title {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n }\n\n .mode-toggle {\n display: flex;\n gap: var(--cg-spacing-4);\n }\n\n .mode-btn {\n background: transparent;\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-xs);\n padding: var(--cg-spacing-4) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\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 .mode-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .mode-btn.active {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-surface-container-background);\n border-color: var(--cg-color-surface-base-text);\n font-weight: var(--cg-font-weight-semibold);\n }\n .mode-btn:hover:not(.active) { border-color: var(--cg-color-surface-cards-border); color: var(--cg-color-input-text-placeholder); }\n .mode-btn:focus-visible {\n outline: none;\n box-shadow: 0 0 0 var(--cg-outline-width-thick) var(--cg-color-focus-ring);\n }\n\n /* ── Template editor area ── */\n .template-area {\n background: var(--cg-color-surface-base-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-100);\n padding: var(--cg-spacing-16);\n min-height: 80px;\n font-size: var(--cg-font-size-sm);\n line-height: var(--cg-line-height-relaxed);\n color: var(--cg-color-input-text-placeholder);\n white-space: pre-wrap;\n word-break: break-word;\n }\n\n .template-textarea {\n background: var(--cg-color-surface-base-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-100);\n padding: var(--cg-spacing-16);\n min-height: 80px;\n width: 100%;\n box-sizing: border-box;\n font-size: var(--cg-font-size-sm);\n font-family: var(--cg-font-family-mono);\n line-height: var(--cg-line-height-relaxed);\n color: var(--cg-color-input-text-placeholder);\n resize: vertical;\n }\n .template-textarea:focus-visible {\n outline: var(--cg-outline-width-default) solid var(--cg-color-focus-ring);\n outline-offset: calc(-1 * var(--cg-outline-offset-default));\n }\n\n .var-highlight {\n background: var(--cg-overlay-accent-subtle);\n color: var(--cg-color-surface-base-text);\n padding: var(--cg-spacing-1) var(--cg-spacing-4);\n border-radius: var(--cg-border-radius-50);\n font-weight: var(--cg-font-weight-semibold);\n font-family: var(--cg-font-family-mono);\n font-size: var(--cg-font-size-xs);\n }\n\n .var-value {\n color: var(--cg-color-status-success-text-default);\n font-weight: var(--cg-font-weight-semibold);\n }\n\n /* ── Variables panel ── */\n .variables-section {\n margin-top: var(--cg-spacing-12);\n }\n\n .variables-title {\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-input-text-placeholder);\n margin-bottom: var(--cg-spacing-8);\n }\n\n .variable-row {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n margin-bottom: var(--cg-spacing-6);\n }\n\n .var-name {\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 font-family: var(--cg-font-family-mono);\n min-width: var(--cg-spacing-96);\n }\n\n .var-input {\n flex: 1;\n background: var(--cg-color-surface-base-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-xs);\n padding: var(--cg-spacing-6) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-100);\n font-family: inherit;\n }\n .var-input:focus-visible {\n outline: var(--cg-outline-width-default) solid var(--cg-color-focus-ring);\n outline-offset: calc(-1 * var(--cg-outline-offset-default));\n }\n .var-input:disabled {\n opacity: var(--cg-opacity-50);\n cursor: not-allowed;\n }\n\n .empty-state {\n text-align: center;\n color: var(--cg-color-input-border-hover);\n font-size: var(--cg-font-size-sm);\n padding: var(--cg-spacing-16) 0;\n }\n\n /* ── Rounded variants ── */\n :host([rounded=\"none\"]) .container { border-radius: 0; }\n :host([rounded=\"sm\"]) .container { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .container { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .container { border-radius: var(--cg-border-radius-150); }\n :host([rounded=\"full\"]) .container { border-radius: var(--cg-border-radius-full); }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ type: String }) template = '';\n @property({ type: Object }) variables: Record<string, string> = {};\n @property({ type: Boolean }) editable = true;\n\n @state() private _mode: 'edit' | 'preview' = 'edit';\n\n private get _templateVars(): string[] {\n const matches = this.template.match(/\\{\\{(\\w+)\\}\\}/g) || [];\n return [...new Set(matches.map(m => m.replace(/\\{\\{|\\}\\}/g, '')))];\n }\n\n private _renderHighlightedTemplate() {\n const parts: (string | { varName: string })[] = [];\n let remaining = this.template;\n const regex = /\\{\\{(\\w+)\\}\\}/g;\n let match: RegExpExecArray | null;\n let lastIndex = 0;\n\n regex.lastIndex = 0;\n while ((match = regex.exec(remaining)) !== null) {\n if (match.index > lastIndex) {\n parts.push(remaining.slice(lastIndex, match.index));\n }\n parts.push({ varName: match[1]! });\n lastIndex = regex.lastIndex;\n }\n if (lastIndex < remaining.length) {\n parts.push(remaining.slice(lastIndex));\n }\n\n return parts.map(p => {\n if (typeof p === 'string') return p;\n if (this._mode === 'preview' && this.variables[p.varName]) {\n return html`<span class=\"var-value\">${this.variables[p.varName]}</span>`;\n }\n return html`<span class=\"var-highlight\">{{${p.varName}}}</span>`;\n });\n }\n\n private _handleTemplateChange(e: Event) {\n const value = (e.target as HTMLTextAreaElement).value;\n this.dispatchEvent(new CustomEvent('ai-template-change', {\n detail: { template: value },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _handleVariableChange(varName: string, value: string) {\n this.dispatchEvent(new CustomEvent('ai-template-variable-change', {\n detail: { variable: varName, value },\n bubbles: true,\n composed: true,\n }));\n }\n\n override render() {\n return html`\n <div class=\"container\" role=\"region\" aria-label=\"Prompt template editor\">\n <div class=\"header\">\n <span class=\"title\">Prompt Template</span>\n <div class=\"mode-toggle\" role=\"radiogroup\" aria-label=\"View mode\">\n <button\n class=\"mode-btn ${this._mode === 'edit' ? 'active' : ''}\"\n role=\"radio\"\n aria-checked=${this._mode === 'edit' ? 'true' : 'false'}\n @click=${() => { this._mode = 'edit'; }}\n tabindex=\"0\"\n >Edit</button>\n <button\n class=\"mode-btn ${this._mode === 'preview' ? 'active' : ''}\"\n role=\"radio\"\n aria-checked=${this._mode === 'preview' ? 'true' : 'false'}\n @click=${() => { this._mode = 'preview'; }}\n tabindex=\"0\"\n >Preview</button>\n </div>\n </div>\n\n ${this._mode === 'edit' && this.editable ? html`\n <textarea\n class=\"template-textarea\"\n .value=${this.template}\n @input=${this._handleTemplateChange}\n aria-label=\"Template content\"\n rows=\"4\"\n ></textarea>\n ` : html`\n <div class=\"template-area\" role=\"document\" aria-label=\"Template preview\">\n ${this.template ? this._renderHighlightedTemplate() : html`<span class=\"empty-state\">No template defined</span>`}\n </div>\n `}\n\n ${this._templateVars.length > 0 ? html`\n <div class=\"variables-section\">\n <div class=\"variables-title\">Variables (${this._templateVars.length})</div>\n ${this._templateVars.map(v => html`\n <div class=\"variable-row\">\n <span class=\"var-name\">{{${v}}}</span>\n <input\n class=\"var-input\"\n type=\"text\"\n .value=${this.variables[v] || ''}\n ?disabled=${!this.editable}\n placeholder=\"Enter value...\"\n aria-label=\"Value for variable ${v}\"\n @input=${(e: Event) => this._handleVariableChange(v, (e.target as HTMLInputElement).value)}\n />\n </div>\n `)}\n </div>\n ` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-prompt-template': AiPromptTemplate;\n }\n}\n"],"names":["AiPromptTemplate","LitElement","matches","m","parts","remaining","regex","match","lastIndex","p","html","value","varName","v","e","nothing","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as v, LitElement as p, html as n, nothing as u } from "lit";
2
2
  import { property as s, state as g, customElement as f } from "lit/decorators.js";
3
- import { h, r as b } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h, r as b } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var m = Object.defineProperty, y = Object.getOwnPropertyDescriptor, i = (e, a, r, c) => {
5
5
  for (var t = c > 1 ? void 0 : c ? y(a, r) : a, d = e.length - 1, l; d >= 0; d--)
6
6
  (l = e[d]) && (t = (c ? l(a, r, t) : l(t)) || t);
@@ -126,7 +126,7 @@ o.styles = [h, b, v`
126
126
  }
127
127
  .control-btn:hover { border-color: var(--cg-color-surface-cards-hover-border); color: var(--cg-color-surface-base-text); }
128
128
  .control-btn:active { transform: scale(var(--cg-interaction-press-scale)); }
129
- .control-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong); }
129
+ .control-btn:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-focus-ring-width) var(--cg-overlay-accent-strong); }
130
130
  .control-btn.active { border-color: var(--cg-color-action-primary-background-default); color: var(--cg-color-action-primary-background-default); background: var(--cg-overlay-accent-subtle); }
131
131
 
132
132
  /* ── Documents ── */
@@ -142,7 +142,7 @@ o.styles = [h, b, v`
142
142
  .doc:last-child { border-bottom: none; }
143
143
  .doc:focus-visible {
144
144
  outline: none;
145
- box-shadow: inset 0 0 0 2px var(--cg-overlay-accent-strong);
145
+ box-shadow: inset 0 0 0 var(--cg-focus-ring-width) var(--cg-overlay-accent-strong);
146
146
  }
147
147
 
148
148
  .doc-header { display: flex; align-items: center; gap: var(--cg-spacing-12); margin-bottom: var(--cg-spacing-4); }
@@ -184,7 +184,7 @@ o.styles = [h, b, v`
184
184
  .relevance-fill {
185
185
  height: 100%; border-radius: var(--cg-border-radius-full);
186
186
  background: var(--cg-color-action-primary-background-default);
187
- opacity: 0.6;
187
+ opacity: var(--cg-opacity-60);
188
188
  transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);
189
189
  }
190
190
 
@@ -1 +1 @@
1
- {"version":3,"file":"ai-rag-panel.js","sources":["../../../src/components/ai-rag-panel/ai-rag-panel.ts"],"sourcesContent":["/**\n * @element ai-rag-panel\n * RAG results panel showing retrieved documents with relevance scores, type badges, and excerpts.\n *\n * @fires {CustomEvent<{index: number, document: object}>} ai-rag-document-click - Document clicked\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 RagDocument {\n title: string;\n source: string;\n excerpt: string;\n relevance: number;\n type?: 'doc' | 'web' | 'database' | 'api';\n url?: string;\n}\n\n@customElement('ai-rag-panel')\nexport class AiRagPanel extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\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-component-card-radius);\n overflow: hidden;\n }\n\n /* ── Header ── */\n .header {\n display: flex; align-items: center; justify-content: space-between;\n padding: var(--cg-spacing-16) var(--cg-spacing-20);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n .header-left { display: flex; align-items: center; gap: var(--cg-spacing-12); }\n .header-icon {\n width: var(--cg-spacing-16); height: var(--cg-spacing-16);\n color: var(--cg-color-surface-container-outlined);\n display: flex; align-items: center; justify-content: center;\n flex-shrink: 0;\n }\n .header-icon svg { width: 100%; height: 100%; }\n .header-title {\n font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-container-outlined);\n text-transform: uppercase; letter-spacing: var(--cg-letter-spacing-wide);\n }\n .header-stats { font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined); }\n\n /* ── Filter controls ── */\n .controls {\n display: flex; gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-12) var(--cg-spacing-20);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n .control-btn {\n padding: var(--cg-spacing-4) var(--cg-spacing-8); 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 .control-btn:hover { border-color: var(--cg-color-surface-cards-hover-border); color: var(--cg-color-surface-base-text); }\n .control-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .control-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong); }\n .control-btn.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 /* ── Documents ── */\n .documents { max-height: 400px; overflow-y: auto; }\n\n .doc {\n padding: var(--cg-spacing-16) var(--cg-spacing-20);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n cursor: pointer;\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .doc:hover { background: var(--cg-overlay-dark-subtle); }\n .doc:last-child { border-bottom: none; }\n .doc:focus-visible {\n outline: none;\n box-shadow: inset 0 0 0 2px var(--cg-overlay-accent-strong);\n }\n\n .doc-header { display: flex; align-items: center; gap: var(--cg-spacing-12); margin-bottom: var(--cg-spacing-4); }\n .doc-type {\n font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-medium);\n padding: var(--cg-spacing-2) var(--cg-spacing-6); border-radius: var(--cg-border-radius-full);\n text-transform: uppercase; letter-spacing: var(--cg-letter-spacing-wide);\n background: var(--cg-overlay-accent-light);\n color: var(--cg-color-action-primary-background-default);\n }\n\n .doc-title {\n font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-medium); color: var(--cg-color-surface-base-text);\n flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;\n }\n\n .doc-relevance {\n font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-medium);\n flex-shrink: 0; font-family: var(--cg-font-family-mono);\n color: var(--cg-color-surface-container-outlined);\n }\n\n .doc-source {\n font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined); margin-bottom: var(--cg-spacing-4);\n }\n\n .doc-excerpt {\n font-size: var(--cg-font-size-sm); color: var(--cg-color-surface-base-text); opacity: 0.8;\n line-height: var(--cg-line-height-relaxed);\n display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;\n }\n .doc.expanded .doc-excerpt { -webkit-line-clamp: unset; display: block; }\n\n /* Relevance bar */\n .relevance-bar {\n height: var(--cg-spacing-2); border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-surface-cards-border); margin-top: var(--cg-spacing-12); overflow: hidden;\n }\n .relevance-fill {\n height: 100%; border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-action-primary-background-default);\n opacity: 0.6;\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n\n .empty {\n padding: var(--cg-spacing-48) var(--cg-spacing-24);\n text-align: center; color: var(--cg-color-surface-container-outlined); font-size: var(--cg-font-size-sm);\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-component-card-radius); }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' = 'lg';\n @property({ type: Array }) documents: RagDocument[] = [];\n @property() query = '';\n @property() sortBy: 'relevance' | 'recency' | 'source' = 'relevance';\n\n @state() private _expandedIndex = -1;\n @state() private _filterType = '';\n\n private get _filteredDocs(): RagDocument[] {\n let docs = [...this.documents];\n if (this._filterType) docs = docs.filter(d => d.type === this._filterType);\n if (this.sortBy === 'relevance') docs.sort((a, b) => b.relevance - a.relevance);\n return docs;\n }\n\n private get _types(): string[] {\n return [...new Set(this.documents.map(d => d.type || 'doc'))];\n }\n\n private _formatRelevance(r: number): string {\n return `${Math.round(r * 100)}%`;\n }\n\n private _handleDocClick(index: number) {\n this._expandedIndex = this._expandedIndex === index ? -1 : index;\n this.dispatchEvent(new CustomEvent('ai-rag-document-click', {\n bubbles: true, composed: true,\n detail: { index, document: this._filteredDocs[index] },\n }));\n }\n\n override render() {\n if (this.documents.length === 0) {\n return html`<div class=\"panel\"><div class=\"empty\">No documents retrieved</div></div>`;\n }\n\n const docs = this._filteredDocs;\n const types = this._types;\n\n return html`\n <div class=\"panel\" role=\"region\" aria-label=\"Retrieved documents\">\n <div class=\"header\">\n <div class=\"header-left\">\n <div class=\"header-icon\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z\"/><polyline points=\"14 2 14 8 20 8\"/></svg>\n </div>\n <span class=\"header-title\">Retrieved Sources</span>\n </div>\n <span class=\"header-stats\">${docs.length} document${docs.length !== 1 ? 's' : ''}</span>\n </div>\n\n ${types.length > 1 ? html`\n <div class=\"controls\">\n <button class=\"control-btn ${!this._filterType ? 'active' : ''}\" @click=${() => { this._filterType = ''; }}>All</button>\n ${types.map(t => html`\n <button class=\"control-btn ${this._filterType === t ? 'active' : ''}\" @click=${() => { this._filterType = this._filterType === t ? '' : t; }}>${t}</button>\n `)}\n </div>\n ` : nothing}\n\n <div class=\"documents\">\n ${docs.map((doc, i) => html`\n <div class=\"doc ${this._expandedIndex === i ? 'expanded' : ''}\"\n @click=${() => this._handleDocClick(i)}\n role=\"article\" tabindex=\"0\"\n @keydown=${(e: KeyboardEvent) => { if (e.key === 'Enter' || e.key === ' ') { e.preventDefault(); this._handleDocClick(i); } }}>\n <div class=\"doc-header\">\n <span class=\"doc-type\">${doc.type || 'doc'}</span>\n <span class=\"doc-title\">${doc.title}</span>\n <span class=\"doc-relevance\">${this._formatRelevance(doc.relevance)}</span>\n </div>\n <div class=\"doc-source\">${doc.source}</div>\n <div class=\"doc-excerpt\">${doc.excerpt}</div>\n <div class=\"relevance-bar\">\n <div class=\"relevance-fill\" style=\"width: ${doc.relevance * 100}%\"></div>\n </div>\n </div>\n `)}\n </div>\n </div>\n `;\n }\n}\n"],"names":["AiRagPanel","LitElement","docs","d","b","r","index","html","types","t","nothing","doc","i","e","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-rag-panel.js","sources":["../../../src/components/ai-rag-panel/ai-rag-panel.ts"],"sourcesContent":["/**\n * @element ai-rag-panel\n * RAG results panel showing retrieved documents with relevance scores, type badges, and excerpts.\n *\n * @fires {CustomEvent<{index: number, document: object}>} ai-rag-document-click - Document clicked\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 RagDocument {\n title: string;\n source: string;\n excerpt: string;\n relevance: number;\n type?: 'doc' | 'web' | 'database' | 'api';\n url?: string;\n}\n\n@customElement('ai-rag-panel')\nexport class AiRagPanel extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\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-component-card-radius);\n overflow: hidden;\n }\n\n /* ── Header ── */\n .header {\n display: flex; align-items: center; justify-content: space-between;\n padding: var(--cg-spacing-16) var(--cg-spacing-20);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n .header-left { display: flex; align-items: center; gap: var(--cg-spacing-12); }\n .header-icon {\n width: var(--cg-spacing-16); height: var(--cg-spacing-16);\n color: var(--cg-color-surface-container-outlined);\n display: flex; align-items: center; justify-content: center;\n flex-shrink: 0;\n }\n .header-icon svg { width: 100%; height: 100%; }\n .header-title {\n font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-container-outlined);\n text-transform: uppercase; letter-spacing: var(--cg-letter-spacing-wide);\n }\n .header-stats { font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined); }\n\n /* ── Filter controls ── */\n .controls {\n display: flex; gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-12) var(--cg-spacing-20);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n .control-btn {\n padding: var(--cg-spacing-4) var(--cg-spacing-8); 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 .control-btn:hover { border-color: var(--cg-color-surface-cards-hover-border); color: var(--cg-color-surface-base-text); }\n .control-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .control-btn:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-focus-ring-width) var(--cg-overlay-accent-strong); }\n .control-btn.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 /* ── Documents ── */\n .documents { max-height: 400px; overflow-y: auto; }\n\n .doc {\n padding: var(--cg-spacing-16) var(--cg-spacing-20);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n cursor: pointer;\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .doc:hover { background: var(--cg-overlay-dark-subtle); }\n .doc:last-child { border-bottom: none; }\n .doc:focus-visible {\n outline: none;\n box-shadow: inset 0 0 0 var(--cg-focus-ring-width) var(--cg-overlay-accent-strong);\n }\n\n .doc-header { display: flex; align-items: center; gap: var(--cg-spacing-12); margin-bottom: var(--cg-spacing-4); }\n .doc-type {\n font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-medium);\n padding: var(--cg-spacing-2) var(--cg-spacing-6); border-radius: var(--cg-border-radius-full);\n text-transform: uppercase; letter-spacing: var(--cg-letter-spacing-wide);\n background: var(--cg-overlay-accent-light);\n color: var(--cg-color-action-primary-background-default);\n }\n\n .doc-title {\n font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-medium); color: var(--cg-color-surface-base-text);\n flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;\n }\n\n .doc-relevance {\n font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-medium);\n flex-shrink: 0; font-family: var(--cg-font-family-mono);\n color: var(--cg-color-surface-container-outlined);\n }\n\n .doc-source {\n font-size: var(--cg-font-size-xs); color: var(--cg-color-surface-container-outlined); margin-bottom: var(--cg-spacing-4);\n }\n\n .doc-excerpt {\n font-size: var(--cg-font-size-sm); color: var(--cg-color-surface-base-text); opacity: 0.8;\n line-height: var(--cg-line-height-relaxed);\n display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;\n }\n .doc.expanded .doc-excerpt { -webkit-line-clamp: unset; display: block; }\n\n /* Relevance bar */\n .relevance-bar {\n height: var(--cg-spacing-2); border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-surface-cards-border); margin-top: var(--cg-spacing-12); overflow: hidden;\n }\n .relevance-fill {\n height: 100%; border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-action-primary-background-default);\n opacity: var(--cg-opacity-60);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n\n .empty {\n padding: var(--cg-spacing-48) var(--cg-spacing-24);\n text-align: center; color: var(--cg-color-surface-container-outlined); font-size: var(--cg-font-size-sm);\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-component-card-radius); }\n `];\n\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' = 'lg';\n @property({ type: Array }) documents: RagDocument[] = [];\n @property() query = '';\n @property() sortBy: 'relevance' | 'recency' | 'source' = 'relevance';\n\n @state() private _expandedIndex = -1;\n @state() private _filterType = '';\n\n private get _filteredDocs(): RagDocument[] {\n let docs = [...this.documents];\n if (this._filterType) docs = docs.filter(d => d.type === this._filterType);\n if (this.sortBy === 'relevance') docs.sort((a, b) => b.relevance - a.relevance);\n return docs;\n }\n\n private get _types(): string[] {\n return [...new Set(this.documents.map(d => d.type || 'doc'))];\n }\n\n private _formatRelevance(r: number): string {\n return `${Math.round(r * 100)}%`;\n }\n\n private _handleDocClick(index: number) {\n this._expandedIndex = this._expandedIndex === index ? -1 : index;\n this.dispatchEvent(new CustomEvent('ai-rag-document-click', {\n bubbles: true, composed: true,\n detail: { index, document: this._filteredDocs[index] },\n }));\n }\n\n override render() {\n if (this.documents.length === 0) {\n return html`<div class=\"panel\"><div class=\"empty\">No documents retrieved</div></div>`;\n }\n\n const docs = this._filteredDocs;\n const types = this._types;\n\n return html`\n <div class=\"panel\" role=\"region\" aria-label=\"Retrieved documents\">\n <div class=\"header\">\n <div class=\"header-left\">\n <div class=\"header-icon\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z\"/><polyline points=\"14 2 14 8 20 8\"/></svg>\n </div>\n <span class=\"header-title\">Retrieved Sources</span>\n </div>\n <span class=\"header-stats\">${docs.length} document${docs.length !== 1 ? 's' : ''}</span>\n </div>\n\n ${types.length > 1 ? html`\n <div class=\"controls\">\n <button class=\"control-btn ${!this._filterType ? 'active' : ''}\" @click=${() => { this._filterType = ''; }}>All</button>\n ${types.map(t => html`\n <button class=\"control-btn ${this._filterType === t ? 'active' : ''}\" @click=${() => { this._filterType = this._filterType === t ? '' : t; }}>${t}</button>\n `)}\n </div>\n ` : nothing}\n\n <div class=\"documents\">\n ${docs.map((doc, i) => html`\n <div class=\"doc ${this._expandedIndex === i ? 'expanded' : ''}\"\n @click=${() => this._handleDocClick(i)}\n role=\"article\" tabindex=\"0\"\n @keydown=${(e: KeyboardEvent) => { if (e.key === 'Enter' || e.key === ' ') { e.preventDefault(); this._handleDocClick(i); } }}>\n <div class=\"doc-header\">\n <span class=\"doc-type\">${doc.type || 'doc'}</span>\n <span class=\"doc-title\">${doc.title}</span>\n <span class=\"doc-relevance\">${this._formatRelevance(doc.relevance)}</span>\n </div>\n <div class=\"doc-source\">${doc.source}</div>\n <div class=\"doc-excerpt\">${doc.excerpt}</div>\n <div class=\"relevance-bar\">\n <div class=\"relevance-fill\" style=\"width: ${doc.relevance * 100}%\"></div>\n </div>\n </div>\n `)}\n </div>\n </div>\n `;\n }\n}\n"],"names":["AiRagPanel","LitElement","docs","d","b","r","index","html","types","t","nothing","doc","i","e","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { css as p, LitElement as h, nothing as d, html as s } from "lit";
2
- import { property as i, customElement as v } from "lit/decorators.js";
3
- import { h as u, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
4
- var b = Object.defineProperty, m = Object.getOwnPropertyDescriptor, n = (t, e, o, c) => {
2
+ import { property as n, customElement as v } from "lit/decorators.js";
3
+ import { h as u, r as f } from "../../chunks/premium.css-DHekUEUt.js";
4
+ var b = Object.defineProperty, m = Object.getOwnPropertyDescriptor, i = (t, e, o, c) => {
5
5
  for (var a = c > 1 ? void 0 : c ? m(e, o) : e, g = t.length - 1, l; g >= 0; g--)
6
6
  (l = t[g]) && (a = (c ? l(e, o, a) : l(a)) || a);
7
7
  return c && a && b(e, o, a), a;
@@ -78,7 +78,7 @@ r.styles = [u, f, p`
78
78
  background: none;
79
79
  border: none;
80
80
  font: inherit;
81
- color: var(--cg-color-surface-container-outlined);
81
+ color: var(--cg-color-ai-reasoning-text);
82
82
  font-size: var(--cg-font-size-sm);
83
83
  font-weight: var(--cg-font-weight-medium);
84
84
  width: 100%;
@@ -88,7 +88,7 @@ r.styles = [u, f, p`
88
88
  .toggle:focus-visible {
89
89
  outline: none;
90
90
  border-radius: var(--cg-border-radius-50);
91
- box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
91
+ box-shadow: 0 0 0 var(--cg-outline-width-thick) var(--cg-color-focus-ring);
92
92
  }
93
93
 
94
94
  .chevron {
@@ -156,22 +156,22 @@ r.styles = [u, f, p`
156
156
  .chevron { transition: none; }
157
157
  }
158
158
  `];
159
- n([
160
- i({ type: Array })
159
+ i([
160
+ n({ type: Array })
161
161
  ], r.prototype, "nodes", 2);
162
- n([
163
- i({ type: Array })
162
+ i([
163
+ n({ type: Array })
164
164
  ], r.prototype, "highlightPath", 2);
165
- n([
166
- i()
165
+ i([
166
+ n()
167
167
  ], r.prototype, "label", 2);
168
- n([
169
- i({ type: Boolean, reflect: !0 })
168
+ i([
169
+ n({ type: Boolean, reflect: !0 })
170
170
  ], r.prototype, "collapsed", 2);
171
- n([
172
- i({ reflect: !0 })
171
+ i([
172
+ n({ reflect: !0 })
173
173
  ], r.prototype, "variant", 2);
174
- r = n([
174
+ r = i([
175
175
  v("ai-reasoning-tree")
176
176
  ], r);
177
177
  export {
@@ -1 +1 @@
1
- {"version":3,"file":"ai-reasoning-tree.js","sources":["../../../src/components/ai-reasoning-tree/ai-reasoning-tree.ts"],"sourcesContent":["/**\n * @element ai-reasoning-tree\n * Collapsible AI chain-of-thought display. Two variants:\n * - minimal (Claude-style): left border, no background\n * - contained (DeepSeek-style): subtle background card\n *\n * @fires {CustomEvent<{id: string, type: string, content: string}>} ai-reasoning-node-click\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 ReasoningNode {\n id: string;\n type: 'thought' | 'action' | 'observation' | 'conclusion';\n content: string;\n confidence?: number;\n children?: ReasoningNode[];\n}\n\n@customElement('ai-reasoning-tree')\nexport class AiReasoningTree extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n\n /* ── Minimal variant (default) — Claude-style ── */\n .reasoning {\n border-left: var(--cg-border-width-100) solid var(--cg-color-surface-cards-border);\n padding-left: var(--cg-spacing-20);\n }\n\n /* ── Contained variant — DeepSeek-style ── */\n :host([variant=\"contained\"]) .reasoning {\n border-left: none;\n padding-left: 0;\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-component-card-radius);\n padding: var(--cg-spacing-12);\n }\n :host([variant=\"contained\"]) .toggle {\n padding: var(--cg-spacing-12) var(--cg-spacing-16);\n }\n :host([variant=\"contained\"]) .steps {\n padding: 0 var(--cg-spacing-16) var(--cg-spacing-16);\n }\n\n /* ── Toggle ── */\n .toggle {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-8) 0;\n cursor: pointer;\n background: none;\n border: none;\n font: inherit;\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n width: 100%;\n text-align: left;\n }\n .toggle:hover { color: var(--cg-color-surface-base-text); }\n .toggle:focus-visible {\n outline: none;\n border-radius: var(--cg-border-radius-50);\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n .chevron {\n width: var(--cg-spacing-12);\n height: var(--cg-spacing-12);\n transition: transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n flex-shrink: 0;\n opacity: 0.5;\n }\n :host(:not([collapsed])) .chevron { transform: rotate(90deg); }\n\n .toggle-count {\n font-size: var(--cg-font-size-xs);\n opacity: 0.5;\n margin-left: auto;\n }\n\n /* ── Steps ── */\n .steps {\n display: flex;\n flex-direction: column;\n padding: var(--cg-spacing-6) 0 var(--cg-spacing-12);\n }\n\n .step {\n display: flex;\n align-items: baseline;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-12) var(--cg-spacing-12);\n font-size: var(--cg-font-size-sm);\n color: var(--cg-color-surface-base-text);\n line-height: var(--cg-line-height-relaxed);\n border-radius: var(--cg-border-radius-50);\n cursor: default;\n opacity: 0.8;\n }\n .step:hover { background: var(--cg-overlay-dark-subtle); }\n\n .dot {\n width: var(--cg-spacing-6);\n height: var(--cg-spacing-6);\n border-radius: var(--cg-border-radius-full);\n flex-shrink: 0;\n margin-top: var(--cg-spacing-6);\n }\n .dot.thought { background: var(--cg-color-action-primary-background-default); opacity: 0.7; }\n .dot.action { background: var(--cg-color-status-info-text-default); opacity: 0.7; }\n .dot.observation { background: var(--cg-color-status-warning-text-default); opacity: 0.7; }\n .dot.conclusion { background: var(--cg-color-status-success-text-default); opacity: 0.7; }\n\n .step-text { flex: 1; }\n\n .conf {\n font-size: var(--cg-font-size-xs);\n font-family: var(--cg-font-family-mono);\n opacity: 0.4;\n flex-shrink: 0;\n }\n\n .children { padding-left: var(--cg-spacing-20); }\n\n .step.highlighted { background: var(--cg-overlay-accent-subtle); }\n\n @media (prefers-reduced-motion: reduce) {\n .chevron { transition: none; }\n }\n `];\n\n @property({ type: Array }) nodes: ReasoningNode[] = [];\n @property({ type: Array }) highlightPath: string[] = [];\n @property() label = 'Thinking';\n @property({ type: Boolean, reflect: true }) collapsed = true;\n @property({ reflect: true }) variant: 'minimal' | 'contained' = 'minimal';\n\n private _count(nodes: ReasoningNode[]): number {\n let c = 0;\n for (const n of nodes) { c++; if (n.children) c += this._count(n.children); }\n return c;\n }\n\n private _renderNodes(nodes: ReasoningNode[]): unknown {\n return nodes.map(n => html`\n <div class=\"step ${this.highlightPath.includes(n.id) ? 'highlighted' : ''}\"\n @click=${() => this.dispatchEvent(new CustomEvent('ai-reasoning-node-click', { bubbles: true, composed: true, detail: { id: n.id, type: n.type, content: n.content } }))}>\n <span class=\"dot ${n.type}\"></span>\n <span class=\"step-text\">${n.content}</span>\n ${n.confidence ? html`<span class=\"conf\">${Math.round(n.confidence * 100)}%</span>` : nothing}\n </div>\n ${n.children?.length ? html`<div class=\"children\">${this._renderNodes(n.children)}</div>` : nothing}\n `);\n }\n\n override render() {\n if (!this.nodes.length) return nothing;\n const total = this._count(this.nodes);\n\n return html`\n <div class=\"reasoning\">\n <button class=\"toggle\" @click=${() => { this.collapsed = !this.collapsed; }} aria-expanded=${!this.collapsed}>\n <svg class=\"chevron\" viewBox=\"0 0 24 24\" fill=\"currentColor\"><path d=\"M8 5v14l11-7z\"/></svg>\n <span>${this.label}</span>\n <span class=\"toggle-count\">${total} step${total !== 1 ? 's' : ''}</span>\n </button>\n ${!this.collapsed ? html`<div class=\"steps\">${this._renderNodes(this.nodes)}</div>` : nothing}\n </div>\n `;\n }\n}\n"],"names":["AiReasoningTree","LitElement","nodes","c","n","html","nothing","total","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-reasoning-tree.js","sources":["../../../src/components/ai-reasoning-tree/ai-reasoning-tree.ts"],"sourcesContent":["/**\n * @element ai-reasoning-tree\n * Collapsible AI chain-of-thought display. Two variants:\n * - minimal (Claude-style): left border, no background\n * - contained (DeepSeek-style): subtle background card\n *\n * @fires {CustomEvent<{id: string, type: string, content: string}>} ai-reasoning-node-click\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 ReasoningNode {\n id: string;\n type: 'thought' | 'action' | 'observation' | 'conclusion';\n content: string;\n confidence?: number;\n children?: ReasoningNode[];\n}\n\n@customElement('ai-reasoning-tree')\nexport class AiReasoningTree extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n\n /* ── Minimal variant (default) — Claude-style ── */\n .reasoning {\n border-left: var(--cg-border-width-100) solid var(--cg-color-surface-cards-border);\n padding-left: var(--cg-spacing-20);\n }\n\n /* ── Contained variant — DeepSeek-style ── */\n :host([variant=\"contained\"]) .reasoning {\n border-left: none;\n padding-left: 0;\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-component-card-radius);\n padding: var(--cg-spacing-12);\n }\n :host([variant=\"contained\"]) .toggle {\n padding: var(--cg-spacing-12) var(--cg-spacing-16);\n }\n :host([variant=\"contained\"]) .steps {\n padding: 0 var(--cg-spacing-16) var(--cg-spacing-16);\n }\n\n /* ── Toggle ── */\n .toggle {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-8) 0;\n cursor: pointer;\n background: none;\n border: none;\n font: inherit;\n color: var(--cg-color-ai-reasoning-text);\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n width: 100%;\n text-align: left;\n }\n .toggle:hover { color: var(--cg-color-surface-base-text); }\n .toggle:focus-visible {\n outline: none;\n border-radius: var(--cg-border-radius-50);\n box-shadow: 0 0 0 var(--cg-outline-width-thick) var(--cg-color-focus-ring);\n }\n\n .chevron {\n width: var(--cg-spacing-12);\n height: var(--cg-spacing-12);\n transition: transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n flex-shrink: 0;\n opacity: 0.5;\n }\n :host(:not([collapsed])) .chevron { transform: rotate(90deg); }\n\n .toggle-count {\n font-size: var(--cg-font-size-xs);\n opacity: 0.5;\n margin-left: auto;\n }\n\n /* ── Steps ── */\n .steps {\n display: flex;\n flex-direction: column;\n padding: var(--cg-spacing-6) 0 var(--cg-spacing-12);\n }\n\n .step {\n display: flex;\n align-items: baseline;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-12) var(--cg-spacing-12);\n font-size: var(--cg-font-size-sm);\n color: var(--cg-color-surface-base-text);\n line-height: var(--cg-line-height-relaxed);\n border-radius: var(--cg-border-radius-50);\n cursor: default;\n opacity: 0.8;\n }\n .step:hover { background: var(--cg-overlay-dark-subtle); }\n\n .dot {\n width: var(--cg-spacing-6);\n height: var(--cg-spacing-6);\n border-radius: var(--cg-border-radius-full);\n flex-shrink: 0;\n margin-top: var(--cg-spacing-6);\n }\n .dot.thought { background: var(--cg-color-action-primary-background-default); opacity: 0.7; }\n .dot.action { background: var(--cg-color-status-info-text-default); opacity: 0.7; }\n .dot.observation { background: var(--cg-color-status-warning-text-default); opacity: 0.7; }\n .dot.conclusion { background: var(--cg-color-status-success-text-default); opacity: 0.7; }\n\n .step-text { flex: 1; }\n\n .conf {\n font-size: var(--cg-font-size-xs);\n font-family: var(--cg-font-family-mono);\n opacity: 0.4;\n flex-shrink: 0;\n }\n\n .children { padding-left: var(--cg-spacing-20); }\n\n .step.highlighted { background: var(--cg-overlay-accent-subtle); }\n\n @media (prefers-reduced-motion: reduce) {\n .chevron { transition: none; }\n }\n `];\n\n @property({ type: Array }) nodes: ReasoningNode[] = [];\n @property({ type: Array }) highlightPath: string[] = [];\n @property() label = 'Thinking';\n @property({ type: Boolean, reflect: true }) collapsed = true;\n @property({ reflect: true }) variant: 'minimal' | 'contained' = 'minimal';\n\n private _count(nodes: ReasoningNode[]): number {\n let c = 0;\n for (const n of nodes) { c++; if (n.children) c += this._count(n.children); }\n return c;\n }\n\n private _renderNodes(nodes: ReasoningNode[]): unknown {\n return nodes.map(n => html`\n <div class=\"step ${this.highlightPath.includes(n.id) ? 'highlighted' : ''}\"\n @click=${() => this.dispatchEvent(new CustomEvent('ai-reasoning-node-click', { bubbles: true, composed: true, detail: { id: n.id, type: n.type, content: n.content } }))}>\n <span class=\"dot ${n.type}\"></span>\n <span class=\"step-text\">${n.content}</span>\n ${n.confidence ? html`<span class=\"conf\">${Math.round(n.confidence * 100)}%</span>` : nothing}\n </div>\n ${n.children?.length ? html`<div class=\"children\">${this._renderNodes(n.children)}</div>` : nothing}\n `);\n }\n\n override render() {\n if (!this.nodes.length) return nothing;\n const total = this._count(this.nodes);\n\n return html`\n <div class=\"reasoning\">\n <button class=\"toggle\" @click=${() => { this.collapsed = !this.collapsed; }} aria-expanded=${!this.collapsed}>\n <svg class=\"chevron\" viewBox=\"0 0 24 24\" fill=\"currentColor\"><path d=\"M8 5v14l11-7z\"/></svg>\n <span>${this.label}</span>\n <span class=\"toggle-count\">${total} step${total !== 1 ? 's' : ''}</span>\n </button>\n ${!this.collapsed ? html`<div class=\"steps\">${this._renderNodes(this.nodes)}</div>` : nothing}\n </div>\n `;\n }\n}\n"],"names":["AiReasoningTree","LitElement","nodes","c","n","html","nothing","total","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as h, nothing as o, html as e } from "lit";
2
2
  import { property as s, state as v, customElement as u } from "lit/decorators.js";
3
- import { h as b, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as b, r as f } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var m = Object.defineProperty, x = Object.getOwnPropertyDescriptor, i = (t, r, l, n) => {
5
5
  for (var c = n > 1 ? void 0 : n ? x(r, l) : r, d = t.length - 1, g; d >= 0; d--)
6
6
  (g = t[d]) && (c = (n ? g(r, l, c) : g(c)) || c);
@@ -1,6 +1,6 @@
1
1
  import { css as c, LitElement as d, html as m } from "lit";
2
2
  import { property as s, state as v, customElement as h } from "lit/decorators.js";
3
- import { h as f, r as u } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as f, r as u } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var y = Object.defineProperty, b = Object.getOwnPropertyDescriptor, i = (e, a, n, o) => {
5
5
  for (var r = o > 1 ? void 0 : o ? b(a, n) : a, l = e.length - 1, p; l >= 0; l--)
6
6
  (p = e[l]) && (r = (o ? p(a, n, r) : p(r)) || r);
@@ -69,7 +69,7 @@ t.styles = [f, u, c`
69
69
  .wrapper.fade { opacity: 0; }
70
70
  .wrapper.slide-up {
71
71
  opacity: 0;
72
- transform: translateY(var(--cg-spacing-24);
72
+ transform: translateY(var(--cg-spacing-24));
73
73
  }
74
74
  .wrapper.scale {
75
75
  opacity: 0;
@@ -107,7 +107,7 @@ t.styles = [f, u, c`
107
107
  }
108
108
 
109
109
  @keyframes reveal-slide-up {
110
- from { opacity: 0; transform: translateY(var(--cg-spacing-24); }
110
+ from { opacity: 0; transform: translateY(var(--cg-spacing-24)); }
111
111
  to { opacity: 1; transform: translateY(0); }
112
112
  }
113
113
 
@@ -1 +1 @@
1
- {"version":3,"file":"ai-reveal-animation.js","sources":["../../../src/components/ai-reveal-animation/ai-reveal-animation.ts"],"sourcesContent":["/**\n * @element ai-reveal-animation\n * Entrance animation wrapper that reveals slotted content with fade,\n * slide-up, scale, or flip animations. Respects prefers-reduced-motion\n * and dispatches a completion event.\n *\n * @example\n * ```html\n * <ai-reveal-animation type=\"slide-up\" delay=\"200\" duration=\"500\" visible>\n * <ai-result-panel title=\"Results\"></ai-result-panel>\n * </ai-reveal-animation>\n * ```\n *\n * @prop {'fade'|'slide-up'|'scale'|'flip'} type - Animation type (default 'fade')\n * @prop {number} delay - Delay before animation starts in ms (default 0)\n * @prop {number} duration - Animation duration in ms (default 400)\n * @prop {boolean} visible - Trigger the reveal animation\n *\n * @fires ai-reveal-complete - When the animation finishes\n *\n * @slot - Content to reveal\n */\nimport { LitElement, html, css } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\ntype RevealType = 'fade' | 'slide-up' | 'scale' | 'flip';\n\n@customElement('ai-reveal-animation')\nexport class AiRevealAnimation extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n\n .wrapper {\n opacity: 0;\n will-change: transform, opacity;\n }\n\n /* ── Initial hidden states ── */\n .wrapper.fade { opacity: 0; }\n .wrapper.slide-up {\n opacity: 0;\n transform: translateY(var(--cg-spacing-24);\n }\n .wrapper.scale {\n opacity: 0;\n transform: scale(0.85);\n }\n .wrapper.flip {\n opacity: 0;\n transform: perspective(600px) rotateX(-15deg);\n }\n\n /* ── Visible / animated states ── */\n .wrapper.visible.fade {\n animation: reveal-fade var(--_duration) var(--_delay) ease both;\n }\n .wrapper.visible.slide-up {\n animation: reveal-slide-up var(--_duration) var(--_delay) var(--cg-transition-easing-materialize) both;\n }\n .wrapper.visible.scale {\n animation: reveal-scale var(--_duration) var(--_delay) var(--cg-transition-easing-materialize) both;\n }\n .wrapper.visible.flip {\n animation: reveal-flip var(--_duration) var(--_delay) var(--cg-transition-easing-materialize) both;\n }\n\n /* ── Completed ── */\n .wrapper.done {\n opacity: 1;\n transform: none;\n animation: none;\n }\n\n @keyframes reveal-fade {\n from { opacity: 0; }\n to { opacity: 1; }\n }\n\n @keyframes reveal-slide-up {\n from { opacity: 0; transform: translateY(var(--cg-spacing-24); }\n to { opacity: 1; transform: translateY(0); }\n }\n\n @keyframes reveal-scale {\n from { opacity: 0; transform: scale(0.85); }\n to { opacity: 1; transform: scale(1); }\n }\n\n @keyframes reveal-flip {\n from { opacity: 0; transform: perspective(600px) rotateX(-15deg); }\n to { opacity: 1; transform: perspective(600px) rotateX(0deg); }\n }\n\n `];\n\n /** Animation type */\n @property({ type: String }) type: RevealType = 'fade';\n\n /** Delay before animation starts (ms) */\n @property({ type: Number }) delay = 0;\n\n /** Animation duration (ms) */\n @property({ type: Number }) duration = 400;\n\n /** Trigger visibility / animation */\n @property({ type: Boolean }) visible = false;\n\n @state() private _done = false;\n private _animAbort?: AbortController;\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this._animAbort?.abort();\n }\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('visible') && this.visible) {\n this._done = false;\n // Clean up previous listener\n this._animAbort?.abort();\n this._animAbort = new AbortController();\n const wrapper = this.shadowRoot?.querySelector('.wrapper');\n if (wrapper) {\n wrapper.addEventListener('animationend', this._onAnimEnd, { once: true, signal: this._animAbort.signal });\n }\n }\n if (changed.has('visible') && !this.visible) {\n this._done = false;\n this._animAbort?.abort();\n }\n }\n\n private _onAnimEnd = () => {\n this._done = true;\n // Release will-change after animation completes\n const wrapper = this.shadowRoot?.querySelector('.wrapper') as HTMLElement | null;\n if (wrapper) {\n wrapper.style.willChange = 'auto';\n }\n this.dispatchEvent(new CustomEvent('ai-reveal-complete', {\n bubbles: true, composed: true,\n }));\n };\n\n private _checkReducedMotion(): boolean {\n return window.matchMedia('(prefers-reduced-motion: reduce)').matches;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n // If reduced motion and visible, mark done immediately\n if (this.visible && this._checkReducedMotion()) {\n this._done = true;\n // Dispatch async so listeners can attach\n requestAnimationFrame(() => {\n this.dispatchEvent(new CustomEvent('ai-reveal-complete', {\n bubbles: true, composed: true,\n }));\n });\n }\n }\n\n override render() {\n const classes = [\n 'wrapper',\n this.type,\n this.visible ? 'visible' : '',\n this._done ? 'done' : '',\n ].filter(Boolean).join(' ');\n\n return html`\n <div\n class=${classes}\n style=\"--_duration: ${this.duration}ms; --_delay: ${this.delay}ms;\"\n role=\"presentation\"\n aria-hidden=${!this.visible && !this._done ? 'true' : 'false'}\n >\n <slot></slot>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-reveal-animation': AiRevealAnimation;\n }\n}\n"],"names":["AiRevealAnimation","LitElement","wrapper","changed","classes","html","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-reveal-animation.js","sources":["../../../src/components/ai-reveal-animation/ai-reveal-animation.ts"],"sourcesContent":["/**\n * @element ai-reveal-animation\n * Entrance animation wrapper that reveals slotted content with fade,\n * slide-up, scale, or flip animations. Respects prefers-reduced-motion\n * and dispatches a completion event.\n *\n * @example\n * ```html\n * <ai-reveal-animation type=\"slide-up\" delay=\"200\" duration=\"500\" visible>\n * <ai-result-panel title=\"Results\"></ai-result-panel>\n * </ai-reveal-animation>\n * ```\n *\n * @prop {'fade'|'slide-up'|'scale'|'flip'} type - Animation type (default 'fade')\n * @prop {number} delay - Delay before animation starts in ms (default 0)\n * @prop {number} duration - Animation duration in ms (default 400)\n * @prop {boolean} visible - Trigger the reveal animation\n *\n * @fires ai-reveal-complete - When the animation finishes\n *\n * @slot - Content to reveal\n */\nimport { LitElement, html, css } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\ntype RevealType = 'fade' | 'slide-up' | 'scale' | 'flip';\n\n@customElement('ai-reveal-animation')\nexport class AiRevealAnimation extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n\n .wrapper {\n opacity: 0;\n will-change: transform, opacity;\n }\n\n /* ── Initial hidden states ── */\n .wrapper.fade { opacity: 0; }\n .wrapper.slide-up {\n opacity: 0;\n transform: translateY(var(--cg-spacing-24));\n }\n .wrapper.scale {\n opacity: 0;\n transform: scale(0.85);\n }\n .wrapper.flip {\n opacity: 0;\n transform: perspective(600px) rotateX(-15deg);\n }\n\n /* ── Visible / animated states ── */\n .wrapper.visible.fade {\n animation: reveal-fade var(--_duration) var(--_delay) ease both;\n }\n .wrapper.visible.slide-up {\n animation: reveal-slide-up var(--_duration) var(--_delay) var(--cg-transition-easing-materialize) both;\n }\n .wrapper.visible.scale {\n animation: reveal-scale var(--_duration) var(--_delay) var(--cg-transition-easing-materialize) both;\n }\n .wrapper.visible.flip {\n animation: reveal-flip var(--_duration) var(--_delay) var(--cg-transition-easing-materialize) both;\n }\n\n /* ── Completed ── */\n .wrapper.done {\n opacity: 1;\n transform: none;\n animation: none;\n }\n\n @keyframes reveal-fade {\n from { opacity: 0; }\n to { opacity: 1; }\n }\n\n @keyframes reveal-slide-up {\n from { opacity: 0; transform: translateY(var(--cg-spacing-24)); }\n to { opacity: 1; transform: translateY(0); }\n }\n\n @keyframes reveal-scale {\n from { opacity: 0; transform: scale(0.85); }\n to { opacity: 1; transform: scale(1); }\n }\n\n @keyframes reveal-flip {\n from { opacity: 0; transform: perspective(600px) rotateX(-15deg); }\n to { opacity: 1; transform: perspective(600px) rotateX(0deg); }\n }\n\n `];\n\n /** Animation type */\n @property({ type: String }) type: RevealType = 'fade';\n\n /** Delay before animation starts (ms) */\n @property({ type: Number }) delay = 0;\n\n /** Animation duration (ms) */\n @property({ type: Number }) duration = 400;\n\n /** Trigger visibility / animation */\n @property({ type: Boolean }) visible = false;\n\n @state() private _done = false;\n private _animAbort?: AbortController;\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this._animAbort?.abort();\n }\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('visible') && this.visible) {\n this._done = false;\n // Clean up previous listener\n this._animAbort?.abort();\n this._animAbort = new AbortController();\n const wrapper = this.shadowRoot?.querySelector('.wrapper');\n if (wrapper) {\n wrapper.addEventListener('animationend', this._onAnimEnd, { once: true, signal: this._animAbort.signal });\n }\n }\n if (changed.has('visible') && !this.visible) {\n this._done = false;\n this._animAbort?.abort();\n }\n }\n\n private _onAnimEnd = () => {\n this._done = true;\n // Release will-change after animation completes\n const wrapper = this.shadowRoot?.querySelector('.wrapper') as HTMLElement | null;\n if (wrapper) {\n wrapper.style.willChange = 'auto';\n }\n this.dispatchEvent(new CustomEvent('ai-reveal-complete', {\n bubbles: true, composed: true,\n }));\n };\n\n private _checkReducedMotion(): boolean {\n return window.matchMedia('(prefers-reduced-motion: reduce)').matches;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n // If reduced motion and visible, mark done immediately\n if (this.visible && this._checkReducedMotion()) {\n this._done = true;\n // Dispatch async so listeners can attach\n requestAnimationFrame(() => {\n this.dispatchEvent(new CustomEvent('ai-reveal-complete', {\n bubbles: true, composed: true,\n }));\n });\n }\n }\n\n override render() {\n const classes = [\n 'wrapper',\n this.type,\n this.visible ? 'visible' : '',\n this._done ? 'done' : '',\n ].filter(Boolean).join(' ');\n\n return html`\n <div\n class=${classes}\n style=\"--_duration: ${this.duration}ms; --_delay: ${this.delay}ms;\"\n role=\"presentation\"\n aria-hidden=${!this.visible && !this._done ? 'true' : 'false'}\n >\n <slot></slot>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-reveal-animation': AiRevealAnimation;\n }\n}\n"],"names":["AiRevealAnimation","LitElement","wrapper","changed","classes","html","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as x, LitElement as y, nothing as h, html as p } from "lit";
2
2
  import { property as n, customElement as w } from "lit/decorators.js";
3
- import { h as k, r as $ } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as k, r as $ } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var _ = Object.defineProperty, S = Object.getOwnPropertyDescriptor, s = (t, r, a, i) => {
5
5
  for (var o = i > 1 ? void 0 : i ? S(r, a) : r, c = t.length - 1, d; c >= 0; c--)
6
6
  (d = t[c]) && (o = (i ? d(r, a, o) : d(o)) || o);
@@ -1 +1 @@
1
- {"version":3,"file":"ai-rich-message.d.ts","sourceRoot":"","sources":["../../../src/components/ai-rich-message/ai-rich-message.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD,UAAU,OAAO;IACf,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,OAAO,CAAC;CACf;AAED,UAAU,SAAS;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,qBACa,aAAc,SAAQ,UAAU;IAC3C,OAAgB,MAAM,4BA0InB;IAEkC,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAe;IAC7D,IAAI,SAAM;IACN,KAAK,EAAE,OAAO,EAAE,CAAM;IAC1B,MAAM,SAAM;IACZ,SAAS,SAAM;IACX,OAAO,EAAE,SAAS,EAAE,CAAM;IAE1D,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,aAAa;IAUrB,OAAO,CAAC,WAAW;IAWnB,OAAO,CAAC,UAAU,CAAC,CAAkB;IAE5B,oBAAoB;IAK7B,2EAA2E;IAC3E,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAK7B;IAEH,OAAO,CAAC,gBAAgB;IAOxB,OAAO,CAAC,YAAY;IAgCpB,OAAO,CAAC,cAAc;IAeb,MAAM;CAqBhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,iBAAiB,EAAE,aAAa,CAAC;KAClC;CACF"}
1
+ {"version":3,"file":"ai-rich-message.d.ts","sourceRoot":"","sources":["../../../src/components/ai-rich-message/ai-rich-message.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD,UAAU,OAAO;IACf,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,OAAO,CAAC;CACf;AAED,UAAU,SAAS;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,qBACa,aAAc,SAAQ,UAAU;IAC3C,OAAgB,MAAM,4BAiJnB;IAEkC,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAe;IAC7D,IAAI,SAAM;IACN,KAAK,EAAE,OAAO,EAAE,CAAM;IAC1B,MAAM,SAAM;IACZ,SAAS,SAAM;IACX,OAAO,EAAE,SAAS,EAAE,CAAM;IAE1D,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,aAAa;IAUrB,OAAO,CAAC,WAAW;IAWnB,OAAO,CAAC,UAAU,CAAC,CAAkB;IAE5B,oBAAoB;IAK7B,2EAA2E;IAC3E,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAK7B;IAEH,OAAO,CAAC,gBAAgB;IAOxB,OAAO,CAAC,YAAY;IAgCpB,OAAO,CAAC,cAAc;IAeb,MAAM;CAqBhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,iBAAiB,EAAE,aAAa,CAAC;KAClC;CACF"}