@cognivo/components 0.8.0 → 0.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (543) hide show
  1. package/dist/chunks/focus-trap-vlQwKK-3.js +82 -0
  2. package/dist/chunks/focus-trap-vlQwKK-3.js.map +1 -0
  3. package/dist/chunks/{premium.css-9I4kHrsl.js → premium.css-DHekUEUt.js} +25 -25
  4. package/dist/chunks/{premium.css-9I4kHrsl.js.map → premium.css-DHekUEUt.js.map} +1 -1
  5. package/dist/cognivo.min.js +3375 -5270
  6. package/dist/cognivo.min.js.map +1 -1
  7. package/dist/components/ai-ab-test/ai-ab-test.js +1 -1
  8. package/dist/components/ai-accessibility-report/ai-accessibility-report.d.ts.map +1 -1
  9. package/dist/components/ai-accessibility-report/ai-accessibility-report.js +14 -13
  10. package/dist/components/ai-accessibility-report/ai-accessibility-report.js.map +1 -1
  11. package/dist/components/ai-action-preview/ai-action-preview.d.ts.map +1 -1
  12. package/dist/components/ai-action-preview/ai-action-preview.js +15 -14
  13. package/dist/components/ai-action-preview/ai-action-preview.js.map +1 -1
  14. package/dist/components/ai-agent-card/ai-agent-card.js +1 -1
  15. package/dist/components/ai-agent-steps/ai-agent-steps.d.ts +8 -21
  16. package/dist/components/ai-agent-steps/ai-agent-steps.d.ts.map +1 -1
  17. package/dist/components/ai-agent-steps/ai-agent-steps.js +85 -139
  18. package/dist/components/ai-agent-steps/ai-agent-steps.js.map +1 -1
  19. package/dist/components/ai-alert-card/ai-alert-card.js +5 -5
  20. package/dist/components/ai-alert-card/ai-alert-card.js.map +1 -1
  21. package/dist/components/ai-analytics-chart/ai-analytics-chart.d.ts +0 -13
  22. package/dist/components/ai-analytics-chart/ai-analytics-chart.d.ts.map +1 -1
  23. package/dist/components/ai-analytics-chart/ai-analytics-chart.js +75 -125
  24. package/dist/components/ai-analytics-chart/ai-analytics-chart.js.map +1 -1
  25. package/dist/components/ai-annotation/ai-annotation.js +2 -2
  26. package/dist/components/ai-annotation/ai-annotation.js.map +1 -1
  27. package/dist/components/ai-api-key-manager/ai-api-key-manager.d.ts +0 -9
  28. package/dist/components/ai-api-key-manager/ai-api-key-manager.d.ts.map +1 -1
  29. package/dist/components/ai-api-key-manager/ai-api-key-manager.js +115 -276
  30. package/dist/components/ai-api-key-manager/ai-api-key-manager.js.map +1 -1
  31. package/dist/components/ai-app-sidebar/ai-app-sidebar.js +13 -13
  32. package/dist/components/ai-app-sidebar/ai-app-sidebar.js.map +1 -1
  33. package/dist/components/ai-assistant-widget/ai-assistant-widget.d.ts.map +1 -1
  34. package/dist/components/ai-assistant-widget/ai-assistant-widget.js +5 -2
  35. package/dist/components/ai-assistant-widget/ai-assistant-widget.js.map +1 -1
  36. package/dist/components/ai-audio-player/ai-audio-player.d.ts.map +1 -1
  37. package/dist/components/ai-audio-player/ai-audio-player.js +23 -19
  38. package/dist/components/ai-audio-player/ai-audio-player.js.map +1 -1
  39. package/dist/components/ai-avatar/ai-avatar.js +1 -1
  40. package/dist/components/ai-badge/ai-badge.js +1 -1
  41. package/dist/components/ai-batch-progress/ai-batch-progress.js +6 -6
  42. package/dist/components/ai-batch-progress/ai-batch-progress.js.map +1 -1
  43. package/dist/components/ai-cache-indicator/ai-cache-indicator.d.ts +0 -13
  44. package/dist/components/ai-cache-indicator/ai-cache-indicator.d.ts.map +1 -1
  45. package/dist/components/ai-cache-indicator/ai-cache-indicator.js +90 -185
  46. package/dist/components/ai-cache-indicator/ai-cache-indicator.js.map +1 -1
  47. package/dist/components/ai-capture-flow/ai-capture-flow.js +21 -21
  48. package/dist/components/ai-capture-flow/ai-capture-flow.js.map +1 -1
  49. package/dist/components/ai-changelog/ai-changelog.js +26 -26
  50. package/dist/components/ai-changelog/ai-changelog.js.map +1 -1
  51. package/dist/components/ai-chart-summary/ai-chart-summary.d.ts +0 -6
  52. package/dist/components/ai-chart-summary/ai-chart-summary.d.ts.map +1 -1
  53. package/dist/components/ai-chart-summary/ai-chart-summary.js +100 -103
  54. package/dist/components/ai-chart-summary/ai-chart-summary.js.map +1 -1
  55. package/dist/components/ai-chat/ai-chat.d.ts.map +1 -1
  56. package/dist/components/ai-chat/ai-chat.js +9 -3
  57. package/dist/components/ai-chat/ai-chat.js.map +1 -1
  58. package/dist/components/ai-citation/ai-citation.d.ts +0 -6
  59. package/dist/components/ai-citation/ai-citation.d.ts.map +1 -1
  60. package/dist/components/ai-citation/ai-citation.js +64 -90
  61. package/dist/components/ai-citation/ai-citation.js.map +1 -1
  62. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.d.ts +1 -27
  63. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.d.ts.map +1 -1
  64. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js +114 -260
  65. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js.map +1 -1
  66. package/dist/components/ai-command-palette/ai-command-palette.js +1 -1
  67. package/dist/components/ai-confidence-badge/ai-confidence-badge.d.ts +11 -9
  68. package/dist/components/ai-confidence-badge/ai-confidence-badge.d.ts.map +1 -1
  69. package/dist/components/ai-confidence-badge/ai-confidence-badge.js +183 -101
  70. package/dist/components/ai-confidence-badge/ai-confidence-badge.js.map +1 -1
  71. package/dist/components/ai-confidence-slider/ai-confidence-slider.js +27 -27
  72. package/dist/components/ai-confidence-slider/ai-confidence-slider.js.map +1 -1
  73. package/dist/components/ai-consent-manager/ai-consent-manager.js +2 -2
  74. package/dist/components/ai-consent-manager/ai-consent-manager.js.map +1 -1
  75. package/dist/components/ai-context-window/ai-context-window.js +19 -19
  76. package/dist/components/ai-context-window/ai-context-window.js.map +1 -1
  77. package/dist/components/ai-copy-button/ai-copy-button.js +4 -4
  78. package/dist/components/ai-copy-button/ai-copy-button.js.map +1 -1
  79. package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js +14 -14
  80. package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js.map +1 -1
  81. package/dist/components/ai-data-card/ai-data-card.js +2 -2
  82. package/dist/components/ai-data-card/ai-data-card.js.map +1 -1
  83. package/dist/components/ai-data-lineage/ai-data-lineage.js +6 -6
  84. package/dist/components/ai-data-lineage/ai-data-lineage.js.map +1 -1
  85. package/dist/components/ai-data-preview/ai-data-preview.d.ts +0 -7
  86. package/dist/components/ai-data-preview/ai-data-preview.d.ts.map +1 -1
  87. package/dist/components/ai-data-preview/ai-data-preview.js +130 -267
  88. package/dist/components/ai-data-preview/ai-data-preview.js.map +1 -1
  89. package/dist/components/ai-data-table/ai-data-table.js +9 -9
  90. package/dist/components/ai-data-table/ai-data-table.js.map +1 -1
  91. package/dist/components/ai-debug-console/ai-debug-console.d.ts +1 -13
  92. package/dist/components/ai-debug-console/ai-debug-console.d.ts.map +1 -1
  93. package/dist/components/ai-debug-console/ai-debug-console.js +134 -340
  94. package/dist/components/ai-debug-console/ai-debug-console.js.map +1 -1
  95. package/dist/components/ai-detection-canvas/ai-detection-canvas.js +2 -2
  96. package/dist/components/ai-detection-canvas/ai-detection-canvas.js.map +1 -1
  97. package/dist/components/ai-diff-panel/ai-diff-panel.js +1 -1
  98. package/dist/components/ai-embedding-viz/ai-embedding-viz.js +4 -4
  99. package/dist/components/ai-embedding-viz/ai-embedding-viz.js.map +1 -1
  100. package/dist/components/ai-empty-state/ai-empty-state.js +1 -1
  101. package/dist/components/ai-error-boundary/ai-error-boundary.d.ts.map +1 -1
  102. package/dist/components/ai-error-boundary/ai-error-boundary.js +26 -21
  103. package/dist/components/ai-error-boundary/ai-error-boundary.js.map +1 -1
  104. package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js +5 -5
  105. package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js.map +1 -1
  106. package/dist/components/ai-feature-flag/ai-feature-flag.d.ts +0 -14
  107. package/dist/components/ai-feature-flag/ai-feature-flag.d.ts.map +1 -1
  108. package/dist/components/ai-feature-flag/ai-feature-flag.js +181 -322
  109. package/dist/components/ai-feature-flag/ai-feature-flag.js.map +1 -1
  110. package/dist/components/ai-feedback/ai-feedback.d.ts.map +1 -1
  111. package/dist/components/ai-feedback/ai-feedback.js +10 -5
  112. package/dist/components/ai-feedback/ai-feedback.js.map +1 -1
  113. package/dist/components/ai-file-upload/ai-file-upload.js +1 -1
  114. package/dist/components/ai-form-generator/ai-form-generator.js +1 -1
  115. package/dist/components/ai-guardrail/ai-guardrail.js +2 -2
  116. package/dist/components/ai-guardrail/ai-guardrail.js.map +1 -1
  117. package/dist/components/ai-heatmap/ai-heatmap.js +1 -1
  118. package/dist/components/ai-insight-card/ai-insight-card.js +4 -4
  119. package/dist/components/ai-insight-card/ai-insight-card.js.map +1 -1
  120. package/dist/components/ai-json-viewer/ai-json-viewer.js +13 -13
  121. package/dist/components/ai-json-viewer/ai-json-viewer.js.map +1 -1
  122. package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js +24 -24
  123. package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js.map +1 -1
  124. package/dist/components/ai-kpi-grid/ai-kpi-grid.js +2 -2
  125. package/dist/components/ai-kpi-grid/ai-kpi-grid.js.map +1 -1
  126. package/dist/components/ai-labeling-board/ai-labeling-board.js +11 -11
  127. package/dist/components/ai-labeling-board/ai-labeling-board.js.map +1 -1
  128. package/dist/components/ai-memory-panel/ai-memory-panel.js +7 -7
  129. package/dist/components/ai-memory-panel/ai-memory-panel.js.map +1 -1
  130. package/dist/components/ai-model-comparison/ai-model-comparison.js +2 -2
  131. package/dist/components/ai-model-comparison/ai-model-comparison.js.map +1 -1
  132. package/dist/components/ai-model-selector/ai-model-selector.js +7 -7
  133. package/dist/components/ai-model-selector/ai-model-selector.js.map +1 -1
  134. package/dist/components/ai-notification-center/ai-notification-center.js +27 -27
  135. package/dist/components/ai-notification-center/ai-notification-center.js.map +1 -1
  136. package/dist/components/ai-onboarding/ai-onboarding.js +5 -5
  137. package/dist/components/ai-onboarding/ai-onboarding.js.map +1 -1
  138. package/dist/components/ai-permission-gate/ai-permission-gate.js +1 -1
  139. package/dist/components/ai-personalization-dash/ai-personalization-dash.js +1 -1
  140. package/dist/components/ai-presence/ai-presence.js +25 -25
  141. package/dist/components/ai-presence/ai-presence.js.map +1 -1
  142. package/dist/components/ai-progress-steps/ai-progress-steps.js +11 -11
  143. package/dist/components/ai-progress-steps/ai-progress-steps.js.map +1 -1
  144. package/dist/components/ai-prompt-editor/ai-prompt-editor.js +1 -1
  145. package/dist/components/ai-prompt-template/ai-prompt-template.js +29 -29
  146. package/dist/components/ai-prompt-template/ai-prompt-template.js.map +1 -1
  147. package/dist/components/ai-rag-panel/ai-rag-panel.js +4 -4
  148. package/dist/components/ai-rag-panel/ai-rag-panel.js.map +1 -1
  149. package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js +16 -16
  150. package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js.map +1 -1
  151. package/dist/components/ai-result-panel/ai-result-panel.js +1 -1
  152. package/dist/components/ai-reveal-animation/ai-reveal-animation.js +3 -3
  153. package/dist/components/ai-reveal-animation/ai-reveal-animation.js.map +1 -1
  154. package/dist/components/ai-reward-signal/ai-reward-signal.js +1 -1
  155. package/dist/components/ai-rich-message/ai-rich-message.d.ts.map +1 -1
  156. package/dist/components/ai-rich-message/ai-rich-message.js +37 -30
  157. package/dist/components/ai-rich-message/ai-rich-message.js.map +1 -1
  158. package/dist/components/ai-scenario-panel/ai-scenario-panel.js +10 -10
  159. package/dist/components/ai-scenario-panel/ai-scenario-panel.js.map +1 -1
  160. package/dist/components/ai-search/ai-search.js +1 -1
  161. package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js +3 -3
  162. package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js.map +1 -1
  163. package/dist/components/ai-sidebar/ai-sidebar.js +1 -1
  164. package/dist/components/ai-similarity-card/ai-similarity-card.js +1 -1
  165. package/dist/components/ai-source-graph/ai-source-graph.js +2 -2
  166. package/dist/components/ai-source-graph/ai-source-graph.js.map +1 -1
  167. package/dist/components/ai-status-page/ai-status-page.js +15 -15
  168. package/dist/components/ai-status-page/ai-status-page.js.map +1 -1
  169. package/dist/components/ai-streaming-text/ai-streaming-text.js +1 -1
  170. package/dist/components/ai-test-runner/ai-test-runner.d.ts +0 -8
  171. package/dist/components/ai-test-runner/ai-test-runner.d.ts.map +1 -1
  172. package/dist/components/ai-test-runner/ai-test-runner.js +100 -257
  173. package/dist/components/ai-test-runner/ai-test-runner.js.map +1 -1
  174. package/dist/components/ai-thinking/ai-thinking.js +1 -1
  175. package/dist/components/ai-timeline/ai-timeline.js +2 -2
  176. package/dist/components/ai-timeline/ai-timeline.js.map +1 -1
  177. package/dist/components/ai-token-tracker/ai-token-tracker.js +3 -3
  178. package/dist/components/ai-token-tracker/ai-token-tracker.js.map +1 -1
  179. package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js +23 -23
  180. package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js.map +1 -1
  181. package/dist/components/ai-tool-indicator/ai-tool-indicator.js +3 -3
  182. package/dist/components/ai-tool-indicator/ai-tool-indicator.js.map +1 -1
  183. package/dist/components/ai-transform-slider/ai-transform-slider.js +1 -1
  184. package/dist/components/ai-translation-panel/ai-translation-panel.js +2 -2
  185. package/dist/components/ai-translation-panel/ai-translation-panel.js.map +1 -1
  186. package/dist/components/ai-usage-meter/ai-usage-meter.js +1 -1
  187. package/dist/components/ai-validation-checklist/ai-validation-checklist.d.ts +1 -11
  188. package/dist/components/ai-validation-checklist/ai-validation-checklist.d.ts.map +1 -1
  189. package/dist/components/ai-validation-checklist/ai-validation-checklist.js +133 -187
  190. package/dist/components/ai-validation-checklist/ai-validation-checklist.js.map +1 -1
  191. package/dist/components/ai-version-selector/ai-version-selector.d.ts +0 -4
  192. package/dist/components/ai-version-selector/ai-version-selector.d.ts.map +1 -1
  193. package/dist/components/ai-version-selector/ai-version-selector.js +189 -210
  194. package/dist/components/ai-version-selector/ai-version-selector.js.map +1 -1
  195. package/dist/components/ai-voice-panel/ai-voice-panel.js +28 -28
  196. package/dist/components/ai-voice-panel/ai-voice-panel.js.map +1 -1
  197. package/dist/components/ai-webhook-config/ai-webhook-config.d.ts +0 -17
  198. package/dist/components/ai-webhook-config/ai-webhook-config.d.ts.map +1 -1
  199. package/dist/components/ai-webhook-config/ai-webhook-config.js +281 -221
  200. package/dist/components/ai-webhook-config/ai-webhook-config.js.map +1 -1
  201. package/dist/components/ai-workflow-builder/ai-workflow-builder.js +2 -2
  202. package/dist/components/ai-workflow-builder/ai-workflow-builder.js.map +1 -1
  203. package/dist/components/bias-anchoring/bias-anchoring.js +1 -1
  204. package/dist/components/bias-authority/bias-authority.js +1 -1
  205. package/dist/components/bias-commitment/bias-commitment.js +1 -1
  206. package/dist/components/bias-reciprocity/bias-reciprocity.js +1 -1
  207. package/dist/components/bias-scarcity/bias-scarcity.js +1 -1
  208. package/dist/components/bias-social-proof/bias-social-proof.js +1 -1
  209. package/dist/components/cg-accordion/cg-accordion.d.ts.map +1 -1
  210. package/dist/components/cg-accordion/cg-accordion.js +51 -43
  211. package/dist/components/cg-accordion/cg-accordion.js.map +1 -1
  212. package/dist/components/cg-alert-dialog/cg-alert-dialog.js +18 -18
  213. package/dist/components/cg-alert-dialog/cg-alert-dialog.js.map +1 -1
  214. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.d.ts.map +1 -1
  215. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js +25 -21
  216. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js.map +1 -1
  217. package/dist/components/cg-autocomplete/cg-autocomplete.d.ts +1 -0
  218. package/dist/components/cg-autocomplete/cg-autocomplete.d.ts.map +1 -1
  219. package/dist/components/cg-autocomplete/cg-autocomplete.js +59 -43
  220. package/dist/components/cg-autocomplete/cg-autocomplete.js.map +1 -1
  221. package/dist/components/cg-avatar/cg-avatar.d.ts.map +1 -1
  222. package/dist/components/cg-avatar/cg-avatar.js +24 -24
  223. package/dist/components/cg-avatar/cg-avatar.js.map +1 -1
  224. package/dist/components/cg-avatar-group/cg-avatar-group.d.ts.map +1 -1
  225. package/dist/components/cg-avatar-group/cg-avatar-group.js +18 -12
  226. package/dist/components/cg-avatar-group/cg-avatar-group.js.map +1 -1
  227. package/dist/components/cg-badge/cg-badge.d.ts.map +1 -1
  228. package/dist/components/cg-badge/cg-badge.js +26 -20
  229. package/dist/components/cg-badge/cg-badge.js.map +1 -1
  230. package/dist/components/cg-badge-group/cg-badge-group.d.ts +0 -1
  231. package/dist/components/cg-badge-group/cg-badge-group.d.ts.map +1 -1
  232. package/dist/components/cg-badge-group/cg-badge-group.js +31 -29
  233. package/dist/components/cg-badge-group/cg-badge-group.js.map +1 -1
  234. package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js +21 -21
  235. package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js.map +1 -1
  236. package/dist/components/cg-button/cg-button.d.ts +5 -71
  237. package/dist/components/cg-button/cg-button.d.ts.map +1 -1
  238. package/dist/components/cg-button/cg-button.js +63 -172
  239. package/dist/components/cg-button/cg-button.js.map +1 -1
  240. package/dist/components/cg-button-group/cg-button-group.d.ts +2 -0
  241. package/dist/components/cg-button-group/cg-button-group.d.ts.map +1 -1
  242. package/dist/components/cg-button-group/cg-button-group.js +43 -29
  243. package/dist/components/cg-button-group/cg-button-group.js.map +1 -1
  244. package/dist/components/cg-calendar/cg-calendar.d.ts +4 -0
  245. package/dist/components/cg-calendar/cg-calendar.d.ts.map +1 -1
  246. package/dist/components/cg-calendar/cg-calendar.js +28 -12
  247. package/dist/components/cg-calendar/cg-calendar.js.map +1 -1
  248. package/dist/components/cg-callout/cg-callout.d.ts.map +1 -1
  249. package/dist/components/cg-callout/cg-callout.js +49 -48
  250. package/dist/components/cg-callout/cg-callout.js.map +1 -1
  251. package/dist/components/cg-card/cg-card.d.ts +9 -22
  252. package/dist/components/cg-card/cg-card.d.ts.map +1 -1
  253. package/dist/components/cg-card/cg-card.js +28 -56
  254. package/dist/components/cg-card/cg-card.js.map +1 -1
  255. package/dist/components/cg-carousel/cg-carousel.d.ts.map +1 -1
  256. package/dist/components/cg-carousel/cg-carousel.js +19 -13
  257. package/dist/components/cg-carousel/cg-carousel.js.map +1 -1
  258. package/dist/components/cg-chart/cg-chart.d.ts.map +1 -1
  259. package/dist/components/cg-chart/cg-chart.js +63 -58
  260. package/dist/components/cg-chart/cg-chart.js.map +1 -1
  261. package/dist/components/cg-checkbox/cg-checkbox.d.ts +0 -6
  262. package/dist/components/cg-checkbox/cg-checkbox.d.ts.map +1 -1
  263. package/dist/components/cg-checkbox/cg-checkbox.js +51 -51
  264. package/dist/components/cg-checkbox/cg-checkbox.js.map +1 -1
  265. package/dist/components/cg-chip/cg-chip.js +31 -31
  266. package/dist/components/cg-chip/cg-chip.js.map +1 -1
  267. package/dist/components/cg-code-block/cg-code-block.d.ts.map +1 -1
  268. package/dist/components/cg-code-block/cg-code-block.js +36 -34
  269. package/dist/components/cg-code-block/cg-code-block.js.map +1 -1
  270. package/dist/components/cg-collapsible/cg-collapsible.d.ts.map +1 -1
  271. package/dist/components/cg-collapsible/cg-collapsible.js +23 -18
  272. package/dist/components/cg-collapsible/cg-collapsible.js.map +1 -1
  273. package/dist/components/cg-color-picker/cg-color-picker.d.ts +3 -0
  274. package/dist/components/cg-color-picker/cg-color-picker.d.ts.map +1 -1
  275. package/dist/components/cg-color-picker/cg-color-picker.js +189 -91
  276. package/dist/components/cg-color-picker/cg-color-picker.js.map +1 -1
  277. package/dist/components/cg-combobox/cg-combobox.d.ts.map +1 -1
  278. package/dist/components/cg-combobox/cg-combobox.js +13 -6
  279. package/dist/components/cg-combobox/cg-combobox.js.map +1 -1
  280. package/dist/components/cg-command/cg-command.d.ts.map +1 -1
  281. package/dist/components/cg-command/cg-command.js +52 -45
  282. package/dist/components/cg-command/cg-command.js.map +1 -1
  283. package/dist/components/cg-context-menu/cg-context-menu.js +1 -1
  284. package/dist/components/cg-date-picker/cg-date-picker.d.ts.map +1 -1
  285. package/dist/components/cg-date-picker/cg-date-picker.js +36 -34
  286. package/dist/components/cg-date-picker/cg-date-picker.js.map +1 -1
  287. package/dist/components/cg-date-range-picker/cg-date-range-picker.d.ts +2 -0
  288. package/dist/components/cg-date-range-picker/cg-date-range-picker.d.ts.map +1 -1
  289. package/dist/components/cg-date-range-picker/cg-date-range-picker.js +12 -8
  290. package/dist/components/cg-date-range-picker/cg-date-range-picker.js.map +1 -1
  291. package/dist/components/cg-date-time-picker/cg-date-time-picker.d.ts.map +1 -1
  292. package/dist/components/cg-date-time-picker/cg-date-time-picker.js +3 -1
  293. package/dist/components/cg-date-time-picker/cg-date-time-picker.js.map +1 -1
  294. package/dist/components/cg-drawer/cg-drawer.js +3 -3
  295. package/dist/components/cg-drawer/cg-drawer.js.map +1 -1
  296. package/dist/components/cg-dropdown/cg-dropdown.d.ts.map +1 -1
  297. package/dist/components/cg-dropdown/cg-dropdown.js +1 -2
  298. package/dist/components/cg-dropdown/cg-dropdown.js.map +1 -1
  299. package/dist/components/cg-empty-state/cg-empty-state.d.ts +3 -24
  300. package/dist/components/cg-empty-state/cg-empty-state.d.ts.map +1 -1
  301. package/dist/components/cg-empty-state/cg-empty-state.js +51 -74
  302. package/dist/components/cg-empty-state/cg-empty-state.js.map +1 -1
  303. package/dist/components/cg-file-input/cg-file-input.d.ts.map +1 -1
  304. package/dist/components/cg-file-input/cg-file-input.js +9 -10
  305. package/dist/components/cg-file-input/cg-file-input.js.map +1 -1
  306. package/dist/components/cg-focus-scope/cg-focus-scope.js +1 -1
  307. package/dist/components/cg-follow-up/cg-follow-up.d.ts.map +1 -1
  308. package/dist/components/cg-follow-up/cg-follow-up.js +6 -7
  309. package/dist/components/cg-follow-up/cg-follow-up.js.map +1 -1
  310. package/dist/components/cg-form/cg-form.js +17 -17
  311. package/dist/components/cg-form/cg-form.js.map +1 -1
  312. package/dist/components/cg-hover-card/cg-hover-card.d.ts +1 -0
  313. package/dist/components/cg-hover-card/cg-hover-card.d.ts.map +1 -1
  314. package/dist/components/cg-hover-card/cg-hover-card.js +37 -32
  315. package/dist/components/cg-hover-card/cg-hover-card.js.map +1 -1
  316. package/dist/components/cg-icon/cg-icon.d.ts.map +1 -1
  317. package/dist/components/cg-icon/cg-icon.js +44 -37
  318. package/dist/components/cg-icon/cg-icon.js.map +1 -1
  319. package/dist/components/cg-image/cg-image.js +2 -2
  320. package/dist/components/cg-image/cg-image.js.map +1 -1
  321. package/dist/components/cg-image-block/cg-image-block.js +3 -3
  322. package/dist/components/cg-image-block/cg-image-block.js.map +1 -1
  323. package/dist/components/cg-image-gallery/cg-image-gallery.js +20 -20
  324. package/dist/components/cg-image-gallery/cg-image-gallery.js.map +1 -1
  325. package/dist/components/cg-input/cg-input.js +3 -3
  326. package/dist/components/cg-input/cg-input.js.map +1 -1
  327. package/dist/components/cg-kbd/cg-kbd.d.ts.map +1 -1
  328. package/dist/components/cg-kbd/cg-kbd.js +26 -24
  329. package/dist/components/cg-kbd/cg-kbd.js.map +1 -1
  330. package/dist/components/cg-label/cg-label.d.ts +4 -1
  331. package/dist/components/cg-label/cg-label.d.ts.map +1 -1
  332. package/dist/components/cg-label/cg-label.js +44 -41
  333. package/dist/components/cg-label/cg-label.js.map +1 -1
  334. package/dist/components/cg-link/cg-link.js +23 -23
  335. package/dist/components/cg-link/cg-link.js.map +1 -1
  336. package/dist/components/cg-list/cg-list.js +5 -5
  337. package/dist/components/cg-list/cg-list.js.map +1 -1
  338. package/dist/components/cg-listbox/cg-listbox.d.ts.map +1 -1
  339. package/dist/components/cg-listbox/cg-listbox.js +46 -40
  340. package/dist/components/cg-listbox/cg-listbox.js.map +1 -1
  341. package/dist/components/cg-markdown/cg-markdown.d.ts +2 -0
  342. package/dist/components/cg-markdown/cg-markdown.d.ts.map +1 -1
  343. package/dist/components/cg-markdown/cg-markdown.js +171 -121
  344. package/dist/components/cg-markdown/cg-markdown.js.map +1 -1
  345. package/dist/components/cg-menubar/cg-menubar.d.ts +6 -0
  346. package/dist/components/cg-menubar/cg-menubar.d.ts.map +1 -1
  347. package/dist/components/cg-menubar/cg-menubar.js +59 -47
  348. package/dist/components/cg-menubar/cg-menubar.js.map +1 -1
  349. package/dist/components/cg-meter/cg-meter.d.ts.map +1 -1
  350. package/dist/components/cg-meter/cg-meter.js +76 -76
  351. package/dist/components/cg-meter/cg-meter.js.map +1 -1
  352. package/dist/components/cg-metric-card/cg-metric-card.d.ts.map +1 -1
  353. package/dist/components/cg-metric-card/cg-metric-card.js +65 -68
  354. package/dist/components/cg-metric-card/cg-metric-card.js.map +1 -1
  355. package/dist/components/cg-modal/cg-modal.d.ts +3 -0
  356. package/dist/components/cg-modal/cg-modal.d.ts.map +1 -1
  357. package/dist/components/cg-modal/cg-modal.js +82 -83
  358. package/dist/components/cg-modal/cg-modal.js.map +1 -1
  359. package/dist/components/cg-navbar/cg-navbar.d.ts +1 -1
  360. package/dist/components/cg-navbar/cg-navbar.d.ts.map +1 -1
  361. package/dist/components/cg-navbar/cg-navbar.js +64 -55
  362. package/dist/components/cg-navbar/cg-navbar.js.map +1 -1
  363. package/dist/components/cg-navigation-menu/cg-navigation-menu.d.ts +3 -0
  364. package/dist/components/cg-navigation-menu/cg-navigation-menu.d.ts.map +1 -1
  365. package/dist/components/cg-navigation-menu/cg-navigation-menu.js +38 -26
  366. package/dist/components/cg-navigation-menu/cg-navigation-menu.js.map +1 -1
  367. package/dist/components/cg-number-input/cg-number-input.d.ts +1 -0
  368. package/dist/components/cg-number-input/cg-number-input.d.ts.map +1 -1
  369. package/dist/components/cg-number-input/cg-number-input.js +90 -77
  370. package/dist/components/cg-number-input/cg-number-input.js.map +1 -1
  371. package/dist/components/cg-otp-input/cg-otp-input.d.ts.map +1 -1
  372. package/dist/components/cg-otp-input/cg-otp-input.js +70 -60
  373. package/dist/components/cg-otp-input/cg-otp-input.js.map +1 -1
  374. package/dist/components/cg-pagination/cg-pagination.d.ts +2 -0
  375. package/dist/components/cg-pagination/cg-pagination.d.ts.map +1 -1
  376. package/dist/components/cg-pagination/cg-pagination.js +50 -49
  377. package/dist/components/cg-pagination/cg-pagination.js.map +1 -1
  378. package/dist/components/cg-password-input/cg-password-input.d.ts.map +1 -1
  379. package/dist/components/cg-password-input/cg-password-input.js +42 -34
  380. package/dist/components/cg-password-input/cg-password-input.js.map +1 -1
  381. package/dist/components/cg-phone-input/cg-phone-input.d.ts.map +1 -1
  382. package/dist/components/cg-phone-input/cg-phone-input.js +18 -14
  383. package/dist/components/cg-phone-input/cg-phone-input.js.map +1 -1
  384. package/dist/components/cg-popover/cg-popover.d.ts +12 -2
  385. package/dist/components/cg-popover/cg-popover.d.ts.map +1 -1
  386. package/dist/components/cg-popover/cg-popover.js +90 -63
  387. package/dist/components/cg-popover/cg-popover.js.map +1 -1
  388. package/dist/components/cg-portal/cg-portal.d.ts.map +1 -1
  389. package/dist/components/cg-portal/cg-portal.js +42 -41
  390. package/dist/components/cg-portal/cg-portal.js.map +1 -1
  391. package/dist/components/cg-progress-bar/cg-progress-bar.d.ts.map +1 -1
  392. package/dist/components/cg-progress-bar/cg-progress-bar.js +25 -25
  393. package/dist/components/cg-progress-bar/cg-progress-bar.js.map +1 -1
  394. package/dist/components/cg-radio/cg-radio.d.ts +10 -0
  395. package/dist/components/cg-radio/cg-radio.d.ts.map +1 -1
  396. package/dist/components/cg-radio/cg-radio.js +59 -48
  397. package/dist/components/cg-radio/cg-radio.js.map +1 -1
  398. package/dist/components/cg-radio-group/cg-radio-group.d.ts +6 -0
  399. package/dist/components/cg-radio-group/cg-radio-group.d.ts.map +1 -1
  400. package/dist/components/cg-radio-group/cg-radio-group.js +50 -37
  401. package/dist/components/cg-radio-group/cg-radio-group.js.map +1 -1
  402. package/dist/components/cg-rating/cg-rating.d.ts.map +1 -1
  403. package/dist/components/cg-rating/cg-rating.js +56 -54
  404. package/dist/components/cg-rating/cg-rating.js.map +1 -1
  405. package/dist/components/cg-resizable/cg-resizable.d.ts +4 -1
  406. package/dist/components/cg-resizable/cg-resizable.d.ts.map +1 -1
  407. package/dist/components/cg-resizable/cg-resizable.js +45 -35
  408. package/dist/components/cg-resizable/cg-resizable.js.map +1 -1
  409. package/dist/components/cg-scroll-area/cg-scroll-area.d.ts +8 -0
  410. package/dist/components/cg-scroll-area/cg-scroll-area.d.ts.map +1 -1
  411. package/dist/components/cg-scroll-area/cg-scroll-area.js +64 -21
  412. package/dist/components/cg-scroll-area/cg-scroll-area.js.map +1 -1
  413. package/dist/components/cg-segmented-control/cg-segmented-control.d.ts +4 -0
  414. package/dist/components/cg-segmented-control/cg-segmented-control.d.ts.map +1 -1
  415. package/dist/components/cg-segmented-control/cg-segmented-control.js +75 -39
  416. package/dist/components/cg-segmented-control/cg-segmented-control.js.map +1 -1
  417. package/dist/components/cg-select/cg-select.d.ts +4 -2
  418. package/dist/components/cg-select/cg-select.d.ts.map +1 -1
  419. package/dist/components/cg-select/cg-select.js +96 -58
  420. package/dist/components/cg-select/cg-select.js.map +1 -1
  421. package/dist/components/cg-separator/cg-separator.d.ts +1 -2
  422. package/dist/components/cg-separator/cg-separator.d.ts.map +1 -1
  423. package/dist/components/cg-separator/cg-separator.js +5 -8
  424. package/dist/components/cg-separator/cg-separator.js.map +1 -1
  425. package/dist/components/cg-sheet/cg-sheet.d.ts +4 -0
  426. package/dist/components/cg-sheet/cg-sheet.d.ts.map +1 -1
  427. package/dist/components/cg-sheet/cg-sheet.js +80 -43
  428. package/dist/components/cg-sheet/cg-sheet.js.map +1 -1
  429. package/dist/components/cg-sidebar/cg-sidebar.d.ts.map +1 -1
  430. package/dist/components/cg-sidebar/cg-sidebar.js +82 -19
  431. package/dist/components/cg-sidebar/cg-sidebar.js.map +1 -1
  432. package/dist/components/cg-skeleton/cg-skeleton.d.ts +7 -1
  433. package/dist/components/cg-skeleton/cg-skeleton.d.ts.map +1 -1
  434. package/dist/components/cg-skeleton/cg-skeleton.js +61 -63
  435. package/dist/components/cg-skeleton/cg-skeleton.js.map +1 -1
  436. package/dist/components/cg-slider/cg-slider.d.ts.map +1 -1
  437. package/dist/components/cg-slider/cg-slider.js +80 -73
  438. package/dist/components/cg-slider/cg-slider.js.map +1 -1
  439. package/dist/components/cg-spinner/cg-spinner.d.ts.map +1 -1
  440. package/dist/components/cg-spinner/cg-spinner.js +10 -19
  441. package/dist/components/cg-spinner/cg-spinner.js.map +1 -1
  442. package/dist/components/cg-split-button/cg-split-button.d.ts.map +1 -1
  443. package/dist/components/cg-split-button/cg-split-button.js +64 -50
  444. package/dist/components/cg-split-button/cg-split-button.js.map +1 -1
  445. package/dist/components/cg-stack/cg-stack.js +1 -1
  446. package/dist/components/cg-steps/cg-steps.js +1 -1
  447. package/dist/components/cg-switch/cg-switch.d.ts +3 -0
  448. package/dist/components/cg-switch/cg-switch.d.ts.map +1 -1
  449. package/dist/components/cg-switch/cg-switch.js +39 -47
  450. package/dist/components/cg-switch/cg-switch.js.map +1 -1
  451. package/dist/components/cg-table/cg-table.d.ts +0 -7
  452. package/dist/components/cg-table/cg-table.d.ts.map +1 -1
  453. package/dist/components/cg-table/cg-table.js +50 -47
  454. package/dist/components/cg-table/cg-table.js.map +1 -1
  455. package/dist/components/cg-tabs/cg-tabs.js +1 -1
  456. package/dist/components/cg-tag-input/cg-tag-input.js +1 -1
  457. package/dist/components/cg-text/cg-text.js +1 -1
  458. package/dist/components/cg-textarea/cg-textarea.js +1 -1
  459. package/dist/components/cg-time-picker/cg-time-picker.js +1 -1
  460. package/dist/components/cg-toaster/cg-toaster.js +3 -3
  461. package/dist/components/cg-toaster/cg-toaster.js.map +1 -1
  462. package/dist/components/cg-toggle/cg-toggle.js +1 -1
  463. package/dist/components/cg-toggle-group/cg-toggle-group.js +1 -1
  464. package/dist/components/cg-tree-view/cg-tree-view.js +1 -1
  465. package/dist/foundation.d.ts +0 -16
  466. package/dist/foundation.d.ts.map +1 -1
  467. package/dist/foundation.js +174 -206
  468. package/dist/foundation.js.map +1 -1
  469. package/dist/index.d.ts +1 -17
  470. package/dist/index.d.ts.map +1 -1
  471. package/dist/index.js +100 -132
  472. package/dist/index.js.map +1 -1
  473. package/dist/utils/focus-trap.d.ts +19 -2
  474. package/dist/utils/focus-trap.d.ts.map +1 -1
  475. package/package.json +6 -810
  476. package/dist/chunks/focus-trap-BdRNhSPD.js +0 -53
  477. package/dist/chunks/focus-trap-BdRNhSPD.js.map +0 -1
  478. package/dist/components/cg-app-shell/cg-app-shell.d.ts +0 -54
  479. package/dist/components/cg-app-shell/cg-app-shell.d.ts.map +0 -1
  480. package/dist/components/cg-app-shell/cg-app-shell.js +0 -135
  481. package/dist/components/cg-app-shell/cg-app-shell.js.map +0 -1
  482. package/dist/components/cg-auth-shell/cg-auth-shell.d.ts +0 -61
  483. package/dist/components/cg-auth-shell/cg-auth-shell.d.ts.map +0 -1
  484. package/dist/components/cg-auth-shell/cg-auth-shell.js +0 -163
  485. package/dist/components/cg-auth-shell/cg-auth-shell.js.map +0 -1
  486. package/dist/components/cg-definition-list/cg-definition-list.d.ts +0 -99
  487. package/dist/components/cg-definition-list/cg-definition-list.d.ts.map +0 -1
  488. package/dist/components/cg-definition-list/cg-definition-list.js +0 -332
  489. package/dist/components/cg-definition-list/cg-definition-list.js.map +0 -1
  490. package/dist/components/cg-draggable/cg-draggable.d.ts +0 -53
  491. package/dist/components/cg-draggable/cg-draggable.d.ts.map +0 -1
  492. package/dist/components/cg-draggable/cg-draggable.js +0 -136
  493. package/dist/components/cg-draggable/cg-draggable.js.map +0 -1
  494. package/dist/components/cg-droppable/cg-droppable.d.ts +0 -57
  495. package/dist/components/cg-droppable/cg-droppable.d.ts.map +0 -1
  496. package/dist/components/cg-droppable/cg-droppable.js +0 -114
  497. package/dist/components/cg-droppable/cg-droppable.js.map +0 -1
  498. package/dist/components/cg-filter-bar/cg-filter-bar.d.ts +0 -50
  499. package/dist/components/cg-filter-bar/cg-filter-bar.d.ts.map +0 -1
  500. package/dist/components/cg-filter-bar/cg-filter-bar.js +0 -115
  501. package/dist/components/cg-filter-bar/cg-filter-bar.js.map +0 -1
  502. package/dist/components/cg-filter-chip/cg-filter-chip.d.ts +0 -55
  503. package/dist/components/cg-filter-chip/cg-filter-chip.d.ts.map +0 -1
  504. package/dist/components/cg-filter-chip/cg-filter-chip.js +0 -213
  505. package/dist/components/cg-filter-chip/cg-filter-chip.js.map +0 -1
  506. package/dist/components/cg-kanban/cg-kanban.d.ts +0 -44
  507. package/dist/components/cg-kanban/cg-kanban.d.ts.map +0 -1
  508. package/dist/components/cg-kanban/cg-kanban.js +0 -86
  509. package/dist/components/cg-kanban/cg-kanban.js.map +0 -1
  510. package/dist/components/cg-kanban-column/cg-kanban-column.d.ts +0 -58
  511. package/dist/components/cg-kanban-column/cg-kanban-column.d.ts.map +0 -1
  512. package/dist/components/cg-kanban-column/cg-kanban-column.js +0 -144
  513. package/dist/components/cg-kanban-column/cg-kanban-column.js.map +0 -1
  514. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.d.ts +0 -77
  515. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.d.ts.map +0 -1
  516. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.js +0 -245
  517. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.js.map +0 -1
  518. package/dist/components/cg-search-input/cg-search-input.d.ts +0 -62
  519. package/dist/components/cg-search-input/cg-search-input.d.ts.map +0 -1
  520. package/dist/components/cg-search-input/cg-search-input.js +0 -106
  521. package/dist/components/cg-search-input/cg-search-input.js.map +0 -1
  522. package/dist/components/cg-sortable/cg-sortable.d.ts +0 -72
  523. package/dist/components/cg-sortable/cg-sortable.d.ts.map +0 -1
  524. package/dist/components/cg-sortable/cg-sortable.js +0 -177
  525. package/dist/components/cg-sortable/cg-sortable.js.map +0 -1
  526. package/dist/components/cg-theme/cg-theme.d.ts +0 -82
  527. package/dist/components/cg-theme/cg-theme.d.ts.map +0 -1
  528. package/dist/components/cg-theme/cg-theme.js +0 -91
  529. package/dist/components/cg-theme/cg-theme.js.map +0 -1
  530. package/dist/components/cg-theme-editor/cg-theme-editor.d.ts +0 -98
  531. package/dist/components/cg-theme-editor/cg-theme-editor.d.ts.map +0 -1
  532. package/dist/components/cg-theme-editor/cg-theme-editor.js +0 -341
  533. package/dist/components/cg-theme-editor/cg-theme-editor.js.map +0 -1
  534. package/dist/components/cg-timeline/cg-timeline.d.ts +0 -70
  535. package/dist/components/cg-timeline/cg-timeline.d.ts.map +0 -1
  536. package/dist/components/cg-timeline/cg-timeline.js +0 -131
  537. package/dist/components/cg-timeline/cg-timeline.js.map +0 -1
  538. package/dist/components/cg-timeline-event/cg-timeline-event.d.ts +0 -59
  539. package/dist/components/cg-timeline-event/cg-timeline-event.d.ts.map +0 -1
  540. package/dist/components/cg-timeline-event/cg-timeline-event.js +0 -190
  541. package/dist/components/cg-timeline-event/cg-timeline-event.js.map +0 -1
  542. package/dist/utils/drag-manager.d.ts +0 -40
  543. package/dist/utils/drag-manager.d.ts.map +0 -1
@@ -1,10 +1,10 @@
1
- import { css as N, LitElement as I, nothing as v, svg as x, html as b } from "lit";
2
- import { property as _, state as z, customElement as E } from "lit/decorators.js";
3
- import { h as W, r as Y } from "../../chunks/premium.css-9I4kHrsl.js";
4
- var q = Object.defineProperty, C = Object.getOwnPropertyDescriptor, f = (t, a, r, s) => {
5
- for (var e = s > 1 ? void 0 : s ? C(a, r) : a, n = t.length - 1, o; n >= 0; n--)
1
+ import { css as N, LitElement as I, nothing as v, svg as f, html as _ } from "lit";
2
+ import { property as b, state as z, customElement as C } from "lit/decorators.js";
3
+ import { h as E, r as W } from "../../chunks/premium.css-DHekUEUt.js";
4
+ var Y = Object.defineProperty, q = Object.getOwnPropertyDescriptor, x = (t, a, r, s) => {
5
+ for (var e = s > 1 ? void 0 : s ? q(a, r) : a, n = t.length - 1, o; n >= 0; n--)
6
6
  (o = t[n]) && (e = (s ? o(a, r, e) : o(e)) || e);
7
- return s && e && q(a, r, e), e;
7
+ return s && e && Y(a, r, e), e;
8
8
  };
9
9
  const P = [
10
10
  "#dfff61",
@@ -23,7 +23,7 @@ let u = class extends I {
23
23
  _resolve() {
24
24
  if (this._resolved) return;
25
25
  const t = getComputedStyle(this);
26
- this._grid = t.getPropertyValue("--cg-color-chart-grid").trim() || t.getPropertyValue("--cg-color-border-default").trim(), this._axis = t.getPropertyValue("--cg-color-chart-axis").trim() || t.getPropertyValue("--cg-color-text-muted").trim(), this._text = t.getPropertyValue("--cg-color-surface-base-text").trim() || t.getPropertyValue("--cg-color-text-default").trim(), this._bg = t.getPropertyValue("--cg-color-surface-container-background").trim() || t.getPropertyValue("--cg-color-surface-base").trim();
26
+ this._grid = t.getPropertyValue("--cg-color-chart-grid").trim() || t.getPropertyValue("--cg-color-surface-cards-border").trim(), this._axis = t.getPropertyValue("--cg-color-chart-axis").trim() || t.getPropertyValue("--cg-color-input-text-placeholder").trim(), this._text = t.getPropertyValue("--cg-color-surface-base-text").trim() || t.getPropertyValue("--cg-color-surface-base-text").trim(), this._bg = t.getPropertyValue("--cg-color-surface-container-background").trim() || t.getPropertyValue("--cg-color-surface-base-background").trim();
27
27
  for (let a = 0; a < 8; a++) {
28
28
  const r = t.getPropertyValue(`--cg-color-chart-${a + 1}`).trim();
29
29
  r && (P[a] = r);
@@ -84,22 +84,22 @@ let u = class extends I {
84
84
  // ═══ BAR ═══
85
85
  _bar() {
86
86
  const { data: t, height: a } = this, r = 400, s = 20, e = 16, n = 28, o = 44, l = r - o - e, m = a - s - n, i = Math.max(...t.map((h) => h.value), 1), c = t.length, p = l / c * 0.6, $ = l / c;
87
- return x`
87
+ return f`
88
88
  ${this.showGrid ? [0.25, 0.5, 0.75, 1].map((h) => {
89
89
  const y = s + m - m * h;
90
- return x`
90
+ return f`
91
91
  <line x1="${o}" y1="${y}" x2="${r - e}" y2="${y}" stroke="${this._grid}" stroke-width="0.5" stroke-dasharray="3,3" />
92
92
  <text x="${o - 6}" y="${y + 4}" text-anchor="end" fill="${this._axis}" font-size="10">${this._fmt(i * h)}</text>
93
93
  `;
94
94
  }) : v}
95
95
  ${t.map((h, y) => {
96
96
  const g = h.value / i * m, d = o + y * $ + ($ - p) / 2, w = s + m - g, F = s + m, k = this._color(y, h);
97
- return x`
97
+ return f`
98
98
  <rect class="bar-anim" x="${d}" y="${F}" width="${p}" height="0" rx="4" fill="${k}" style="cursor:pointer"
99
99
  data-y="${w}" data-h="${g}" data-delay="${y * 50}"
100
100
  @mouseenter=${(M) => this._tip(M, h.label, h.value)}
101
101
  @mouseleave=${this._untip} />
102
- ${this.showValues ? x`<text class="val-anim" x="${d + p / 2}" y="${w - 6}" text-anchor="middle" fill="${this._text}" font-size="10" font-weight="600" opacity="0" data-delay="${y * 50 + 300}">${this._fmt(h.value)}</text>` : v}
102
+ ${this.showValues ? f`<text class="val-anim" x="${d + p / 2}" y="${w - 6}" text-anchor="middle" fill="${this._text}" font-size="10" font-weight="600" opacity="0" data-delay="${y * 50 + 300}">${this._fmt(h.value)}</text>` : v}
103
103
  <text x="${d + p / 2}" y="${a - 6}" text-anchor="middle" fill="${this._axis}" font-size="10">${h.label}</text>
104
104
  `;
105
105
  })}
@@ -110,10 +110,10 @@ let u = class extends I {
110
110
  const { data: t } = this, a = 400, r = 72, s = 8, e = 28;
111
111
  t.length * (e + s);
112
112
  const n = Math.max(...t.map((o) => o.value), 1);
113
- return x`
113
+ return f`
114
114
  ${t.map((o, l) => {
115
115
  const m = l * (e + s), i = o.value / n * (a - r - 60), c = this._color(l, o);
116
- return x`
116
+ return f`
117
117
  <text x="${r - 6}" y="${m + e / 2 + 4}" text-anchor="end" fill="${this._axis}" font-size="11">${o.label}</text>
118
118
  <rect class="hbar-anim" x="${r}" y="${m}" width="0" height="${e}" rx="4" fill="${c}" style="cursor:pointer"
119
119
  data-w="${i}" data-delay="${l * 50}"
@@ -130,22 +130,22 @@ let u = class extends I {
130
130
  x: l + d / Math.max(a.length - 1, 1) * m,
131
131
  y: e + i - g.value / c * i
132
132
  })), h = $.map((g, d) => `${d ? "L" : "M"}${g.x.toFixed(1)},${g.y.toFixed(1)}`).join(" "), y = `${h} L${$.at(-1).x.toFixed(1)},${(e + i).toFixed(1)} L${$[0].x.toFixed(1)},${(e + i).toFixed(1)} Z`;
133
- return x`
133
+ return f`
134
134
  ${this.showGrid ? [0.25, 0.5, 0.75, 1].map((g) => {
135
135
  const d = e + i - i * g;
136
- return x`
136
+ return f`
137
137
  <line x1="${l}" y1="${d}" x2="${s - n}" y2="${d}" stroke="${this._grid}" stroke-width="0.5" stroke-dasharray="3,3" />
138
138
  <text x="${l - 6}" y="${d + 4}" text-anchor="end" fill="${this._axis}" font-size="10">${this._fmt(c * g)}</text>
139
139
  `;
140
140
  }) : v}
141
- ${t ? x`<path d="${y}" fill="${p}" opacity="0.2" />` : v}
141
+ ${t ? f`<path d="${y}" fill="${p}" opacity="0.2" />` : v}
142
142
  <path class="anim-line" d="${h}" fill="none" stroke="${p}" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round" style="--dash:2000" />
143
- ${$.map((g, d) => x`
143
+ ${$.map((g, d) => f`
144
144
  <circle class="anim-dot" cx="${g.x}" cy="${g.y}" r="4" fill="${p}" stroke="${this._bg}" stroke-width="2" style="cursor:pointer; animation-delay:${400 + d * 50}ms"
145
145
  @mouseenter=${(w) => this._tip(w, a[d].label, a[d].value)}
146
146
  @mouseleave=${this._untip} />
147
147
  `)}
148
- ${a.map((g, d) => x`
148
+ ${a.map((g, d) => f`
149
149
  <text x="${$[d].x}" y="${r - 6}" text-anchor="middle" fill="${this._axis}" font-size="10">${g.label}</text>
150
150
  `)}
151
151
  `;
@@ -156,16 +156,16 @@ let u = class extends I {
156
156
  let m = -90;
157
157
  const i = a.map((c, p) => {
158
158
  const $ = c.value / r * 360, h = m + $, y = $ > 180 ? 1 : 0, g = n + e * Math.cos(l(m)), d = o + e * Math.sin(l(m)), w = n + e * Math.cos(l(h)), F = o + e * Math.sin(l(h)), k = m + $ / 2, M = e * (t ? 1.2 : 0.6), A = n + M * Math.cos(l(k)), S = o + M * Math.sin(l(k)), T = Math.round(c.value / r * 100), B = this._color(p, c), L = `M${n},${o} L${g.toFixed(1)},${d.toFixed(1)} A${e},${e} 0 ${y} 1 ${w.toFixed(1)},${F.toFixed(1)} Z`;
159
- return m = h, x`
159
+ return m = h, f`
160
160
  <path class="anim-slice" d="${L}" fill="${B}" style="cursor:pointer; animation-delay:${p * 60}ms"
161
161
  @mouseenter=${(V) => this._tip(V, c.label, c.value)}
162
162
  @mouseleave=${this._untip} />
163
- ${T >= 5 ? x`<text x="${A}" y="${S}" text-anchor="middle" dominant-baseline="central" fill="${t ? this._axis : this._text}" font-size="10" font-weight="600">${T}%</text>` : v}
163
+ ${T >= 5 ? f`<text x="${A}" y="${S}" text-anchor="middle" dominant-baseline="central" fill="${t ? this._axis : this._text}" font-size="10" font-weight="600">${T}%</text>` : v}
164
164
  `;
165
165
  });
166
- return x`
166
+ return f`
167
167
  ${i}
168
- ${t ? x`
168
+ ${t ? f`
169
169
  <circle cx="${n}" cy="${o}" r="${e * 0.55}" fill="${this._bg}" />
170
170
  <text x="${n}" y="${o - 4}" text-anchor="middle" fill="${this._text}" font-size="16" font-weight="700">${this._fmt(r)}</text>
171
171
  <text x="${n}" y="${o + 12}" text-anchor="middle" fill="${this._axis}" font-size="9">Total</text>
@@ -179,7 +179,7 @@ let u = class extends I {
179
179
  return this.type === "pie" || this.type === "donut" ? Math.min(this.height, 240) : 400;
180
180
  }
181
181
  render() {
182
- if (!this.data.length) return b`<div class="wrap ${this.contained ? "contained" : ""}"><div class="empty">${this.emptyText}</div></div>`;
182
+ if (!this.data.length) return _`<div class="wrap ${this.contained ? "contained" : ""}"><div class="empty">${this.emptyText}</div></div>`;
183
183
  const t = this._svgWidth(), a = this._svgHeight(), r = this.type === "pie" || this.type === "donut";
184
184
  let s;
185
185
  switch (this.type) {
@@ -202,17 +202,22 @@ let u = class extends I {
202
202
  s = this._pie(!0);
203
203
  break;
204
204
  }
205
- return b`
205
+ return _`
206
206
  <div class="wrap ${this.contained ? "contained" : ""}">
207
- ${this.title || this.subtitle ? b`
207
+ ${this.title || this.subtitle ? _`
208
208
  <div class="header">
209
- ${this.title ? b`<div class="title">${this.title}</div>` : v}
210
- ${this.subtitle ? b`<div class="subtitle">${this.subtitle}</div>` : v}
209
+ ${this.title ? _`<div class="title">${this.title}</div>` : v}
210
+ ${this.subtitle ? _`<div class="subtitle">${this.subtitle}</div>` : v}
211
211
  </div>
212
212
  ` : v}
213
213
 
214
214
  <div class="svg-wrap">
215
- <svg viewBox="0 0 ${t} ${a}" style="${r ? `max-width:${t}px; margin:0 auto;` : ""}">
215
+ <svg
216
+ role="img"
217
+ aria-label=${`${this.title || "Chart"}: ${this.data.map((e) => `${e.label} ${this._fmt(e.value)}`).join(", ")}`}
218
+ viewBox="0 0 ${t} ${a}"
219
+ style="${r ? `max-width:${t}px; margin:0 auto;` : ""}"
220
+ >
216
221
  ${s}
217
222
  </svg>
218
223
  <div class="tip ${this._tipShow ? "show" : ""}" style="left:${this._tipX}px;top:${this._tipY}px;">
@@ -220,9 +225,9 @@ let u = class extends I {
220
225
  </div>
221
226
  </div>
222
227
 
223
- ${this.showLegend ? b`
228
+ ${this.showLegend ? _`
224
229
  <div class="legend">
225
- ${this.data.map((e, n) => b`
230
+ ${this.data.map((e, n) => _`
226
231
  <span class="legend-item anim-legend" style="animation-delay:${300 + n * 40}ms">
227
232
  <span class="legend-dot" style="background:${this._color(n, e)}"></span>
228
233
  <span>${e.label}</span>
@@ -235,7 +240,7 @@ let u = class extends I {
235
240
  `;
236
241
  }
237
242
  };
238
- u.styles = [W, Y, N`
243
+ u.styles = [E, W, N`
239
244
  :host { display: block; }
240
245
 
241
246
  .wrap { position: relative; }
@@ -299,7 +304,7 @@ u.styles = [W, Y, N`
299
304
  pointer-events: none;
300
305
  white-space: nowrap;
301
306
  transform: translate(-50%, -100%);
302
- margin-top: -8px;
307
+ margin-top: calc(var(--cg-spacing-8) * -1);
303
308
  z-index: 10;
304
309
  display: none;
305
310
  }
@@ -330,50 +335,50 @@ u.styles = [W, Y, N`
330
335
  font-size: var(--cg-font-size-sm); min-height: 120px;
331
336
  }
332
337
  `];
333
- f([
334
- _({ type: Array })
338
+ x([
339
+ b({ type: Array })
335
340
  ], u.prototype, "data", 2);
336
- f([
337
- _()
341
+ x([
342
+ b()
338
343
  ], u.prototype, "type", 2);
339
- f([
340
- _()
344
+ x([
345
+ b()
341
346
  ], u.prototype, "title", 2);
342
- f([
343
- _()
347
+ x([
348
+ b()
344
349
  ], u.prototype, "subtitle", 2);
345
- f([
346
- _({ type: Number })
350
+ x([
351
+ b({ type: Number })
347
352
  ], u.prototype, "height", 2);
348
- f([
349
- _({ type: Boolean })
353
+ x([
354
+ b({ type: Boolean })
350
355
  ], u.prototype, "showLegend", 2);
351
- f([
352
- _({ type: Boolean })
356
+ x([
357
+ b({ type: Boolean })
353
358
  ], u.prototype, "showValues", 2);
354
- f([
355
- _({ type: Boolean })
359
+ x([
360
+ b({ type: Boolean })
356
361
  ], u.prototype, "contained", 2);
357
- f([
358
- _({ type: Boolean })
362
+ x([
363
+ b({ type: Boolean })
359
364
  ], u.prototype, "showGrid", 2);
360
- f([
361
- _()
365
+ x([
366
+ b()
362
367
  ], u.prototype, "emptyText", 2);
363
- f([
368
+ x([
364
369
  z()
365
370
  ], u.prototype, "_tipX", 2);
366
- f([
371
+ x([
367
372
  z()
368
373
  ], u.prototype, "_tipY", 2);
369
- f([
374
+ x([
370
375
  z()
371
376
  ], u.prototype, "_tipText", 2);
372
- f([
377
+ x([
373
378
  z()
374
379
  ], u.prototype, "_tipShow", 2);
375
- u = f([
376
- E("cg-chart")
380
+ u = x([
381
+ C("cg-chart")
377
382
  ], u);
378
383
  export {
379
384
  u as CgChart
@@ -1 +1 @@
1
- {"version":3,"file":"cg-chart.js","sources":["../../../src/components/cg-chart/cg-chart.ts"],"sourcesContent":["import { LitElement, html, css, nothing, svg } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/** Data point for cg-chart */\nexport interface ChartSeries {\n label: string;\n value: number;\n color?: string;\n}\n\n/** Default palette — hex colors that work directly in SVG fill/stroke attributes */\nconst PALETTE = [\n '#dfff61', '#14b8a6', '#22c55e', '#f59e0b',\n '#f97316', '#ec4899', '#8b5cf6', '#ef4444',\n];\n\n@customElement('cg-chart')\nexport class CgChart extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host { display: block; }\n\n .wrap { position: relative; }\n .wrap.contained {\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-component-card-radius);\n padding: var(--cg-spacing-20);\n }\n\n .header { margin-bottom: var(--cg-spacing-12); }\n .title {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n .subtitle {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n margin-top: var(--cg-spacing-2);\n }\n\n .svg-wrap { position: relative; }\n svg { display: block; width: 100%; }\n\n /* ── Entrance animations ── */\n @keyframes fadeIn {\n from { opacity: 0; }\n to { opacity: 1; }\n }\n @keyframes lineTrace {\n from { stroke-dashoffset: var(--dash); }\n to { stroke-dashoffset: 0; }\n }\n\n .anim-line {\n stroke-dasharray: var(--dash);\n stroke-dashoffset: var(--dash);\n animation: lineTrace 900ms var(--cg-transition-easing-ease-out) forwards;\n }\n .anim-dot {\n animation: fadeIn 200ms var(--cg-transition-easing-ease-out) both;\n }\n .anim-slice {\n animation: fadeIn 400ms var(--cg-transition-easing-ease-out) both;\n }\n .anim-legend {\n animation: fadeIn 200ms var(--cg-transition-easing-ease-out) both;\n }\n\n /* Tooltip */\n .tip {\n position: absolute;\n background: var(--cg-color-surface-container-background);\n color: var(--cg-color-surface-base-text);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n padding: var(--cg-spacing-4) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-50);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-medium);\n pointer-events: none;\n white-space: nowrap;\n transform: translate(-50%, -100%);\n margin-top: -8px;\n z-index: 10;\n display: none;\n }\n .tip.show { display: block; }\n\n /* Legend */\n .legend {\n display: flex; flex-wrap: wrap; gap: var(--cg-spacing-12);\n margin-top: var(--cg-spacing-16); padding-top: var(--cg-spacing-12);\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n .legend-item {\n display: inline-flex; align-items: center; gap: var(--cg-spacing-4);\n font-size: var(--cg-font-size-xs); color: var(--cg-color-input-text-placeholder);\n }\n .legend-dot {\n width: var(--cg-spacing-8); height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full); flex-shrink: 0;\n }\n .legend-val {\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n\n .empty {\n display: flex; align-items: center; justify-content: center;\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-sm); min-height: 120px;\n }\n `];\n\n @property({ type: Array }) data: ChartSeries[] = [];\n @property() type: 'bar' | 'horizontal-bar' | 'line' | 'area' | 'pie' | 'donut' = 'bar';\n @property() override title = '';\n @property() subtitle = '';\n @property({ type: Number }) height = 200;\n @property({ type: Boolean }) showLegend = true;\n @property({ type: Boolean }) showValues = true;\n /** Wrap chart in a card container */\n @property({ type: Boolean }) contained = false;\n @property({ type: Boolean }) showGrid = true;\n @property() emptyText = 'No data';\n\n @state() private _tipX = 0;\n @state() private _tipY = 0;\n @state() private _tipText = '';\n @state() private _tipShow = false;\n\n // Resolved theme colors for SVG — pulled from CSS custom properties at runtime\n private _grid = '';\n private _axis = '';\n private _text = '';\n private _bg = '';\n private _resolved = false;\n\n private _resolve() {\n if (this._resolved) return;\n const s = getComputedStyle(this);\n this._grid = s.getPropertyValue('--cg-color-chart-grid').trim() || s.getPropertyValue('--cg-color-border-default').trim();\n this._axis = s.getPropertyValue('--cg-color-chart-axis').trim() || s.getPropertyValue('--cg-color-text-muted').trim();\n this._text = s.getPropertyValue('--cg-color-surface-base-text').trim() || s.getPropertyValue('--cg-color-text-default').trim();\n this._bg = s.getPropertyValue('--cg-color-surface-container-background').trim() || s.getPropertyValue('--cg-color-surface-base').trim();\n for (let i = 0; i < 8; i++) {\n const v = s.getPropertyValue(`--cg-color-chart-${i + 1}`).trim();\n if (v) PALETTE[i] = v;\n }\n this._resolved = true;\n }\n\n override firstUpdated() {\n this._resolve();\n this.requestUpdate();\n }\n\n private _animId = 0;\n private _animated = false;\n\n override updated(changed: Map<string, unknown>) {\n if (!this._animated && this.data.length > 0) {\n this._animated = true;\n this._animateBars();\n }\n if (changed.has('data') || changed.has('type')) {\n this._animated = false;\n cancelAnimationFrame(this._animId);\n // Re-animate on next frame after render\n requestAnimationFrame(() => {\n this._animated = true;\n this._animateBars();\n });\n }\n }\n\n private _easeOut(t: number) { return 1 - (1 - t) * (1 - t); }\n\n private _animateBars() {\n const bars = this.shadowRoot?.querySelectorAll<SVGRectElement>('.bar-anim');\n const hbars = this.shadowRoot?.querySelectorAll<SVGRectElement>('.hbar-anim');\n const vals = this.shadowRoot?.querySelectorAll<SVGElement>('.val-anim');\n if (!bars?.length && !hbars?.length) return;\n\n const dur = 500;\n const start = performance.now();\n\n const tick = (now: number) => {\n const elapsed = now - start;\n\n bars?.forEach(rect => {\n const delay = Number(rect.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / dur));\n const p = this._easeOut(t);\n const targetH = Number(rect.dataset.h);\n const targetY = Number(rect.dataset.y);\n const baseY = targetY + targetH;\n const h = targetH * p;\n rect.setAttribute('height', String(h));\n rect.setAttribute('y', String(baseY - h));\n });\n\n hbars?.forEach(rect => {\n const delay = Number(rect.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / dur));\n const p = this._easeOut(t);\n const targetW = Number(rect.dataset.w);\n rect.setAttribute('width', String(targetW * p));\n });\n\n vals?.forEach(el => {\n const delay = Number(el.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / 200));\n el.setAttribute('opacity', String(t));\n });\n\n const maxDelay = Math.max(\n ...[...bars || []].map(r => Number(r.dataset.delay) || 0),\n ...[...hbars || []].map(r => Number(r.dataset.delay) || 0),\n ...[...vals || []].map(r => Number(r.dataset.delay) || 0),\n );\n if (elapsed < maxDelay + dur + 200) {\n this._animId = requestAnimationFrame(tick);\n }\n };\n\n this._animId = requestAnimationFrame(tick);\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n cancelAnimationFrame(this._animId);\n }\n\n private _color(i: number, d: ChartSeries) { return d.color || PALETTE[i % PALETTE.length]!; }\n\n private _fmt(v: number) {\n if (Math.abs(v) >= 1e6) return (v / 1e6).toFixed(1) + 'M';\n if (Math.abs(v) >= 1e3) return (v / 1e3).toFixed(1) + 'K';\n return v % 1 === 0 ? String(v) : v.toFixed(1);\n }\n\n private _tip(e: MouseEvent, label: string, value: number) {\n const r = (e.currentTarget as Element).closest('.svg-wrap')!.getBoundingClientRect();\n this._tipX = e.clientX - r.left;\n this._tipY = e.clientY - r.top;\n this._tipText = `${label}: ${this._fmt(value)}`;\n this._tipShow = true;\n }\n private _untip() { this._tipShow = false; }\n\n // ═══ BAR ═══\n private _bar() {\n const { data, height: H } = this;\n const W = 400, T = 20, R = 16, B = 28, L = 44;\n const pw = W - L - R, ph = H - T - B;\n const max = Math.max(...data.map(d => d.value), 1);\n const n = data.length;\n const bw = (pw / n) * 0.6;\n const step = pw / n;\n\n return svg`\n ${this.showGrid ? [0.25, 0.5, 0.75, 1].map(p => {\n const y = T + ph - ph * p;\n return svg`\n <line x1=\"${L}\" y1=\"${y}\" x2=\"${W - R}\" y2=\"${y}\" stroke=\"${this._grid}\" stroke-width=\"0.5\" stroke-dasharray=\"3,3\" />\n <text x=\"${L - 6}\" y=\"${y + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"10\">${this._fmt(max * p)}</text>\n `;\n }) : nothing}\n ${data.map((d, i) => {\n const bh = (d.value / max) * ph;\n const x = L + i * step + (step - bw) / 2;\n const yFinal = T + ph - bh;\n const yBase = T + ph;\n const c = this._color(i, d);\n return svg`\n <rect class=\"bar-anim\" x=\"${x}\" y=\"${yBase}\" width=\"${bw}\" height=\"0\" rx=\"4\" fill=\"${c}\" style=\"cursor:pointer\"\n data-y=\"${yFinal}\" data-h=\"${bh}\" data-delay=\"${i * 50}\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n ${this.showValues ? svg`<text class=\"val-anim\" x=\"${x + bw / 2}\" y=\"${yFinal - 6}\" text-anchor=\"middle\" fill=\"${this._text}\" font-size=\"10\" font-weight=\"600\" opacity=\"0\" data-delay=\"${i * 50 + 300}\">${this._fmt(d.value)}</text>` : nothing}\n <text x=\"${x + bw / 2}\" y=\"${H - 6}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"10\">${d.label}</text>\n `;\n })}\n `;\n }\n\n // ═══ HORIZONTAL BAR ═══\n private _hbar() {\n const { data } = this;\n const W = 400, lW = 72, gap = 8, bH = 28;\n const H = data.length * (bH + gap);\n const max = Math.max(...data.map(d => d.value), 1);\n\n return svg`\n ${data.map((d, i) => {\n const y = i * (bH + gap);\n const bW = (d.value / max) * (W - lW - 60);\n const c = this._color(i, d);\n return svg`\n <text x=\"${lW - 6}\" y=\"${y + bH / 2 + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"11\">${d.label}</text>\n <rect class=\"hbar-anim\" x=\"${lW}\" y=\"${y}\" width=\"0\" height=\"${bH}\" rx=\"4\" fill=\"${c}\" style=\"cursor:pointer\"\n data-w=\"${bW}\" data-delay=\"${i * 50}\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n <text class=\"val-anim\" x=\"${lW + bW + 8}\" y=\"${y + bH / 2 + 4}\" fill=\"${this._text}\" font-size=\"11\" font-weight=\"600\" opacity=\"0\" data-delay=\"${i * 50 + 300}\">${this._fmt(d.value)}</text>\n `;\n })}\n `;\n }\n\n // ═══ LINE / AREA ═══\n private _line(area: boolean) {\n const { data, height: H } = this;\n const W = 400, T = 12, R = 16, B = 28, L = 44;\n const pw = W - L - R, ph = H - T - B;\n const max = Math.max(...data.map(d => d.value), 1);\n const c = this._color(0, data[0]!);\n\n const pts = data.map((d, i) => ({\n x: L + (i / Math.max(data.length - 1, 1)) * pw,\n y: T + ph - (d.value / max) * ph,\n }));\n const line = pts.map((p, i) => `${i ? 'L' : 'M'}${p.x.toFixed(1)},${p.y.toFixed(1)}`).join(' ');\n const areaD = `${line} L${pts.at(-1)!.x.toFixed(1)},${(T + ph).toFixed(1)} L${pts[0]!.x.toFixed(1)},${(T + ph).toFixed(1)} Z`;\n\n return svg`\n ${this.showGrid ? [0.25, 0.5, 0.75, 1].map(p => {\n const y = T + ph - ph * p;\n return svg`\n <line x1=\"${L}\" y1=\"${y}\" x2=\"${W - R}\" y2=\"${y}\" stroke=\"${this._grid}\" stroke-width=\"0.5\" stroke-dasharray=\"3,3\" />\n <text x=\"${L - 6}\" y=\"${y + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"10\">${this._fmt(max * p)}</text>\n `;\n }) : nothing}\n ${area ? svg`<path d=\"${areaD}\" fill=\"${c}\" opacity=\"0.2\" />` : nothing}\n <path class=\"anim-line\" d=\"${line}\" fill=\"none\" stroke=\"${c}\" stroke-width=\"2.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" style=\"--dash:2000\" />\n ${pts.map((p, i) => svg`\n <circle class=\"anim-dot\" cx=\"${p.x}\" cy=\"${p.y}\" r=\"4\" fill=\"${c}\" stroke=\"${this._bg}\" stroke-width=\"2\" style=\"cursor:pointer; animation-delay:${400 + i * 50}ms\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, data[i]!.label, data[i]!.value)}\n @mouseleave=${this._untip} />\n `)}\n ${data.map((d, i) => svg`\n <text x=\"${pts[i]!.x}\" y=\"${H - 6}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"10\">${d.label}</text>\n `)}\n `;\n }\n\n // ═══ PIE / DONUT ═══\n private _pie(donut: boolean) {\n const { data } = this;\n const total = data.reduce((s, d) => s + d.value, 0) || 1;\n const sz = Math.min(this.height, 240);\n const r = sz * 0.4;\n const cx = sz / 2, cy = sz / 2;\n const rad = (a: number) => a * Math.PI / 180;\n let ang = -90;\n\n const slices = data.map((d, i) => {\n const sw = (d.value / total) * 360;\n const end = ang + sw;\n const lg = sw > 180 ? 1 : 0;\n const x1 = cx + r * Math.cos(rad(ang));\n const y1 = cy + r * Math.sin(rad(ang));\n const x2 = cx + r * Math.cos(rad(end));\n const y2 = cy + r * Math.sin(rad(end));\n const mid = ang + sw / 2;\n const lr = r * (donut ? 1.2 : 0.6);\n const lx = cx + lr * Math.cos(rad(mid));\n const ly = cy + lr * Math.sin(rad(mid));\n const pct = Math.round((d.value / total) * 100);\n const c = this._color(i, d);\n const p = `M${cx},${cy} L${x1.toFixed(1)},${y1.toFixed(1)} A${r},${r} 0 ${lg} 1 ${x2.toFixed(1)},${y2.toFixed(1)} Z`;\n ang = end;\n\n return svg`\n <path class=\"anim-slice\" d=\"${p}\" fill=\"${c}\" style=\"cursor:pointer; animation-delay:${i * 60}ms\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n ${pct >= 5 ? svg`<text x=\"${lx}\" y=\"${ly}\" text-anchor=\"middle\" dominant-baseline=\"central\" fill=\"${donut ? this._axis : this._text}\" font-size=\"10\" font-weight=\"600\">${pct}%</text>` : nothing}\n `;\n });\n\n return svg`\n ${slices}\n ${donut ? svg`\n <circle cx=\"${cx}\" cy=\"${cy}\" r=\"${r * 0.55}\" fill=\"${this._bg}\" />\n <text x=\"${cx}\" y=\"${cy - 4}\" text-anchor=\"middle\" fill=\"${this._text}\" font-size=\"16\" font-weight=\"700\">${this._fmt(total)}</text>\n <text x=\"${cx}\" y=\"${cy + 12}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"9\">Total</text>\n ` : nothing}\n `;\n }\n\n private _svgHeight() {\n if (this.type === 'horizontal-bar') return this.data.length * 36;\n if (this.type === 'pie' || this.type === 'donut') return Math.min(this.height, 240);\n return this.height;\n }\n\n private _svgWidth() {\n if (this.type === 'pie' || this.type === 'donut') return Math.min(this.height, 240);\n return 400;\n }\n\n override render() {\n if (!this.data.length) return html`<div class=\"wrap ${this.contained ? 'contained' : ''}\"><div class=\"empty\">${this.emptyText}</div></div>`;\n\n const vw = this._svgWidth();\n const vh = this._svgHeight();\n const isPie = this.type === 'pie' || this.type === 'donut';\n\n let chartSvg;\n switch (this.type) {\n case 'bar': chartSvg = this._bar(); break;\n case 'horizontal-bar': chartSvg = this._hbar(); break;\n case 'line': chartSvg = this._line(false); break;\n case 'area': chartSvg = this._line(true); break;\n case 'pie': chartSvg = this._pie(false); break;\n case 'donut': chartSvg = this._pie(true); break;\n }\n\n return html`\n <div class=\"wrap ${this.contained ? 'contained' : ''}\">\n ${this.title || this.subtitle ? html`\n <div class=\"header\">\n ${this.title ? html`<div class=\"title\">${this.title}</div>` : nothing}\n ${this.subtitle ? html`<div class=\"subtitle\">${this.subtitle}</div>` : nothing}\n </div>\n ` : nothing}\n\n <div class=\"svg-wrap\">\n <svg viewBox=\"0 0 ${vw} ${vh}\" style=\"${isPie ? `max-width:${vw}px; margin:0 auto;` : ''}\">\n ${chartSvg}\n </svg>\n <div class=\"tip ${this._tipShow ? 'show' : ''}\" style=\"left:${this._tipX}px;top:${this._tipY}px;\">\n ${this._tipText}\n </div>\n </div>\n\n ${this.showLegend ? html`\n <div class=\"legend\">\n ${this.data.map((d, i) => html`\n <span class=\"legend-item anim-legend\" style=\"animation-delay:${300 + i * 40}ms\">\n <span class=\"legend-dot\" style=\"background:${this._color(i, d)}\"></span>\n <span>${d.label}</span>\n <span class=\"legend-val\">${this._fmt(d.value)}</span>\n </span>\n `)}\n </div>\n ` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-chart': CgChart; }\n}\n"],"names":["PALETTE","CgChart","LitElement","s","i","v","changed","bars","hbars","vals","dur","start","tick","now","elapsed","rect","delay","t","p","targetH","baseY","h","targetW","el","maxDelay","r","d","e","label","value","data","H","W","T","R","B","L","pw","ph","max","n","bw","step","svg","nothing","bh","x","yFinal","yBase","c","lW","gap","bH","y","bW","area","pts","line","areaD","donut","total","sz","cx","cy","rad","a","ang","slices","sw","end","lg","x1","y1","x2","y2","mid","lr","lx","ly","pct","html","vw","vh","isPie","chartSvg","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"cg-chart.js","sources":["../../../src/components/cg-chart/cg-chart.ts"],"sourcesContent":["import { LitElement, html, css, nothing, svg } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/** Data point for cg-chart */\nexport interface ChartSeries {\n label: string;\n value: number;\n color?: string;\n}\n\n/** Default palette — hex colors that work directly in SVG fill/stroke attributes */\nconst PALETTE = [\n '#dfff61', '#14b8a6', '#22c55e', '#f59e0b',\n '#f97316', '#ec4899', '#8b5cf6', '#ef4444',\n];\n\n@customElement('cg-chart')\nexport class CgChart extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host { display: block; }\n\n .wrap { position: relative; }\n .wrap.contained {\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-component-card-radius);\n padding: var(--cg-spacing-20);\n }\n\n .header { margin-bottom: var(--cg-spacing-12); }\n .title {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n .subtitle {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n margin-top: var(--cg-spacing-2);\n }\n\n .svg-wrap { position: relative; }\n svg { display: block; width: 100%; }\n\n /* ── Entrance animations ── */\n @keyframes fadeIn {\n from { opacity: 0; }\n to { opacity: 1; }\n }\n @keyframes lineTrace {\n from { stroke-dashoffset: var(--dash); }\n to { stroke-dashoffset: 0; }\n }\n\n .anim-line {\n stroke-dasharray: var(--dash);\n stroke-dashoffset: var(--dash);\n animation: lineTrace 900ms var(--cg-transition-easing-ease-out) forwards;\n }\n .anim-dot {\n animation: fadeIn 200ms var(--cg-transition-easing-ease-out) both;\n }\n .anim-slice {\n animation: fadeIn 400ms var(--cg-transition-easing-ease-out) both;\n }\n .anim-legend {\n animation: fadeIn 200ms var(--cg-transition-easing-ease-out) both;\n }\n\n /* Tooltip */\n .tip {\n position: absolute;\n background: var(--cg-color-surface-container-background);\n color: var(--cg-color-surface-base-text);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n padding: var(--cg-spacing-4) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-50);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-medium);\n pointer-events: none;\n white-space: nowrap;\n transform: translate(-50%, -100%);\n margin-top: calc(var(--cg-spacing-8) * -1);\n z-index: 10;\n display: none;\n }\n .tip.show { display: block; }\n\n /* Legend */\n .legend {\n display: flex; flex-wrap: wrap; gap: var(--cg-spacing-12);\n margin-top: var(--cg-spacing-16); padding-top: var(--cg-spacing-12);\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n .legend-item {\n display: inline-flex; align-items: center; gap: var(--cg-spacing-4);\n font-size: var(--cg-font-size-xs); color: var(--cg-color-input-text-placeholder);\n }\n .legend-dot {\n width: var(--cg-spacing-8); height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full); flex-shrink: 0;\n }\n .legend-val {\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n\n .empty {\n display: flex; align-items: center; justify-content: center;\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-sm); min-height: 120px;\n }\n `];\n\n @property({ type: Array }) data: ChartSeries[] = [];\n @property() type: 'bar' | 'horizontal-bar' | 'line' | 'area' | 'pie' | 'donut' = 'bar';\n @property() override title = '';\n @property() subtitle = '';\n @property({ type: Number }) height = 200;\n @property({ type: Boolean }) showLegend = true;\n @property({ type: Boolean }) showValues = true;\n /** Wrap chart in a card container */\n @property({ type: Boolean }) contained = false;\n @property({ type: Boolean }) showGrid = true;\n @property() emptyText = 'No data';\n\n @state() private _tipX = 0;\n @state() private _tipY = 0;\n @state() private _tipText = '';\n @state() private _tipShow = false;\n\n // Resolved theme colors for SVG — pulled from CSS custom properties at runtime\n private _grid = '';\n private _axis = '';\n private _text = '';\n private _bg = '';\n private _resolved = false;\n\n private _resolve() {\n if (this._resolved) return;\n const s = getComputedStyle(this);\n this._grid = s.getPropertyValue('--cg-color-chart-grid').trim() || s.getPropertyValue('--cg-color-surface-cards-border').trim();\n this._axis = s.getPropertyValue('--cg-color-chart-axis').trim() || s.getPropertyValue('--cg-color-input-text-placeholder').trim();\n this._text = s.getPropertyValue('--cg-color-surface-base-text').trim() || s.getPropertyValue('--cg-color-surface-base-text').trim();\n this._bg = s.getPropertyValue('--cg-color-surface-container-background').trim() || s.getPropertyValue('--cg-color-surface-base-background').trim();\n for (let i = 0; i < 8; i++) {\n const v = s.getPropertyValue(`--cg-color-chart-${i + 1}`).trim();\n if (v) PALETTE[i] = v;\n }\n this._resolved = true;\n }\n\n override firstUpdated() {\n this._resolve();\n this.requestUpdate();\n }\n\n private _animId = 0;\n private _animated = false;\n\n override updated(changed: Map<string, unknown>) {\n if (!this._animated && this.data.length > 0) {\n this._animated = true;\n this._animateBars();\n }\n if (changed.has('data') || changed.has('type')) {\n this._animated = false;\n cancelAnimationFrame(this._animId);\n // Re-animate on next frame after render\n requestAnimationFrame(() => {\n this._animated = true;\n this._animateBars();\n });\n }\n }\n\n private _easeOut(t: number) { return 1 - (1 - t) * (1 - t); }\n\n private _animateBars() {\n const bars = this.shadowRoot?.querySelectorAll<SVGRectElement>('.bar-anim');\n const hbars = this.shadowRoot?.querySelectorAll<SVGRectElement>('.hbar-anim');\n const vals = this.shadowRoot?.querySelectorAll<SVGElement>('.val-anim');\n if (!bars?.length && !hbars?.length) return;\n\n const dur = 500;\n const start = performance.now();\n\n const tick = (now: number) => {\n const elapsed = now - start;\n\n bars?.forEach(rect => {\n const delay = Number(rect.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / dur));\n const p = this._easeOut(t);\n const targetH = Number(rect.dataset.h);\n const targetY = Number(rect.dataset.y);\n const baseY = targetY + targetH;\n const h = targetH * p;\n rect.setAttribute('height', String(h));\n rect.setAttribute('y', String(baseY - h));\n });\n\n hbars?.forEach(rect => {\n const delay = Number(rect.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / dur));\n const p = this._easeOut(t);\n const targetW = Number(rect.dataset.w);\n rect.setAttribute('width', String(targetW * p));\n });\n\n vals?.forEach(el => {\n const delay = Number(el.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / 200));\n el.setAttribute('opacity', String(t));\n });\n\n const maxDelay = Math.max(\n ...[...bars || []].map(r => Number(r.dataset.delay) || 0),\n ...[...hbars || []].map(r => Number(r.dataset.delay) || 0),\n ...[...vals || []].map(r => Number(r.dataset.delay) || 0),\n );\n if (elapsed < maxDelay + dur + 200) {\n this._animId = requestAnimationFrame(tick);\n }\n };\n\n this._animId = requestAnimationFrame(tick);\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n cancelAnimationFrame(this._animId);\n }\n\n private _color(i: number, d: ChartSeries) { return d.color || PALETTE[i % PALETTE.length]!; }\n\n private _fmt(v: number) {\n if (Math.abs(v) >= 1e6) return (v / 1e6).toFixed(1) + 'M';\n if (Math.abs(v) >= 1e3) return (v / 1e3).toFixed(1) + 'K';\n return v % 1 === 0 ? String(v) : v.toFixed(1);\n }\n\n private _tip(e: MouseEvent, label: string, value: number) {\n const r = (e.currentTarget as Element).closest('.svg-wrap')!.getBoundingClientRect();\n this._tipX = e.clientX - r.left;\n this._tipY = e.clientY - r.top;\n this._tipText = `${label}: ${this._fmt(value)}`;\n this._tipShow = true;\n }\n private _untip() { this._tipShow = false; }\n\n // ═══ BAR ═══\n private _bar() {\n const { data, height: H } = this;\n const W = 400, T = 20, R = 16, B = 28, L = 44;\n const pw = W - L - R, ph = H - T - B;\n const max = Math.max(...data.map(d => d.value), 1);\n const n = data.length;\n const bw = (pw / n) * 0.6;\n const step = pw / n;\n\n return svg`\n ${this.showGrid ? [0.25, 0.5, 0.75, 1].map(p => {\n const y = T + ph - ph * p;\n return svg`\n <line x1=\"${L}\" y1=\"${y}\" x2=\"${W - R}\" y2=\"${y}\" stroke=\"${this._grid}\" stroke-width=\"0.5\" stroke-dasharray=\"3,3\" />\n <text x=\"${L - 6}\" y=\"${y + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"10\">${this._fmt(max * p)}</text>\n `;\n }) : nothing}\n ${data.map((d, i) => {\n const bh = (d.value / max) * ph;\n const x = L + i * step + (step - bw) / 2;\n const yFinal = T + ph - bh;\n const yBase = T + ph;\n const c = this._color(i, d);\n return svg`\n <rect class=\"bar-anim\" x=\"${x}\" y=\"${yBase}\" width=\"${bw}\" height=\"0\" rx=\"4\" fill=\"${c}\" style=\"cursor:pointer\"\n data-y=\"${yFinal}\" data-h=\"${bh}\" data-delay=\"${i * 50}\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n ${this.showValues ? svg`<text class=\"val-anim\" x=\"${x + bw / 2}\" y=\"${yFinal - 6}\" text-anchor=\"middle\" fill=\"${this._text}\" font-size=\"10\" font-weight=\"600\" opacity=\"0\" data-delay=\"${i * 50 + 300}\">${this._fmt(d.value)}</text>` : nothing}\n <text x=\"${x + bw / 2}\" y=\"${H - 6}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"10\">${d.label}</text>\n `;\n })}\n `;\n }\n\n // ═══ HORIZONTAL BAR ═══\n private _hbar() {\n const { data } = this;\n const W = 400, lW = 72, gap = 8, bH = 28;\n const H = data.length * (bH + gap);\n const max = Math.max(...data.map(d => d.value), 1);\n\n return svg`\n ${data.map((d, i) => {\n const y = i * (bH + gap);\n const bW = (d.value / max) * (W - lW - 60);\n const c = this._color(i, d);\n return svg`\n <text x=\"${lW - 6}\" y=\"${y + bH / 2 + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"11\">${d.label}</text>\n <rect class=\"hbar-anim\" x=\"${lW}\" y=\"${y}\" width=\"0\" height=\"${bH}\" rx=\"4\" fill=\"${c}\" style=\"cursor:pointer\"\n data-w=\"${bW}\" data-delay=\"${i * 50}\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n <text class=\"val-anim\" x=\"${lW + bW + 8}\" y=\"${y + bH / 2 + 4}\" fill=\"${this._text}\" font-size=\"11\" font-weight=\"600\" opacity=\"0\" data-delay=\"${i * 50 + 300}\">${this._fmt(d.value)}</text>\n `;\n })}\n `;\n }\n\n // ═══ LINE / AREA ═══\n private _line(area: boolean) {\n const { data, height: H } = this;\n const W = 400, T = 12, R = 16, B = 28, L = 44;\n const pw = W - L - R, ph = H - T - B;\n const max = Math.max(...data.map(d => d.value), 1);\n const c = this._color(0, data[0]!);\n\n const pts = data.map((d, i) => ({\n x: L + (i / Math.max(data.length - 1, 1)) * pw,\n y: T + ph - (d.value / max) * ph,\n }));\n const line = pts.map((p, i) => `${i ? 'L' : 'M'}${p.x.toFixed(1)},${p.y.toFixed(1)}`).join(' ');\n const areaD = `${line} L${pts.at(-1)!.x.toFixed(1)},${(T + ph).toFixed(1)} L${pts[0]!.x.toFixed(1)},${(T + ph).toFixed(1)} Z`;\n\n return svg`\n ${this.showGrid ? [0.25, 0.5, 0.75, 1].map(p => {\n const y = T + ph - ph * p;\n return svg`\n <line x1=\"${L}\" y1=\"${y}\" x2=\"${W - R}\" y2=\"${y}\" stroke=\"${this._grid}\" stroke-width=\"0.5\" stroke-dasharray=\"3,3\" />\n <text x=\"${L - 6}\" y=\"${y + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"10\">${this._fmt(max * p)}</text>\n `;\n }) : nothing}\n ${area ? svg`<path d=\"${areaD}\" fill=\"${c}\" opacity=\"0.2\" />` : nothing}\n <path class=\"anim-line\" d=\"${line}\" fill=\"none\" stroke=\"${c}\" stroke-width=\"2.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" style=\"--dash:2000\" />\n ${pts.map((p, i) => svg`\n <circle class=\"anim-dot\" cx=\"${p.x}\" cy=\"${p.y}\" r=\"4\" fill=\"${c}\" stroke=\"${this._bg}\" stroke-width=\"2\" style=\"cursor:pointer; animation-delay:${400 + i * 50}ms\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, data[i]!.label, data[i]!.value)}\n @mouseleave=${this._untip} />\n `)}\n ${data.map((d, i) => svg`\n <text x=\"${pts[i]!.x}\" y=\"${H - 6}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"10\">${d.label}</text>\n `)}\n `;\n }\n\n // ═══ PIE / DONUT ═══\n private _pie(donut: boolean) {\n const { data } = this;\n const total = data.reduce((s, d) => s + d.value, 0) || 1;\n const sz = Math.min(this.height, 240);\n const r = sz * 0.4;\n const cx = sz / 2, cy = sz / 2;\n const rad = (a: number) => a * Math.PI / 180;\n let ang = -90;\n\n const slices = data.map((d, i) => {\n const sw = (d.value / total) * 360;\n const end = ang + sw;\n const lg = sw > 180 ? 1 : 0;\n const x1 = cx + r * Math.cos(rad(ang));\n const y1 = cy + r * Math.sin(rad(ang));\n const x2 = cx + r * Math.cos(rad(end));\n const y2 = cy + r * Math.sin(rad(end));\n const mid = ang + sw / 2;\n const lr = r * (donut ? 1.2 : 0.6);\n const lx = cx + lr * Math.cos(rad(mid));\n const ly = cy + lr * Math.sin(rad(mid));\n const pct = Math.round((d.value / total) * 100);\n const c = this._color(i, d);\n const p = `M${cx},${cy} L${x1.toFixed(1)},${y1.toFixed(1)} A${r},${r} 0 ${lg} 1 ${x2.toFixed(1)},${y2.toFixed(1)} Z`;\n ang = end;\n\n return svg`\n <path class=\"anim-slice\" d=\"${p}\" fill=\"${c}\" style=\"cursor:pointer; animation-delay:${i * 60}ms\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n ${pct >= 5 ? svg`<text x=\"${lx}\" y=\"${ly}\" text-anchor=\"middle\" dominant-baseline=\"central\" fill=\"${donut ? this._axis : this._text}\" font-size=\"10\" font-weight=\"600\">${pct}%</text>` : nothing}\n `;\n });\n\n return svg`\n ${slices}\n ${donut ? svg`\n <circle cx=\"${cx}\" cy=\"${cy}\" r=\"${r * 0.55}\" fill=\"${this._bg}\" />\n <text x=\"${cx}\" y=\"${cy - 4}\" text-anchor=\"middle\" fill=\"${this._text}\" font-size=\"16\" font-weight=\"700\">${this._fmt(total)}</text>\n <text x=\"${cx}\" y=\"${cy + 12}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"9\">Total</text>\n ` : nothing}\n `;\n }\n\n private _svgHeight() {\n if (this.type === 'horizontal-bar') return this.data.length * 36;\n if (this.type === 'pie' || this.type === 'donut') return Math.min(this.height, 240);\n return this.height;\n }\n\n private _svgWidth() {\n if (this.type === 'pie' || this.type === 'donut') return Math.min(this.height, 240);\n return 400;\n }\n\n override render() {\n if (!this.data.length) return html`<div class=\"wrap ${this.contained ? 'contained' : ''}\"><div class=\"empty\">${this.emptyText}</div></div>`;\n\n const vw = this._svgWidth();\n const vh = this._svgHeight();\n const isPie = this.type === 'pie' || this.type === 'donut';\n\n let chartSvg;\n switch (this.type) {\n case 'bar': chartSvg = this._bar(); break;\n case 'horizontal-bar': chartSvg = this._hbar(); break;\n case 'line': chartSvg = this._line(false); break;\n case 'area': chartSvg = this._line(true); break;\n case 'pie': chartSvg = this._pie(false); break;\n case 'donut': chartSvg = this._pie(true); break;\n }\n\n return html`\n <div class=\"wrap ${this.contained ? 'contained' : ''}\">\n ${this.title || this.subtitle ? html`\n <div class=\"header\">\n ${this.title ? html`<div class=\"title\">${this.title}</div>` : nothing}\n ${this.subtitle ? html`<div class=\"subtitle\">${this.subtitle}</div>` : nothing}\n </div>\n ` : nothing}\n\n <div class=\"svg-wrap\">\n <svg\n role=\"img\"\n aria-label=${`${this.title || 'Chart'}: ${this.data.map((d) => `${d.label} ${this._fmt(d.value)}`).join(', ')}`}\n viewBox=\"0 0 ${vw} ${vh}\"\n style=\"${isPie ? `max-width:${vw}px; margin:0 auto;` : ''}\"\n >\n ${chartSvg}\n </svg>\n <div class=\"tip ${this._tipShow ? 'show' : ''}\" style=\"left:${this._tipX}px;top:${this._tipY}px;\">\n ${this._tipText}\n </div>\n </div>\n\n ${this.showLegend ? html`\n <div class=\"legend\">\n ${this.data.map((d, i) => html`\n <span class=\"legend-item anim-legend\" style=\"animation-delay:${300 + i * 40}ms\">\n <span class=\"legend-dot\" style=\"background:${this._color(i, d)}\"></span>\n <span>${d.label}</span>\n <span class=\"legend-val\">${this._fmt(d.value)}</span>\n </span>\n `)}\n </div>\n ` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-chart': CgChart; }\n}\n"],"names":["PALETTE","CgChart","LitElement","s","i","v","changed","bars","hbars","vals","dur","start","tick","now","elapsed","rect","delay","t","p","targetH","baseY","h","targetW","el","maxDelay","r","d","e","label","value","data","H","W","T","R","B","L","pw","ph","max","n","bw","step","svg","nothing","bh","x","yFinal","yBase","c","lW","gap","bH","y","bW","area","pts","line","areaD","donut","total","sz","cx","cy","rad","a","ang","slices","sw","end","lg","x1","y1","x2","y2","mid","lr","lx","ly","pct","html","vw","vh","isPie","chartSvg","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -2,8 +2,6 @@ import { LitElement, PropertyValues } from 'lit';
2
2
  /**
3
3
  * @element cg-checkbox
4
4
  * Checkbox with animated tick draw, spring bounce, and indeterminate state.
5
- * Supports rich label content via the default slot — links and other
6
- * interactive elements inside the label do not toggle the checkbox.
7
5
  *
8
6
  * @example
9
7
  * ```html
@@ -11,12 +9,8 @@ import { LitElement, PropertyValues } from 'lit';
11
9
  * <cg-checkbox checked label="Notifications"></cg-checkbox>
12
10
  * <cg-checkbox indeterminate label="Select all"></cg-checkbox>
13
11
  * <cg-checkbox rounded="full" checked label="Round checkbox"></cg-checkbox>
14
- * <cg-checkbox>I agree to the <a href="/terms">terms</a></cg-checkbox>
15
12
  * ```
16
13
  *
17
- * @slot - Default slot for label content (overrides `label` prop)
18
- * @slot description - Description content (overrides `description` prop)
19
- *
20
14
  * @fires {CustomEvent<{checked: boolean, value: string}>} cg-change - When toggled
21
15
  */
22
16
  export declare class CgCheckbox extends LitElement {
@@ -1 +1 @@
1
- {"version":3,"file":"cg-checkbox.d.ts","sourceRoot":"","sources":["../../../src/components/cg-checkbox/cg-checkbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E;;;;;;;;;;;;;;;;;;;GAmBG;AACH,qBACa,UAAW,SAAQ,UAAU;IACxC,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,4BA+KnB;IAES,KAAK,SAAM;IACX,WAAW,SAAM;IACjB,IAAI,SAAM;IACV,KAAK,SAAM;IACM,OAAO,UAAS;IAChB,aAAa,UAAS;IACP,QAAQ,UAAS;IACjB,KAAK,UAAS;IACd,OAAO,UAAS;IAChB,OAAO,UAAS;IAC/B,QAAQ,UAAS;IACjB,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAQ;IAEzE,OAAO,CAAC,OAAO,EAAE,cAAc;IAcxC,iBAAiB;IAIjB,wBAAwB,CAAC,KAAK,EAAE,MAAM;IAItC,OAAO,CAAC,OAAO;IAkBN,MAAM;CAwChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,aAAa,EAAE,UAAU,CAAC;KAAE;CAC/D"}
1
+ {"version":3,"file":"cg-checkbox.d.ts","sourceRoot":"","sources":["../../../src/components/cg-checkbox/cg-checkbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E;;;;;;;;;;;;;GAaG;AACH,qBACa,UAAW,SAAQ,UAAU;IACxC,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,4BAiLnB;IAES,KAAK,SAAM;IACX,WAAW,SAAM;IACjB,IAAI,SAAM;IACV,KAAK,SAAM;IACM,OAAO,UAAS;IAChB,aAAa,UAAS;IACP,QAAQ,UAAS;IACjB,KAAK,UAAS;IACd,OAAO,UAAS;IAChB,OAAO,UAAS;IAC/B,QAAQ,UAAS;IACjB,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAQ;IAEzE,OAAO,CAAC,OAAO,EAAE,cAAc;IAcxC,iBAAiB;IAIjB,wBAAwB,CAAC,KAAK,EAAE,MAAM;IAItC,OAAO,CAAC,OAAO;IAWN,MAAM;CA0ChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,aAAa,EAAE,UAAU,CAAC;KAAE;CAC/D"}
@@ -1,10 +1,10 @@
1
- import { css as u, LitElement as g, html as i, nothing as h } from "lit";
2
- import { property as a, customElement as b } from "lit/decorators.js";
3
- import { h as p, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
4
- var v = Object.defineProperty, k = Object.getOwnPropertyDescriptor, o = (r, t, c, n) => {
5
- for (var s = n > 1 ? void 0 : n ? k(t, c) : t, l = r.length - 1, d; l >= 0; l--)
6
- (d = r[l]) && (s = (n ? d(t, c, s) : d(s)) || s);
7
- return n && s && v(t, c, s), s;
1
+ import { css as u, LitElement as g, nothing as n, html as i } from "lit";
2
+ import { property as o, customElement as b } from "lit/decorators.js";
3
+ import { h as p, r as f } from "../../chunks/premium.css-DHekUEUt.js";
4
+ var v = Object.defineProperty, k = Object.getOwnPropertyDescriptor, t = (r, a, d, c) => {
5
+ for (var s = c > 1 ? void 0 : c ? k(a, d) : a, l = r.length - 1, h; l >= 0; l--)
6
+ (h = r[l]) && (s = (c ? h(a, d, s) : h(s)) || s);
7
+ return c && s && v(a, d, s), s;
8
8
  };
9
9
  let e = class extends g {
10
10
  constructor() {
@@ -20,11 +20,7 @@ let e = class extends g {
20
20
  this.checked = r === (this.value || "on");
21
21
  }
22
22
  _toggle(r) {
23
- if (r.preventDefault(), this.disabled || this.loading) return;
24
- const t = r.target;
25
- t && t !== this && t.closest(
26
- 'a, button, [role="button"], [role="link"], input:not([type="checkbox"]), select, textarea'
27
- ) || (this.checked = !this.checked, this.indeterminate = !1, this.dispatchEvent(new CustomEvent("cg-change", {
23
+ r.preventDefault(), !(this.disabled || this.loading) && (this.checked = !this.checked, this.indeterminate = !1, this.dispatchEvent(new CustomEvent("cg-change", {
28
24
  detail: { checked: this.checked, value: this.value },
29
25
  bubbles: !0,
30
26
  composed: !0
@@ -42,32 +38,34 @@ let e = class extends g {
42
38
  aria-invalid=${this.error ? "true" : "false"}
43
39
  aria-busy=${this.loading ? "true" : "false"}
44
40
  @click=${this._toggle}
45
- @keydown=${(t) => {
46
- (t.key === " " || t.key === "Enter") && (t.preventDefault(), this._toggle(t));
41
+ @keydown=${(a) => {
42
+ (a.key === " " || a.key === "Enter") && (a.preventDefault(), this._toggle(a));
47
43
  }}
48
44
  >
49
45
  <input type="checkbox" .checked=${this.checked} .indeterminate=${this.indeterminate}
50
46
  ?disabled=${this.disabled} name=${this.name} value=${this.value}
51
47
  tabindex="-1" aria-hidden="true"
52
- @click=${(t) => t.stopPropagation()} />
48
+ @click=${(a) => a.stopPropagation()} />
53
49
 
54
50
  ${this.loading ? i`<span class="loading-spinner" aria-hidden="true"></span>` : i`<span class="box ${r}">
55
51
  ${this.checked ? i`
56
52
  <svg class="check-icon" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="3" stroke-linecap="round" stroke-linejoin="round">
57
53
  <path class="tick" d="M4 12L9 17L20 6"></path>
58
54
  </svg>
59
- ` : h}
55
+ ` : n}
60
56
  ${this.indeterminate ? i`
61
57
  <svg class="check-icon" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="3" stroke-linecap="round">
62
58
  <path class="dash" d="M5 12h14"></path>
63
59
  </svg>
64
- ` : h}
60
+ ` : n}
65
61
  </span>`}
66
62
 
67
- <span class="text-group">
68
- <span class="label-text"><slot>${this.label}</slot></span>
69
- <span class="description"><slot name="description">${this.description}</slot></span>
70
- </span>
63
+ ${this.label ? i`
64
+ <span class="text-group">
65
+ <span class="label-text">${this.label}</span>
66
+ ${this.description ? i`<span class="description">${this.description}</span>` : n}
67
+ </span>
68
+ ` : n}
71
69
  </label>
72
70
  `;
73
71
  }
@@ -119,9 +117,10 @@ e.styles = [p, f, u`
119
117
  :host([rounded="lg"]) .box { border-radius: var(--cg-border-radius-150); }
120
118
  :host([rounded="full"]) .box { border-radius: var(--cg-border-radius-full); }
121
119
 
122
- /* Hover */
123
- :host(:not([disabled])) label:hover .box {
124
- border-color: var(--cg-color-checkbox-background-hover);
120
+ /* Hover — scoped so it doesn't override the error/success border, and
121
+ uses the accent BORDER token (not a -background- fill) for the edge. */
122
+ :host(:not([disabled]):not([error]):not([success])) label:hover .box {
123
+ border-color: var(--cg-color-checkbox-border-checked);
125
124
  }
126
125
 
127
126
  /* Pressed */
@@ -132,7 +131,7 @@ e.styles = [p, f, u`
132
131
  /* Focus ring */
133
132
  label:focus-visible .box {
134
133
  border-color: var(--cg-color-checkbox-border-focus);
135
- box-shadow: 0 0 0 2px var(--cg-color-focus-ring-offset), 0 0 0 4px var(--cg-color-focus-ring);
134
+ box-shadow: 0 0 0 var(--cg-border-width-100) var(--cg-color-focus-ring-offset), 0 0 0 calc(var(--cg-border-width-100) * 2) var(--cg-color-focus-ring);
136
135
  }
137
136
 
138
137
  /* ── Checked state ── */
@@ -142,10 +141,11 @@ e.styles = [p, f, u`
142
141
  animation: boxPop var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);
143
142
  }
144
143
 
145
- /* Indeterminate */
144
+ /* Indeterminate — same spring entry as checked for consistent feedback. */
146
145
  .box.indeterminate {
147
146
  background: var(--cg-color-checkbox-background-checked);
148
147
  border-color: var(--cg-color-checkbox-border-checked);
148
+ animation: boxPop var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);
149
149
  }
150
150
 
151
151
  /* ── Animated tick — stroke reveal ── */
@@ -249,43 +249,43 @@ e.styles = [p, f, u`
249
249
  line-height: var(--cg-line-height-snug);
250
250
  }
251
251
  `];
252
- o([
253
- a()
252
+ t([
253
+ o()
254
254
  ], e.prototype, "label", 2);
255
- o([
256
- a()
255
+ t([
256
+ o()
257
257
  ], e.prototype, "description", 2);
258
- o([
259
- a()
258
+ t([
259
+ o()
260
260
  ], e.prototype, "name", 2);
261
- o([
262
- a()
261
+ t([
262
+ o()
263
263
  ], e.prototype, "value", 2);
264
- o([
265
- a({ type: Boolean })
264
+ t([
265
+ o({ type: Boolean })
266
266
  ], e.prototype, "checked", 2);
267
- o([
268
- a({ type: Boolean })
267
+ t([
268
+ o({ type: Boolean })
269
269
  ], e.prototype, "indeterminate", 2);
270
- o([
271
- a({ type: Boolean, reflect: !0 })
270
+ t([
271
+ o({ type: Boolean, reflect: !0 })
272
272
  ], e.prototype, "disabled", 2);
273
- o([
274
- a({ type: Boolean, reflect: !0 })
273
+ t([
274
+ o({ type: Boolean, reflect: !0 })
275
275
  ], e.prototype, "error", 2);
276
- o([
277
- a({ type: Boolean, reflect: !0 })
276
+ t([
277
+ o({ type: Boolean, reflect: !0 })
278
278
  ], e.prototype, "success", 2);
279
- o([
280
- a({ type: Boolean, reflect: !0 })
279
+ t([
280
+ o({ type: Boolean, reflect: !0 })
281
281
  ], e.prototype, "loading", 2);
282
- o([
283
- a({ type: Boolean })
282
+ t([
283
+ o({ type: Boolean })
284
284
  ], e.prototype, "required", 2);
285
- o([
286
- a({ reflect: !0 })
285
+ t([
286
+ o({ reflect: !0 })
287
287
  ], e.prototype, "rounded", 2);
288
- e = o([
288
+ e = t([
289
289
  b("cg-checkbox")
290
290
  ], e);
291
291
  export {