@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,56 +1,30 @@
1
- import { css as x, LitElement as y, svg as p, html as s, nothing as i } from "lit";
2
- import { property as m, state as b, customElement as w } from "lit/decorators.js";
3
- import { h as _, r as $, f as k } from "../../chunks/premium.css-9I4kHrsl.js";
1
+ import { css as p, LitElement as v, svg as g, html as e, nothing as i } from "lit";
2
+ import { property as u, state as h, customElement as f } from "lit/decorators.js";
3
+ import { h as m, r as x, c as b, f as w } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  import "../cg-card/cg-card.js";
5
5
  import "../cg-text/cg-text.js";
6
6
  import "../cg-button/cg-button.js";
7
- import "../cg-spinner/cg-spinner.js";
8
- var C = Object.defineProperty, z = Object.getOwnPropertyDescriptor, d = (t, a, r, o) => {
9
- for (var n = o > 1 ? void 0 : o ? z(a, r) : a, l = t.length - 1, g; l >= 0; l--)
10
- (g = t[l]) && (n = (o ? g(a, r, n) : g(n)) || n);
11
- return o && n && C(a, r, n), n;
7
+ var y = Object.defineProperty, _ = Object.getOwnPropertyDescriptor, c = (t, a, o, s) => {
8
+ for (var r = s > 1 ? void 0 : s ? _(a, o) : a, l = t.length - 1, d; l >= 0; l--)
9
+ (d = t[l]) && (r = (s ? d(a, o, r) : d(r)) || r);
10
+ return s && r && y(a, o, r), r;
12
11
  };
13
- let c = class extends y {
12
+ let n = class extends v {
14
13
  constructor() {
15
- super(...arguments), this.tests = [], this.title = "Test Results", this._expanded = /* @__PURE__ */ new Set(), this._filter = "all";
16
- }
17
- // ─── Derived counts ─────────────────────────────────────────────────────
18
- _countByStatus(t) {
19
- return this.tests.filter((a) => a.status === t).length;
14
+ super(...arguments), this.tests = [], this.title = "Test Results", this._expanded = /* @__PURE__ */ new Set();
20
15
  }
21
16
  get _passCount() {
22
- return this._countByStatus("pass");
17
+ return this.tests.filter((t) => t.status === "pass").length;
23
18
  }
24
19
  get _failCount() {
25
- return this._countByStatus("fail");
20
+ return this.tests.filter((t) => t.status === "fail").length;
26
21
  }
27
22
  get _runningCount() {
28
- return this._countByStatus("running");
23
+ return this.tests.filter((t) => t.status === "running").length;
29
24
  }
30
25
  get _pendingCount() {
31
- return this._countByStatus("pending");
32
- }
33
- /** Sum of test.duration (skipping undefined). */
34
- get _totalDuration() {
35
- return this.tests.reduce((t, a) => t + (a.duration ?? 0), 0);
36
- }
37
- /** Average of defined `score` values; null if no scores present. */
38
- get _avgScore() {
39
- const t = this.tests.filter((r) => typeof r.score == "number");
40
- if (!t.length) return null;
41
- const a = t.reduce((r, o) => r + (o.score ?? 0), 0);
42
- return Math.round(a / t.length);
43
- }
44
- _formatDuration(t) {
45
- if (t < 1e3) return `${Math.round(t)} ms`;
46
- if (t < 6e4) return `${(t / 1e3).toFixed(1)} s`;
47
- const a = Math.floor(t / 6e4), r = Math.round(t % 6e4 / 1e3);
48
- return `${a}m ${r}s`;
26
+ return this.tests.filter((t) => t.status === "pending").length;
49
27
  }
50
- get _visibleTests() {
51
- return this.tests.map((t, a) => ({ test: t, index: a })).filter(({ test: t }) => this._filter === "all" || t.status === this._filter);
52
- }
53
- // ─── Handlers ───────────────────────────────────────────────────────────
54
28
  _toggle(t) {
55
29
  const a = new Set(this._expanded);
56
30
  a.has(t) ? a.delete(t) : a.add(t), this._expanded = a, this.dispatchEvent(new CustomEvent("ai-test-click", {
@@ -66,24 +40,17 @@ let c = class extends y {
66
40
  detail: { tests: this.tests.map((t) => t.name) }
67
41
  }));
68
42
  }
69
- // ─── Renderers ──────────────────────────────────────────────────────────
70
43
  _statusIcon(t) {
71
- return t === "pass" ? s`<span class="status-icon pass" aria-label="Passed">${p`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><polyline points="20 6 9 17 4 12"/></svg>`}</span>` : t === "fail" ? s`<span class="status-icon fail" aria-label="Failed">${p`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="3" stroke-linecap="round"><path d="M18 6L6 18M6 6l12 12"/></svg>`}</span>` : t === "running" ? s`<span class="status-icon running" aria-label="Running"><cg-spinner size="sm"></cg-spinner></span>` : s`<span class="status-icon pending" aria-label="Pending">${p`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="9"/></svg>`}</span>`;
44
+ return t === "pass" ? e`<span class="status-icon pass" aria-label="Passed">${g`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><polyline points="20 6 9 17 4 12"/></svg>`}</span>` : t === "fail" ? e`<span class="status-icon fail" aria-label="Failed">${g`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="3" stroke-linecap="round"><path d="M18 6L6 18M6 6l12 12"/></svg>`}</span>` : t === "running" ? e`<span class="spinner" role="status" aria-label="Running"></span>` : e`<span class="status-icon pending" aria-label="Pending">${g`<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="9"/></svg>`}</span>`;
72
45
  }
73
46
  render() {
74
- const t = this.tests.length || 1, a = this._passCount / t * 100, r = this._failCount / t * 100, o = this._totalDuration, n = this._avgScore, l = this._visibleTests, v = [
75
- { id: "all", label: "All", count: this.tests.length },
76
- { id: "pass", label: "Passed", count: this._passCount },
77
- { id: "fail", label: "Failed", count: this._failCount },
78
- { id: "running", label: "Running", count: this._runningCount },
79
- { id: "pending", label: "Pending", count: this._pendingCount }
80
- ].filter((e) => e.id === "all" || e.count > 0);
81
- return s`
82
- <cg-card variant="elevated" padding="md" rounded="lg">
47
+ const t = this.tests.length || 1, a = this._passCount / t * 100, o = this._failCount / t * 100;
48
+ return e`
49
+ <cg-card variant="outlined" padding="md" rounded="lg">
83
50
  <div slot="header" class="header-row">
84
51
  <cg-text as="h3" size="sm" weight="semibold">${this.title}</cg-text>
85
52
  <cg-button variant="primary" size="sm" @click=${this._runAll} aria-label="Run all tests">
86
- Run all
53
+ Run All
87
54
  </cg-button>
88
55
  </div>
89
56
 
@@ -96,111 +63,72 @@ let c = class extends y {
96
63
  <span class="dot dot-fail" aria-hidden="true"></span>
97
64
  <cg-text size="xs" color="muted">${this._failCount} failed</cg-text>
98
65
  </span>
99
- ${this._runningCount ? s`
66
+ ${this._runningCount ? e`
100
67
  <span class="summary-item">
101
68
  <span class="dot dot-running" aria-hidden="true"></span>
102
69
  <cg-text size="xs" color="muted">${this._runningCount} running</cg-text>
103
70
  </span>
104
71
  ` : i}
105
- ${this._pendingCount ? s`
72
+ ${this._pendingCount ? e`
106
73
  <span class="summary-item">
107
74
  <span class="dot dot-pending" aria-hidden="true"></span>
108
75
  <cg-text size="xs" color="muted">${this._pendingCount} pending</cg-text>
109
76
  </span>
110
77
  ` : i}
111
- <span class="summary-spacer"></span>
112
- ${n != null ? s`
113
- <span class="summary-item">
114
- <cg-text size="xs" color="muted">Avg score:</cg-text>
115
- <cg-text size="xs" weight="semibold">${n}%</cg-text>
116
- </span>
117
- ` : i}
118
- ${o > 0 ? s`
119
- <span class="summary-item">
120
- <cg-text size="xs" color="muted">${this._formatDuration(o)}</cg-text>
121
- </span>
122
- ` : i}
123
78
  </div>
124
79
 
125
80
  <div class="progress-bar" aria-hidden="true">
126
81
  <div class="progress-pass" style="width:${a}%"></div>
127
- <div class="progress-fail" style="width:${r}%"></div>
82
+ <div class="progress-fail" style="width:${o}%"></div>
128
83
  </div>
129
84
 
130
- ${this.tests.length > 1 && v.length > 1 ? s`
131
- <div class="filter-chips">
132
- ${v.map((e) => s`
85
+ <div class="test-list" role="list" aria-label="Tests">
86
+ ${this.tests.map((s, r) => e`
87
+ <div class="test-item" role="listitem">
133
88
  <button
134
- class="filter-chip ${this._filter === e.id ? "active" : ""}"
135
- type="button"
136
- @click=${() => {
137
- this._filter = e.id;
138
- }}
139
- aria-pressed=${this._filter === e.id ? "true" : "false"}
89
+ class="test-header"
90
+ @click=${() => this._toggle(r)}
91
+ aria-expanded=${this._expanded.has(r)}
140
92
  >
141
- <span>${e.label}</span>
142
- <span class="filter-count">${e.count}</span>
93
+ ${this._statusIcon(s.status)}
94
+ <cg-text class="test-name" size="sm">${s.name}</cg-text>
95
+ <div class="test-meta">
96
+ ${s.score != null ? e`<cg-text size="xs" weight="semibold">${s.score}%</cg-text>` : i}
97
+ ${s.duration != null ? e`<cg-text size="xs" color="muted">${s.duration}ms</cg-text>` : i}
98
+ </div>
143
99
  </button>
144
- `)}
145
- </div>
146
- ` : i}
147
-
148
- <div class="test-list" role="list" aria-label="Tests">
149
- ${l.length === 0 ? s`
150
- <div class="empty">No tests match the current filter.</div>
151
- ` : l.map(({ test: e, index: h }) => {
152
- const u = !!(e.expected || e.actual), f = this._expanded.has(h);
153
- return s`
154
- <div class="test-item ${e.status === "running" ? "running-row" : ""}" role="listitem">
155
- <button
156
- class="test-header ${u ? "expandable" : ""}"
157
- type="button"
158
- @click=${() => {
159
- u && this._toggle(h);
160
- }}
161
- aria-expanded=${u ? f ? "true" : "false" : i}
162
- >
163
- ${this._statusIcon(e.status)}
164
- <cg-text class="test-name" size="sm">${e.name}</cg-text>
165
- <div class="test-meta">
166
- ${e.score != null ? s`<cg-text size="xs" weight="semibold">${e.score}%</cg-text>` : i}
167
- ${e.duration != null ? s`<cg-text size="xs" color="muted">${this._formatDuration(e.duration)}</cg-text>` : i}
168
- </div>
169
- </button>
170
- ${f && u ? s`
171
- <div class="test-details">
172
- ${e.expected ? s`
173
- <div class="detail-row">
174
- <cg-text class="detail-label" size="xs" color="muted">Expected</cg-text>
175
- <span class="detail-value detail-expected">${e.expected}</span>
176
- </div>
177
- ` : i}
178
- ${e.actual ? s`
179
- <div class="detail-row">
180
- <cg-text class="detail-label" size="xs" color="muted">Actual</cg-text>
181
- <span class="detail-value detail-actual">${e.actual}</span>
182
- </div>
183
- ` : i}
184
- </div>
185
- ` : i}
186
- </div>
187
- `;
188
- })}
100
+ ${this._expanded.has(r) && (s.expected || s.actual) ? e`
101
+ <div class="test-details">
102
+ ${s.expected ? e`
103
+ <div class="detail-row">
104
+ <cg-text class="detail-label" size="xs" color="muted">Expected:</cg-text>
105
+ <cg-text size="xs" class="detail-expected">${s.expected}</cg-text>
106
+ </div>
107
+ ` : i}
108
+ ${s.actual ? e`
109
+ <div class="detail-row">
110
+ <cg-text class="detail-label" size="xs" color="muted">Actual:</cg-text>
111
+ <cg-text size="xs" class="detail-actual">${s.actual}</cg-text>
112
+ </div>
113
+ ` : i}
114
+ </div>
115
+ ` : i}
116
+ </div>
117
+ `)}
189
118
  </div>
190
119
  </cg-card>
191
120
  `;
192
121
  }
193
122
  };
194
- c.styles = [_, $, k, x`
123
+ n.styles = [m, x, b, w, p`
195
124
  :host {
196
125
  display: block;
197
- animation: fadeSlideIn var(--cg-transition-duration-default) var(--cg-transition-easing-default);
126
+ animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
198
127
  }
199
128
  :host([hidden]) { display: none; }
200
129
 
201
130
  cg-card { display: block; }
202
131
 
203
- /* ── Header row ── */
204
132
  .header-row {
205
133
  display: flex;
206
134
  align-items: center;
@@ -209,20 +137,15 @@ c.styles = [_, $, k, x`
209
137
  width: 100%;
210
138
  }
211
139
 
212
- /* ── Summary bar ── */
213
140
  .summary-bar {
214
141
  display: flex;
215
- flex-wrap: wrap;
216
142
  gap: var(--cg-spacing-16);
217
143
  margin-bottom: var(--cg-spacing-8);
218
- align-items: center;
219
144
  }
220
- .summary-spacer { flex: 1; }
221
145
  .summary-item {
222
146
  display: inline-flex;
223
147
  align-items: center;
224
148
  gap: var(--cg-spacing-6);
225
- font-variant-numeric: tabular-nums;
226
149
  }
227
150
  .dot {
228
151
  width: var(--cg-spacing-8);
@@ -234,12 +157,10 @@ c.styles = [_, $, k, x`
234
157
  .dot-running { background: var(--cg-color-status-warning-text-default); }
235
158
  .dot-pending { background: var(--cg-color-surface-container-outlined); }
236
159
 
237
- /* Combined pass/fail progress bar — track uses divider semantic, not a
238
- border-color token. */
239
160
  .progress-bar {
240
- height: var(--cg-spacing-6);
161
+ height: var(--cg-spacing-4);
241
162
  border-radius: var(--cg-border-radius-full);
242
- background: var(--cg-color-surface-cards-divider);
163
+ background: var(--cg-color-surface-cards-border);
243
164
  margin-bottom: var(--cg-spacing-12);
244
165
  overflow: hidden;
245
166
  display: flex;
@@ -247,72 +168,27 @@ c.styles = [_, $, k, x`
247
168
  .progress-pass {
248
169
  background: var(--cg-color-status-success-text-default);
249
170
  height: 100%;
250
- transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);
171
+ transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);
251
172
  }
252
173
  .progress-fail {
253
174
  background: var(--cg-color-status-error-text-default);
254
175
  height: 100%;
255
- transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);
256
- }
257
-
258
- /* ── Filter chips ── */
259
- .filter-chips {
260
- display: flex;
261
- gap: var(--cg-spacing-6);
262
- flex-wrap: wrap;
263
- margin-bottom: var(--cg-spacing-12);
264
- }
265
- .filter-chip {
266
- display: inline-flex;
267
- align-items: center;
268
- gap: var(--cg-spacing-4);
269
- padding: var(--cg-spacing-2) var(--cg-spacing-8);
270
- border-radius: var(--cg-border-radius-full);
271
- border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
272
- background: transparent;
273
- color: var(--cg-color-input-text-placeholder);
274
- font-size: var(--cg-font-size-xs);
275
- font-weight: var(--cg-font-weight-medium);
276
- font-family: inherit;
277
- cursor: pointer;
278
- transition:
279
- background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
280
- border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
281
- color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
282
- }
283
- .filter-chip:hover {
284
- border-color: var(--cg-color-surface-cards-border-strong);
285
- color: var(--cg-color-surface-base-text);
286
- }
287
- .filter-chip:focus-visible {
288
- outline: none;
289
- box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
176
+ transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);
290
177
  }
291
- .filter-chip.active {
292
- background: var(--cg-color-surface-cards-emphasis);
293
- border-color: var(--cg-color-surface-cards-border-strong);
294
- color: var(--cg-color-surface-base-text);
295
- }
296
- .filter-count {
297
- font-variant-numeric: tabular-nums;
298
- color: var(--cg-color-input-text-placeholder);
299
- }
300
- .filter-chip.active .filter-count { color: var(--cg-color-surface-base-text); }
301
178
 
302
- /* ── Test list ──
303
- Items render as a single grouped table inside the card, divided
304
- by hairlines. Per-item border-radius is omitted so every row's
305
- hover/focus bg fills consistently corner-to-corner — the previous
306
- version rounded only the first row, which made the first hover
307
- look different from the rest. The parent <cg-card> handles the
308
- outer rounding. */
309
179
  .test-list {
310
180
  display: flex;
311
181
  flex-direction: column;
182
+ gap: 0;
312
183
  }
313
184
 
185
+ .test-item {
186
+ border-radius: var(--cg-border-radius-100);
187
+ overflow: hidden;
188
+ }
314
189
  .test-item + .test-item {
315
- border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);
190
+ border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
191
+ border-radius: 0;
316
192
  }
317
193
 
318
194
  .test-header {
@@ -320,6 +196,7 @@ c.styles = [_, $, k, x`
320
196
  align-items: center;
321
197
  gap: var(--cg-spacing-12);
322
198
  padding: var(--cg-spacing-12);
199
+ cursor: pointer;
323
200
  background: transparent;
324
201
  border: none;
325
202
  color: inherit;
@@ -327,16 +204,14 @@ c.styles = [_, $, k, x`
327
204
  font-family: inherit;
328
205
  text-align: left;
329
206
  min-height: var(--cg-spacing-48);
330
- cursor: default;
331
- transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
207
+ transition:
208
+ background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
209
+ transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
332
210
  }
333
- /* Only rows that have details to reveal get the clickable affordance.
334
- Running/pending tests have nothing to expand, so they shouldn't
335
- suggest interaction. */
336
- .test-header.expandable { cursor: pointer; }
337
- .test-header.expandable:hover {
338
- background: var(--cg-color-action-tertiary-background-hover);
211
+ .test-header:hover {
212
+ background: var(--cg-color-action-secondary-background-hover);
339
213
  }
214
+ .test-header:active { transform: scale(var(--cg-interaction-press-scale)); }
340
215
  .test-header:focus-visible {
341
216
  outline: none;
342
217
  box-shadow: inset 0 0 0 3px var(--cg-overlay-accent-strong);
@@ -347,23 +222,14 @@ c.styles = [_, $, k, x`
347
222
  display: inline-flex;
348
223
  align-items: center;
349
224
  justify-content: center;
350
- width: var(--cg-icon-size-150);
351
- height: var(--cg-icon-size-150);
225
+ width: var(--cg-spacing-16);
226
+ height: var(--cg-spacing-16);
352
227
  }
353
228
  .status-icon svg { width: 100%; height: 100%; }
354
229
  .status-icon.pass { color: var(--cg-color-status-success-text-default); }
355
230
  .status-icon.fail { color: var(--cg-color-status-error-text-default); }
356
231
  .status-icon.pending { color: var(--cg-color-surface-container-outlined); }
357
232
 
358
- /* Subtle pulse on the running spinner host so the row visibly "breathes". */
359
- .running-row .status-icon {
360
- animation: cg-test-pulse 1.6s var(--cg-transition-easing-ease-in-out) infinite;
361
- }
362
- @keyframes cg-test-pulse {
363
- 0%, 100% { opacity: 1; }
364
- 50% { opacity: 0.55; }
365
- }
366
-
367
233
  .test-name {
368
234
  flex: 1;
369
235
  min-width: 0;
@@ -380,69 +246,46 @@ c.styles = [_, $, k, x`
380
246
  font-variant-numeric: tabular-nums;
381
247
  }
382
248
 
383
- /* ── Expanded details ── */
384
249
  .test-details {
385
- padding: var(--cg-spacing-12) var(--cg-spacing-12) var(--cg-spacing-16) var(--cg-spacing-32);
386
- border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);
250
+ padding: var(--cg-spacing-8) var(--cg-spacing-12) var(--cg-spacing-12) var(--cg-spacing-32);
251
+ border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
387
252
  font-family: var(--cg-font-family-mono);
388
253
  background: var(--cg-color-code-background);
389
- animation: cg-test-detail-expand var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;
390
- }
391
- @keyframes cg-test-detail-expand {
392
- from { opacity: 0; transform: translateY(-4px); }
393
- to { opacity: 1; transform: translateY(0); }
394
254
  }
395
255
  .detail-row {
396
256
  display: flex;
397
- gap: var(--cg-spacing-12);
398
- padding: var(--cg-spacing-4) 0;
399
- align-items: flex-start;
257
+ gap: var(--cg-spacing-8);
258
+ margin-bottom: var(--cg-spacing-4);
400
259
  }
401
260
  .detail-label {
402
261
  min-width: var(--cg-spacing-64);
403
- flex-shrink: 0;
404
- text-transform: uppercase;
405
- letter-spacing: var(--cg-letter-spacing-wide);
406
- }
407
- .detail-value {
408
- flex: 1;
409
- word-break: break-word;
410
- white-space: pre-wrap;
411
- }
412
- .detail-expected {
413
- color: var(--cg-color-status-success-text-default);
414
- border-left: var(--cg-spacing-2) solid var(--cg-color-status-success-text-default);
415
- padding-left: var(--cg-spacing-8);
416
- }
417
- .detail-actual {
418
- color: var(--cg-color-status-error-text-default);
419
- border-left: var(--cg-spacing-2) solid var(--cg-color-status-error-text-default);
420
- padding-left: var(--cg-spacing-8);
421
262
  }
263
+ .detail-expected { color: var(--cg-color-status-success-text-default); }
264
+ .detail-actual { color: var(--cg-color-status-error-text-default); }
422
265
 
423
- .empty {
424
- padding: var(--cg-spacing-32);
425
- text-align: center;
426
- color: var(--cg-color-input-text-placeholder);
427
- font-size: var(--cg-font-size-xs);
266
+ .spinner {
267
+ display: inline-block;
268
+ width: var(--cg-spacing-16);
269
+ height: var(--cg-spacing-16);
270
+ border: var(--cg-border-width-100) solid var(--cg-color-status-warning-text-default);
271
+ border-top-color: transparent;
272
+ border-radius: var(--cg-border-radius-full);
273
+ animation: spin var(--cg-transition-duration-slow) linear infinite;
428
274
  }
429
275
  `];
430
- d([
431
- m({ type: Array })
432
- ], c.prototype, "tests", 2);
433
- d([
434
- m({ type: String })
435
- ], c.prototype, "title", 2);
436
- d([
437
- b()
438
- ], c.prototype, "_expanded", 2);
439
- d([
440
- b()
441
- ], c.prototype, "_filter", 2);
442
- c = d([
443
- w("ai-test-runner")
444
- ], c);
276
+ c([
277
+ u({ type: Array })
278
+ ], n.prototype, "tests", 2);
279
+ c([
280
+ u({ type: String })
281
+ ], n.prototype, "title", 2);
282
+ c([
283
+ h()
284
+ ], n.prototype, "_expanded", 2);
285
+ n = c([
286
+ f("ai-test-runner")
287
+ ], n);
445
288
  export {
446
- c as AiTestRunner
289
+ n as AiTestRunner
447
290
  };
448
291
  //# sourceMappingURL=ai-test-runner.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ai-test-runner.js","sources":["../../../src/components/ai-test-runner/ai-test-runner.ts"],"sourcesContent":["/**\n * @element ai-test-runner\n * AI evaluation test results panel built from design-system primitives\n * (cg-card, cg-text, cg-button, cg-spinner). Status icons (pass / fail /\n * running / pending), per-test duration + score, summary bar with combined\n * pass/fail progress, total duration + avg score, status filter chips, and\n * a \"Run All\" CTA. Modeled on the Vitest / Playwright UI mode.\n *\n * @example\n * ```html\n * <ai-test-runner title=\"Eval Suite\" .tests=${[\n * { name: 'Summarization accuracy', status: 'pass', duration: 340, score: 92 },\n * { name: 'Hallucination check', status: 'fail', duration: 210,\n * expected: 'No hallucinations', actual: 'Found 2 claims' }\n * ]}></ai-test-runner>\n * ```\n *\n * @prop {TestEntry[]} tests - Test entries\n * @prop {string} title - Panel header title (default 'Test Results')\n *\n * @fires {CustomEvent<{tests: string[]}>} ai-test-run - \"Run All\" clicked\n * @fires {CustomEvent<{index: number, test: TestEntry}>} ai-test-click - Test row toggled\n */\nimport { LitElement, html, css, nothing, svg } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\nimport '../cg-card/cg-card.js';\nimport '../cg-text/cg-text.js';\nimport '../cg-button/cg-button.js';\nimport '../cg-spinner/cg-spinner.js';\n\nexport interface TestEntry {\n name: string;\n status: 'pass' | 'fail' | 'running' | 'pending';\n duration?: number;\n expected?: string;\n actual?: string;\n score?: number;\n}\n\ntype FilterId = 'all' | 'pass' | 'fail' | 'running' | 'pending';\n\n@customElement('ai-test-runner')\nexport class AiTestRunner extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n display: block;\n animation: fadeSlideIn var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n :host([hidden]) { display: none; }\n\n cg-card { display: block; }\n\n /* ── Header row ── */\n .header-row {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: var(--cg-spacing-12);\n width: 100%;\n }\n\n /* ── Summary bar ── */\n .summary-bar {\n display: flex;\n flex-wrap: wrap;\n gap: var(--cg-spacing-16);\n margin-bottom: var(--cg-spacing-8);\n align-items: center;\n }\n .summary-spacer { flex: 1; }\n .summary-item {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n font-variant-numeric: tabular-nums;\n }\n .dot {\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n }\n .dot-pass { background: var(--cg-color-status-success-text-default); }\n .dot-fail { background: var(--cg-color-status-error-text-default); }\n .dot-running { background: var(--cg-color-status-warning-text-default); }\n .dot-pending { background: var(--cg-color-surface-container-outlined); }\n\n /* Combined pass/fail progress bar — track uses divider semantic, not a\n border-color token. */\n .progress-bar {\n height: var(--cg-spacing-6);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-surface-cards-divider);\n margin-bottom: var(--cg-spacing-12);\n overflow: hidden;\n display: flex;\n }\n .progress-pass {\n background: var(--cg-color-status-success-text-default);\n height: 100%;\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);\n }\n .progress-fail {\n background: var(--cg-color-status-error-text-default);\n height: 100%;\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);\n }\n\n /* ── Filter chips ── */\n .filter-chips {\n display: flex;\n gap: var(--cg-spacing-6);\n flex-wrap: wrap;\n margin-bottom: var(--cg-spacing-12);\n }\n .filter-chip {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-4);\n padding: var(--cg-spacing-2) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n background: transparent;\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-medium);\n font-family: inherit;\n cursor: pointer;\n transition:\n background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .filter-chip:hover {\n border-color: var(--cg-color-surface-cards-border-strong);\n color: var(--cg-color-surface-base-text);\n }\n .filter-chip:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n .filter-chip.active {\n background: var(--cg-color-surface-cards-emphasis);\n border-color: var(--cg-color-surface-cards-border-strong);\n color: var(--cg-color-surface-base-text);\n }\n .filter-count {\n font-variant-numeric: tabular-nums;\n color: var(--cg-color-input-text-placeholder);\n }\n .filter-chip.active .filter-count { color: var(--cg-color-surface-base-text); }\n\n /* ── Test list ──\n Items render as a single grouped table inside the card, divided\n by hairlines. Per-item border-radius is omitted so every row's\n hover/focus bg fills consistently corner-to-corner — the previous\n version rounded only the first row, which made the first hover\n look different from the rest. The parent <cg-card> handles the\n outer rounding. */\n .test-list {\n display: flex;\n flex-direction: column;\n }\n\n .test-item + .test-item {\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n\n .test-header {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-12);\n background: transparent;\n border: none;\n color: inherit;\n width: 100%;\n font-family: inherit;\n text-align: left;\n min-height: var(--cg-spacing-48);\n cursor: default;\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n /* Only rows that have details to reveal get the clickable affordance.\n Running/pending tests have nothing to expand, so they shouldn't\n suggest interaction. */\n .test-header.expandable { cursor: pointer; }\n .test-header.expandable:hover {\n background: var(--cg-color-action-tertiary-background-hover);\n }\n .test-header:focus-visible {\n outline: none;\n box-shadow: inset 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n .status-icon {\n flex-shrink: 0;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--cg-icon-size-150);\n height: var(--cg-icon-size-150);\n }\n .status-icon svg { width: 100%; height: 100%; }\n .status-icon.pass { color: var(--cg-color-status-success-text-default); }\n .status-icon.fail { color: var(--cg-color-status-error-text-default); }\n .status-icon.pending { color: var(--cg-color-surface-container-outlined); }\n\n /* Subtle pulse on the running spinner host so the row visibly \"breathes\". */\n .running-row .status-icon {\n animation: cg-test-pulse 1.6s var(--cg-transition-easing-ease-in-out) infinite;\n }\n @keyframes cg-test-pulse {\n 0%, 100% { opacity: 1; }\n 50% { opacity: 0.55; }\n }\n\n .test-name {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n\n .test-meta {\n flex-shrink: 0;\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n font-variant-numeric: tabular-nums;\n }\n\n /* ── Expanded details ── */\n .test-details {\n padding: var(--cg-spacing-12) var(--cg-spacing-12) var(--cg-spacing-16) var(--cg-spacing-32);\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n font-family: var(--cg-font-family-mono);\n background: var(--cg-color-code-background);\n animation: cg-test-detail-expand var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;\n }\n @keyframes cg-test-detail-expand {\n from { opacity: 0; transform: translateY(-4px); }\n to { opacity: 1; transform: translateY(0); }\n }\n .detail-row {\n display: flex;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-4) 0;\n align-items: flex-start;\n }\n .detail-label {\n min-width: var(--cg-spacing-64);\n flex-shrink: 0;\n text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wide);\n }\n .detail-value {\n flex: 1;\n word-break: break-word;\n white-space: pre-wrap;\n }\n .detail-expected {\n color: var(--cg-color-status-success-text-default);\n border-left: var(--cg-spacing-2) solid var(--cg-color-status-success-text-default);\n padding-left: var(--cg-spacing-8);\n }\n .detail-actual {\n color: var(--cg-color-status-error-text-default);\n border-left: var(--cg-spacing-2) solid var(--cg-color-status-error-text-default);\n padding-left: var(--cg-spacing-8);\n }\n\n .empty {\n padding: var(--cg-spacing-32);\n text-align: center;\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-xs);\n }\n `];\n\n @property({ type: Array }) tests: TestEntry[] = [];\n @property({ type: String }) override title = 'Test Results';\n\n @state() private _expanded = new Set<number>();\n @state() private _filter: FilterId = 'all';\n\n // ─── Derived counts ─────────────────────────────────────────────────────\n\n private _countByStatus(status: TestEntry['status']): number {\n return this.tests.filter(t => t.status === status).length;\n }\n private get _passCount() { return this._countByStatus('pass'); }\n private get _failCount() { return this._countByStatus('fail'); }\n private get _runningCount() { return this._countByStatus('running'); }\n private get _pendingCount() { return this._countByStatus('pending'); }\n\n /** Sum of test.duration (skipping undefined). */\n private get _totalDuration(): number {\n return this.tests.reduce((acc, t) => acc + (t.duration ?? 0), 0);\n }\n\n /** Average of defined `score` values; null if no scores present. */\n private get _avgScore(): number | null {\n const scored = this.tests.filter(t => typeof t.score === 'number');\n if (!scored.length) return null;\n const sum = scored.reduce((acc, t) => acc + (t.score ?? 0), 0);\n return Math.round(sum / scored.length);\n }\n\n private _formatDuration(ms: number): string {\n if (ms < 1000) return `${Math.round(ms)} ms`;\n if (ms < 60_000) return `${(ms / 1000).toFixed(1)} s`;\n const m = Math.floor(ms / 60_000);\n const s = Math.round((ms % 60_000) / 1000);\n return `${m}m ${s}s`;\n }\n\n private get _visibleTests(): Array<{ test: TestEntry; index: number }> {\n return this.tests\n .map((test, index) => ({ test, index }))\n .filter(({ test }) => this._filter === 'all' || test.status === this._filter);\n }\n\n // ─── Handlers ───────────────────────────────────────────────────────────\n\n private _toggle(idx: number): void {\n const next = new Set(this._expanded);\n if (next.has(idx)) next.delete(idx); else next.add(idx);\n this._expanded = next;\n this.dispatchEvent(new CustomEvent('ai-test-click', {\n bubbles: true, composed: true,\n detail: { index: idx, test: this.tests[idx] },\n }));\n }\n\n private _runAll(): void {\n this.dispatchEvent(new CustomEvent('ai-test-run', {\n bubbles: true, composed: true,\n detail: { tests: this.tests.map(t => t.name) },\n }));\n }\n\n // ─── Renderers ──────────────────────────────────────────────────────────\n\n private _statusIcon(status: TestEntry['status']) {\n if (status === 'pass') {\n return html`<span class=\"status-icon pass\" aria-label=\"Passed\">${svg`<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><polyline points=\"20 6 9 17 4 12\"/></svg>`}</span>`;\n }\n if (status === 'fail') {\n return html`<span class=\"status-icon fail\" aria-label=\"Failed\">${svg`<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg>`}</span>`;\n }\n if (status === 'running') {\n return html`<span class=\"status-icon running\" aria-label=\"Running\"><cg-spinner size=\"sm\"></cg-spinner></span>`;\n }\n return html`<span class=\"status-icon pending\" aria-label=\"Pending\">${svg`<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><circle cx=\"12\" cy=\"12\" r=\"9\"/></svg>`}</span>`;\n }\n\n override render() {\n const total = this.tests.length || 1;\n const passP = (this._passCount / total) * 100;\n const failP = (this._failCount / total) * 100;\n const totalDur = this._totalDuration;\n const avgScore = this._avgScore;\n const visible = this._visibleTests;\n\n const allFilters: Array<{ id: FilterId; label: string; count: number }> = [\n { id: 'all', label: 'All', count: this.tests.length },\n { id: 'pass', label: 'Passed', count: this._passCount },\n { id: 'fail', label: 'Failed', count: this._failCount },\n { id: 'running', label: 'Running', count: this._runningCount },\n { id: 'pending', label: 'Pending', count: this._pendingCount },\n ];\n const FILTERS = allFilters.filter(f => f.id === 'all' || f.count > 0);\n\n return html`\n <cg-card variant=\"elevated\" padding=\"md\" rounded=\"lg\">\n <div slot=\"header\" class=\"header-row\">\n <cg-text as=\"h3\" size=\"sm\" weight=\"semibold\">${this.title}</cg-text>\n <cg-button variant=\"primary\" size=\"sm\" @click=${this._runAll} aria-label=\"Run all tests\">\n Run all\n </cg-button>\n </div>\n\n <div class=\"summary-bar\" role=\"status\" aria-label=\"Test summary\">\n <span class=\"summary-item\">\n <span class=\"dot dot-pass\" aria-hidden=\"true\"></span>\n <cg-text size=\"xs\" color=\"muted\">${this._passCount} passed</cg-text>\n </span>\n <span class=\"summary-item\">\n <span class=\"dot dot-fail\" aria-hidden=\"true\"></span>\n <cg-text size=\"xs\" color=\"muted\">${this._failCount} failed</cg-text>\n </span>\n ${this._runningCount ? html`\n <span class=\"summary-item\">\n <span class=\"dot dot-running\" aria-hidden=\"true\"></span>\n <cg-text size=\"xs\" color=\"muted\">${this._runningCount} running</cg-text>\n </span>\n ` : nothing}\n ${this._pendingCount ? html`\n <span class=\"summary-item\">\n <span class=\"dot dot-pending\" aria-hidden=\"true\"></span>\n <cg-text size=\"xs\" color=\"muted\">${this._pendingCount} pending</cg-text>\n </span>\n ` : nothing}\n <span class=\"summary-spacer\"></span>\n ${avgScore != null ? html`\n <span class=\"summary-item\">\n <cg-text size=\"xs\" color=\"muted\">Avg score:</cg-text>\n <cg-text size=\"xs\" weight=\"semibold\">${avgScore}%</cg-text>\n </span>\n ` : nothing}\n ${totalDur > 0 ? html`\n <span class=\"summary-item\">\n <cg-text size=\"xs\" color=\"muted\">${this._formatDuration(totalDur)}</cg-text>\n </span>\n ` : nothing}\n </div>\n\n <div class=\"progress-bar\" aria-hidden=\"true\">\n <div class=\"progress-pass\" style=\"width:${passP}%\"></div>\n <div class=\"progress-fail\" style=\"width:${failP}%\"></div>\n </div>\n\n ${this.tests.length > 1 && FILTERS.length > 1 ? html`\n <div class=\"filter-chips\">\n ${FILTERS.map(f => html`\n <button\n class=\"filter-chip ${this._filter === f.id ? 'active' : ''}\"\n type=\"button\"\n @click=${() => { this._filter = f.id; }}\n aria-pressed=${this._filter === f.id ? 'true' : 'false'}\n >\n <span>${f.label}</span>\n <span class=\"filter-count\">${f.count}</span>\n </button>\n `)}\n </div>\n ` : nothing}\n\n <div class=\"test-list\" role=\"list\" aria-label=\"Tests\">\n ${visible.length === 0 ? html`\n <div class=\"empty\">No tests match the current filter.</div>\n ` : visible.map(({ test, index }) => {\n const expandable = !!(test.expected || test.actual);\n const expanded = this._expanded.has(index);\n return html`\n <div class=\"test-item ${test.status === 'running' ? 'running-row' : ''}\" role=\"listitem\">\n <button\n class=\"test-header ${expandable ? 'expandable' : ''}\"\n type=\"button\"\n @click=${() => { if (expandable) this._toggle(index); }}\n aria-expanded=${expandable ? (expanded ? 'true' : 'false') : nothing}\n >\n ${this._statusIcon(test.status)}\n <cg-text class=\"test-name\" size=\"sm\">${test.name}</cg-text>\n <div class=\"test-meta\">\n ${test.score != null ? html`<cg-text size=\"xs\" weight=\"semibold\">${test.score}%</cg-text>` : nothing}\n ${test.duration != null ? html`<cg-text size=\"xs\" color=\"muted\">${this._formatDuration(test.duration)}</cg-text>` : nothing}\n </div>\n </button>\n ${expanded && expandable ? html`\n <div class=\"test-details\">\n ${test.expected ? html`\n <div class=\"detail-row\">\n <cg-text class=\"detail-label\" size=\"xs\" color=\"muted\">Expected</cg-text>\n <span class=\"detail-value detail-expected\">${test.expected}</span>\n </div>\n ` : nothing}\n ${test.actual ? html`\n <div class=\"detail-row\">\n <cg-text class=\"detail-label\" size=\"xs\" color=\"muted\">Actual</cg-text>\n <span class=\"detail-value detail-actual\">${test.actual}</span>\n </div>\n ` : nothing}\n </div>\n ` : nothing}\n </div>\n `;\n })}\n </div>\n </cg-card>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-test-runner': AiTestRunner;\n }\n}\n"],"names":["AiTestRunner","LitElement","status","t","acc","scored","sum","ms","m","s","test","index","idx","next","html","svg","total","passP","failP","totalDur","avgScore","visible","FILTERS","f","nothing","expandable","expanded","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"ai-test-runner.js","sources":["../../../src/components/ai-test-runner/ai-test-runner.ts"],"sourcesContent":["/**\n * @element ai-test-runner\n * AI evaluation test results panel built from design-system primitives\n * (cg-card, cg-text, cg-button). Pass/fail/running/pending status icons,\n * duration, optional scores, expandable expected/actual details, summary bar,\n * combined pass/fail progress bar, and a \"Run All\" CTA.\n *\n * @example\n * ```html\n * <ai-test-runner title=\"Eval Suite\" .tests=${[\n * { name: 'Summarization accuracy', status: 'pass', duration: 340, score: 92 },\n * { name: 'Hallucination check', status: 'fail', duration: 210,\n * expected: 'No hallucinations', actual: 'Found 2 claims' }\n * ]}></ai-test-runner>\n * ```\n *\n * @prop {TestEntry[]} tests - Test entries\n * @prop {string} title - Panel header title (default 'Test Results')\n *\n * @fires {CustomEvent<{tests: string[]}>} ai-test-run - \"Run All\" clicked\n * @fires {CustomEvent<{index: number, test: TestEntry}>} ai-test-click - Test row toggled\n */\nimport { LitElement, html, css, nothing, svg } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, spinKeyframes, fadeSlideInKeyframes } from '../../styles/index.js';\nimport '../cg-card/cg-card.js';\nimport '../cg-text/cg-text.js';\nimport '../cg-button/cg-button.js';\n\nexport interface TestEntry {\n name: string;\n status: 'pass' | 'fail' | 'running' | 'pending';\n duration?: number;\n expected?: string;\n actual?: string;\n score?: number;\n}\n\n@customElement('ai-test-runner')\nexport class AiTestRunner extends LitElement {\n static override styles = [hostBlock, reducedMotion, spinKeyframes, fadeSlideInKeyframes, css`\n :host {\n display: block;\n animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n :host([hidden]) { display: none; }\n\n cg-card { display: block; }\n\n .header-row {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: var(--cg-spacing-12);\n width: 100%;\n }\n\n .summary-bar {\n display: flex;\n gap: var(--cg-spacing-16);\n margin-bottom: var(--cg-spacing-8);\n }\n .summary-item {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n }\n .dot {\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n }\n .dot-pass { background: var(--cg-color-status-success-text-default); }\n .dot-fail { background: var(--cg-color-status-error-text-default); }\n .dot-running { background: var(--cg-color-status-warning-text-default); }\n .dot-pending { background: var(--cg-color-surface-container-outlined); }\n\n .progress-bar {\n height: var(--cg-spacing-4);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-surface-cards-border);\n margin-bottom: var(--cg-spacing-12);\n overflow: hidden;\n display: flex;\n }\n .progress-pass {\n background: var(--cg-color-status-success-text-default);\n height: 100%;\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n .progress-fail {\n background: var(--cg-color-status-error-text-default);\n height: 100%;\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n\n .test-list {\n display: flex;\n flex-direction: column;\n gap: 0;\n }\n\n .test-item {\n border-radius: var(--cg-border-radius-100);\n overflow: hidden;\n }\n .test-item + .test-item {\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: 0;\n }\n\n .test-header {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-12);\n cursor: pointer;\n background: transparent;\n border: none;\n color: inherit;\n width: 100%;\n font-family: inherit;\n text-align: left;\n min-height: var(--cg-spacing-48);\n transition:\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .test-header:hover {\n background: var(--cg-color-action-secondary-background-hover);\n }\n .test-header:active { transform: scale(var(--cg-interaction-press-scale)); }\n .test-header:focus-visible {\n outline: none;\n box-shadow: inset 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n .status-icon {\n flex-shrink: 0;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--cg-spacing-16);\n height: var(--cg-spacing-16);\n }\n .status-icon svg { width: 100%; height: 100%; }\n .status-icon.pass { color: var(--cg-color-status-success-text-default); }\n .status-icon.fail { color: var(--cg-color-status-error-text-default); }\n .status-icon.pending { color: var(--cg-color-surface-container-outlined); }\n\n .test-name {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n\n .test-meta {\n flex-shrink: 0;\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n font-variant-numeric: tabular-nums;\n }\n\n .test-details {\n padding: var(--cg-spacing-8) var(--cg-spacing-12) var(--cg-spacing-12) var(--cg-spacing-32);\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n font-family: var(--cg-font-family-mono);\n background: var(--cg-color-code-background);\n }\n .detail-row {\n display: flex;\n gap: var(--cg-spacing-8);\n margin-bottom: var(--cg-spacing-4);\n }\n .detail-label {\n min-width: var(--cg-spacing-64);\n }\n .detail-expected { color: var(--cg-color-status-success-text-default); }\n .detail-actual { color: var(--cg-color-status-error-text-default); }\n\n .spinner {\n display: inline-block;\n width: var(--cg-spacing-16);\n height: var(--cg-spacing-16);\n border: var(--cg-border-width-100) solid var(--cg-color-status-warning-text-default);\n border-top-color: transparent;\n border-radius: var(--cg-border-radius-full);\n animation: spin var(--cg-transition-duration-slow) linear infinite;\n }\n `];\n\n @property({ type: Array }) tests: TestEntry[] = [];\n @property({ type: String }) override title = 'Test Results';\n\n @state() private _expanded = new Set<number>();\n\n private get _passCount() { return this.tests.filter(t => t.status === 'pass').length; }\n private get _failCount() { return this.tests.filter(t => t.status === 'fail').length; }\n private get _runningCount() { return this.tests.filter(t => t.status === 'running').length; }\n private get _pendingCount() { return this.tests.filter(t => t.status === 'pending').length; }\n\n private _toggle(idx: number): void {\n const next = new Set(this._expanded);\n if (next.has(idx)) next.delete(idx); else next.add(idx);\n this._expanded = next;\n this.dispatchEvent(new CustomEvent('ai-test-click', {\n bubbles: true, composed: true,\n detail: { index: idx, test: this.tests[idx] },\n }));\n }\n\n private _runAll(): void {\n this.dispatchEvent(new CustomEvent('ai-test-run', {\n bubbles: true, composed: true,\n detail: { tests: this.tests.map(t => t.name) },\n }));\n }\n\n private _statusIcon(status: TestEntry['status']) {\n if (status === 'pass') {\n return html`<span class=\"status-icon pass\" aria-label=\"Passed\">${svg`<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><polyline points=\"20 6 9 17 4 12\"/></svg>`}</span>`;\n }\n if (status === 'fail') {\n return html`<span class=\"status-icon fail\" aria-label=\"Failed\">${svg`<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg>`}</span>`;\n }\n if (status === 'running') {\n return html`<span class=\"spinner\" role=\"status\" aria-label=\"Running\"></span>`;\n }\n return html`<span class=\"status-icon pending\" aria-label=\"Pending\">${svg`<svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><circle cx=\"12\" cy=\"12\" r=\"9\"/></svg>`}</span>`;\n }\n\n override render() {\n const total = this.tests.length || 1;\n const passP = (this._passCount / total) * 100;\n const failP = (this._failCount / total) * 100;\n\n return html`\n <cg-card variant=\"outlined\" padding=\"md\" rounded=\"lg\">\n <div slot=\"header\" class=\"header-row\">\n <cg-text as=\"h3\" size=\"sm\" weight=\"semibold\">${this.title}</cg-text>\n <cg-button variant=\"primary\" size=\"sm\" @click=${this._runAll} aria-label=\"Run all tests\">\n Run All\n </cg-button>\n </div>\n\n <div class=\"summary-bar\" role=\"status\" aria-label=\"Test summary\">\n <span class=\"summary-item\">\n <span class=\"dot dot-pass\" aria-hidden=\"true\"></span>\n <cg-text size=\"xs\" color=\"muted\">${this._passCount} passed</cg-text>\n </span>\n <span class=\"summary-item\">\n <span class=\"dot dot-fail\" aria-hidden=\"true\"></span>\n <cg-text size=\"xs\" color=\"muted\">${this._failCount} failed</cg-text>\n </span>\n ${this._runningCount ? html`\n <span class=\"summary-item\">\n <span class=\"dot dot-running\" aria-hidden=\"true\"></span>\n <cg-text size=\"xs\" color=\"muted\">${this._runningCount} running</cg-text>\n </span>\n ` : nothing}\n ${this._pendingCount ? html`\n <span class=\"summary-item\">\n <span class=\"dot dot-pending\" aria-hidden=\"true\"></span>\n <cg-text size=\"xs\" color=\"muted\">${this._pendingCount} pending</cg-text>\n </span>\n ` : nothing}\n </div>\n\n <div class=\"progress-bar\" aria-hidden=\"true\">\n <div class=\"progress-pass\" style=\"width:${passP}%\"></div>\n <div class=\"progress-fail\" style=\"width:${failP}%\"></div>\n </div>\n\n <div class=\"test-list\" role=\"list\" aria-label=\"Tests\">\n ${this.tests.map((t, i) => html`\n <div class=\"test-item\" role=\"listitem\">\n <button\n class=\"test-header\"\n @click=${() => this._toggle(i)}\n aria-expanded=${this._expanded.has(i)}\n >\n ${this._statusIcon(t.status)}\n <cg-text class=\"test-name\" size=\"sm\">${t.name}</cg-text>\n <div class=\"test-meta\">\n ${t.score != null ? html`<cg-text size=\"xs\" weight=\"semibold\">${t.score}%</cg-text>` : nothing}\n ${t.duration != null ? html`<cg-text size=\"xs\" color=\"muted\">${t.duration}ms</cg-text>` : nothing}\n </div>\n </button>\n ${this._expanded.has(i) && (t.expected || t.actual) ? html`\n <div class=\"test-details\">\n ${t.expected ? html`\n <div class=\"detail-row\">\n <cg-text class=\"detail-label\" size=\"xs\" color=\"muted\">Expected:</cg-text>\n <cg-text size=\"xs\" class=\"detail-expected\">${t.expected}</cg-text>\n </div>\n ` : nothing}\n ${t.actual ? html`\n <div class=\"detail-row\">\n <cg-text class=\"detail-label\" size=\"xs\" color=\"muted\">Actual:</cg-text>\n <cg-text size=\"xs\" class=\"detail-actual\">${t.actual}</cg-text>\n </div>\n ` : nothing}\n </div>\n ` : nothing}\n </div>\n `)}\n </div>\n </cg-card>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-test-runner': AiTestRunner;\n }\n}\n"],"names":["AiTestRunner","LitElement","idx","next","status","html","svg","total","passP","failP","nothing","t","i","hostBlock","reducedMotion","spinKeyframes","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as h, LitElement as u, html as t, nothing as s } from "lit";
2
2
  import { property as i, state as p, customElement as v } from "lit/decorators.js";
3
- import { h as m, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as m, r as f } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var b = Object.defineProperty, y = Object.getOwnPropertyDescriptor, r = (e, o, c, l) => {
5
5
  for (var n = l > 1 ? void 0 : l ? y(o, c) : o, g = e.length - 1, d; g >= 0; g--)
6
6
  (d = e[g]) && (n = (l ? d(o, c, n) : d(n)) || n);