@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 +1 @@
1
- {"version":3,"file":"ai-webhook-config.js","sources":["../../../src/components/ai-webhook-config/ai-webhook-config.ts"],"sourcesContent":["/**\n * @element ai-webhook-config\n * Webhook endpoint management — Stripe / Svix style. Composed entirely\n * from design-system primitives:\n * • <cg-input> for the URL field (HTTPS validation)\n * • <cg-button> for Add / Cancel / Create / Test / Delete actions\n * • <cg-switch> for the on/off toggle\n * • <cg-chip> for selectable events in the form + event tags on rows\n * • <cg-badge> for the last-delivery HTTP status code (success/warning/danger)\n * Lists configured webhooks with URL, event chips, last delivery status\n * (code + retries + relative time), test + delete actions, and an inline\n * Add form with HTTPS-validated input + selectable event picker.\n *\n * @example\n * ```html\n * <ai-webhook-config\n * .webhooks=${[{ id: 'wh1', url: 'https://example.com/hook', events: ['model.complete'], active: true,\n * lastDelivery: { status: 200, at: Date.now() - 3600000 } }]}\n * .availableEvents=${['model.complete', 'model.error', 'usage.limit']}\n * ></ai-webhook-config>\n * ```\n *\n * @prop {WebhookEntry[]} webhooks - Configured webhook entries\n * @prop {string[]} availableEvents - Event types available for subscription\n *\n * @fires {CustomEvent<{url, events}>} ai-webhook-create\n * @fires {CustomEvent<{id, active}>} ai-webhook-toggle\n * @fires {CustomEvent<{id}>} ai-webhook-delete\n * @fires {CustomEvent<{id, url}>} ai-webhook-test\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\nimport '../cg-button/cg-button.js';\nimport '../cg-input/cg-input.js';\nimport '../cg-switch/cg-switch.js';\nimport '../cg-chip/cg-chip.js';\nimport '../cg-badge/cg-badge.js';\n\nexport interface WebhookDelivery {\n /** HTTP status code from the last delivery attempt. */\n status: number;\n /** ISO date or epoch ms of the last attempt. */\n at: string | number;\n /** Number of retries that preceded the final result. */\n retries?: number;\n}\n\nexport interface WebhookEntry {\n id: string;\n url: string;\n events: string[];\n active: boolean;\n /** Stripe / Svix-style: most recent delivery result. */\n lastDelivery?: WebhookDelivery;\n /** Auto-disabled after consecutive failures. */\n disabled?: boolean;\n /** @deprecated use lastDelivery instead */\n lastTriggered?: string;\n}\n\n@customElement('ai-webhook-config')\nexport class AiWebhookConfig extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n display: block;\n background: var(--cg-color-surface-cards-background);\n color: var(--cg-color-surface-base-text);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n box-shadow: var(--cg-elevation-1);\n padding: var(--cg-spacing-20);\n animation: fadeSlideIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;\n }\n :host([hidden]) { display: none; }\n\n .header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding-bottom: var(--cg-spacing-16);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n margin-bottom: var(--cg-spacing-16);\n }\n h3 {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n margin: 0;\n }\n\n /* ── Add-webhook form ── */\n .form {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-16);\n background: var(--cg-overlay-dark-subtle);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-100);\n margin-bottom: var(--cg-spacing-12);\n }\n .form-events {\n display: flex;\n flex-wrap: wrap;\n gap: var(--cg-spacing-6);\n }\n .form-events-label {\n width: 100%;\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n letter-spacing: var(--cg-letter-spacing-wide);\n text-transform: uppercase;\n font-weight: var(--cg-font-weight-bold);\n }\n .form-actions {\n display: flex;\n gap: var(--cg-spacing-8);\n justify-content: flex-end;\n }\n\n /* ── Webhook list ── */\n .webhook-list {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-8);\n }\n\n .webhook-item {\n padding: var(--cg-spacing-16);\n background: var(--cg-color-surface-cards-emphasis);\n border-radius: var(--cg-border-radius-100);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-8);\n }\n .webhook-item.is-disabled { opacity: 0.65; }\n\n .webhook-top {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n }\n .webhook-url {\n flex: 1;\n min-width: 0;\n font-family: var(--cg-font-family-mono);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-base-text);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n\n .webhook-events {\n display: flex;\n flex-wrap: wrap;\n gap: var(--cg-spacing-4);\n }\n\n /* ── Footer (last delivery + actions) ── */\n .webhook-footer {\n display: flex;\n justify-content: space-between;\n align-items: center;\n gap: var(--cg-spacing-12);\n flex-wrap: wrap;\n }\n\n .last-delivery {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n font-variant-numeric: tabular-nums;\n }\n .last-delivery cg-badge {\n font-variant-numeric: tabular-nums;\n }\n .delivery-retries {\n color: var(--cg-color-status-warning-text-default);\n font-weight: var(--cg-font-weight-medium);\n }\n\n .webhook-actions {\n display: flex;\n gap: var(--cg-spacing-6);\n flex-shrink: 0;\n }\n\n .empty {\n text-align: center;\n padding: var(--cg-spacing-32);\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-sm);\n }\n `];\n\n @property({ type: Array }) webhooks: WebhookEntry[] = [];\n @property({ type: Array }) availableEvents: string[] = [];\n\n @state() private _showForm = false;\n @state() private _newUrl = '';\n @state() private _selectedEvents = new Set<string>();\n @state() private _urlError = '';\n\n // ─── Form lifecycle ─────────────────────────────────────────────────────\n\n private _toggleForm(): void {\n this._showForm = !this._showForm;\n this._newUrl = '';\n this._urlError = '';\n this._selectedEvents = new Set();\n }\n\n private _onUrlInput(e: Event): void {\n const detail = (e as CustomEvent<{ value: string }>).detail;\n this._newUrl = detail?.value ?? (e.target as HTMLInputElement).value ?? '';\n this._urlError = '';\n }\n\n private _toggleEvent(evt: string): void {\n const next = new Set(this._selectedEvents);\n if (next.has(evt)) next.delete(evt); else next.add(evt);\n this._selectedEvents = next;\n }\n\n private _onCreate(): void {\n if (!this._newUrl) {\n this._urlError = 'URL is required';\n return;\n }\n if (!/^https:\\/\\//i.test(this._newUrl)) {\n this._urlError = 'URL must use HTTPS';\n return;\n }\n this.dispatchEvent(new CustomEvent('ai-webhook-create', {\n bubbles: true, composed: true,\n detail: { url: this._newUrl, events: [...this._selectedEvents] },\n }));\n this._toggleForm();\n }\n\n // ─── Per-webhook handlers ───────────────────────────────────────────────\n\n private _onToggle(wh: WebhookEntry, e: Event): void {\n const detail = (e as CustomEvent<{ checked: boolean }>).detail;\n this.dispatchEvent(new CustomEvent('ai-webhook-toggle', {\n bubbles: true, composed: true,\n detail: { id: wh.id, active: detail?.checked ?? !wh.active },\n }));\n }\n\n private _onDelete(wh: WebhookEntry): void {\n this.dispatchEvent(new CustomEvent('ai-webhook-delete', {\n bubbles: true, composed: true,\n detail: { id: wh.id },\n }));\n }\n\n private _onTest(wh: WebhookEntry): void {\n this.dispatchEvent(new CustomEvent('ai-webhook-test', {\n bubbles: true, composed: true,\n detail: { id: wh.id, url: wh.url },\n }));\n }\n\n // ─── Helpers ────────────────────────────────────────────────────────────\n\n private _deliveryVariant(status: number): 'success' | 'warning' | 'danger' | 'neutral' {\n if (status >= 200 && status < 300) return 'success';\n if (status >= 400 && status < 500) return 'warning';\n if (status >= 500) return 'danger';\n return 'neutral';\n }\n\n private _relativeTime(input: string | number): string {\n const date = new Date(input);\n if (isNaN(date.getTime())) return String(input);\n const diffMs = date.getTime() - Date.now();\n const abs = Math.abs(diffMs);\n const min = 60_000, hr = 60 * min, day = 24 * hr, week = 7 * day;\n let value: number, unit: Intl.RelativeTimeFormatUnit;\n if (abs < hr) { value = Math.round(diffMs / min); unit = 'minute'; }\n else if (abs < day) { value = Math.round(diffMs / hr); unit = 'hour'; }\n else if (abs < week) { value = Math.round(diffMs / day); unit = 'day'; }\n else { value = Math.round(diffMs / week); unit = 'week'; }\n try { return new Intl.RelativeTimeFormat('en', { numeric: 'auto' }).format(value, unit); }\n catch { return String(input); }\n }\n\n // ─── Render ─────────────────────────────────────────────────────────────\n\n override render() {\n return html`\n <div class=\"header\">\n <h3>Webhooks</h3>\n <cg-button\n variant=${this._showForm ? 'secondary' : 'primary'}\n size=\"sm\"\n @click=${this._toggleForm}\n aria-label=\"${this._showForm ? 'Cancel new webhook' : 'Add webhook'}\"\n >${this._showForm ? 'Cancel' : 'Add webhook'}</cg-button>\n </div>\n\n ${this._showForm ? html`\n <div class=\"form\" role=\"form\" aria-label=\"New webhook\">\n <cg-input\n type=\"url\"\n label=\"Endpoint URL\"\n placeholder=\"https://example.com/webhook\"\n .value=${this._newUrl}\n ?error=${!!this._urlError}\n helper=${this._urlError || 'Must use HTTPS in production.'}\n required\n @cg-input=${this._onUrlInput}\n ></cg-input>\n\n ${this.availableEvents.length ? html`\n <div role=\"group\" aria-label=\"Subscribed events\">\n <span class=\"form-events-label\">Subscribe to events</span>\n <div class=\"form-events\">\n ${this.availableEvents.map(evt => html`\n <cg-chip\n label=${evt}\n size=\"sm\"\n ?selected=${this._selectedEvents.has(evt)}\n @click=${() => this._toggleEvent(evt)}\n ></cg-chip>\n `)}\n </div>\n </div>\n ` : nothing}\n\n <div class=\"form-actions\">\n <cg-button variant=\"tertiary\" size=\"sm\" @click=${this._toggleForm}>\n Cancel\n </cg-button>\n <cg-button variant=\"primary\" size=\"sm\" @click=${this._onCreate}>\n Create webhook\n </cg-button>\n </div>\n </div>\n ` : nothing}\n\n ${this.webhooks.length === 0 ? html`\n <div class=\"empty\" role=\"status\">No webhooks configured yet.</div>\n ` : html`\n <div class=\"webhook-list\" role=\"list\" aria-label=\"Configured webhooks\">\n ${this.webhooks.map(wh => {\n const lastDelivery = wh.lastDelivery;\n return html`\n <div class=\"webhook-item ${wh.disabled ? 'is-disabled' : ''}\" role=\"listitem\">\n <div class=\"webhook-top\">\n <span class=\"webhook-url\" title=${wh.url}>${wh.url}</span>\n <cg-switch\n .checked=${wh.active}\n ?disabled=${wh.disabled}\n aria-label=\"Toggle webhook ${wh.url}\"\n @cg-change=${(e: Event) => this._onToggle(wh, e)}\n ></cg-switch>\n </div>\n\n ${wh.events.length ? html`\n <div class=\"webhook-events\">\n ${wh.events.map(e => html`\n <cg-chip label=${e} size=\"sm\" variant=\"info\"></cg-chip>\n `)}\n </div>\n ` : nothing}\n\n <div class=\"webhook-footer\">\n <div class=\"last-delivery\">\n ${lastDelivery ? html`\n <cg-badge\n variant=${this._deliveryVariant(lastDelivery.status)}\n label=${String(lastDelivery.status)}\n size=\"sm\"\n ></cg-badge>\n <span>${this._relativeTime(lastDelivery.at)}</span>\n ${lastDelivery.retries && lastDelivery.retries > 0 ? html`\n <span class=\"delivery-retries\">· ${lastDelivery.retries} ${lastDelivery.retries === 1 ? 'retry' : 'retries'}</span>\n ` : nothing}\n ` : wh.lastTriggered ? html`\n <span>Last triggered ${wh.lastTriggered}</span>\n ` : html`\n <span>Never triggered</span>\n `}\n </div>\n <div class=\"webhook-actions\">\n <cg-button variant=\"secondary\" size=\"sm\" @click=${() => this._onTest(wh)}>\n Test\n </cg-button>\n <cg-button variant=\"secondary\" size=\"sm\" type=\"danger\" @click=${() => this._onDelete(wh)}>\n Delete\n </cg-button>\n </div>\n </div>\n </div>\n `;\n })}\n </div>\n `}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-webhook-config': AiWebhookConfig;\n }\n}\n"],"names":["AiWebhookConfig","LitElement","detail","evt","next","wh","e","status","input","date","diffMs","abs","min","hr","day","week","value","unit","html","nothing","lastDelivery","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","customElement"],"mappings":";;;;;;;;;;;;;AA8DO,IAAMA,IAAN,cAA8BC,EAAW;AAAA,EAAzC,cAAA;AAAA,UAAA,GAAA,SAAA,GA0IsB,KAAA,WAA2B,CAAA,GAC3B,KAAA,kBAA4B,CAAA,GAE9C,KAAQ,YAAY,IACpB,KAAQ,UAAU,IAClB,KAAQ,sCAAsB,IAAA,GAC9B,KAAQ,YAAY;AAAA,EAAA;AAAA;AAAA,EAIrB,cAAoB;AAC1B,SAAK,YAAY,CAAC,KAAK,WACvB,KAAK,UAAU,IACf,KAAK,YAAY,IACjB,KAAK,sCAAsB,IAAA;AAAA,EAC7B;AAAA,EAEQ,YAAY,GAAgB;AAClC,UAAMC,IAAU,EAAqC;AACrD,SAAK,UAAUA,GAAQ,SAAU,EAAE,OAA4B,SAAS,IACxE,KAAK,YAAY;AAAA,EACnB;AAAA,EAEQ,aAAaC,GAAmB;AACtC,UAAMC,IAAO,IAAI,IAAI,KAAK,eAAe;AACzC,IAAIA,EAAK,IAAID,CAAG,IAAGC,EAAK,OAAOD,CAAG,IAAQC,EAAK,IAAID,CAAG,GACtD,KAAK,kBAAkBC;AAAA,EACzB;AAAA,EAEQ,YAAkB;AACxB,QAAI,CAAC,KAAK,SAAS;AACjB,WAAK,YAAY;AACjB;AAAA,IACF;AACA,QAAI,CAAC,eAAe,KAAK,KAAK,OAAO,GAAG;AACtC,WAAK,YAAY;AACjB;AAAA,IACF;AACA,SAAK,cAAc,IAAI,YAAY,qBAAqB;AAAA,MACtD,SAAS;AAAA,MAAM,UAAU;AAAA,MACzB,QAAQ,EAAE,KAAK,KAAK,SAAS,QAAQ,CAAC,GAAG,KAAK,eAAe,EAAA;AAAA,IAAE,CAChE,CAAC,GACF,KAAK,YAAA;AAAA,EACP;AAAA;AAAA,EAIQ,UAAUC,GAAkBC,GAAgB;AAClD,UAAMJ,IAAUI,EAAwC;AACxD,SAAK,cAAc,IAAI,YAAY,qBAAqB;AAAA,MACtD,SAAS;AAAA,MAAM,UAAU;AAAA,MACzB,QAAQ,EAAE,IAAID,EAAG,IAAI,QAAQH,GAAQ,WAAW,CAACG,EAAG,OAAA;AAAA,IAAO,CAC5D,CAAC;AAAA,EACJ;AAAA,EAEQ,UAAUA,GAAwB;AACxC,SAAK,cAAc,IAAI,YAAY,qBAAqB;AAAA,MACtD,SAAS;AAAA,MAAM,UAAU;AAAA,MACzB,QAAQ,EAAE,IAAIA,EAAG,GAAA;AAAA,IAAG,CACrB,CAAC;AAAA,EACJ;AAAA,EAEQ,QAAQA,GAAwB;AACtC,SAAK,cAAc,IAAI,YAAY,mBAAmB;AAAA,MACpD,SAAS;AAAA,MAAM,UAAU;AAAA,MACzB,QAAQ,EAAE,IAAIA,EAAG,IAAI,KAAKA,EAAG,IAAA;AAAA,IAAI,CAClC,CAAC;AAAA,EACJ;AAAA;AAAA,EAIQ,iBAAiBE,GAA8D;AACrF,WAAIA,KAAU,OAAOA,IAAS,MAAY,YACtCA,KAAU,OAAOA,IAAS,MAAY,YACtCA,KAAU,MAAY,WACnB;AAAA,EACT;AAAA,EAEQ,cAAcC,GAAgC;AACpD,UAAMC,IAAO,IAAI,KAAKD,CAAK;AAC3B,QAAI,MAAMC,EAAK,QAAA,CAAS,EAAG,QAAO,OAAOD,CAAK;AAC9C,UAAME,IAASD,EAAK,QAAA,IAAY,KAAK,IAAA,GAC/BE,IAAM,KAAK,IAAID,CAAM,GACrBE,IAAM,KAAQC,IAAK,KAAKD,GAAKE,IAAM,KAAKD,GAAIE,IAAO,IAAID;AAC7D,QAAIE,GAAeC;AACnB,IAAIN,IAAME,KAAMG,IAAQ,KAAK,MAAMN,IAASE,CAAG,GAAGK,IAAO,YAChDN,IAAMG,KAAOE,IAAQ,KAAK,MAAMN,IAASG,CAAE,GAAGI,IAAO,UACrDN,IAAMI,KAAQC,IAAQ,KAAK,MAAMN,IAASI,CAAG,GAAGG,IAAO,UACzDD,IAAQ,KAAK,MAAMN,IAASK,CAAI,GAAGE,IAAO;AACjD,QAAI;AAAE,aAAO,IAAI,KAAK,mBAAmB,MAAM,EAAE,SAAS,OAAA,CAAQ,EAAE,OAAOD,GAAOC,CAAI;AAAA,IAAG,QACnF;AAAE,aAAO,OAAOT,CAAK;AAAA,IAAG;AAAA,EAChC;AAAA;AAAA,EAIS,SAAS;AAChB,WAAOU;AAAA;AAAA;AAAA;AAAA,oBAIS,KAAK,YAAY,cAAc,SAAS;AAAA;AAAA,mBAEzC,KAAK,WAAW;AAAA,wBACX,KAAK,YAAY,uBAAuB,aAAa;AAAA,WAClE,KAAK,YAAY,WAAW,aAAa;AAAA;AAAA;AAAA,QAG5C,KAAK,YAAYA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qBAMJ,KAAK,OAAO;AAAA,qBACZ,CAAC,CAAC,KAAK,SAAS;AAAA,qBAChB,KAAK,aAAa,+BAA+B;AAAA;AAAA,wBAE9C,KAAK,WAAW;AAAA;AAAA;AAAA,YAG5B,KAAK,gBAAgB,SAASA;AAAA;AAAA;AAAA;AAAA,kBAIxB,KAAK,gBAAgB,IAAI,CAAAf,MAAOe;AAAA;AAAA,4BAEtBf,CAAG;AAAA;AAAA,gCAEC,KAAK,gBAAgB,IAAIA,CAAG,CAAC;AAAA,6BAChC,MAAM,KAAK,aAAaA,CAAG,CAAC;AAAA;AAAA,iBAExC,CAAC;AAAA;AAAA;AAAA,cAGJgB,CAAO;AAAA;AAAA;AAAA,6DAGwC,KAAK,WAAW;AAAA;AAAA;AAAA,4DAGjB,KAAK,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA,UAKhEA,CAAO;AAAA;AAAA,QAET,KAAK,SAAS,WAAW,IAAID;AAAA;AAAA,UAE3BA;AAAA;AAAA,YAEE,KAAK,SAAS,IAAI,CAAAb,MAAM;AACxB,YAAMe,IAAef,EAAG;AACxB,aAAOa;AAAA,yCACsBb,EAAG,WAAW,gBAAgB,EAAE;AAAA;AAAA,oDAErBA,EAAG,GAAG,IAAIA,EAAG,GAAG;AAAA;AAAA,+BAErCA,EAAG,MAAM;AAAA,gCACRA,EAAG,QAAQ;AAAA,iDACMA,EAAG,GAAG;AAAA,iCACtB,CAACC,MAAa,KAAK,UAAUD,GAAIC,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA,kBAIlDD,EAAG,OAAO,SAASa;AAAA;AAAA,sBAEfb,EAAG,OAAO,IAAI,CAAAC,MAAKY;AAAA,uCACFZ,CAAC;AAAA,qBACnB,CAAC;AAAA;AAAA,oBAEFa,CAAO;AAAA;AAAA;AAAA;AAAA,sBAILC,IAAeF;AAAA;AAAA,kCAEH,KAAK,iBAAiBE,EAAa,MAAM,CAAC;AAAA,gCAC5C,OAAOA,EAAa,MAAM,CAAC;AAAA;AAAA;AAAA,8BAG7B,KAAK,cAAcA,EAAa,EAAE,CAAC;AAAA,wBACzCA,EAAa,WAAWA,EAAa,UAAU,IAAIF;AAAA,2DAChBE,EAAa,OAAO,IAAIA,EAAa,YAAY,IAAI,UAAU,SAAS;AAAA,0BACzGD,CAAO;AAAA,wBACTd,EAAG,gBAAgBa;AAAA,6CACEb,EAAG,aAAa;AAAA,wBACrCa;AAAA;AAAA,qBAEH;AAAA;AAAA;AAAA,sEAGiD,MAAM,KAAK,QAAQb,CAAE,CAAC;AAAA;AAAA;AAAA,oFAGR,MAAM,KAAK,UAAUA,CAAE,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOlG,CAAC,CAAC;AAAA;AAAA,OAEL;AAAA;AAAA,EAEL;AACF;AAzVaL,EACK,SAAS,CAACqB,GAAWC,GAAeC,GAAsBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAuIzE;AAE0BC,EAAA;AAAA,EAA1BC,EAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GA1Id1B,EA0IgB,WAAA,YAAA,CAAA;AACAyB,EAAA;AAAA,EAA1BC,EAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GA3Id1B,EA2IgB,WAAA,mBAAA,CAAA;AAEVyB,EAAA;AAAA,EAAhBE,EAAA;AAAM,GA7II3B,EA6IM,WAAA,aAAA,CAAA;AACAyB,EAAA;AAAA,EAAhBE,EAAA;AAAM,GA9II3B,EA8IM,WAAA,WAAA,CAAA;AACAyB,EAAA;AAAA,EAAhBE,EAAA;AAAM,GA/II3B,EA+IM,WAAA,mBAAA,CAAA;AACAyB,EAAA;AAAA,EAAhBE,EAAA;AAAM,GAhJI3B,EAgJM,WAAA,aAAA,CAAA;AAhJNA,IAANyB,EAAA;AAAA,EADNG,EAAc,mBAAmB;AAAA,GACrB5B,CAAA;"}
1
+ {"version":3,"file":"ai-webhook-config.js","sources":["../../../src/components/ai-webhook-config/ai-webhook-config.ts"],"sourcesContent":["/**\n * @element ai-webhook-config\n * Webhook endpoint management panel. Lists configured webhooks with URL,\n * event tags, on/off toggle, test and delete actions. Includes an \"Add\n * Webhook\" form with URL input and event selection chips.\n *\n * @example\n * ```html\n * <ai-webhook-config\n * .webhooks=${[{ id: 'wh1', url: 'https://example.com/hook', events: ['model.complete'], active: true }]}\n * .availableEvents=${['model.complete', 'model.error', 'usage.limit']}\n * ></ai-webhook-config>\n * ```\n *\n * @prop {WebhookEntry[]} webhooks - Array of configured webhook entries\n * @prop {string[]} availableEvents - Event types available for subscription\n *\n * @fires {CustomEvent<{url: string, events: string[]}>} ai-webhook-create - When a new webhook is created\n * @fires {CustomEvent<{id: string, active: boolean}>} ai-webhook-toggle - When a webhook is toggled on/off\n * @fires {CustomEvent<{id: string}>} ai-webhook-delete - When a webhook is deleted\n * @fires {CustomEvent<{id: string, url: string}>} ai-webhook-test - When a webhook test is triggered\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\nexport interface WebhookEntry {\n id: string;\n url: string;\n events: string[];\n active: boolean;\n lastTriggered?: string;\n}\n\n@customElement('ai-webhook-config')\nexport class AiWebhookConfig extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n background: var(--cg-color-surface-base-background);\n color: var(--cg-color-surface-base-text);\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 animation: fadeSlideIn var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n :host([hidden]) { display: none; }\n\n .header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding-bottom: var(--cg-spacing-12);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n margin-bottom: var(--cg-spacing-12);\n }\n\n h3 {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n margin: 0;\n }\n\n .add-btn {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-surface-container-background);\n border: none;\n border-radius: var(--cg-border-radius-100);\n padding: var(--cg-spacing-6) var(--cg-spacing-12);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n cursor: pointer;\n font-family: inherit;\n transition: filter var(--cg-transition-duration-fast) var(--cg-transition-easing-default), transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .add-btn:hover {\n filter: brightness(1.1);\n transform: translateY(calc(-1 * var(--cg-spacing-1)));\n }\n\n .add-btn:focus-visible {\n outline: var(--cg-outline-width-default) solid var(--cg-overlay-accent-strong);\n outline-offset: var(--cg-outline-offset-default);\n }\n\n .form {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-12);\n background: var(--cg-color-surface-inset-background);\n border-radius: var(--cg-border-radius-100);\n margin-bottom: var(--cg-spacing-12);\n }\n\n .form-row {\n display: flex;\n gap: var(--cg-spacing-8);\n }\n\n input[type=\"url\"] {\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 border-radius: var(--cg-border-radius-50);\n padding: var(--cg-spacing-6) var(--cg-spacing-8);\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-sm);\n font-family: var(--cg-font-family-mono);\n }\n\n input[type=\"url\"]:focus-visible {\n outline: var(--cg-outline-width-default) solid var(--cg-overlay-accent-strong);\n outline-offset: -2px;\n }\n\n .events-select {\n display: flex;\n flex-wrap: wrap;\n gap: var(--cg-spacing-4);\n }\n\n .event-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 background: transparent;\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-full);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n cursor: pointer;\n font-family: inherit;\n }\n\n .event-chip:focus-visible {\n outline: var(--cg-outline-width-default) solid var(--cg-overlay-accent-strong);\n outline-offset: var(--cg-outline-offset-default);\n }\n\n .event-chip[aria-pressed=\"true\"] {\n background: var(--cg-overlay-accent-strong);\n border-color: var(--cg-color-surface-base-text);\n color: var(--cg-color-surface-base-text);\n }\n\n .form-actions {\n display: flex;\n gap: var(--cg-spacing-8);\n justify-content: flex-end;\n }\n\n .btn-sm {\n background: transparent;\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-50);\n padding: var(--cg-spacing-4) var(--cg-spacing-8);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n cursor: pointer;\n font-family: inherit;\n transition: opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .btn-sm:hover {\n border-color: var(--cg-color-surface-base-text);\n color: var(--cg-color-surface-base-text);\n transform: translateY(calc(-1 * var(--cg-spacing-1)));\n }\n\n .btn-sm:focus-visible {\n outline: var(--cg-outline-width-default) solid var(--cg-overlay-accent-strong);\n outline-offset: var(--cg-outline-offset-default);\n }\n\n .btn-sm.primary {\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 .btn-sm.primary:hover {\n filter: brightness(1.1);\n }\n\n .webhook-list {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-8);\n }\n\n .webhook-item {\n padding: var(--cg-spacing-12);\n background: var(--cg-color-surface-inset-background);\n border-radius: var(--cg-border-radius-100);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n\n .webhook-top {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n margin-bottom: var(--cg-spacing-6);\n }\n\n .webhook-url {\n flex: 1;\n font-family: var(--cg-font-family-mono);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-base-text);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n\n .toggle-switch {\n position: relative;\n display: inline-block;\n width: var(--cg-spacing-32);\n height: var(--cg-spacing-16);\n flex-shrink: 0;\n }\n\n .toggle-switch input {\n opacity: 0;\n width: 0;\n height: 0;\n position: absolute;\n }\n\n .toggle-track {\n position: absolute;\n inset: 0;\n background: var(--cg-color-surface-base-background);\n border-radius: var(--cg-border-radius-full);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n cursor: pointer;\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n\n .toggle-track::after {\n content: '';\n position: absolute;\n width: var(--cg-spacing-12);\n height: var(--cg-spacing-12);\n border-radius: 50%;\n background: var(--cg-color-input-text-placeholder);\n top: var(--cg-spacing-2);\n left: var(--cg-spacing-2);\n transition: transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n\n .toggle-switch input:checked + .toggle-track {\n background: var(--cg-overlay-accent-strong);\n border-color: var(--cg-color-surface-base-text);\n }\n\n .toggle-switch input:checked + .toggle-track::after {\n transform: translateX(var(--cg-spacing-12));\n background: var(--cg-color-action-primary-background-default);\n }\n\n .toggle-switch input:focus-visible + .toggle-track {\n outline: var(--cg-outline-width-default) solid var(--cg-overlay-accent-strong);\n outline-offset: var(--cg-outline-offset-default);\n }\n\n .webhook-events {\n display: flex;\n flex-wrap: wrap;\n gap: var(--cg-spacing-4);\n margin-bottom: var(--cg-spacing-6);\n }\n\n .event-tag {\n padding: var(--cg-spacing-2) var(--cg-spacing-6);\n background: var(--cg-overlay-accent-medium);\n border-radius: var(--cg-border-radius-50);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-base-text);\n }\n\n .webhook-footer {\n display: flex;\n justify-content: space-between;\n align-items: center;\n }\n\n .last-triggered {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n }\n\n .webhook-actions {\n display: flex;\n gap: var(--cg-spacing-4);\n }\n\n .btn-sm.danger {\n color: var(--cg-color-status-error-text-default);\n border-color: var(--cg-color-status-error-text-default);\n }\n .btn-sm.danger:hover {\n background: var(--cg-color-status-error-background-default);\n }\n\n .empty {\n text-align: center;\n padding: var(--cg-spacing-24);\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-sm);\n }\n\n `];\n\n @property({ type: Array }) webhooks: WebhookEntry[] = [];\n @property({ type: Array }) availableEvents: string[] = [];\n\n @state() private _showForm = false;\n @state() private _newUrl = '';\n @state() private _selectedEvents = new Set<string>();\n\n private _toggleForm(): void {\n this._showForm = !this._showForm;\n this._newUrl = '';\n this._selectedEvents = new Set();\n }\n\n private _toggleEvent(evt: string): void {\n const next = new Set(this._selectedEvents);\n if (next.has(evt)) next.delete(evt); else next.add(evt);\n this._selectedEvents = next;\n }\n\n private _onCreate(): void {\n if (!this._newUrl) return;\n this.dispatchEvent(new CustomEvent('ai-webhook-create', {\n bubbles: true, composed: true,\n detail: { url: this._newUrl, events: [...this._selectedEvents] },\n }));\n this._toggleForm();\n }\n\n private _onToggle(wh: WebhookEntry): void {\n this.dispatchEvent(new CustomEvent('ai-webhook-toggle', {\n bubbles: true, composed: true,\n detail: { id: wh.id, active: !wh.active },\n }));\n }\n\n private _onDelete(wh: WebhookEntry): void {\n this.dispatchEvent(new CustomEvent('ai-webhook-delete', {\n bubbles: true, composed: true,\n detail: { id: wh.id },\n }));\n }\n\n private _onTest(wh: WebhookEntry): void {\n this.dispatchEvent(new CustomEvent('ai-webhook-test', {\n bubbles: true, composed: true,\n detail: { id: wh.id, url: wh.url },\n }));\n }\n\n override render() {\n return html`\n <div class=\"header\">\n <h3>Webhooks</h3>\n <button class=\"add-btn\" @click=${this._toggleForm}\n aria-label=\"${this._showForm ? 'Cancel' : 'Add webhook'}\"\n tabindex=\"0\">\n ${this._showForm ? 'Cancel' : '+ Add Webhook'}\n </button>\n </div>\n ${this._showForm ? html`\n <div class=\"form\" role=\"form\" aria-label=\"New webhook form\">\n <div class=\"form-row\">\n <input type=\"url\" placeholder=\"https://example.com/webhook\"\n .value=${this._newUrl}\n @input=${(e: Event) => { this._newUrl = (e.target as HTMLInputElement).value; }}\n aria-label=\"Webhook URL\" tabindex=\"0\" />\n </div>\n <div class=\"events-select\" role=\"group\" aria-label=\"Select events\">\n ${this.availableEvents.map(evt => html`\n <button class=\"event-chip\"\n aria-pressed=${this._selectedEvents.has(evt) ? 'true' : 'false'}\n @click=${() => this._toggleEvent(evt)}\n tabindex=\"0\">\n ${evt}\n </button>\n `)}\n </div>\n <div class=\"form-actions\">\n <button class=\"btn-sm\" @click=${this._toggleForm} tabindex=\"0\">Cancel</button>\n <button class=\"btn-sm primary\" @click=${this._onCreate} tabindex=\"0\">Create</button>\n </div>\n </div>\n ` : nothing}\n ${this.webhooks.length === 0 ? html`\n <div class=\"empty\" role=\"status\">No webhooks configured.</div>\n ` : html`\n <div class=\"webhook-list\" role=\"list\" aria-label=\"Configured webhooks\">\n ${this.webhooks.map(wh => html`\n <div class=\"webhook-item\" role=\"listitem\">\n <div class=\"webhook-top\">\n <span class=\"webhook-url\">${wh.url}</span>\n <label class=\"toggle-switch\">\n <input type=\"checkbox\" .checked=${wh.active}\n @change=${() => this._onToggle(wh)}\n aria-label=\"Toggle webhook ${wh.url}\" />\n <span class=\"toggle-track\"></span>\n </label>\n </div>\n <div class=\"webhook-events\">\n ${wh.events.map(e => html`<span class=\"event-tag\">${e}</span>`)}\n </div>\n <div class=\"webhook-footer\">\n <span class=\"last-triggered\">\n ${wh.lastTriggered ? `Last triggered: ${wh.lastTriggered}` : 'Never triggered'}\n </span>\n <div class=\"webhook-actions\">\n <button class=\"btn-sm\" @click=${() => this._onTest(wh)}\n aria-label=\"Test webhook\" tabindex=\"0\">Test</button>\n <button class=\"btn-sm danger\" @click=${() => this._onDelete(wh)}\n aria-label=\"Delete webhook\" tabindex=\"0\">Delete</button>\n </div>\n </div>\n </div>\n `)}\n </div>\n `}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-webhook-config': AiWebhookConfig;\n }\n}\n"],"names":["AiWebhookConfig","LitElement","evt","next","wh","html","nothing","e","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 h, html as t, nothing as d } from "lit";
2
2
  import { property as g, state as u, queryAll as p, customElement as f } from "lit/decorators.js";
3
- import { h as b, r as w, f as x } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as b, r as w, f as x } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var k = Object.defineProperty, m = Object.getOwnPropertyDescriptor, c = (e, r, o, a) => {
5
5
  for (var i = a > 1 ? void 0 : a ? m(r, o) : r, n = e.length - 1, l; n >= 0; n--)
6
6
  (l = e[n]) && (i = (a ? l(r, o, i) : l(i)) || i);
@@ -115,7 +115,7 @@ s.styles = [b, w, x, v`
115
115
  min-width: var(--cg-spacing-96); cursor: pointer; transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
116
116
  }
117
117
  .step:hover { border-color: var(--cg-color-input-border-hover); }
118
- .step:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-spacing-2) var(--cg-overlay-accent-strong); outline-offset: var(--cg-outline-offset-default); }
118
+ .step:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-spacing-2) var(--cg-color-focus-ring); outline-offset: var(--cg-outline-offset-default); }
119
119
  .step:active { transform: scale(var(--cg-interaction-press-scale)); }
120
120
  .step.active { border-color: var(--cg-color-surface-base-text); background: var(--cg-overlay-accent-subtle); }
121
121
  .step.complete { border-color: var(--cg-color-status-success-text-default); }
@@ -1 +1 @@
1
- {"version":3,"file":"ai-workflow-builder.js","sources":["../../../src/components/ai-workflow-builder/ai-workflow-builder.ts"],"sourcesContent":["/**\n * @element ai-workflow-builder\n * Visual agent workflow rendered as a vertical DAG (directed acyclic graph).\n * Each step displays a type icon (start/agent/tool/condition/end), label,\n * description, and status with connecting lines between steps.\n *\n * @example\n * ```html\n * <ai-workflow-builder heading=\"Support Agent\" .steps=${[\n * { id: '1', label: 'Receive Query', type: 'start', status: 'complete' },\n * { id: '2', label: 'Classify Intent', type: 'agent', status: 'active', description: 'Using GPT-4' },\n * { id: '3', label: 'Search KB', type: 'tool', status: 'pending', next: ['4'] },\n * { id: '4', label: 'Respond', type: 'end', status: 'pending' }\n * ]}></ai-workflow-builder>\n * ```\n *\n * @prop {WorkflowStep[]} steps - Array of workflow step objects\n * @prop {string} heading - Workflow header title (default 'Workflow')\n *\n * @fires {CustomEvent<{id: string, label: string, type: string, status: string}>} ai-workflow-step-click - When a step is clicked\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement, queryAll } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\ninterface WorkflowStep {\n id: string;\n label: string;\n type: 'start' | 'agent' | 'tool' | 'condition' | 'end';\n status?: 'pending' | 'active' | 'complete' | 'error' | 'skipped';\n description?: string;\n next?: string[]; // IDs of next steps\n}\n\n@customElement('ai-workflow-builder')\nexport class AiWorkflowBuilder 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\n .container {\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150); padding: var(--cg-spacing-16); overflow: auto;\n }\n\n .header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--cg-spacing-16); }\n .title { font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-bold); color: var(--cg-color-surface-base-text); }\n .step-count { font-size: var(--cg-font-size-xs); color: var(--cg-color-input-text-placeholder); }\n\n .flow { display: flex; flex-direction: column; align-items: center; gap: 0; }\n\n .step-wrapper { display: flex; flex-direction: column; align-items: center; }\n\n .connector { width: var(--cg-spacing-2); height: var(--cg-spacing-20); background: var(--cg-color-surface-cards-border); }\n .connector.active { background: var(--cg-color-action-primary-background-default); }\n\n .step {\n display: flex; align-items: center; gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-8) var(--cg-spacing-16); border-radius: var(--cg-border-radius-100);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n background: var(--cg-color-surface-base-background);\n min-width: var(--cg-spacing-96); cursor: pointer; transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .step:hover { border-color: var(--cg-color-input-border-hover); }\n .step:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-spacing-2) var(--cg-overlay-accent-strong); outline-offset: var(--cg-outline-offset-default); }\n .step:active { transform: scale(var(--cg-interaction-press-scale)); }\n .step.active { border-color: var(--cg-color-surface-base-text); background: var(--cg-overlay-accent-subtle); }\n .step.complete { border-color: var(--cg-color-status-success-text-default); }\n .step.error { border-color: var(--cg-color-status-error-text-default); }\n .step.skipped { opacity: 0.5; }\n\n .step-icon {\n width: var(--cg-spacing-24); height: var(--cg-spacing-24); border-radius: var(--cg-border-radius-100);\n display: flex; align-items: center; justify-content: center;\n font-size: var(--cg-font-size-xs); flex-shrink: 0;\n }\n .step-icon.start { background: var(--cg-color-status-success-background-default); color: var(--cg-color-status-success-text-default); }\n .step-icon.agent { background: var(--cg-overlay-accent-light); color: var(--cg-color-surface-base-text); }\n .step-icon.tool { background: var(--cg-color-status-info-background-default); color: var(--cg-color-status-info-text-default); }\n .step-icon.condition { background: var(--cg-color-status-warning-background-default); color: var(--cg-color-status-warning-text-default); }\n .step-icon.end { background: var(--cg-color-surface-container-background); color: var(--cg-color-input-text-placeholder); }\n\n .step-info { flex: 1; min-width: 0; }\n .step-label { font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-semibold); color: var(--cg-color-surface-base-text); }\n .step-desc { font-size: var(--cg-font-size-xs); color: var(--cg-color-input-text-placeholder); margin-top: var(--cg-spacing-2); }\n .step-type { font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-bold); text-transform: uppercase; letter-spacing: var(--cg-letter-spacing-wider); color: var(--cg-color-input-text-placeholder); }\n\n .step-status { font-size: var(--cg-font-size-xs); flex-shrink: 0; }\n\n .branch { display: flex; gap: var(--cg-spacing-16); align-items: flex-start; }\n .branch-line { width: var(--cg-spacing-1); height: 100%; background: var(--cg-color-surface-cards-border); }\n\n .empty { text-align: center; padding: var(--cg-spacing-32); color: var(--cg-color-input-text-placeholder); font-size: var(--cg-font-size-sm); }\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: Array }) steps: WorkflowStep[] = [];\n @property({ type: String }) heading: string = 'Workflow';\n\n @state() private _activeIndex = 0;\n @state() private _shouldFocusActive = false;\n\n @queryAll('.step') private _stepEls!: NodeListOf<HTMLElement>;\n\n private _getTypeIcon(type: string): unknown {\n if (type === 'start') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"currentColor\"><path d=\"M8 5v14l11-7z\"/></svg>`;\n if (type === 'agent') return html`<svg width=\"14\" height=\"14\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\"><rect x=\"3\" y=\"8\" width=\"18\" height=\"12\" rx=\"3\"/><circle cx=\"9\" cy=\"14\" r=\"1.5\"/><circle cx=\"15\" cy=\"14\" r=\"1.5\"/><path d=\"M12 2v4M8 8V6a4 4 0 018 0v2\"/></svg>`;\n if (type === 'tool') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><path d=\"M14.7 6.3a1 1 0 000 1.4l1.6 1.6a1 1 0 001.4 0l3.77-3.77a6 6 0 01-7.94 7.94l-6.91 6.91a2.12 2.12 0 01-3-3l6.91-6.91a6 6 0 017.94-7.94l-3.76 3.76z\"/></svg>`;\n if (type === 'condition') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"currentColor\"><path d=\"M12 2l10 10-10 10L2 12z\"/></svg>`;\n if (type === 'end') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"currentColor\"><rect x=\"6\" y=\"6\" width=\"12\" height=\"12\" rx=\"1\"/></svg>`;\n return html`<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\"><circle cx=\"4\" cy=\"4\" r=\"4\" fill=\"currentColor\"/></svg>`;\n }\n private _getStatusIcon(status: string): unknown {\n if (status === 'complete') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M20 6L9 17l-5-5\"/></svg>`;\n if (status === 'error') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg>`;\n if (status === 'active') return html`<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\"><circle cx=\"4\" cy=\"4\" r=\"4\" fill=\"currentColor\"/></svg>`;\n if (status === 'pending') return html`<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\"><circle cx=\"4\" cy=\"4\" r=\"3\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\"/></svg>`;\n return html`<span>--</span>`;\n }\n\n private _handleStepClick(step: WorkflowStep, index: number) {\n this._activeIndex = index;\n this.dispatchEvent(new CustomEvent('ai-workflow-step-click', {\n bubbles: true, composed: true,\n detail: { id: step.id, label: step.label, type: step.type, status: step.status },\n }));\n }\n\n private _handleStepKeyDown(e: KeyboardEvent, step: WorkflowStep, index: number) {\n const total = this.steps.length;\n if (total === 0) return;\n\n switch (e.key) {\n case 'ArrowRight':\n case 'ArrowDown':\n e.preventDefault();\n this._activeIndex = (index + 1) % total;\n this._shouldFocusActive = true;\n break;\n case 'ArrowLeft':\n case 'ArrowUp':\n e.preventDefault();\n this._activeIndex = (index - 1 + total) % total;\n this._shouldFocusActive = true;\n break;\n case 'Home':\n e.preventDefault();\n this._activeIndex = 0;\n this._shouldFocusActive = true;\n break;\n case 'End':\n e.preventDefault();\n this._activeIndex = total - 1;\n this._shouldFocusActive = true;\n break;\n case 'Enter':\n case ' ':\n e.preventDefault();\n this._handleStepClick(step, index);\n break;\n }\n }\n\n override updated(changed: Map<string, unknown>) {\n super.updated(changed);\n // Clamp active index if steps array shrunk.\n if (changed.has('steps') && this._activeIndex >= this.steps.length) {\n this._activeIndex = Math.max(0, this.steps.length - 1);\n }\n if (this._shouldFocusActive) {\n this._shouldFocusActive = false;\n const els = this._stepEls;\n const target = els?.[this._activeIndex];\n if (target) target.focus();\n }\n }\n\n override render() {\n if (this.steps.length === 0) return html`<div class=\"container\"><div class=\"empty\">No workflow defined</div></div>`;\n\n return html`\n <div class=\"container\" role=\"figure\" aria-label=\"${this.heading}\">\n <div class=\"header\">\n <span class=\"title\">${this.heading}</span>\n <span class=\"step-count\">${this.steps.length} steps</span>\n </div>\n <div class=\"flow\" role=\"toolbar\" aria-label=\"${this.heading} workflow steps (vertical orientation)\" aria-orientation=\"vertical\">\n ${this.steps.map((step, i) => html`\n ${i > 0 ? html`<div class=\"connector ${step.status === 'active' || step.status === 'complete' ? 'active' : ''}\"></div>` : nothing}\n <div class=\"step ${step.status || 'pending'}\"\n tabindex=${i === this._activeIndex ? '0' : '-1'}\n role=\"button\"\n aria-label=\"${step.label}\"\n aria-current=${step.status === 'active' ? 'step' : nothing}\n @click=${() => this._handleStepClick(step, i)}\n @keydown=${(e: KeyboardEvent) => this._handleStepKeyDown(e, step, i)}>\n <div class=\"step-icon ${step.type}\" aria-hidden=\"true\">${this._getTypeIcon(step.type)}</div>\n <div class=\"step-info\">\n <div class=\"step-type\">${step.type}</div>\n <div class=\"step-label\">${step.label}</div>\n ${step.description ? html`<div class=\"step-desc\">${step.description}</div>` : nothing}\n </div>\n <span class=\"step-status\" aria-hidden=\"true\">${this._getStatusIcon(step.status || 'pending')}</span>\n </div>\n `)}\n </div>\n </div>\n `;\n }\n}\n"],"names":["AiWorkflowBuilder","LitElement","type","html","status","step","index","total","changed","target","i","nothing","e","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","queryAll","customElement"],"mappings":";;;;;;;;AAmCO,IAAMA,IAAN,cAAgCC,EAAW;AAAA,EAA3C,cAAA;AAAA,UAAA,GAAA,SAAA,GAqEwB,KAAA,UAAgD,MAClD,KAAA,QAAwB,CAAA,GACvB,KAAA,UAAkB,YAErC,KAAQ,eAAe,GACvB,KAAQ,qBAAqB;AAAA,EAAA;AAAA,EAI9B,aAAaC,GAAuB;AAC1C,WAAIA,MAAS,UAAgBC,yGACzBD,MAAS,UAAgBC,0QACzBD,MAAS,SAAeC,2QACxBD,MAAS,cAAoBC,mHAC7BD,MAAS,QAAcC,iIACpBA;AAAA,EACT;AAAA,EACQ,eAAeC,GAAyB;AAC9C,WAAIA,MAAW,aAAmBD,yLAC9BC,MAAW,UAAgBD,sKAC3BC,MAAW,WAAiBD,yGAC5BC,MAAW,YAAkBD,0IAC1BA;AAAA,EACT;AAAA,EAEQ,iBAAiBE,GAAoBC,GAAe;AAC1D,SAAK,eAAeA,GACpB,KAAK,cAAc,IAAI,YAAY,0BAA0B;AAAA,MAC3D,SAAS;AAAA,MAAM,UAAU;AAAA,MACzB,QAAQ,EAAE,IAAID,EAAK,IAAI,OAAOA,EAAK,OAAO,MAAMA,EAAK,MAAM,QAAQA,EAAK,OAAA;AAAA,IAAO,CAChF,CAAC;AAAA,EACJ;AAAA,EAEQ,mBAAmB,GAAkBA,GAAoBC,GAAe;AAC9E,UAAMC,IAAQ,KAAK,MAAM;AACzB,QAAIA,MAAU;AAEd,cAAQ,EAAE,KAAA;AAAA,QACR,KAAK;AAAA,QACL,KAAK;AACH,YAAE,eAAA,GACF,KAAK,gBAAgBD,IAAQ,KAAKC,GAClC,KAAK,qBAAqB;AAC1B;AAAA,QACF,KAAK;AAAA,QACL,KAAK;AACH,YAAE,eAAA,GACF,KAAK,gBAAgBD,IAAQ,IAAIC,KAASA,GAC1C,KAAK,qBAAqB;AAC1B;AAAA,QACF,KAAK;AACH,YAAE,eAAA,GACF,KAAK,eAAe,GACpB,KAAK,qBAAqB;AAC1B;AAAA,QACF,KAAK;AACH,YAAE,eAAA,GACF,KAAK,eAAeA,IAAQ,GAC5B,KAAK,qBAAqB;AAC1B;AAAA,QACF,KAAK;AAAA,QACL,KAAK;AACH,YAAE,eAAA,GACF,KAAK,iBAAiBF,GAAMC,CAAK;AACjC;AAAA,MAAA;AAAA,EAEN;AAAA,EAES,QAAQE,GAA+B;AAM9C,QALA,MAAM,QAAQA,CAAO,GAEjBA,EAAQ,IAAI,OAAO,KAAK,KAAK,gBAAgB,KAAK,MAAM,WAC1D,KAAK,eAAe,KAAK,IAAI,GAAG,KAAK,MAAM,SAAS,CAAC,IAEnD,KAAK,oBAAoB;AAC3B,WAAK,qBAAqB;AAE1B,YAAMC,IADM,KAAK,WACI,KAAK,YAAY;AACtC,MAAIA,OAAe,MAAA;AAAA,IACrB;AAAA,EACF;AAAA,EAES,SAAS;AAChB,WAAI,KAAK,MAAM,WAAW,IAAUN,+EAE7BA;AAAA,yDAC8C,KAAK,OAAO;AAAA;AAAA,gCAErC,KAAK,OAAO;AAAA,qCACP,KAAK,MAAM,MAAM;AAAA;AAAA,uDAEC,KAAK,OAAO;AAAA,YACvD,KAAK,MAAM,IAAI,CAACE,GAAMK,MAAMP;AAAA,cAC1BO,IAAI,IAAIP,0BAA6BE,EAAK,WAAW,YAAYA,EAAK,WAAW,aAAa,WAAW,EAAE,aAAaM,CAAO;AAAA,+BAC9GN,EAAK,UAAU,SAAS;AAAA,yBAC9BK,MAAM,KAAK,eAAe,MAAM,IAAI;AAAA;AAAA,4BAEjCL,EAAK,KAAK;AAAA,6BACTA,EAAK,WAAW,WAAW,SAASM,CAAO;AAAA,uBACjD,MAAM,KAAK,iBAAiBN,GAAMK,CAAC,CAAC;AAAA,yBAClC,CAACE,MAAqB,KAAK,mBAAmBA,GAAGP,GAAMK,CAAC,CAAC;AAAA,sCAC5CL,EAAK,IAAI,wBAAwB,KAAK,aAAaA,EAAK,IAAI,CAAC;AAAA;AAAA,yCAE1DA,EAAK,IAAI;AAAA,0CACRA,EAAK,KAAK;AAAA,kBAClCA,EAAK,cAAcF,2BAA8BE,EAAK,WAAW,WAAWM,CAAO;AAAA;AAAA,6DAExC,KAAK,eAAeN,EAAK,UAAU,SAAS,CAAC;AAAA;AAAA,WAE/F,CAAC;AAAA;AAAA;AAAA;AAAA,EAIV;AACF;AAvLaL,EACK,SAAS,CAACa,GAAWC,GAAeC,GAAsBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAkEzE;AAE4BC,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GArEhBlB,EAqEkB,WAAA,WAAA,CAAA;AACFiB,EAAA;AAAA,EAA1BC,EAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GAtEdlB,EAsEgB,WAAA,SAAA,CAAA;AACCiB,EAAA;AAAA,EAA3BC,EAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAvEflB,EAuEiB,WAAA,WAAA,CAAA;AAEXiB,EAAA;AAAA,EAAhBE,EAAA;AAAM,GAzEInB,EAyEM,WAAA,gBAAA,CAAA;AACAiB,EAAA;AAAA,EAAhBE,EAAA;AAAM,GA1EInB,EA0EM,WAAA,sBAAA,CAAA;AAEUiB,EAAA;AAAA,EAA1BG,EAAS,OAAO;AAAA,GA5ENpB,EA4EgB,WAAA,YAAA,CAAA;AA5EhBA,IAANiB,EAAA;AAAA,EADNI,EAAc,qBAAqB;AAAA,GACvBrB,CAAA;"}
1
+ {"version":3,"file":"ai-workflow-builder.js","sources":["../../../src/components/ai-workflow-builder/ai-workflow-builder.ts"],"sourcesContent":["/**\n * @element ai-workflow-builder\n * Visual agent workflow rendered as a vertical DAG (directed acyclic graph).\n * Each step displays a type icon (start/agent/tool/condition/end), label,\n * description, and status with connecting lines between steps.\n *\n * @example\n * ```html\n * <ai-workflow-builder heading=\"Support Agent\" .steps=${[\n * { id: '1', label: 'Receive Query', type: 'start', status: 'complete' },\n * { id: '2', label: 'Classify Intent', type: 'agent', status: 'active', description: 'Using GPT-4' },\n * { id: '3', label: 'Search KB', type: 'tool', status: 'pending', next: ['4'] },\n * { id: '4', label: 'Respond', type: 'end', status: 'pending' }\n * ]}></ai-workflow-builder>\n * ```\n *\n * @prop {WorkflowStep[]} steps - Array of workflow step objects\n * @prop {string} heading - Workflow header title (default 'Workflow')\n *\n * @fires {CustomEvent<{id: string, label: string, type: string, status: string}>} ai-workflow-step-click - When a step is clicked\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, state, customElement, queryAll } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\ninterface WorkflowStep {\n id: string;\n label: string;\n type: 'start' | 'agent' | 'tool' | 'condition' | 'end';\n status?: 'pending' | 'active' | 'complete' | 'error' | 'skipped';\n description?: string;\n next?: string[]; // IDs of next steps\n}\n\n@customElement('ai-workflow-builder')\nexport class AiWorkflowBuilder 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\n .container {\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150); padding: var(--cg-spacing-16); overflow: auto;\n }\n\n .header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--cg-spacing-16); }\n .title { font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-bold); color: var(--cg-color-surface-base-text); }\n .step-count { font-size: var(--cg-font-size-xs); color: var(--cg-color-input-text-placeholder); }\n\n .flow { display: flex; flex-direction: column; align-items: center; gap: 0; }\n\n .step-wrapper { display: flex; flex-direction: column; align-items: center; }\n\n .connector { width: var(--cg-spacing-2); height: var(--cg-spacing-20); background: var(--cg-color-surface-cards-border); }\n .connector.active { background: var(--cg-color-action-primary-background-default); }\n\n .step {\n display: flex; align-items: center; gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-8) var(--cg-spacing-16); border-radius: var(--cg-border-radius-100);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n background: var(--cg-color-surface-base-background);\n min-width: var(--cg-spacing-96); cursor: pointer; transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .step:hover { border-color: var(--cg-color-input-border-hover); }\n .step:focus-visible { outline: none; box-shadow: 0 0 0 var(--cg-spacing-2) var(--cg-color-focus-ring); outline-offset: var(--cg-outline-offset-default); }\n .step:active { transform: scale(var(--cg-interaction-press-scale)); }\n .step.active { border-color: var(--cg-color-surface-base-text); background: var(--cg-overlay-accent-subtle); }\n .step.complete { border-color: var(--cg-color-status-success-text-default); }\n .step.error { border-color: var(--cg-color-status-error-text-default); }\n .step.skipped { opacity: 0.5; }\n\n .step-icon {\n width: var(--cg-spacing-24); height: var(--cg-spacing-24); border-radius: var(--cg-border-radius-100);\n display: flex; align-items: center; justify-content: center;\n font-size: var(--cg-font-size-xs); flex-shrink: 0;\n }\n .step-icon.start { background: var(--cg-color-status-success-background-default); color: var(--cg-color-status-success-text-default); }\n .step-icon.agent { background: var(--cg-overlay-accent-light); color: var(--cg-color-surface-base-text); }\n .step-icon.tool { background: var(--cg-color-status-info-background-default); color: var(--cg-color-status-info-text-default); }\n .step-icon.condition { background: var(--cg-color-status-warning-background-default); color: var(--cg-color-status-warning-text-default); }\n .step-icon.end { background: var(--cg-color-surface-container-background); color: var(--cg-color-input-text-placeholder); }\n\n .step-info { flex: 1; min-width: 0; }\n .step-label { font-size: var(--cg-font-size-sm); font-weight: var(--cg-font-weight-semibold); color: var(--cg-color-surface-base-text); }\n .step-desc { font-size: var(--cg-font-size-xs); color: var(--cg-color-input-text-placeholder); margin-top: var(--cg-spacing-2); }\n .step-type { font-size: var(--cg-font-size-xs); font-weight: var(--cg-font-weight-bold); text-transform: uppercase; letter-spacing: var(--cg-letter-spacing-wider); color: var(--cg-color-input-text-placeholder); }\n\n .step-status { font-size: var(--cg-font-size-xs); flex-shrink: 0; }\n\n .branch { display: flex; gap: var(--cg-spacing-16); align-items: flex-start; }\n .branch-line { width: var(--cg-spacing-1); height: 100%; background: var(--cg-color-surface-cards-border); }\n\n .empty { text-align: center; padding: var(--cg-spacing-32); color: var(--cg-color-input-text-placeholder); font-size: var(--cg-font-size-sm); }\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: Array }) steps: WorkflowStep[] = [];\n @property({ type: String }) heading: string = 'Workflow';\n\n @state() private _activeIndex = 0;\n @state() private _shouldFocusActive = false;\n\n @queryAll('.step') private _stepEls!: NodeListOf<HTMLElement>;\n\n private _getTypeIcon(type: string): unknown {\n if (type === 'start') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"currentColor\"><path d=\"M8 5v14l11-7z\"/></svg>`;\n if (type === 'agent') return html`<svg width=\"14\" height=\"14\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\"><rect x=\"3\" y=\"8\" width=\"18\" height=\"12\" rx=\"3\"/><circle cx=\"9\" cy=\"14\" r=\"1.5\"/><circle cx=\"15\" cy=\"14\" r=\"1.5\"/><path d=\"M12 2v4M8 8V6a4 4 0 018 0v2\"/></svg>`;\n if (type === 'tool') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><path d=\"M14.7 6.3a1 1 0 000 1.4l1.6 1.6a1 1 0 001.4 0l3.77-3.77a6 6 0 01-7.94 7.94l-6.91 6.91a2.12 2.12 0 01-3-3l6.91-6.91a6 6 0 017.94-7.94l-3.76 3.76z\"/></svg>`;\n if (type === 'condition') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"currentColor\"><path d=\"M12 2l10 10-10 10L2 12z\"/></svg>`;\n if (type === 'end') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"currentColor\"><rect x=\"6\" y=\"6\" width=\"12\" height=\"12\" rx=\"1\"/></svg>`;\n return html`<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\"><circle cx=\"4\" cy=\"4\" r=\"4\" fill=\"currentColor\"/></svg>`;\n }\n private _getStatusIcon(status: string): unknown {\n if (status === 'complete') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M20 6L9 17l-5-5\"/></svg>`;\n if (status === 'error') return html`<svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg>`;\n if (status === 'active') return html`<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\"><circle cx=\"4\" cy=\"4\" r=\"4\" fill=\"currentColor\"/></svg>`;\n if (status === 'pending') return html`<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\"><circle cx=\"4\" cy=\"4\" r=\"3\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\"/></svg>`;\n return html`<span>--</span>`;\n }\n\n private _handleStepClick(step: WorkflowStep, index: number) {\n this._activeIndex = index;\n this.dispatchEvent(new CustomEvent('ai-workflow-step-click', {\n bubbles: true, composed: true,\n detail: { id: step.id, label: step.label, type: step.type, status: step.status },\n }));\n }\n\n private _handleStepKeyDown(e: KeyboardEvent, step: WorkflowStep, index: number) {\n const total = this.steps.length;\n if (total === 0) return;\n\n switch (e.key) {\n case 'ArrowRight':\n case 'ArrowDown':\n e.preventDefault();\n this._activeIndex = (index + 1) % total;\n this._shouldFocusActive = true;\n break;\n case 'ArrowLeft':\n case 'ArrowUp':\n e.preventDefault();\n this._activeIndex = (index - 1 + total) % total;\n this._shouldFocusActive = true;\n break;\n case 'Home':\n e.preventDefault();\n this._activeIndex = 0;\n this._shouldFocusActive = true;\n break;\n case 'End':\n e.preventDefault();\n this._activeIndex = total - 1;\n this._shouldFocusActive = true;\n break;\n case 'Enter':\n case ' ':\n e.preventDefault();\n this._handleStepClick(step, index);\n break;\n }\n }\n\n override updated(changed: Map<string, unknown>) {\n super.updated(changed);\n // Clamp active index if steps array shrunk.\n if (changed.has('steps') && this._activeIndex >= this.steps.length) {\n this._activeIndex = Math.max(0, this.steps.length - 1);\n }\n if (this._shouldFocusActive) {\n this._shouldFocusActive = false;\n const els = this._stepEls;\n const target = els?.[this._activeIndex];\n if (target) target.focus();\n }\n }\n\n override render() {\n if (this.steps.length === 0) return html`<div class=\"container\"><div class=\"empty\">No workflow defined</div></div>`;\n\n return html`\n <div class=\"container\" role=\"figure\" aria-label=\"${this.heading}\">\n <div class=\"header\">\n <span class=\"title\">${this.heading}</span>\n <span class=\"step-count\">${this.steps.length} steps</span>\n </div>\n <div class=\"flow\" role=\"toolbar\" aria-label=\"${this.heading} workflow steps (vertical orientation)\" aria-orientation=\"vertical\">\n ${this.steps.map((step, i) => html`\n ${i > 0 ? html`<div class=\"connector ${step.status === 'active' || step.status === 'complete' ? 'active' : ''}\"></div>` : nothing}\n <div class=\"step ${step.status || 'pending'}\"\n tabindex=${i === this._activeIndex ? '0' : '-1'}\n role=\"button\"\n aria-label=\"${step.label}\"\n aria-current=${step.status === 'active' ? 'step' : nothing}\n @click=${() => this._handleStepClick(step, i)}\n @keydown=${(e: KeyboardEvent) => this._handleStepKeyDown(e, step, i)}>\n <div class=\"step-icon ${step.type}\" aria-hidden=\"true\">${this._getTypeIcon(step.type)}</div>\n <div class=\"step-info\">\n <div class=\"step-type\">${step.type}</div>\n <div class=\"step-label\">${step.label}</div>\n ${step.description ? html`<div class=\"step-desc\">${step.description}</div>` : nothing}\n </div>\n <span class=\"step-status\" aria-hidden=\"true\">${this._getStatusIcon(step.status || 'pending')}</span>\n </div>\n `)}\n </div>\n </div>\n `;\n }\n}\n"],"names":["AiWorkflowBuilder","LitElement","type","html","status","step","index","total","changed","target","i","nothing","e","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","state","queryAll","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as u, LitElement as d, nothing as h, html as n } from "lit";
2
2
  import { property as s, customElement as p } from "lit/decorators.js";
3
- import { h as v, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as v, r as f } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var b = Object.defineProperty, m = Object.getOwnPropertyDescriptor, a = (e, o, c, i) => {
5
5
  for (var t = i > 1 ? void 0 : i ? m(o, c) : o, l = e.length - 1, g; l >= 0; l--)
6
6
  (g = e[l]) && (t = (i ? g(o, c, t) : g(t)) || t);
@@ -1,6 +1,6 @@
1
1
  import { css as u, LitElement as h, svg as s, html as c, nothing as p } from "lit";
2
2
  import { property as d, customElement as v } from "lit/decorators.js";
3
- import { a as f, r as b } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { a as f, r as b } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var k = Object.defineProperty, x = Object.getOwnPropertyDescriptor, a = (t, r, i, n) => {
5
5
  for (var e = n > 1 ? void 0 : n ? x(r, i) : r, l = t.length - 1, g; l >= 0; l--)
6
6
  (g = t[l]) && (e = (n ? g(r, i, e) : g(e)) || e);
@@ -1,6 +1,6 @@
1
1
  import { css as m, LitElement as d, html as p, nothing as g } from "lit";
2
2
  import { property as c, customElement as h } from "lit/decorators.js";
3
- import { h as u, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as u, r as f } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var v = Object.defineProperty, b = Object.getOwnPropertyDescriptor, i = (t, s, a, o) => {
5
5
  for (var e = o > 1 ? void 0 : o ? b(s, a) : s, n = t.length - 1, l; n >= 0; n--)
6
6
  (l = t[n]) && (e = (o ? l(s, a, e) : l(e)) || e);
@@ -1,6 +1,6 @@
1
1
  import { css as d, LitElement as l, svg as v, html as p } from "lit";
2
2
  import { property as g, customElement as f } from "lit/decorators.js";
3
- import { h as u, r as b } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as u, r as b } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var h = Object.defineProperty, m = Object.getOwnPropertyDescriptor, t = (e, c, i, a) => {
5
5
  for (var r = a > 1 ? void 0 : a ? m(c, i) : c, n = e.length - 1, s; n >= 0; n--)
6
6
  (s = e[n]) && (r = (a ? s(c, i, r) : s(r)) || r);
@@ -1,6 +1,6 @@
1
1
  import { css as u, LitElement as p, svg as d, html as h } from "lit";
2
2
  import { property as n, state as g, customElement as f } from "lit/decorators.js";
3
- import { a as m, r as v } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { a as m, r as v } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var b = Object.defineProperty, y = Object.getOwnPropertyDescriptor, o = (e, r, i, a) => {
5
5
  for (var t = a > 1 ? void 0 : a ? y(r, i) : r, l = e.length - 1, c; l >= 0; l--)
6
6
  (c = e[l]) && (t = (a ? c(r, i, t) : c(t)) || t);
@@ -1,6 +1,6 @@
1
1
  import { css as u, LitElement as d, svg as p, html as h } from "lit";
2
2
  import { property as o, customElement as v } from "lit/decorators.js";
3
- import { a as g, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { a as g, r as f } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var m = Object.defineProperty, b = Object.getOwnPropertyDescriptor, i = (e, a, s, n) => {
5
5
  for (var r = n > 1 ? void 0 : n ? b(a, s) : a, c = e.length - 1, l; c >= 0; c--)
6
6
  (l = e[c]) && (r = (n ? l(a, s, r) : l(r)) || r);
@@ -1 +1 @@
1
- {"version":3,"file":"cg-accordion.d.ts","sourceRoot":"","sources":["../../../src/components/cg-accordion/cg-accordion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD,wCAAwC;AACxC,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED;;;;;GAKG;AACH,qBACa,WAAY,SAAQ,UAAU;IACzC,OAAgB,MAAM,4BAwHnB;IAE0B,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IAClC,KAAK,EAAE,aAAa,EAAE,CAAM;IAC1B,QAAQ,UAAS;IACjB,OAAO,EAAE,SAAS,GAAG,MAAM,GAAG,UAAU,CAAa;IACvD,WAAW,EAAE,MAAM,EAAE,CAAM;IAE7C,OAAO,CAAC,UAAU,CAAqB;IAEvC,YAAY;IAMrB,OAAO,CAAC,qBAAqB;IAkB7B,OAAO,CAAC,OAAO;IAgBN,MAAM;CA4BhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,cAAc,EAAE,WAAW,CAAC;KAAE;CACjE"}
1
+ {"version":3,"file":"cg-accordion.d.ts","sourceRoot":"","sources":["../../../src/components/cg-accordion/cg-accordion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,MAAM,KAAK,CAAC;AAI5C,wCAAwC;AACxC,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED;;;;;GAKG;AACH,qBACa,WAAY,SAAQ,UAAU;IACzC,OAAgB,MAAM,4BAgInB;IAE0B,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IAClC,KAAK,EAAE,aAAa,EAAE,CAAM;IAC1B,QAAQ,UAAS;IACjB,OAAO,EAAE,SAAS,GAAG,MAAM,GAAG,UAAU,CAAa;IACvD,WAAW,EAAE,MAAM,EAAE,CAAM;IAE7C,OAAO,CAAC,UAAU,CAAqB;IAEvC,YAAY;IAMrB,OAAO,CAAC,qBAAqB;IAkB7B,OAAO,CAAC,OAAO;IAgBN,MAAM;CA4BhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,cAAc,EAAE,WAAW,CAAC;KAAE;CACjE"}
@@ -1,69 +1,69 @@
1
- import { css as l, LitElement as p, html as g } from "lit";
2
- import { property as s, state as v, customElement as u } from "lit/decorators.js";
3
- import { h, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
4
- var b = Object.defineProperty, m = Object.getOwnPropertyDescriptor, n = (r, e, o, i) => {
5
- for (var t = i > 1 ? void 0 : i ? m(e, o) : e, c = r.length - 1, d; c >= 0; c--)
6
- (d = r[c]) && (t = (i ? d(e, o, t) : d(t)) || t);
7
- return i && t && b(e, o, t), t;
1
+ import { css as l, LitElement as v, html as g } from "lit";
2
+ import { property as s, state as p, customElement as u } from "lit/decorators.js";
3
+ import { h, r as f } from "../../chunks/premium.css-DHekUEUt.js";
4
+ var b = Object.defineProperty, m = Object.getOwnPropertyDescriptor, n = (e, r, a, i) => {
5
+ for (var t = i > 1 ? void 0 : i ? m(r, a) : r, c = e.length - 1, d; c >= 0; c--)
6
+ (d = e[c]) && (t = (i ? d(r, a, t) : d(t)) || t);
7
+ return i && t && b(r, a, t), t;
8
8
  };
9
- let a = class extends p {
9
+ let o = class extends v {
10
10
  constructor() {
11
11
  super(...arguments), this.size = "md", this.items = [], this.multiple = !1, this.variant = "default", this.defaultOpen = [], this._openItems = /* @__PURE__ */ new Set();
12
12
  }
13
13
  firstUpdated() {
14
14
  this.defaultOpen.length > 0 && (this._openItems = new Set(this.multiple ? this.defaultOpen : [this.defaultOpen[0]]));
15
15
  }
16
- _handleTriggerKeydown(r) {
17
- const e = this.shadowRoot.querySelectorAll(".trigger:not(:disabled)"), o = Array.from(e), i = o.indexOf(r.currentTarget);
16
+ _handleTriggerKeydown(e) {
17
+ const r = this.shadowRoot.querySelectorAll(".trigger:not(:disabled)"), a = Array.from(r), i = a.indexOf(e.currentTarget);
18
18
  let t = i;
19
- switch (r.key) {
19
+ switch (e.key) {
20
20
  case "ArrowDown":
21
- t = (i + 1) % o.length;
21
+ t = (i + 1) % a.length;
22
22
  break;
23
23
  case "ArrowUp":
24
- t = (i - 1 + o.length) % o.length;
24
+ t = (i - 1 + a.length) % a.length;
25
25
  break;
26
26
  case "Home":
27
27
  t = 0;
28
28
  break;
29
29
  case "End":
30
- t = o.length - 1;
30
+ t = a.length - 1;
31
31
  break;
32
32
  default:
33
33
  return;
34
34
  }
35
- r.preventDefault(), o[t]?.focus();
35
+ e.preventDefault(), a[t]?.focus();
36
36
  }
37
- _toggle(r) {
38
- const e = new Set(this._openItems);
39
- e.has(r) ? e.delete(r) : (this.multiple || e.clear(), e.add(r)), this._openItems = e, this.dispatchEvent(new CustomEvent("cg-accordion-change", {
40
- detail: { open: [...e], toggled: r },
37
+ _toggle(e) {
38
+ const r = new Set(this._openItems);
39
+ r.has(e) ? r.delete(e) : (this.multiple || r.clear(), r.add(e)), this._openItems = r, this.dispatchEvent(new CustomEvent("cg-accordion-change", {
40
+ detail: { open: [...r], toggled: e },
41
41
  bubbles: !0,
42
42
  composed: !0
43
43
  }));
44
44
  }
45
45
  render() {
46
- return g`${this.items.map((r) => {
47
- const e = this._openItems.has(r.value);
46
+ return g`${this.items.map((e) => {
47
+ const r = this._openItems.has(e.value);
48
48
  return g`
49
- <div class="item ${e ? "open" : ""}">
49
+ <div class="item ${r ? "open" : ""}">
50
50
  <button
51
51
  class="trigger"
52
- id="trigger-${r.value}"
53
- aria-expanded=${e}
54
- aria-controls="panel-${r.value}"
55
- ?disabled=${r.disabled}
56
- @click=${() => this._toggle(r.value)}
52
+ id="trigger-${e.value}"
53
+ aria-expanded=${r}
54
+ aria-controls="panel-${e.value}"
55
+ ?disabled=${e.disabled}
56
+ @click=${() => this._toggle(e.value)}
57
57
  @keydown=${this._handleTriggerKeydown}
58
58
  >
59
- <span class="trigger-text">${r.trigger}</span>
60
- <svg class="chevron" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round">
59
+ <span class="trigger-text">${e.trigger}</span>
60
+ <svg class="chevron" aria-hidden="true" focusable="false" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round">
61
61
  <path d="M6 9l6 6 6-6"></path>
62
62
  </svg>
63
63
  </button>
64
64
  <div class="content-wrapper">
65
- <div class="content" id="panel-${r.value}" role="region" aria-labelledby="trigger-${r.value}">
66
- <div class="content-inner">${r.content}</div>
65
+ <div class="content" id="panel-${e.value}" role="region" aria-labelledby="trigger-${e.value}">
66
+ <div class="content-inner">${e.content}</div>
67
67
  </div>
68
68
  </div>
69
69
  </div>
@@ -71,7 +71,7 @@ let a = class extends p {
71
71
  })}`;
72
72
  }
73
73
  };
74
- a.styles = [h, f, l`
74
+ o.styles = [h, f, l`
75
75
 
76
76
  /* ── Default variant — minimal dividers, transparent ── */
77
77
  .item {
@@ -132,7 +132,7 @@ a.styles = [h, f, l`
132
132
 
133
133
  .trigger:focus-visible {
134
134
  outline: none;
135
- box-shadow: inset 0 0 0 2px var(--cg-color-focus-ring-offset), inset 0 0 0 4px var(--cg-color-focus-ring);
135
+ box-shadow: inset 0 0 0 var(--cg-border-width-100) var(--cg-color-focus-ring-offset), inset 0 0 0 calc(var(--cg-border-width-100) * 2) var(--cg-color-focus-ring);
136
136
  }
137
137
 
138
138
  .trigger:disabled {
@@ -157,6 +157,14 @@ a.styles = [h, f, l`
157
157
  transform: rotate(180deg);
158
158
  color: var(--cg-color-surface-base-text);
159
159
  }
160
+ /* ── Open trigger: subtle accent so the active section is scannable ──
161
+ The chevron flip alone was the only signal; add a faint accent wash +
162
+ a brand leading edge + brighter title text. */
163
+ .item.open .trigger {
164
+ background: var(--cg-overlay-accent-subtle);
165
+ color: var(--cg-color-surface-base-text);
166
+ box-shadow: inset var(--cg-border-width-100) 0 0 0 var(--cg-color-action-primary-background-default);
167
+ }
160
168
 
161
169
  /* ── Content — CSS grid smooth height ── */
162
170
  .content-wrapper {
@@ -194,26 +202,26 @@ a.styles = [h, f, l`
194
202
  `];
195
203
  n([
196
204
  s({ reflect: !0 })
197
- ], a.prototype, "size", 2);
205
+ ], o.prototype, "size", 2);
198
206
  n([
199
207
  s({ type: Array })
200
- ], a.prototype, "items", 2);
208
+ ], o.prototype, "items", 2);
201
209
  n([
202
210
  s({ type: Boolean })
203
- ], a.prototype, "multiple", 2);
211
+ ], o.prototype, "multiple", 2);
204
212
  n([
205
213
  s({ reflect: !0 })
206
- ], a.prototype, "variant", 2);
214
+ ], o.prototype, "variant", 2);
207
215
  n([
208
216
  s({ type: Array })
209
- ], a.prototype, "defaultOpen", 2);
217
+ ], o.prototype, "defaultOpen", 2);
210
218
  n([
211
- v()
212
- ], a.prototype, "_openItems", 2);
213
- a = n([
219
+ p()
220
+ ], o.prototype, "_openItems", 2);
221
+ o = n([
214
222
  u("cg-accordion")
215
- ], a);
223
+ ], o);
216
224
  export {
217
- a as CgAccordion
225
+ o as CgAccordion
218
226
  };
219
227
  //# sourceMappingURL=cg-accordion.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"cg-accordion.js","sources":["../../../src/components/cg-accordion/cg-accordion.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/** Item definition for cg-accordion. */\nexport interface AccordionItem {\n value: string;\n trigger: string;\n content: string;\n icon?: string;\n disabled?: boolean;\n}\n\n/**\n * @element cg-accordion\n * Expandable content sections with smooth CSS grid height animation.\n *\n * @fires {CustomEvent<{open: string[], toggled: string}>} cg-accordion-change - When an item is toggled\n */\n@customElement('cg-accordion')\nexport class CgAccordion extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n\n /* ── Default variant — minimal dividers, transparent ── */\n .item {\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-base-divider);\n }\n .item:last-child { border-bottom: none; }\n\n /* ── Card variant — separated elevated cards ── */\n :host([variant=\"card\"]) .item {\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-component-card-radius);\n margin-bottom: var(--cg-spacing-8);\n background: var(--cg-color-surface-cards-background);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n overflow: hidden;\n }\n :host([variant=\"card\"]) .item:last-child { margin-bottom: 0; }\n\n /* ── Bordered variant — single grouped container ── */\n :host([variant=\"bordered\"]) {\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-component-card-radius);\n background: var(--cg-color-surface-cards-background);\n overflow: hidden;\n }\n :host([variant=\"bordered\"]) .item {\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n :host([variant=\"bordered\"]) .item:last-child {\n border-bottom: none;\n }\n\n /* ── Trigger ── */\n .trigger {\n width: 100%;\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-16);\n background: transparent;\n border: none;\n font: inherit;\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-base-text);\n cursor: pointer;\n text-align: left;\n transition: background var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n\n .trigger:hover:not(:disabled) {\n background: var(--cg-overlay-dark-subtle);\n }\n\n .trigger:active:not(:disabled) .chevron {\n transform: scale(0.85);\n }\n\n .trigger:focus-visible {\n outline: none;\n box-shadow: inset 0 0 0 2px var(--cg-color-focus-ring-offset), inset 0 0 0 4px var(--cg-color-focus-ring);\n }\n\n .trigger:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .trigger-text {\n flex: 1;\n min-width: 0;\n }\n\n /* ── Chevron — only active signal ── */\n .chevron {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n flex-shrink: 0;\n color: var(--cg-color-surface-container-outlined);\n transition: transform var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out), color var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .item.open .chevron {\n transform: rotate(180deg);\n color: var(--cg-color-surface-base-text);\n }\n\n /* ── Content — CSS grid smooth height ── */\n .content-wrapper {\n display: grid;\n grid-template-rows: 0fr;\n transition: grid-template-rows var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n .item.open .content-wrapper {\n grid-template-rows: 1fr;\n }\n\n .content {\n overflow: hidden;\n }\n\n .content-inner {\n padding: 0 var(--cg-spacing-16) var(--cg-spacing-16);\n font-size: var(--cg-font-size-sm);\n color: var(--cg-color-surface-container-outlined);\n line-height: var(--cg-line-height-relaxed);\n opacity: 0;\n transition: opacity var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n transition-delay: 50ms;\n }\n .item.open .content-inner {\n opacity: 1;\n }\n\n /* ── Size variants ── */\n :host([size=\"sm\"]) .trigger { font-size: var(--cg-font-size-xs); padding: var(--cg-spacing-12); }\n :host([size=\"sm\"]) .content-inner { font-size: var(--cg-font-size-xs); padding: 0 var(--cg-spacing-12) var(--cg-spacing-12); }\n\n :host([size=\"lg\"]) .trigger { font-size: var(--cg-font-size-base); padding: var(--cg-spacing-20); }\n :host([size=\"lg\"]) .content-inner { font-size: var(--cg-font-size-base); padding: 0 var(--cg-spacing-20) var(--cg-spacing-20); }\n `];\n\n @property({ reflect: true }) size: 'sm' | 'md' | 'lg' = 'md';\n @property({ type: Array }) items: AccordionItem[] = [];\n @property({ type: Boolean }) multiple = false;\n @property({ reflect: true }) variant: 'default' | 'card' | 'bordered' = 'default';\n @property({ type: Array }) defaultOpen: string[] = [];\n\n @state() private _openItems = new Set<string>();\n\n override firstUpdated() {\n if (this.defaultOpen.length > 0) {\n this._openItems = new Set(this.multiple ? this.defaultOpen : [this.defaultOpen[0]!]);\n }\n }\n\n private _handleTriggerKeydown(e: KeyboardEvent) {\n const triggers = this.shadowRoot!.querySelectorAll('.trigger:not(:disabled)') as NodeListOf<HTMLElement>;\n const triggerArr = Array.from(triggers);\n const currentIdx = triggerArr.indexOf(e.currentTarget as HTMLElement);\n let nextIdx = currentIdx;\n\n switch (e.key) {\n case 'ArrowDown': nextIdx = (currentIdx + 1) % triggerArr.length; break;\n case 'ArrowUp': nextIdx = (currentIdx - 1 + triggerArr.length) % triggerArr.length; break;\n case 'Home': nextIdx = 0; break;\n case 'End': nextIdx = triggerArr.length - 1; break;\n default: return;\n }\n\n e.preventDefault();\n triggerArr[nextIdx]?.focus();\n }\n\n private _toggle(value: string) {\n const next = new Set(this._openItems);\n if (next.has(value)) {\n next.delete(value);\n } else {\n if (!this.multiple) next.clear();\n next.add(value);\n }\n this._openItems = next;\n this.dispatchEvent(new CustomEvent('cg-accordion-change', {\n detail: { open: [...next], toggled: value },\n bubbles: true,\n composed: true,\n }));\n }\n\n override render() {\n return html`${this.items.map(item => {\n const isOpen = this._openItems.has(item.value);\n return html`\n <div class=\"item ${isOpen ? 'open' : ''}\">\n <button\n class=\"trigger\"\n id=\"trigger-${item.value}\"\n aria-expanded=${isOpen}\n aria-controls=\"panel-${item.value}\"\n ?disabled=${item.disabled}\n @click=${() => this._toggle(item.value)}\n @keydown=${this._handleTriggerKeydown}\n >\n <span class=\"trigger-text\">${item.trigger}</span>\n <svg class=\"chevron\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M6 9l6 6 6-6\"></path>\n </svg>\n </button>\n <div class=\"content-wrapper\">\n <div class=\"content\" id=\"panel-${item.value}\" role=\"region\" aria-labelledby=\"trigger-${item.value}\">\n <div class=\"content-inner\">${item.content}</div>\n </div>\n </div>\n </div>\n `;\n })}`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-accordion': CgAccordion; }\n}\n"],"names":["CgAccordion","LitElement","e","triggers","triggerArr","currentIdx","nextIdx","value","next","html","item","isOpen","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":";;;;;;;;AAoBO,IAAMA,IAAN,cAA0BC,EAAW;AAAA,EAArC,cAAA;AAAA,UAAA,GAAA,SAAA,GA2HwB,KAAA,OAA2B,MAC7B,KAAA,QAAyB,CAAA,GACvB,KAAA,WAAW,IACX,KAAA,UAA2C,WAC7C,KAAA,cAAwB,CAAA,GAE1C,KAAQ,iCAAiB,IAAA;AAAA,EAAY;AAAA,EAErC,eAAe;AACtB,IAAI,KAAK,YAAY,SAAS,MAC5B,KAAK,aAAa,IAAI,IAAI,KAAK,WAAW,KAAK,cAAc,CAAC,KAAK,YAAY,CAAC,CAAE,CAAC;AAAA,EAEvF;AAAA,EAEQ,sBAAsBC,GAAkB;AAC9C,UAAMC,IAAW,KAAK,WAAY,iBAAiB,yBAAyB,GACtEC,IAAa,MAAM,KAAKD,CAAQ,GAChCE,IAAaD,EAAW,QAAQF,EAAE,aAA4B;AACpE,QAAII,IAAUD;AAEd,YAAQH,EAAE,KAAA;AAAA,MACR,KAAK;AAAa,QAAAI,KAAWD,IAAa,KAAKD,EAAW;AAAQ;AAAA,MAClE,KAAK;AAAW,QAAAE,KAAWD,IAAa,IAAID,EAAW,UAAUA,EAAW;AAAQ;AAAA,MACpF,KAAK;AAAQ,QAAAE,IAAU;AAAG;AAAA,MAC1B,KAAK;AAAO,QAAAA,IAAUF,EAAW,SAAS;AAAG;AAAA,MAC7C;AAAS;AAAA,IAAA;AAGX,IAAAF,EAAE,eAAA,GACFE,EAAWE,CAAO,GAAG,MAAA;AAAA,EACvB;AAAA,EAEQ,QAAQC,GAAe;AAC7B,UAAMC,IAAO,IAAI,IAAI,KAAK,UAAU;AACpC,IAAIA,EAAK,IAAID,CAAK,IAChBC,EAAK,OAAOD,CAAK,KAEZ,KAAK,YAAUC,EAAK,MAAA,GACzBA,EAAK,IAAID,CAAK,IAEhB,KAAK,aAAaC,GAClB,KAAK,cAAc,IAAI,YAAY,uBAAuB;AAAA,MACxD,QAAQ,EAAE,MAAM,CAAC,GAAGA,CAAI,GAAG,SAASD,EAAA;AAAA,MACpC,SAAS;AAAA,MACT,UAAU;AAAA,IAAA,CACX,CAAC;AAAA,EACJ;AAAA,EAES,SAAS;AAChB,WAAOE,IAAO,KAAK,MAAM,IAAI,CAAAC,MAAQ;AACnC,YAAMC,IAAS,KAAK,WAAW,IAAID,EAAK,KAAK;AAC7C,aAAOD;AAAA,2BACcE,IAAS,SAAS,EAAE;AAAA;AAAA;AAAA,0BAGrBD,EAAK,KAAK;AAAA,4BACRC,CAAM;AAAA,mCACCD,EAAK,KAAK;AAAA,wBACrBA,EAAK,QAAQ;AAAA,qBAChB,MAAM,KAAK,QAAQA,EAAK,KAAK,CAAC;AAAA,uBAC5B,KAAK,qBAAqB;AAAA;AAAA,yCAERA,EAAK,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,6CAMRA,EAAK,KAAK,4CAA4CA,EAAK,KAAK;AAAA,2CAClEA,EAAK,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA,IAKnD,CAAC,CAAC;AAAA,EACJ;AACF;AAvMaV,EACK,SAAS,CAACY,GAAWC,GAAeC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAwHnD;AAE4BC,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GA3HhBhB,EA2HkB,WAAA,QAAA,CAAA;AACFe,EAAA;AAAA,EAA1BC,EAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GA5HdhB,EA4HgB,WAAA,SAAA,CAAA;AACEe,EAAA;AAAA,EAA5BC,EAAS,EAAE,MAAM,QAAA,CAAS;AAAA,GA7HhBhB,EA6HkB,WAAA,YAAA,CAAA;AACAe,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GA9HhBhB,EA8HkB,WAAA,WAAA,CAAA;AACFe,EAAA;AAAA,EAA1BC,EAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GA/HdhB,EA+HgB,WAAA,eAAA,CAAA;AAEVe,EAAA;AAAA,EAAhBE,EAAA;AAAM,GAjIIjB,EAiIM,WAAA,cAAA,CAAA;AAjINA,IAANe,EAAA;AAAA,EADNG,EAAc,cAAc;AAAA,GAChBlB,CAAA;"}
1
+ {"version":3,"file":"cg-accordion.js","sources":["../../../src/components/cg-accordion/cg-accordion.ts"],"sourcesContent":["import { LitElement, html, css } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/** Item definition for cg-accordion. */\nexport interface AccordionItem {\n value: string;\n trigger: string;\n content: string;\n icon?: string;\n disabled?: boolean;\n}\n\n/**\n * @element cg-accordion\n * Expandable content sections with smooth CSS grid height animation.\n *\n * @fires {CustomEvent<{open: string[], toggled: string}>} cg-accordion-change - When an item is toggled\n */\n@customElement('cg-accordion')\nexport class CgAccordion extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n\n /* ── Default variant — minimal dividers, transparent ── */\n .item {\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-base-divider);\n }\n .item:last-child { border-bottom: none; }\n\n /* ── Card variant — separated elevated cards ── */\n :host([variant=\"card\"]) .item {\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-component-card-radius);\n margin-bottom: var(--cg-spacing-8);\n background: var(--cg-color-surface-cards-background);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n overflow: hidden;\n }\n :host([variant=\"card\"]) .item:last-child { margin-bottom: 0; }\n\n /* ── Bordered variant — single grouped container ── */\n :host([variant=\"bordered\"]) {\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-component-card-radius);\n background: var(--cg-color-surface-cards-background);\n overflow: hidden;\n }\n :host([variant=\"bordered\"]) .item {\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-divider);\n }\n :host([variant=\"bordered\"]) .item:last-child {\n border-bottom: none;\n }\n\n /* ── Trigger ── */\n .trigger {\n width: 100%;\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-16);\n background: transparent;\n border: none;\n font: inherit;\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-base-text);\n cursor: pointer;\n text-align: left;\n transition: background var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n\n .trigger:hover:not(:disabled) {\n background: var(--cg-overlay-dark-subtle);\n }\n\n .trigger:active:not(:disabled) .chevron {\n transform: scale(0.85);\n }\n\n .trigger:focus-visible {\n outline: none;\n box-shadow: inset 0 0 0 var(--cg-border-width-100) var(--cg-color-focus-ring-offset), inset 0 0 0 calc(var(--cg-border-width-100) * 2) var(--cg-color-focus-ring);\n }\n\n .trigger:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n .trigger-text {\n flex: 1;\n min-width: 0;\n }\n\n /* ── Chevron — only active signal ── */\n .chevron {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n flex-shrink: 0;\n color: var(--cg-color-surface-container-outlined);\n transition: transform var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out), color var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .item.open .chevron {\n transform: rotate(180deg);\n color: var(--cg-color-surface-base-text);\n }\n /* ── Open trigger: subtle accent so the active section is scannable ──\n The chevron flip alone was the only signal; add a faint accent wash +\n a brand leading edge + brighter title text. */\n .item.open .trigger {\n background: var(--cg-overlay-accent-subtle);\n color: var(--cg-color-surface-base-text);\n box-shadow: inset var(--cg-border-width-100) 0 0 0 var(--cg-color-action-primary-background-default);\n }\n\n /* ── Content — CSS grid smooth height ── */\n .content-wrapper {\n display: grid;\n grid-template-rows: 0fr;\n transition: grid-template-rows var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n .item.open .content-wrapper {\n grid-template-rows: 1fr;\n }\n\n .content {\n overflow: hidden;\n }\n\n .content-inner {\n padding: 0 var(--cg-spacing-16) var(--cg-spacing-16);\n font-size: var(--cg-font-size-sm);\n color: var(--cg-color-surface-container-outlined);\n line-height: var(--cg-line-height-relaxed);\n opacity: 0;\n transition: opacity var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n transition-delay: 50ms;\n }\n .item.open .content-inner {\n opacity: 1;\n }\n\n /* ── Size variants ── */\n :host([size=\"sm\"]) .trigger { font-size: var(--cg-font-size-xs); padding: var(--cg-spacing-12); }\n :host([size=\"sm\"]) .content-inner { font-size: var(--cg-font-size-xs); padding: 0 var(--cg-spacing-12) var(--cg-spacing-12); }\n\n :host([size=\"lg\"]) .trigger { font-size: var(--cg-font-size-base); padding: var(--cg-spacing-20); }\n :host([size=\"lg\"]) .content-inner { font-size: var(--cg-font-size-base); padding: 0 var(--cg-spacing-20) var(--cg-spacing-20); }\n `];\n\n @property({ reflect: true }) size: 'sm' | 'md' | 'lg' = 'md';\n @property({ type: Array }) items: AccordionItem[] = [];\n @property({ type: Boolean }) multiple = false;\n @property({ reflect: true }) variant: 'default' | 'card' | 'bordered' = 'default';\n @property({ type: Array }) defaultOpen: string[] = [];\n\n @state() private _openItems = new Set<string>();\n\n override firstUpdated() {\n if (this.defaultOpen.length > 0) {\n this._openItems = new Set(this.multiple ? this.defaultOpen : [this.defaultOpen[0]!]);\n }\n }\n\n private _handleTriggerKeydown(e: KeyboardEvent) {\n const triggers = this.shadowRoot!.querySelectorAll('.trigger:not(:disabled)') as NodeListOf<HTMLElement>;\n const triggerArr = Array.from(triggers);\n const currentIdx = triggerArr.indexOf(e.currentTarget as HTMLElement);\n let nextIdx = currentIdx;\n\n switch (e.key) {\n case 'ArrowDown': nextIdx = (currentIdx + 1) % triggerArr.length; break;\n case 'ArrowUp': nextIdx = (currentIdx - 1 + triggerArr.length) % triggerArr.length; break;\n case 'Home': nextIdx = 0; break;\n case 'End': nextIdx = triggerArr.length - 1; break;\n default: return;\n }\n\n e.preventDefault();\n triggerArr[nextIdx]?.focus();\n }\n\n private _toggle(value: string) {\n const next = new Set(this._openItems);\n if (next.has(value)) {\n next.delete(value);\n } else {\n if (!this.multiple) next.clear();\n next.add(value);\n }\n this._openItems = next;\n this.dispatchEvent(new CustomEvent('cg-accordion-change', {\n detail: { open: [...next], toggled: value },\n bubbles: true,\n composed: true,\n }));\n }\n\n override render() {\n return html`${this.items.map(item => {\n const isOpen = this._openItems.has(item.value);\n return html`\n <div class=\"item ${isOpen ? 'open' : ''}\">\n <button\n class=\"trigger\"\n id=\"trigger-${item.value}\"\n aria-expanded=${isOpen}\n aria-controls=\"panel-${item.value}\"\n ?disabled=${item.disabled}\n @click=${() => this._toggle(item.value)}\n @keydown=${this._handleTriggerKeydown}\n >\n <span class=\"trigger-text\">${item.trigger}</span>\n <svg class=\"chevron\" aria-hidden=\"true\" focusable=\"false\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M6 9l6 6 6-6\"></path>\n </svg>\n </button>\n <div class=\"content-wrapper\">\n <div class=\"content\" id=\"panel-${item.value}\" role=\"region\" aria-labelledby=\"trigger-${item.value}\">\n <div class=\"content-inner\">${item.content}</div>\n </div>\n </div>\n </div>\n `;\n })}`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-accordion': CgAccordion; }\n}\n"],"names":["CgAccordion","LitElement","triggers","triggerArr","currentIdx","nextIdx","value","next","html","item","isOpen","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,13 +1,13 @@
1
- import { css as g, LitElement as v, nothing as p, html as c } from "lit";
2
- import { property as o, query as u, customElement as h } from "lit/decorators.js";
3
- import { h as f, r as b } from "../../chunks/premium.css-9I4kHrsl.js";
4
- import { F as m } from "../../chunks/focus-trap-BdRNhSPD.js";
5
- var y = Object.defineProperty, w = Object.getOwnPropertyDescriptor, e = (i, r, n, s) => {
6
- for (var a = s > 1 ? void 0 : s ? w(r, n) : r, l = i.length - 1, d; l >= 0; l--)
7
- (d = i[l]) && (a = (s ? d(r, n, a) : d(a)) || a);
8
- return s && a && y(r, n, a), a;
1
+ import { css as g, LitElement as u, nothing as r, html as n } from "lit";
2
+ import { property as o, query as v, customElement as h } from "lit/decorators.js";
3
+ import { h as f, r as b } from "../../chunks/premium.css-DHekUEUt.js";
4
+ import { F as m } from "../../chunks/focus-trap-vlQwKK-3.js";
5
+ var y = Object.defineProperty, w = Object.getOwnPropertyDescriptor, e = (i, s, l, c) => {
6
+ for (var a = c > 1 ? void 0 : c ? w(s, l) : s, d = i.length - 1, p; d >= 0; d--)
7
+ (p = i[d]) && (a = (c ? p(s, l, a) : p(a)) || a);
8
+ return c && a && y(s, l, a), a;
9
9
  };
10
- let t = class extends v {
10
+ let t = class extends u {
11
11
  constructor() {
12
12
  super(...arguments), this.open = !1, this.title = "", this.description = "", this.confirmLabel = "Confirm", this.cancelLabel = "Cancel", this.destructive = !1, this.loading = !1, this.closable = !1, this._focusTrap = new m(), this._previousOverflow = "";
13
13
  }
@@ -39,30 +39,30 @@ let t = class extends v {
39
39
  this.dispatchEvent(new CustomEvent("cg-alert-cancel", { bubbles: !0, composed: !0 })), this.open = !1;
40
40
  }
41
41
  render() {
42
- return c`
42
+ return n`
43
43
  <div class="backdrop" @click=${() => this.closable && this._cancel()}></div>
44
44
  <div
45
45
  class="dialog"
46
46
  role="alertdialog"
47
47
  aria-modal="true"
48
- aria-labelledby="alert-title"
49
- aria-describedby="alert-description"
48
+ aria-labelledby=${this.title ? "alert-title" : r}
49
+ aria-describedby=${this.description ? "alert-description" : r}
50
50
  ?inert=${!this.open}
51
51
  >
52
52
  <div class="header">
53
53
  <slot name="icon">
54
- ${this.destructive ? c`
54
+ ${this.destructive ? n`
55
55
  <div class="icon-wrap">
56
- <svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
56
+ <svg aria-hidden="true" focusable="false" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
57
57
  <path d="M12 9v4M12 17h.01"/>
58
58
  <path d="M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z"/>
59
59
  </svg>
60
60
  </div>
61
- ` : p}
61
+ ` : r}
62
62
  </slot>
63
63
  <div class="header-text">
64
- ${this.title ? c`<h2 id="alert-title" class="title">${this.title}</h2>` : p}
65
- ${this.description ? c`<p id="alert-description" class="description">${this.description}</p>` : p}
64
+ ${this.title ? n`<h2 id="alert-title" class="title">${this.title}</h2>` : r}
65
+ ${this.description ? n`<p id="alert-description" class="description">${this.description}</p>` : r}
66
66
  </div>
67
67
  </div>
68
68
  <div class="body"><slot></slot></div>
@@ -209,7 +209,7 @@ e([
209
209
  o({ type: Boolean })
210
210
  ], t.prototype, "closable", 2);
211
211
  e([
212
- u(".dialog")
212
+ v(".dialog")
213
213
  ], t.prototype, "_dialogEl", 2);
214
214
  t = e([
215
215
  h("cg-alert-dialog")