@cognivo/components 0.8.0 → 0.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (543) hide show
  1. package/dist/chunks/focus-trap-vlQwKK-3.js +82 -0
  2. package/dist/chunks/focus-trap-vlQwKK-3.js.map +1 -0
  3. package/dist/chunks/{premium.css-9I4kHrsl.js → premium.css-DHekUEUt.js} +25 -25
  4. package/dist/chunks/{premium.css-9I4kHrsl.js.map → premium.css-DHekUEUt.js.map} +1 -1
  5. package/dist/cognivo.min.js +3375 -5270
  6. package/dist/cognivo.min.js.map +1 -1
  7. package/dist/components/ai-ab-test/ai-ab-test.js +1 -1
  8. package/dist/components/ai-accessibility-report/ai-accessibility-report.d.ts.map +1 -1
  9. package/dist/components/ai-accessibility-report/ai-accessibility-report.js +14 -13
  10. package/dist/components/ai-accessibility-report/ai-accessibility-report.js.map +1 -1
  11. package/dist/components/ai-action-preview/ai-action-preview.d.ts.map +1 -1
  12. package/dist/components/ai-action-preview/ai-action-preview.js +15 -14
  13. package/dist/components/ai-action-preview/ai-action-preview.js.map +1 -1
  14. package/dist/components/ai-agent-card/ai-agent-card.js +1 -1
  15. package/dist/components/ai-agent-steps/ai-agent-steps.d.ts +8 -21
  16. package/dist/components/ai-agent-steps/ai-agent-steps.d.ts.map +1 -1
  17. package/dist/components/ai-agent-steps/ai-agent-steps.js +85 -139
  18. package/dist/components/ai-agent-steps/ai-agent-steps.js.map +1 -1
  19. package/dist/components/ai-alert-card/ai-alert-card.js +5 -5
  20. package/dist/components/ai-alert-card/ai-alert-card.js.map +1 -1
  21. package/dist/components/ai-analytics-chart/ai-analytics-chart.d.ts +0 -13
  22. package/dist/components/ai-analytics-chart/ai-analytics-chart.d.ts.map +1 -1
  23. package/dist/components/ai-analytics-chart/ai-analytics-chart.js +75 -125
  24. package/dist/components/ai-analytics-chart/ai-analytics-chart.js.map +1 -1
  25. package/dist/components/ai-annotation/ai-annotation.js +2 -2
  26. package/dist/components/ai-annotation/ai-annotation.js.map +1 -1
  27. package/dist/components/ai-api-key-manager/ai-api-key-manager.d.ts +0 -9
  28. package/dist/components/ai-api-key-manager/ai-api-key-manager.d.ts.map +1 -1
  29. package/dist/components/ai-api-key-manager/ai-api-key-manager.js +115 -276
  30. package/dist/components/ai-api-key-manager/ai-api-key-manager.js.map +1 -1
  31. package/dist/components/ai-app-sidebar/ai-app-sidebar.js +13 -13
  32. package/dist/components/ai-app-sidebar/ai-app-sidebar.js.map +1 -1
  33. package/dist/components/ai-assistant-widget/ai-assistant-widget.d.ts.map +1 -1
  34. package/dist/components/ai-assistant-widget/ai-assistant-widget.js +5 -2
  35. package/dist/components/ai-assistant-widget/ai-assistant-widget.js.map +1 -1
  36. package/dist/components/ai-audio-player/ai-audio-player.d.ts.map +1 -1
  37. package/dist/components/ai-audio-player/ai-audio-player.js +23 -19
  38. package/dist/components/ai-audio-player/ai-audio-player.js.map +1 -1
  39. package/dist/components/ai-avatar/ai-avatar.js +1 -1
  40. package/dist/components/ai-badge/ai-badge.js +1 -1
  41. package/dist/components/ai-batch-progress/ai-batch-progress.js +6 -6
  42. package/dist/components/ai-batch-progress/ai-batch-progress.js.map +1 -1
  43. package/dist/components/ai-cache-indicator/ai-cache-indicator.d.ts +0 -13
  44. package/dist/components/ai-cache-indicator/ai-cache-indicator.d.ts.map +1 -1
  45. package/dist/components/ai-cache-indicator/ai-cache-indicator.js +90 -185
  46. package/dist/components/ai-cache-indicator/ai-cache-indicator.js.map +1 -1
  47. package/dist/components/ai-capture-flow/ai-capture-flow.js +21 -21
  48. package/dist/components/ai-capture-flow/ai-capture-flow.js.map +1 -1
  49. package/dist/components/ai-changelog/ai-changelog.js +26 -26
  50. package/dist/components/ai-changelog/ai-changelog.js.map +1 -1
  51. package/dist/components/ai-chart-summary/ai-chart-summary.d.ts +0 -6
  52. package/dist/components/ai-chart-summary/ai-chart-summary.d.ts.map +1 -1
  53. package/dist/components/ai-chart-summary/ai-chart-summary.js +100 -103
  54. package/dist/components/ai-chart-summary/ai-chart-summary.js.map +1 -1
  55. package/dist/components/ai-chat/ai-chat.d.ts.map +1 -1
  56. package/dist/components/ai-chat/ai-chat.js +9 -3
  57. package/dist/components/ai-chat/ai-chat.js.map +1 -1
  58. package/dist/components/ai-citation/ai-citation.d.ts +0 -6
  59. package/dist/components/ai-citation/ai-citation.d.ts.map +1 -1
  60. package/dist/components/ai-citation/ai-citation.js +64 -90
  61. package/dist/components/ai-citation/ai-citation.js.map +1 -1
  62. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.d.ts +1 -27
  63. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.d.ts.map +1 -1
  64. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js +114 -260
  65. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js.map +1 -1
  66. package/dist/components/ai-command-palette/ai-command-palette.js +1 -1
  67. package/dist/components/ai-confidence-badge/ai-confidence-badge.d.ts +11 -9
  68. package/dist/components/ai-confidence-badge/ai-confidence-badge.d.ts.map +1 -1
  69. package/dist/components/ai-confidence-badge/ai-confidence-badge.js +183 -101
  70. package/dist/components/ai-confidence-badge/ai-confidence-badge.js.map +1 -1
  71. package/dist/components/ai-confidence-slider/ai-confidence-slider.js +27 -27
  72. package/dist/components/ai-confidence-slider/ai-confidence-slider.js.map +1 -1
  73. package/dist/components/ai-consent-manager/ai-consent-manager.js +2 -2
  74. package/dist/components/ai-consent-manager/ai-consent-manager.js.map +1 -1
  75. package/dist/components/ai-context-window/ai-context-window.js +19 -19
  76. package/dist/components/ai-context-window/ai-context-window.js.map +1 -1
  77. package/dist/components/ai-copy-button/ai-copy-button.js +4 -4
  78. package/dist/components/ai-copy-button/ai-copy-button.js.map +1 -1
  79. package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js +14 -14
  80. package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js.map +1 -1
  81. package/dist/components/ai-data-card/ai-data-card.js +2 -2
  82. package/dist/components/ai-data-card/ai-data-card.js.map +1 -1
  83. package/dist/components/ai-data-lineage/ai-data-lineage.js +6 -6
  84. package/dist/components/ai-data-lineage/ai-data-lineage.js.map +1 -1
  85. package/dist/components/ai-data-preview/ai-data-preview.d.ts +0 -7
  86. package/dist/components/ai-data-preview/ai-data-preview.d.ts.map +1 -1
  87. package/dist/components/ai-data-preview/ai-data-preview.js +130 -267
  88. package/dist/components/ai-data-preview/ai-data-preview.js.map +1 -1
  89. package/dist/components/ai-data-table/ai-data-table.js +9 -9
  90. package/dist/components/ai-data-table/ai-data-table.js.map +1 -1
  91. package/dist/components/ai-debug-console/ai-debug-console.d.ts +1 -13
  92. package/dist/components/ai-debug-console/ai-debug-console.d.ts.map +1 -1
  93. package/dist/components/ai-debug-console/ai-debug-console.js +134 -340
  94. package/dist/components/ai-debug-console/ai-debug-console.js.map +1 -1
  95. package/dist/components/ai-detection-canvas/ai-detection-canvas.js +2 -2
  96. package/dist/components/ai-detection-canvas/ai-detection-canvas.js.map +1 -1
  97. package/dist/components/ai-diff-panel/ai-diff-panel.js +1 -1
  98. package/dist/components/ai-embedding-viz/ai-embedding-viz.js +4 -4
  99. package/dist/components/ai-embedding-viz/ai-embedding-viz.js.map +1 -1
  100. package/dist/components/ai-empty-state/ai-empty-state.js +1 -1
  101. package/dist/components/ai-error-boundary/ai-error-boundary.d.ts.map +1 -1
  102. package/dist/components/ai-error-boundary/ai-error-boundary.js +26 -21
  103. package/dist/components/ai-error-boundary/ai-error-boundary.js.map +1 -1
  104. package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js +5 -5
  105. package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js.map +1 -1
  106. package/dist/components/ai-feature-flag/ai-feature-flag.d.ts +0 -14
  107. package/dist/components/ai-feature-flag/ai-feature-flag.d.ts.map +1 -1
  108. package/dist/components/ai-feature-flag/ai-feature-flag.js +181 -322
  109. package/dist/components/ai-feature-flag/ai-feature-flag.js.map +1 -1
  110. package/dist/components/ai-feedback/ai-feedback.d.ts.map +1 -1
  111. package/dist/components/ai-feedback/ai-feedback.js +10 -5
  112. package/dist/components/ai-feedback/ai-feedback.js.map +1 -1
  113. package/dist/components/ai-file-upload/ai-file-upload.js +1 -1
  114. package/dist/components/ai-form-generator/ai-form-generator.js +1 -1
  115. package/dist/components/ai-guardrail/ai-guardrail.js +2 -2
  116. package/dist/components/ai-guardrail/ai-guardrail.js.map +1 -1
  117. package/dist/components/ai-heatmap/ai-heatmap.js +1 -1
  118. package/dist/components/ai-insight-card/ai-insight-card.js +4 -4
  119. package/dist/components/ai-insight-card/ai-insight-card.js.map +1 -1
  120. package/dist/components/ai-json-viewer/ai-json-viewer.js +13 -13
  121. package/dist/components/ai-json-viewer/ai-json-viewer.js.map +1 -1
  122. package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js +24 -24
  123. package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js.map +1 -1
  124. package/dist/components/ai-kpi-grid/ai-kpi-grid.js +2 -2
  125. package/dist/components/ai-kpi-grid/ai-kpi-grid.js.map +1 -1
  126. package/dist/components/ai-labeling-board/ai-labeling-board.js +11 -11
  127. package/dist/components/ai-labeling-board/ai-labeling-board.js.map +1 -1
  128. package/dist/components/ai-memory-panel/ai-memory-panel.js +7 -7
  129. package/dist/components/ai-memory-panel/ai-memory-panel.js.map +1 -1
  130. package/dist/components/ai-model-comparison/ai-model-comparison.js +2 -2
  131. package/dist/components/ai-model-comparison/ai-model-comparison.js.map +1 -1
  132. package/dist/components/ai-model-selector/ai-model-selector.js +7 -7
  133. package/dist/components/ai-model-selector/ai-model-selector.js.map +1 -1
  134. package/dist/components/ai-notification-center/ai-notification-center.js +27 -27
  135. package/dist/components/ai-notification-center/ai-notification-center.js.map +1 -1
  136. package/dist/components/ai-onboarding/ai-onboarding.js +5 -5
  137. package/dist/components/ai-onboarding/ai-onboarding.js.map +1 -1
  138. package/dist/components/ai-permission-gate/ai-permission-gate.js +1 -1
  139. package/dist/components/ai-personalization-dash/ai-personalization-dash.js +1 -1
  140. package/dist/components/ai-presence/ai-presence.js +25 -25
  141. package/dist/components/ai-presence/ai-presence.js.map +1 -1
  142. package/dist/components/ai-progress-steps/ai-progress-steps.js +11 -11
  143. package/dist/components/ai-progress-steps/ai-progress-steps.js.map +1 -1
  144. package/dist/components/ai-prompt-editor/ai-prompt-editor.js +1 -1
  145. package/dist/components/ai-prompt-template/ai-prompt-template.js +29 -29
  146. package/dist/components/ai-prompt-template/ai-prompt-template.js.map +1 -1
  147. package/dist/components/ai-rag-panel/ai-rag-panel.js +4 -4
  148. package/dist/components/ai-rag-panel/ai-rag-panel.js.map +1 -1
  149. package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js +16 -16
  150. package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js.map +1 -1
  151. package/dist/components/ai-result-panel/ai-result-panel.js +1 -1
  152. package/dist/components/ai-reveal-animation/ai-reveal-animation.js +3 -3
  153. package/dist/components/ai-reveal-animation/ai-reveal-animation.js.map +1 -1
  154. package/dist/components/ai-reward-signal/ai-reward-signal.js +1 -1
  155. package/dist/components/ai-rich-message/ai-rich-message.d.ts.map +1 -1
  156. package/dist/components/ai-rich-message/ai-rich-message.js +37 -30
  157. package/dist/components/ai-rich-message/ai-rich-message.js.map +1 -1
  158. package/dist/components/ai-scenario-panel/ai-scenario-panel.js +10 -10
  159. package/dist/components/ai-scenario-panel/ai-scenario-panel.js.map +1 -1
  160. package/dist/components/ai-search/ai-search.js +1 -1
  161. package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js +3 -3
  162. package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js.map +1 -1
  163. package/dist/components/ai-sidebar/ai-sidebar.js +1 -1
  164. package/dist/components/ai-similarity-card/ai-similarity-card.js +1 -1
  165. package/dist/components/ai-source-graph/ai-source-graph.js +2 -2
  166. package/dist/components/ai-source-graph/ai-source-graph.js.map +1 -1
  167. package/dist/components/ai-status-page/ai-status-page.js +15 -15
  168. package/dist/components/ai-status-page/ai-status-page.js.map +1 -1
  169. package/dist/components/ai-streaming-text/ai-streaming-text.js +1 -1
  170. package/dist/components/ai-test-runner/ai-test-runner.d.ts +0 -8
  171. package/dist/components/ai-test-runner/ai-test-runner.d.ts.map +1 -1
  172. package/dist/components/ai-test-runner/ai-test-runner.js +100 -257
  173. package/dist/components/ai-test-runner/ai-test-runner.js.map +1 -1
  174. package/dist/components/ai-thinking/ai-thinking.js +1 -1
  175. package/dist/components/ai-timeline/ai-timeline.js +2 -2
  176. package/dist/components/ai-timeline/ai-timeline.js.map +1 -1
  177. package/dist/components/ai-token-tracker/ai-token-tracker.js +3 -3
  178. package/dist/components/ai-token-tracker/ai-token-tracker.js.map +1 -1
  179. package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js +23 -23
  180. package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js.map +1 -1
  181. package/dist/components/ai-tool-indicator/ai-tool-indicator.js +3 -3
  182. package/dist/components/ai-tool-indicator/ai-tool-indicator.js.map +1 -1
  183. package/dist/components/ai-transform-slider/ai-transform-slider.js +1 -1
  184. package/dist/components/ai-translation-panel/ai-translation-panel.js +2 -2
  185. package/dist/components/ai-translation-panel/ai-translation-panel.js.map +1 -1
  186. package/dist/components/ai-usage-meter/ai-usage-meter.js +1 -1
  187. package/dist/components/ai-validation-checklist/ai-validation-checklist.d.ts +1 -11
  188. package/dist/components/ai-validation-checklist/ai-validation-checklist.d.ts.map +1 -1
  189. package/dist/components/ai-validation-checklist/ai-validation-checklist.js +133 -187
  190. package/dist/components/ai-validation-checklist/ai-validation-checklist.js.map +1 -1
  191. package/dist/components/ai-version-selector/ai-version-selector.d.ts +0 -4
  192. package/dist/components/ai-version-selector/ai-version-selector.d.ts.map +1 -1
  193. package/dist/components/ai-version-selector/ai-version-selector.js +189 -210
  194. package/dist/components/ai-version-selector/ai-version-selector.js.map +1 -1
  195. package/dist/components/ai-voice-panel/ai-voice-panel.js +28 -28
  196. package/dist/components/ai-voice-panel/ai-voice-panel.js.map +1 -1
  197. package/dist/components/ai-webhook-config/ai-webhook-config.d.ts +0 -17
  198. package/dist/components/ai-webhook-config/ai-webhook-config.d.ts.map +1 -1
  199. package/dist/components/ai-webhook-config/ai-webhook-config.js +281 -221
  200. package/dist/components/ai-webhook-config/ai-webhook-config.js.map +1 -1
  201. package/dist/components/ai-workflow-builder/ai-workflow-builder.js +2 -2
  202. package/dist/components/ai-workflow-builder/ai-workflow-builder.js.map +1 -1
  203. package/dist/components/bias-anchoring/bias-anchoring.js +1 -1
  204. package/dist/components/bias-authority/bias-authority.js +1 -1
  205. package/dist/components/bias-commitment/bias-commitment.js +1 -1
  206. package/dist/components/bias-reciprocity/bias-reciprocity.js +1 -1
  207. package/dist/components/bias-scarcity/bias-scarcity.js +1 -1
  208. package/dist/components/bias-social-proof/bias-social-proof.js +1 -1
  209. package/dist/components/cg-accordion/cg-accordion.d.ts.map +1 -1
  210. package/dist/components/cg-accordion/cg-accordion.js +51 -43
  211. package/dist/components/cg-accordion/cg-accordion.js.map +1 -1
  212. package/dist/components/cg-alert-dialog/cg-alert-dialog.js +18 -18
  213. package/dist/components/cg-alert-dialog/cg-alert-dialog.js.map +1 -1
  214. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.d.ts.map +1 -1
  215. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js +25 -21
  216. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js.map +1 -1
  217. package/dist/components/cg-autocomplete/cg-autocomplete.d.ts +1 -0
  218. package/dist/components/cg-autocomplete/cg-autocomplete.d.ts.map +1 -1
  219. package/dist/components/cg-autocomplete/cg-autocomplete.js +59 -43
  220. package/dist/components/cg-autocomplete/cg-autocomplete.js.map +1 -1
  221. package/dist/components/cg-avatar/cg-avatar.d.ts.map +1 -1
  222. package/dist/components/cg-avatar/cg-avatar.js +24 -24
  223. package/dist/components/cg-avatar/cg-avatar.js.map +1 -1
  224. package/dist/components/cg-avatar-group/cg-avatar-group.d.ts.map +1 -1
  225. package/dist/components/cg-avatar-group/cg-avatar-group.js +18 -12
  226. package/dist/components/cg-avatar-group/cg-avatar-group.js.map +1 -1
  227. package/dist/components/cg-badge/cg-badge.d.ts.map +1 -1
  228. package/dist/components/cg-badge/cg-badge.js +26 -20
  229. package/dist/components/cg-badge/cg-badge.js.map +1 -1
  230. package/dist/components/cg-badge-group/cg-badge-group.d.ts +0 -1
  231. package/dist/components/cg-badge-group/cg-badge-group.d.ts.map +1 -1
  232. package/dist/components/cg-badge-group/cg-badge-group.js +31 -29
  233. package/dist/components/cg-badge-group/cg-badge-group.js.map +1 -1
  234. package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js +21 -21
  235. package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js.map +1 -1
  236. package/dist/components/cg-button/cg-button.d.ts +5 -71
  237. package/dist/components/cg-button/cg-button.d.ts.map +1 -1
  238. package/dist/components/cg-button/cg-button.js +63 -172
  239. package/dist/components/cg-button/cg-button.js.map +1 -1
  240. package/dist/components/cg-button-group/cg-button-group.d.ts +2 -0
  241. package/dist/components/cg-button-group/cg-button-group.d.ts.map +1 -1
  242. package/dist/components/cg-button-group/cg-button-group.js +43 -29
  243. package/dist/components/cg-button-group/cg-button-group.js.map +1 -1
  244. package/dist/components/cg-calendar/cg-calendar.d.ts +4 -0
  245. package/dist/components/cg-calendar/cg-calendar.d.ts.map +1 -1
  246. package/dist/components/cg-calendar/cg-calendar.js +28 -12
  247. package/dist/components/cg-calendar/cg-calendar.js.map +1 -1
  248. package/dist/components/cg-callout/cg-callout.d.ts.map +1 -1
  249. package/dist/components/cg-callout/cg-callout.js +49 -48
  250. package/dist/components/cg-callout/cg-callout.js.map +1 -1
  251. package/dist/components/cg-card/cg-card.d.ts +9 -22
  252. package/dist/components/cg-card/cg-card.d.ts.map +1 -1
  253. package/dist/components/cg-card/cg-card.js +28 -56
  254. package/dist/components/cg-card/cg-card.js.map +1 -1
  255. package/dist/components/cg-carousel/cg-carousel.d.ts.map +1 -1
  256. package/dist/components/cg-carousel/cg-carousel.js +19 -13
  257. package/dist/components/cg-carousel/cg-carousel.js.map +1 -1
  258. package/dist/components/cg-chart/cg-chart.d.ts.map +1 -1
  259. package/dist/components/cg-chart/cg-chart.js +63 -58
  260. package/dist/components/cg-chart/cg-chart.js.map +1 -1
  261. package/dist/components/cg-checkbox/cg-checkbox.d.ts +0 -6
  262. package/dist/components/cg-checkbox/cg-checkbox.d.ts.map +1 -1
  263. package/dist/components/cg-checkbox/cg-checkbox.js +51 -51
  264. package/dist/components/cg-checkbox/cg-checkbox.js.map +1 -1
  265. package/dist/components/cg-chip/cg-chip.js +31 -31
  266. package/dist/components/cg-chip/cg-chip.js.map +1 -1
  267. package/dist/components/cg-code-block/cg-code-block.d.ts.map +1 -1
  268. package/dist/components/cg-code-block/cg-code-block.js +36 -34
  269. package/dist/components/cg-code-block/cg-code-block.js.map +1 -1
  270. package/dist/components/cg-collapsible/cg-collapsible.d.ts.map +1 -1
  271. package/dist/components/cg-collapsible/cg-collapsible.js +23 -18
  272. package/dist/components/cg-collapsible/cg-collapsible.js.map +1 -1
  273. package/dist/components/cg-color-picker/cg-color-picker.d.ts +3 -0
  274. package/dist/components/cg-color-picker/cg-color-picker.d.ts.map +1 -1
  275. package/dist/components/cg-color-picker/cg-color-picker.js +189 -91
  276. package/dist/components/cg-color-picker/cg-color-picker.js.map +1 -1
  277. package/dist/components/cg-combobox/cg-combobox.d.ts.map +1 -1
  278. package/dist/components/cg-combobox/cg-combobox.js +13 -6
  279. package/dist/components/cg-combobox/cg-combobox.js.map +1 -1
  280. package/dist/components/cg-command/cg-command.d.ts.map +1 -1
  281. package/dist/components/cg-command/cg-command.js +52 -45
  282. package/dist/components/cg-command/cg-command.js.map +1 -1
  283. package/dist/components/cg-context-menu/cg-context-menu.js +1 -1
  284. package/dist/components/cg-date-picker/cg-date-picker.d.ts.map +1 -1
  285. package/dist/components/cg-date-picker/cg-date-picker.js +36 -34
  286. package/dist/components/cg-date-picker/cg-date-picker.js.map +1 -1
  287. package/dist/components/cg-date-range-picker/cg-date-range-picker.d.ts +2 -0
  288. package/dist/components/cg-date-range-picker/cg-date-range-picker.d.ts.map +1 -1
  289. package/dist/components/cg-date-range-picker/cg-date-range-picker.js +12 -8
  290. package/dist/components/cg-date-range-picker/cg-date-range-picker.js.map +1 -1
  291. package/dist/components/cg-date-time-picker/cg-date-time-picker.d.ts.map +1 -1
  292. package/dist/components/cg-date-time-picker/cg-date-time-picker.js +3 -1
  293. package/dist/components/cg-date-time-picker/cg-date-time-picker.js.map +1 -1
  294. package/dist/components/cg-drawer/cg-drawer.js +3 -3
  295. package/dist/components/cg-drawer/cg-drawer.js.map +1 -1
  296. package/dist/components/cg-dropdown/cg-dropdown.d.ts.map +1 -1
  297. package/dist/components/cg-dropdown/cg-dropdown.js +1 -2
  298. package/dist/components/cg-dropdown/cg-dropdown.js.map +1 -1
  299. package/dist/components/cg-empty-state/cg-empty-state.d.ts +3 -24
  300. package/dist/components/cg-empty-state/cg-empty-state.d.ts.map +1 -1
  301. package/dist/components/cg-empty-state/cg-empty-state.js +51 -74
  302. package/dist/components/cg-empty-state/cg-empty-state.js.map +1 -1
  303. package/dist/components/cg-file-input/cg-file-input.d.ts.map +1 -1
  304. package/dist/components/cg-file-input/cg-file-input.js +9 -10
  305. package/dist/components/cg-file-input/cg-file-input.js.map +1 -1
  306. package/dist/components/cg-focus-scope/cg-focus-scope.js +1 -1
  307. package/dist/components/cg-follow-up/cg-follow-up.d.ts.map +1 -1
  308. package/dist/components/cg-follow-up/cg-follow-up.js +6 -7
  309. package/dist/components/cg-follow-up/cg-follow-up.js.map +1 -1
  310. package/dist/components/cg-form/cg-form.js +17 -17
  311. package/dist/components/cg-form/cg-form.js.map +1 -1
  312. package/dist/components/cg-hover-card/cg-hover-card.d.ts +1 -0
  313. package/dist/components/cg-hover-card/cg-hover-card.d.ts.map +1 -1
  314. package/dist/components/cg-hover-card/cg-hover-card.js +37 -32
  315. package/dist/components/cg-hover-card/cg-hover-card.js.map +1 -1
  316. package/dist/components/cg-icon/cg-icon.d.ts.map +1 -1
  317. package/dist/components/cg-icon/cg-icon.js +44 -37
  318. package/dist/components/cg-icon/cg-icon.js.map +1 -1
  319. package/dist/components/cg-image/cg-image.js +2 -2
  320. package/dist/components/cg-image/cg-image.js.map +1 -1
  321. package/dist/components/cg-image-block/cg-image-block.js +3 -3
  322. package/dist/components/cg-image-block/cg-image-block.js.map +1 -1
  323. package/dist/components/cg-image-gallery/cg-image-gallery.js +20 -20
  324. package/dist/components/cg-image-gallery/cg-image-gallery.js.map +1 -1
  325. package/dist/components/cg-input/cg-input.js +3 -3
  326. package/dist/components/cg-input/cg-input.js.map +1 -1
  327. package/dist/components/cg-kbd/cg-kbd.d.ts.map +1 -1
  328. package/dist/components/cg-kbd/cg-kbd.js +26 -24
  329. package/dist/components/cg-kbd/cg-kbd.js.map +1 -1
  330. package/dist/components/cg-label/cg-label.d.ts +4 -1
  331. package/dist/components/cg-label/cg-label.d.ts.map +1 -1
  332. package/dist/components/cg-label/cg-label.js +44 -41
  333. package/dist/components/cg-label/cg-label.js.map +1 -1
  334. package/dist/components/cg-link/cg-link.js +23 -23
  335. package/dist/components/cg-link/cg-link.js.map +1 -1
  336. package/dist/components/cg-list/cg-list.js +5 -5
  337. package/dist/components/cg-list/cg-list.js.map +1 -1
  338. package/dist/components/cg-listbox/cg-listbox.d.ts.map +1 -1
  339. package/dist/components/cg-listbox/cg-listbox.js +46 -40
  340. package/dist/components/cg-listbox/cg-listbox.js.map +1 -1
  341. package/dist/components/cg-markdown/cg-markdown.d.ts +2 -0
  342. package/dist/components/cg-markdown/cg-markdown.d.ts.map +1 -1
  343. package/dist/components/cg-markdown/cg-markdown.js +171 -121
  344. package/dist/components/cg-markdown/cg-markdown.js.map +1 -1
  345. package/dist/components/cg-menubar/cg-menubar.d.ts +6 -0
  346. package/dist/components/cg-menubar/cg-menubar.d.ts.map +1 -1
  347. package/dist/components/cg-menubar/cg-menubar.js +59 -47
  348. package/dist/components/cg-menubar/cg-menubar.js.map +1 -1
  349. package/dist/components/cg-meter/cg-meter.d.ts.map +1 -1
  350. package/dist/components/cg-meter/cg-meter.js +76 -76
  351. package/dist/components/cg-meter/cg-meter.js.map +1 -1
  352. package/dist/components/cg-metric-card/cg-metric-card.d.ts.map +1 -1
  353. package/dist/components/cg-metric-card/cg-metric-card.js +65 -68
  354. package/dist/components/cg-metric-card/cg-metric-card.js.map +1 -1
  355. package/dist/components/cg-modal/cg-modal.d.ts +3 -0
  356. package/dist/components/cg-modal/cg-modal.d.ts.map +1 -1
  357. package/dist/components/cg-modal/cg-modal.js +82 -83
  358. package/dist/components/cg-modal/cg-modal.js.map +1 -1
  359. package/dist/components/cg-navbar/cg-navbar.d.ts +1 -1
  360. package/dist/components/cg-navbar/cg-navbar.d.ts.map +1 -1
  361. package/dist/components/cg-navbar/cg-navbar.js +64 -55
  362. package/dist/components/cg-navbar/cg-navbar.js.map +1 -1
  363. package/dist/components/cg-navigation-menu/cg-navigation-menu.d.ts +3 -0
  364. package/dist/components/cg-navigation-menu/cg-navigation-menu.d.ts.map +1 -1
  365. package/dist/components/cg-navigation-menu/cg-navigation-menu.js +38 -26
  366. package/dist/components/cg-navigation-menu/cg-navigation-menu.js.map +1 -1
  367. package/dist/components/cg-number-input/cg-number-input.d.ts +1 -0
  368. package/dist/components/cg-number-input/cg-number-input.d.ts.map +1 -1
  369. package/dist/components/cg-number-input/cg-number-input.js +90 -77
  370. package/dist/components/cg-number-input/cg-number-input.js.map +1 -1
  371. package/dist/components/cg-otp-input/cg-otp-input.d.ts.map +1 -1
  372. package/dist/components/cg-otp-input/cg-otp-input.js +70 -60
  373. package/dist/components/cg-otp-input/cg-otp-input.js.map +1 -1
  374. package/dist/components/cg-pagination/cg-pagination.d.ts +2 -0
  375. package/dist/components/cg-pagination/cg-pagination.d.ts.map +1 -1
  376. package/dist/components/cg-pagination/cg-pagination.js +50 -49
  377. package/dist/components/cg-pagination/cg-pagination.js.map +1 -1
  378. package/dist/components/cg-password-input/cg-password-input.d.ts.map +1 -1
  379. package/dist/components/cg-password-input/cg-password-input.js +42 -34
  380. package/dist/components/cg-password-input/cg-password-input.js.map +1 -1
  381. package/dist/components/cg-phone-input/cg-phone-input.d.ts.map +1 -1
  382. package/dist/components/cg-phone-input/cg-phone-input.js +18 -14
  383. package/dist/components/cg-phone-input/cg-phone-input.js.map +1 -1
  384. package/dist/components/cg-popover/cg-popover.d.ts +12 -2
  385. package/dist/components/cg-popover/cg-popover.d.ts.map +1 -1
  386. package/dist/components/cg-popover/cg-popover.js +90 -63
  387. package/dist/components/cg-popover/cg-popover.js.map +1 -1
  388. package/dist/components/cg-portal/cg-portal.d.ts.map +1 -1
  389. package/dist/components/cg-portal/cg-portal.js +42 -41
  390. package/dist/components/cg-portal/cg-portal.js.map +1 -1
  391. package/dist/components/cg-progress-bar/cg-progress-bar.d.ts.map +1 -1
  392. package/dist/components/cg-progress-bar/cg-progress-bar.js +25 -25
  393. package/dist/components/cg-progress-bar/cg-progress-bar.js.map +1 -1
  394. package/dist/components/cg-radio/cg-radio.d.ts +10 -0
  395. package/dist/components/cg-radio/cg-radio.d.ts.map +1 -1
  396. package/dist/components/cg-radio/cg-radio.js +59 -48
  397. package/dist/components/cg-radio/cg-radio.js.map +1 -1
  398. package/dist/components/cg-radio-group/cg-radio-group.d.ts +6 -0
  399. package/dist/components/cg-radio-group/cg-radio-group.d.ts.map +1 -1
  400. package/dist/components/cg-radio-group/cg-radio-group.js +50 -37
  401. package/dist/components/cg-radio-group/cg-radio-group.js.map +1 -1
  402. package/dist/components/cg-rating/cg-rating.d.ts.map +1 -1
  403. package/dist/components/cg-rating/cg-rating.js +56 -54
  404. package/dist/components/cg-rating/cg-rating.js.map +1 -1
  405. package/dist/components/cg-resizable/cg-resizable.d.ts +4 -1
  406. package/dist/components/cg-resizable/cg-resizable.d.ts.map +1 -1
  407. package/dist/components/cg-resizable/cg-resizable.js +45 -35
  408. package/dist/components/cg-resizable/cg-resizable.js.map +1 -1
  409. package/dist/components/cg-scroll-area/cg-scroll-area.d.ts +8 -0
  410. package/dist/components/cg-scroll-area/cg-scroll-area.d.ts.map +1 -1
  411. package/dist/components/cg-scroll-area/cg-scroll-area.js +64 -21
  412. package/dist/components/cg-scroll-area/cg-scroll-area.js.map +1 -1
  413. package/dist/components/cg-segmented-control/cg-segmented-control.d.ts +4 -0
  414. package/dist/components/cg-segmented-control/cg-segmented-control.d.ts.map +1 -1
  415. package/dist/components/cg-segmented-control/cg-segmented-control.js +75 -39
  416. package/dist/components/cg-segmented-control/cg-segmented-control.js.map +1 -1
  417. package/dist/components/cg-select/cg-select.d.ts +4 -2
  418. package/dist/components/cg-select/cg-select.d.ts.map +1 -1
  419. package/dist/components/cg-select/cg-select.js +96 -58
  420. package/dist/components/cg-select/cg-select.js.map +1 -1
  421. package/dist/components/cg-separator/cg-separator.d.ts +1 -2
  422. package/dist/components/cg-separator/cg-separator.d.ts.map +1 -1
  423. package/dist/components/cg-separator/cg-separator.js +5 -8
  424. package/dist/components/cg-separator/cg-separator.js.map +1 -1
  425. package/dist/components/cg-sheet/cg-sheet.d.ts +4 -0
  426. package/dist/components/cg-sheet/cg-sheet.d.ts.map +1 -1
  427. package/dist/components/cg-sheet/cg-sheet.js +80 -43
  428. package/dist/components/cg-sheet/cg-sheet.js.map +1 -1
  429. package/dist/components/cg-sidebar/cg-sidebar.d.ts.map +1 -1
  430. package/dist/components/cg-sidebar/cg-sidebar.js +82 -19
  431. package/dist/components/cg-sidebar/cg-sidebar.js.map +1 -1
  432. package/dist/components/cg-skeleton/cg-skeleton.d.ts +7 -1
  433. package/dist/components/cg-skeleton/cg-skeleton.d.ts.map +1 -1
  434. package/dist/components/cg-skeleton/cg-skeleton.js +61 -63
  435. package/dist/components/cg-skeleton/cg-skeleton.js.map +1 -1
  436. package/dist/components/cg-slider/cg-slider.d.ts.map +1 -1
  437. package/dist/components/cg-slider/cg-slider.js +80 -73
  438. package/dist/components/cg-slider/cg-slider.js.map +1 -1
  439. package/dist/components/cg-spinner/cg-spinner.d.ts.map +1 -1
  440. package/dist/components/cg-spinner/cg-spinner.js +10 -19
  441. package/dist/components/cg-spinner/cg-spinner.js.map +1 -1
  442. package/dist/components/cg-split-button/cg-split-button.d.ts.map +1 -1
  443. package/dist/components/cg-split-button/cg-split-button.js +64 -50
  444. package/dist/components/cg-split-button/cg-split-button.js.map +1 -1
  445. package/dist/components/cg-stack/cg-stack.js +1 -1
  446. package/dist/components/cg-steps/cg-steps.js +1 -1
  447. package/dist/components/cg-switch/cg-switch.d.ts +3 -0
  448. package/dist/components/cg-switch/cg-switch.d.ts.map +1 -1
  449. package/dist/components/cg-switch/cg-switch.js +39 -47
  450. package/dist/components/cg-switch/cg-switch.js.map +1 -1
  451. package/dist/components/cg-table/cg-table.d.ts +0 -7
  452. package/dist/components/cg-table/cg-table.d.ts.map +1 -1
  453. package/dist/components/cg-table/cg-table.js +50 -47
  454. package/dist/components/cg-table/cg-table.js.map +1 -1
  455. package/dist/components/cg-tabs/cg-tabs.js +1 -1
  456. package/dist/components/cg-tag-input/cg-tag-input.js +1 -1
  457. package/dist/components/cg-text/cg-text.js +1 -1
  458. package/dist/components/cg-textarea/cg-textarea.js +1 -1
  459. package/dist/components/cg-time-picker/cg-time-picker.js +1 -1
  460. package/dist/components/cg-toaster/cg-toaster.js +3 -3
  461. package/dist/components/cg-toaster/cg-toaster.js.map +1 -1
  462. package/dist/components/cg-toggle/cg-toggle.js +1 -1
  463. package/dist/components/cg-toggle-group/cg-toggle-group.js +1 -1
  464. package/dist/components/cg-tree-view/cg-tree-view.js +1 -1
  465. package/dist/foundation.d.ts +0 -16
  466. package/dist/foundation.d.ts.map +1 -1
  467. package/dist/foundation.js +174 -206
  468. package/dist/foundation.js.map +1 -1
  469. package/dist/index.d.ts +1 -17
  470. package/dist/index.d.ts.map +1 -1
  471. package/dist/index.js +100 -132
  472. package/dist/index.js.map +1 -1
  473. package/dist/utils/focus-trap.d.ts +19 -2
  474. package/dist/utils/focus-trap.d.ts.map +1 -1
  475. package/package.json +6 -810
  476. package/dist/chunks/focus-trap-BdRNhSPD.js +0 -53
  477. package/dist/chunks/focus-trap-BdRNhSPD.js.map +0 -1
  478. package/dist/components/cg-app-shell/cg-app-shell.d.ts +0 -54
  479. package/dist/components/cg-app-shell/cg-app-shell.d.ts.map +0 -1
  480. package/dist/components/cg-app-shell/cg-app-shell.js +0 -135
  481. package/dist/components/cg-app-shell/cg-app-shell.js.map +0 -1
  482. package/dist/components/cg-auth-shell/cg-auth-shell.d.ts +0 -61
  483. package/dist/components/cg-auth-shell/cg-auth-shell.d.ts.map +0 -1
  484. package/dist/components/cg-auth-shell/cg-auth-shell.js +0 -163
  485. package/dist/components/cg-auth-shell/cg-auth-shell.js.map +0 -1
  486. package/dist/components/cg-definition-list/cg-definition-list.d.ts +0 -99
  487. package/dist/components/cg-definition-list/cg-definition-list.d.ts.map +0 -1
  488. package/dist/components/cg-definition-list/cg-definition-list.js +0 -332
  489. package/dist/components/cg-definition-list/cg-definition-list.js.map +0 -1
  490. package/dist/components/cg-draggable/cg-draggable.d.ts +0 -53
  491. package/dist/components/cg-draggable/cg-draggable.d.ts.map +0 -1
  492. package/dist/components/cg-draggable/cg-draggable.js +0 -136
  493. package/dist/components/cg-draggable/cg-draggable.js.map +0 -1
  494. package/dist/components/cg-droppable/cg-droppable.d.ts +0 -57
  495. package/dist/components/cg-droppable/cg-droppable.d.ts.map +0 -1
  496. package/dist/components/cg-droppable/cg-droppable.js +0 -114
  497. package/dist/components/cg-droppable/cg-droppable.js.map +0 -1
  498. package/dist/components/cg-filter-bar/cg-filter-bar.d.ts +0 -50
  499. package/dist/components/cg-filter-bar/cg-filter-bar.d.ts.map +0 -1
  500. package/dist/components/cg-filter-bar/cg-filter-bar.js +0 -115
  501. package/dist/components/cg-filter-bar/cg-filter-bar.js.map +0 -1
  502. package/dist/components/cg-filter-chip/cg-filter-chip.d.ts +0 -55
  503. package/dist/components/cg-filter-chip/cg-filter-chip.d.ts.map +0 -1
  504. package/dist/components/cg-filter-chip/cg-filter-chip.js +0 -213
  505. package/dist/components/cg-filter-chip/cg-filter-chip.js.map +0 -1
  506. package/dist/components/cg-kanban/cg-kanban.d.ts +0 -44
  507. package/dist/components/cg-kanban/cg-kanban.d.ts.map +0 -1
  508. package/dist/components/cg-kanban/cg-kanban.js +0 -86
  509. package/dist/components/cg-kanban/cg-kanban.js.map +0 -1
  510. package/dist/components/cg-kanban-column/cg-kanban-column.d.ts +0 -58
  511. package/dist/components/cg-kanban-column/cg-kanban-column.d.ts.map +0 -1
  512. package/dist/components/cg-kanban-column/cg-kanban-column.js +0 -144
  513. package/dist/components/cg-kanban-column/cg-kanban-column.js.map +0 -1
  514. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.d.ts +0 -77
  515. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.d.ts.map +0 -1
  516. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.js +0 -245
  517. package/dist/components/cg-mfa-prompt/cg-mfa-prompt.js.map +0 -1
  518. package/dist/components/cg-search-input/cg-search-input.d.ts +0 -62
  519. package/dist/components/cg-search-input/cg-search-input.d.ts.map +0 -1
  520. package/dist/components/cg-search-input/cg-search-input.js +0 -106
  521. package/dist/components/cg-search-input/cg-search-input.js.map +0 -1
  522. package/dist/components/cg-sortable/cg-sortable.d.ts +0 -72
  523. package/dist/components/cg-sortable/cg-sortable.d.ts.map +0 -1
  524. package/dist/components/cg-sortable/cg-sortable.js +0 -177
  525. package/dist/components/cg-sortable/cg-sortable.js.map +0 -1
  526. package/dist/components/cg-theme/cg-theme.d.ts +0 -82
  527. package/dist/components/cg-theme/cg-theme.d.ts.map +0 -1
  528. package/dist/components/cg-theme/cg-theme.js +0 -91
  529. package/dist/components/cg-theme/cg-theme.js.map +0 -1
  530. package/dist/components/cg-theme-editor/cg-theme-editor.d.ts +0 -98
  531. package/dist/components/cg-theme-editor/cg-theme-editor.d.ts.map +0 -1
  532. package/dist/components/cg-theme-editor/cg-theme-editor.js +0 -341
  533. package/dist/components/cg-theme-editor/cg-theme-editor.js.map +0 -1
  534. package/dist/components/cg-timeline/cg-timeline.d.ts +0 -70
  535. package/dist/components/cg-timeline/cg-timeline.d.ts.map +0 -1
  536. package/dist/components/cg-timeline/cg-timeline.js +0 -131
  537. package/dist/components/cg-timeline/cg-timeline.js.map +0 -1
  538. package/dist/components/cg-timeline-event/cg-timeline-event.d.ts +0 -59
  539. package/dist/components/cg-timeline-event/cg-timeline-event.d.ts.map +0 -1
  540. package/dist/components/cg-timeline-event/cg-timeline-event.js +0 -190
  541. package/dist/components/cg-timeline-event/cg-timeline-event.js.map +0 -1
  542. package/dist/utils/drag-manager.d.ts +0 -40
  543. package/dist/utils/drag-manager.d.ts.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"cg-command.js","sources":["../../../src/components/cg-command/cg-command.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state, query } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\nimport { FocusTrap } from '../../utils/focus-trap.js';\nimport { handleRovingKey } from '../../utils/roving-index.js';\n\nexport interface CommandItem {\n id: string;\n label: string;\n group?: string;\n icon?: string;\n shortcut?: string;\n keywords?: string[];\n disabled?: boolean;\n}\n\n/**\n * @element cg-command\n * Searchable command palette foundation. Combobox pattern with grouped items,\n * keyboard navigation, and type-ahead filtering.\n *\n * @example\n * ```html\n * <cg-command\n * open\n * placeholder=\"Type a command...\"\n * .commands=${[\n * { id: 'new', label: 'New file', group: 'File', shortcut: '⌘N' },\n * { id: 'open', label: 'Open file', group: 'File', shortcut: '⌘O' },\n * ]}\n * ></cg-command>\n * ```\n *\n * @slot header - Content above the input\n * @slot footer - Content below the list\n * @slot empty - Custom empty state\n *\n * @fires {CustomEvent<{id: string, command: CommandItem}>} cg-command-select\n * @fires {CustomEvent<{value: string}>} cg-command-input\n * @fires {CustomEvent} cg-command-open\n * @fires {CustomEvent} cg-command-close\n */\n@customElement('cg-command')\nexport class CgCommand extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: contents;\n }\n\n .backdrop {\n position: fixed;\n inset: 0;\n z-index: var(--cg-z-index-500);\n background: var(--cg-color-modal-overlay-background);\n backdrop-filter: blur(var(--cg-blur-backdrop));\n opacity: 0;\n pointer-events: none;\n transition: opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n :host([open]) .backdrop {\n opacity: 1;\n pointer-events: auto;\n }\n\n .palette {\n position: fixed;\n top: 20%;\n left: 50%;\n z-index: var(--cg-z-index-top);\n width: calc(100% - var(--cg-spacing-32));\n max-width: var(--cg-component-command-width);\n max-height: var(--cg-component-command-max-height);\n display: flex;\n flex-direction: column;\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-command-radius);\n box-shadow: var(--cg-shadow-elevation-xl);\n opacity: 0;\n transform: translateX(-50%) translateY(calc(-1 * var(--cg-spacing-8))) scale(0.96);\n pointer-events: none;\n overflow: hidden;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n :host([open]) .palette {\n opacity: 1;\n transform: translateX(-50%) translateY(0) scale(1);\n pointer-events: auto;\n }\n\n .input-wrap {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-20);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n .search-icon {\n color: var(--cg-color-surface-container-outlined);\n flex-shrink: 0;\n }\n input {\n flex: 1;\n border: none;\n outline: none;\n background: none;\n color: var(--cg-color-surface-base-text);\n font-family: inherit;\n font-size: var(--cg-font-size-base);\n }\n input::placeholder { color: var(--cg-color-surface-container-outlined); }\n\n .list {\n flex: 1;\n overflow-y: auto;\n padding: var(--cg-spacing-8);\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-4);\n }\n\n /* Group label — uppercase mono. Extra top margin separates groups\n visually so the eye groups items by section. First group hugs the top. */\n .group-label {\n padding: var(--cg-spacing-6) var(--cg-spacing-12);\n margin-top: var(--cg-spacing-12);\n font: 600 var(--cg-font-size-xs) var(--cg-font-family-mono);\n color: var(--cg-color-surface-container-outlined);\n text-transform: uppercase;\n letter-spacing: 0.06em;\n }\n .group-label:first-child { margin-top: 0; }\n\n .item {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n width: 100%;\n /* min-height + real padding instead of fixed height — gives labels room\n to breathe and lets items grow if content wraps. */\n min-height: var(--cg-component-command-item-height);\n padding: var(--cg-spacing-8) var(--cg-spacing-12);\n border: none;\n background: none;\n color: var(--cg-color-surface-base-text);\n font-family: inherit;\n font-size: var(--cg-font-size-sm);\n line-height: var(--cg-line-height-snug);\n text-align: left;\n cursor: pointer;\n border-radius: var(--cg-border-radius-100);\n transition:\n background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n /* Hover (mouse) AND data-active (keyboard) get the same treatment so both\n input methods feel instant — no waiting for a state-driven re-render. */\n .item:hover:not([disabled]),\n .item[data-active]:not([disabled]) {\n background: var(--cg-color-action-tertiary-background-hover);\n color: var(--cg-color-surface-base-text);\n }\n .item:active:not([disabled]) {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .item[disabled] {\n opacity: 0.5;\n cursor: not-allowed;\n }\n .item-icon {\n flex-shrink: 0;\n color: var(--cg-color-surface-container-outlined);\n opacity: 0.85;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .item[data-active] .item-icon {\n color: var(--cg-color-action-primary-background-default);\n opacity: 1;\n }\n .item-label { flex: 1; }\n\n /* Loading state — small spinner + label, replaces empty/list when loading. */\n .loading {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-32);\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-sm);\n }\n .shortcut {\n font: 500 var(--cg-font-size-xs) var(--cg-font-family-mono);\n color: var(--cg-color-surface-container-outlined);\n padding: var(--cg-spacing-2) var(--cg-spacing-6);\n border-radius: var(--cg-border-radius-50);\n background: var(--cg-color-surface-container-background);\n }\n\n .empty {\n padding: var(--cg-spacing-40);\n text-align: center;\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-sm);\n }\n `];\n\n @property({ type: Boolean, reflect: true }) open = false;\n @property() placeholder = 'Type a command or search...';\n @property({ type: Array }) commands: CommandItem[] = [];\n @property() value = '';\n @property({ attribute: 'empty-text' }) emptyText = 'No results found.';\n @property({ type: Boolean }) loading = false;\n\n @state() private _activeIndex = 0;\n\n @query('input') private _inputEl!: HTMLInputElement;\n @query('.palette') private _paletteEl!: HTMLElement;\n\n private _focusTrap = new FocusTrap();\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this._focusTrap.deactivate();\n }\n\n override updated(changed: Map<string, unknown>): void {\n if (changed.has('open')) {\n if (this.open) this._onOpen();\n else this._onClose();\n }\n }\n\n private _onOpen(): void {\n this._activeIndex = 0;\n this.dispatchEvent(new CustomEvent('cg-command-open', { bubbles: true, composed: true }));\n requestAnimationFrame(() => {\n if (this._paletteEl) {\n this._focusTrap.activate(this._paletteEl, {\n initialFocus: this._inputEl,\n onEscape: () => { this.open = false; },\n });\n }\n });\n }\n\n private _onClose(): void {\n this._focusTrap.deactivate();\n this.dispatchEvent(new CustomEvent('cg-command-close', { bubbles: true, composed: true }));\n }\n\n private get _filteredCommands(): CommandItem[] {\n const query = this.value.toLowerCase().trim();\n if (!query) return this.commands;\n return this.commands.filter(c => {\n if (c.disabled) return false;\n const label = c.label.toLowerCase();\n const keywords = (c.keywords || []).join(' ').toLowerCase();\n return label.includes(query) || keywords.includes(query);\n });\n }\n\n private get _groupedCommands(): Array<{ group: string; items: CommandItem[] }> {\n const filtered = this._filteredCommands;\n const groups = new Map<string, CommandItem[]>();\n for (const cmd of filtered) {\n const group = cmd.group || '';\n if (!groups.has(group)) groups.set(group, []);\n groups.get(group)!.push(cmd);\n }\n return Array.from(groups.entries()).map(([group, items]) => ({ group, items }));\n }\n\n private _handleInput(e: Event): void {\n this.value = (e.target as HTMLInputElement).value;\n this._activeIndex = 0;\n this.dispatchEvent(new CustomEvent('cg-command-input', {\n detail: { value: this.value },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _handleKeydown(e: KeyboardEvent): void {\n // Enter-only select — Space is reserved for typing the query.\n if (e.key === ' ') return;\n const { index, handled } = handleRovingKey(e, {\n items: this._filteredCommands,\n activeIndex: this._activeIndex,\n onSelect: item => this._select(item),\n });\n if (handled) {\n e.preventDefault();\n this._activeIndex = index;\n }\n }\n\n private _select(item: CommandItem): void {\n if (item.disabled) return;\n this.dispatchEvent(new CustomEvent('cg-command-select', {\n detail: { id: item.id, command: item },\n bubbles: true,\n composed: true,\n }));\n this.open = false;\n this.value = '';\n }\n\n override render() {\n const groups = this._groupedCommands;\n const filtered = this._filteredCommands;\n let flatIndex = -1;\n\n return html`\n <div class=\"backdrop\" @click=${() => this.open = false}></div>\n <div\n class=\"palette\"\n role=\"dialog\"\n aria-label=\"Command palette\"\n aria-modal=\"true\"\n ?hidden=${!this.open}\n >\n <slot name=\"header\"></slot>\n <div class=\"input-wrap\">\n <cg-icon class=\"search-icon\" name=\"minimalistic-magnifer-linear\" size=\"sm\" aria-hidden=\"true\"></cg-icon>\n <input\n type=\"text\"\n role=\"combobox\"\n aria-expanded=${this.open ? 'true' : 'false'}\n aria-controls=\"command-list\"\n aria-autocomplete=\"list\"\n placeholder=${this.placeholder}\n .value=${this.value}\n @input=${this._handleInput}\n @keydown=${this._handleKeydown}\n />\n </div>\n <div class=\"list\" id=\"command-list\" role=\"listbox\">\n ${this.loading ? html`\n <div class=\"loading\" aria-busy=\"true\">\n <cg-spinner size=\"sm\"></cg-spinner>\n <span>Loading…</span>\n </div>\n ` : filtered.length === 0 ? html`\n <slot name=\"empty\">\n <div class=\"empty\">${this.emptyText}</div>\n </slot>\n ` : groups.map(({ group, items }) => html`\n ${group ? html`<div class=\"group-label\">${group}</div>` : nothing}\n ${items.map(item => {\n flatIndex++;\n const isActive = flatIndex === this._activeIndex;\n return html`\n <button\n class=\"item\"\n role=\"option\"\n ?disabled=${item.disabled}\n aria-selected=${isActive ? 'true' : 'false'}\n data-active=${isActive ? 'true' : nothing}\n @click=${() => this._select(item)}\n @mouseenter=${() => { this._activeIndex = flatIndex; }}\n >\n ${item.icon ? html`<cg-icon class=\"item-icon\" name=${item.icon} size=\"sm\" aria-hidden=\"true\"></cg-icon>` : nothing}\n <span class=\"item-label\">${item.label}</span>\n ${item.shortcut ? html`<span class=\"shortcut\">${item.shortcut}</span>` : nothing}\n </button>\n `;\n })}\n `)}\n </div>\n <slot name=\"footer\"></slot>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-command': CgCommand;\n }\n}\n"],"names":["CgCommand","LitElement","FocusTrap","changed","query","c","label","keywords","filtered","groups","cmd","group","items","index","handled","handleRovingKey","item","flatIndex","html","nothing","isActive","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"cg-command.js","sources":["../../../src/components/cg-command/cg-command.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state, query } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\nimport { FocusTrap } from '../../utils/focus-trap.js';\nimport { handleRovingKey } from '../../utils/roving-index.js';\n\nexport interface CommandItem {\n id: string;\n label: string;\n group?: string;\n icon?: string;\n shortcut?: string;\n keywords?: string[];\n disabled?: boolean;\n}\n\n/**\n * @element cg-command\n * Searchable command palette foundation. Combobox pattern with grouped items,\n * keyboard navigation, and type-ahead filtering.\n *\n * @example\n * ```html\n * <cg-command\n * open\n * placeholder=\"Type a command...\"\n * .commands=${[\n * { id: 'new', label: 'New file', group: 'File', shortcut: '⌘N' },\n * { id: 'open', label: 'Open file', group: 'File', shortcut: '⌘O' },\n * ]}\n * ></cg-command>\n * ```\n *\n * @slot header - Content above the input\n * @slot footer - Content below the list\n * @slot empty - Custom empty state\n *\n * @fires {CustomEvent<{id: string, command: CommandItem}>} cg-command-select\n * @fires {CustomEvent<{value: string}>} cg-command-input\n * @fires {CustomEvent} cg-command-open\n * @fires {CustomEvent} cg-command-close\n */\n@customElement('cg-command')\nexport class CgCommand extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: contents;\n }\n\n .backdrop {\n position: fixed;\n inset: 0;\n z-index: var(--cg-z-index-500);\n background: var(--cg-color-modal-overlay-background);\n backdrop-filter: blur(var(--cg-blur-backdrop));\n opacity: 0;\n pointer-events: none;\n transition: opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n :host([open]) .backdrop {\n opacity: 1;\n pointer-events: auto;\n }\n\n .palette {\n position: fixed;\n top: 20%;\n left: 50%;\n z-index: var(--cg-z-index-top);\n width: calc(100% - var(--cg-spacing-32));\n max-width: var(--cg-component-command-width);\n max-height: var(--cg-component-command-max-height);\n display: flex;\n flex-direction: column;\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-command-radius);\n box-shadow: var(--cg-shadow-elevation-xl);\n opacity: 0;\n transform: translateX(-50%) translateY(calc(-1 * var(--cg-spacing-8))) scale(0.96);\n pointer-events: none;\n overflow: hidden;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n :host([open]) .palette {\n opacity: 1;\n transform: translateX(-50%) translateY(0) scale(1);\n pointer-events: auto;\n }\n\n .input-wrap {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-20);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n .search-icon {\n color: var(--cg-color-surface-container-outlined);\n flex-shrink: 0;\n }\n input {\n flex: 1;\n border: none;\n outline: none;\n background: none;\n color: var(--cg-color-surface-base-text);\n font-family: inherit;\n font-size: var(--cg-font-size-base);\n }\n input::placeholder { color: var(--cg-color-surface-container-outlined); }\n\n .list {\n flex: 1;\n overflow-y: auto;\n padding: var(--cg-spacing-8);\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-4);\n }\n\n /* Group label — uppercase mono. Extra top margin separates groups\n visually so the eye groups items by section. First group hugs the top. */\n .group-label {\n padding: var(--cg-spacing-6) var(--cg-spacing-12);\n margin-top: var(--cg-spacing-12);\n font: 600 var(--cg-font-size-xs) var(--cg-font-family-mono);\n color: var(--cg-color-surface-container-outlined);\n text-transform: uppercase;\n letter-spacing: 0.06em;\n }\n .group-label:first-child { margin-top: 0; }\n\n .item {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n width: 100%;\n /* min-height + real padding instead of fixed height — gives labels room\n to breathe and lets items grow if content wraps. */\n min-height: var(--cg-component-command-item-height);\n padding: var(--cg-spacing-8) var(--cg-spacing-12);\n border: none;\n background: none;\n color: var(--cg-color-surface-base-text);\n font-family: inherit;\n font-size: var(--cg-font-size-sm);\n line-height: var(--cg-line-height-snug);\n text-align: left;\n cursor: pointer;\n border-radius: var(--cg-border-radius-100);\n transition:\n background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n /* Hover (mouse) AND data-active (keyboard) share the background so both\n input methods feel instant. The keyboard-active row additionally gets\n an accent left bar so the item Enter will trigger is unmistakable in a\n palette (a faint gray fill alone was too easy to lose track of). */\n .item:hover:not([disabled]),\n .item[data-active]:not([disabled]) {\n background: var(--cg-color-action-tertiary-background-hover);\n color: var(--cg-color-surface-base-text);\n }\n .item[data-active]:not([disabled]) {\n box-shadow: inset var(--cg-spacing-2) 0 0 0 var(--cg-color-action-primary-background-default);\n }\n .item:active:not([disabled]) {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .item[disabled] {\n opacity: 0.5;\n cursor: not-allowed;\n }\n .item-icon {\n flex-shrink: 0;\n color: var(--cg-color-surface-container-outlined);\n opacity: 0.85;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .item[data-active] .item-icon {\n color: var(--cg-color-action-primary-background-default);\n opacity: 1;\n }\n .item-label { flex: 1; }\n\n /* Loading state — small spinner + label, replaces empty/list when loading. */\n .loading {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: var(--cg-spacing-8);\n padding: var(--cg-spacing-32);\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-sm);\n }\n .shortcut {\n font: 500 var(--cg-font-size-xs) var(--cg-font-family-mono);\n color: var(--cg-color-surface-container-outlined);\n padding: var(--cg-spacing-2) var(--cg-spacing-6);\n border-radius: var(--cg-border-radius-50);\n background: var(--cg-color-surface-container-background);\n }\n\n .empty {\n padding: var(--cg-spacing-40);\n text-align: center;\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-sm);\n }\n `];\n\n @property({ type: Boolean, reflect: true }) open = false;\n @property() placeholder = 'Type a command or search...';\n @property({ type: Array }) commands: CommandItem[] = [];\n @property() value = '';\n @property({ attribute: 'empty-text' }) emptyText = 'No results found.';\n @property({ type: Boolean }) loading = false;\n\n @state() private _activeIndex = 0;\n\n @query('input') private _inputEl!: HTMLInputElement;\n @query('.palette') private _paletteEl!: HTMLElement;\n\n private _focusTrap = new FocusTrap();\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this._focusTrap.deactivate();\n }\n\n override updated(changed: Map<string, unknown>): void {\n if (changed.has('open')) {\n if (this.open) this._onOpen();\n else this._onClose();\n }\n }\n\n private _onOpen(): void {\n this._activeIndex = 0;\n this.dispatchEvent(new CustomEvent('cg-command-open', { bubbles: true, composed: true }));\n requestAnimationFrame(() => {\n if (this._paletteEl) {\n this._focusTrap.activate(this._paletteEl, {\n initialFocus: this._inputEl,\n onEscape: () => { this.open = false; },\n });\n }\n });\n }\n\n private _onClose(): void {\n this._focusTrap.deactivate();\n this.dispatchEvent(new CustomEvent('cg-command-close', { bubbles: true, composed: true }));\n }\n\n private get _filteredCommands(): CommandItem[] {\n const query = this.value.toLowerCase().trim();\n if (!query) return this.commands;\n return this.commands.filter(c => {\n if (c.disabled) return false;\n const label = c.label.toLowerCase();\n const keywords = (c.keywords || []).join(' ').toLowerCase();\n return label.includes(query) || keywords.includes(query);\n });\n }\n\n private get _groupedCommands(): Array<{ group: string; items: CommandItem[] }> {\n const filtered = this._filteredCommands;\n const groups = new Map<string, CommandItem[]>();\n for (const cmd of filtered) {\n const group = cmd.group || '';\n if (!groups.has(group)) groups.set(group, []);\n groups.get(group)!.push(cmd);\n }\n return Array.from(groups.entries()).map(([group, items]) => ({ group, items }));\n }\n\n private _handleInput(e: Event): void {\n this.value = (e.target as HTMLInputElement).value;\n this._activeIndex = 0;\n this.dispatchEvent(new CustomEvent('cg-command-input', {\n detail: { value: this.value },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _handleKeydown(e: KeyboardEvent): void {\n // Enter-only select — Space is reserved for typing the query.\n if (e.key === ' ') return;\n const { index, handled } = handleRovingKey(e, {\n items: this._filteredCommands,\n activeIndex: this._activeIndex,\n onSelect: item => this._select(item),\n });\n if (handled) {\n e.preventDefault();\n this._activeIndex = index;\n }\n }\n\n private _select(item: CommandItem): void {\n if (item.disabled) return;\n this.dispatchEvent(new CustomEvent('cg-command-select', {\n detail: { id: item.id, command: item },\n bubbles: true,\n composed: true,\n }));\n this.open = false;\n this.value = '';\n }\n\n override render() {\n const groups = this._groupedCommands;\n const filtered = this._filteredCommands;\n let flatIndex = -1;\n\n return html`\n <div class=\"backdrop\" @click=${() => this.open = false}></div>\n <div\n class=\"palette\"\n role=\"dialog\"\n aria-label=\"Command palette\"\n aria-modal=\"true\"\n ?hidden=${!this.open}\n >\n <slot name=\"header\"></slot>\n <div class=\"input-wrap\">\n <cg-icon class=\"search-icon\" name=\"minimalistic-magnifer-linear\" size=\"sm\" aria-hidden=\"true\"></cg-icon>\n <input\n type=\"text\"\n role=\"combobox\"\n aria-expanded=${this.open ? 'true' : 'false'}\n aria-controls=\"command-list\"\n aria-activedescendant=${this.open && filtered.length ? `command-opt-${this._activeIndex}` : nothing}\n aria-autocomplete=\"list\"\n placeholder=${this.placeholder}\n .value=${this.value}\n @input=${this._handleInput}\n @keydown=${this._handleKeydown}\n />\n </div>\n <div class=\"list\" id=\"command-list\" role=\"listbox\" aria-label=\"Commands\">\n ${this.loading ? html`\n <div class=\"loading\" aria-busy=\"true\">\n <cg-spinner size=\"sm\"></cg-spinner>\n <span>Loading…</span>\n </div>\n ` : filtered.length === 0 ? html`\n <slot name=\"empty\">\n <div class=\"empty\">${this.emptyText}</div>\n </slot>\n ` : groups.map(({ group, items }) => html`\n ${group ? html`<div class=\"group-label\">${group}</div>` : nothing}\n ${items.map(item => {\n flatIndex++;\n const isActive = flatIndex === this._activeIndex;\n return html`\n <button\n class=\"item\"\n id=${`command-opt-${flatIndex}`}\n role=\"option\"\n ?disabled=${item.disabled}\n aria-selected=${isActive ? 'true' : 'false'}\n data-active=${isActive ? 'true' : nothing}\n @click=${() => this._select(item)}\n @mouseenter=${() => { this._activeIndex = flatIndex; }}\n >\n ${item.icon ? html`<cg-icon class=\"item-icon\" name=${item.icon} size=\"sm\" aria-hidden=\"true\"></cg-icon>` : nothing}\n <span class=\"item-label\">${item.label}</span>\n ${item.shortcut ? html`<span class=\"shortcut\">${item.shortcut}</span>` : nothing}\n </button>\n `;\n })}\n `)}\n </div>\n <slot name=\"footer\"></slot>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-command': CgCommand;\n }\n}\n"],"names":["CgCommand","LitElement","FocusTrap","changed","query","c","label","keywords","filtered","groups","cmd","group","items","index","handled","handleRovingKey","item","flatIndex","html","nothing","isActive","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as u, html as l, nothing as d } from "lit";
2
2
  import { property as h, state as _, query as m, customElement as v } from "lit/decorators.js";
3
- import { h as f, r as b, m as E } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as f, r as b, m as E } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  import { a as g } from "../../chunks/floating-DfsaYJnh.js";
5
5
  import { b as L } from "../../chunks/outside-click-CP1P1fK3.js";
6
6
  import { h as x } from "../../chunks/roving-index-BuO0tTba.js";
@@ -1 +1 @@
1
- {"version":3,"file":"cg-date-picker.d.ts","sourceRoot":"","sources":["../../../src/components/cg-date-picker/cg-date-picker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAGrD,OAAO,+BAA+B,CAAC;AAEvC;;;;;;;;;;;GAWG;AACH,qBACa,YAAa,SAAQ,UAAU;IAC1C,OAAgB,MAAM,4BA8GnB;IAES,KAAK,SAAM;IACX,KAAK,SAAM;IACX,WAAW,SAAiB;IAC5B,IAAI,SAAM;IACV,MAAM,SAAM;IACZ,GAAG,SAAM;IACT,GAAG,SAAM;IACQ,IAAI,EAAE,IAAI,GAAG,IAAI,CAAQ;IACzB,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IAC5C,QAAQ,UAAS;IACF,KAAK,UAAS;IACd,OAAO,UAAS;IAEnD,OAAO,CAAC,KAAK,CAAS;IAE/B,OAAO,CAAC,OAAO;IAKf,OAAO,CAAC,MAAM;IAEd,OAAO,CAAC,iBAAiB;IAQzB,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,mBAAmB,CAEzB;IAEF,OAAO,CAAC,cAAc;IAOb,iBAAiB;IAIjB,oBAAoB;IAKpB,MAAM;CAwChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,gBAAgB,EAAE,YAAY,CAAC;KAAE;CACpE"}
1
+ {"version":3,"file":"cg-date-picker.d.ts","sourceRoot":"","sources":["../../../src/components/cg-date-picker/cg-date-picker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAGrD,OAAO,+BAA+B,CAAC;AAEvC;;;;;;;;;;;GAWG;AACH,qBACa,YAAa,SAAQ,UAAU;IAC1C,OAAgB,MAAM,4BA8GnB;IAES,KAAK,SAAM;IACX,KAAK,SAAM;IACX,WAAW,SAAiB;IAC5B,IAAI,SAAM;IACV,MAAM,SAAM;IACZ,GAAG,SAAM;IACT,GAAG,SAAM;IACQ,IAAI,EAAE,IAAI,GAAG,IAAI,CAAQ;IACzB,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IAC5C,QAAQ,UAAS;IACF,KAAK,UAAS;IACd,OAAO,UAAS;IAEnD,OAAO,CAAC,KAAK,CAAS;IAE/B,OAAO,CAAC,OAAO;IAKf,OAAO,CAAC,MAAM;IAEd,OAAO,CAAC,iBAAiB;IAQzB,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,mBAAmB,CAEzB;IAEF,OAAO,CAAC,cAAc;IAOb,iBAAiB;IAIjB,oBAAoB;IAKpB,MAAM;CA0ChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,gBAAgB,EAAE,YAAY,CAAC;KAAE;CACpE"}
@@ -1,8 +1,8 @@
1
- import { css as p, LitElement as u, nothing as g, html as d } from "lit";
2
- import { property as o, state as h, customElement as v } from "lit/decorators.js";
3
- import { h as f, r as b } from "../../chunks/premium.css-9I4kHrsl.js";
1
+ import { css as p, LitElement as u, nothing as d, html as g } from "lit";
2
+ import { property as t, state as h, customElement as v } from "lit/decorators.js";
3
+ import { h as f, r as b } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  import "../cg-calendar/cg-calendar.js";
5
- var m = Object.defineProperty, y = Object.getOwnPropertyDescriptor, t = (e, a, n, s) => {
5
+ var m = Object.defineProperty, y = Object.getOwnPropertyDescriptor, o = (e, a, n, s) => {
6
6
  for (var i = s > 1 ? void 0 : s ? y(a, n) : a, c = e.length - 1, l; c >= 0; c--)
7
7
  (l = e[c]) && (i = (s ? l(a, n, i) : l(i)) || i);
8
8
  return s && i && m(a, n, i), i;
@@ -43,14 +43,16 @@ let r = class extends u {
43
43
  }
44
44
  render() {
45
45
  const e = this._formatDisplay();
46
- return d`
47
- ${this.label ? d`<div class="label">${this.label}</div>` : g}
46
+ return g`
47
+ ${this.label ? g`<div class="label">${this.label}</div>` : d}
48
48
  <div
49
49
  class="trigger ${this._open ? "open" : ""} ${this.disabled ? "disabled" : ""}"
50
50
  tabindex=${this.disabled ? "-1" : "0"}
51
51
  role="combobox"
52
52
  aria-expanded=${this._open}
53
53
  aria-haspopup="dialog"
54
+ aria-controls="cg-dp-popover"
55
+ aria-invalid=${this.error ? "true" : d}
54
56
  aria-label=${this.label || "Date picker"}
55
57
  @click=${this._toggle}
56
58
  @keydown=${this._handleKeydown}
@@ -68,7 +70,7 @@ let r = class extends u {
68
70
  </span>
69
71
  </div>
70
72
 
71
- <div class="popover ${this._open ? "open" : ""}" role="dialog" aria-label="Calendar">
73
+ <div id="cg-dp-popover" class="popover ${this._open ? "open" : ""}" role="dialog" aria-label="Calendar">
72
74
  <cg-calendar
73
75
  mode="single"
74
76
  .value=${this.value}
@@ -77,7 +79,7 @@ let r = class extends u {
77
79
  @cg-calendar-change=${this._onCalendarChange}
78
80
  ></cg-calendar>
79
81
  </div>
80
- ${this.helper ? d`<div class="helper">${this.helper}</div>` : g}
82
+ ${this.helper ? g`<div class="helper">${this.helper}</div>` : d}
81
83
  `;
82
84
  }
83
85
  };
@@ -192,46 +194,46 @@ r.styles = [f, b, p`
192
194
  :host([error]) .helper { color: var(--cg-color-status-error-text-default); }
193
195
  :host([success]) .helper { color: var(--cg-color-status-success-text-default); }
194
196
  `];
195
- t([
196
- o()
197
+ o([
198
+ t()
197
199
  ], r.prototype, "label", 2);
198
- t([
199
- o()
200
+ o([
201
+ t()
200
202
  ], r.prototype, "value", 2);
201
- t([
202
- o()
203
+ o([
204
+ t()
203
205
  ], r.prototype, "placeholder", 2);
204
- t([
205
- o()
206
+ o([
207
+ t()
206
208
  ], r.prototype, "name", 2);
207
- t([
208
- o()
209
+ o([
210
+ t()
209
211
  ], r.prototype, "helper", 2);
210
- t([
211
- o()
212
+ o([
213
+ t()
212
214
  ], r.prototype, "min", 2);
213
- t([
214
- o()
215
+ o([
216
+ t()
215
217
  ], r.prototype, "max", 2);
216
- t([
217
- o({ reflect: !0 })
218
+ o([
219
+ t({ reflect: !0 })
218
220
  ], r.prototype, "size", 2);
219
- t([
220
- o({ reflect: !0 })
221
+ o([
222
+ t({ reflect: !0 })
221
223
  ], r.prototype, "rounded", 2);
222
- t([
223
- o({ type: Boolean })
224
+ o([
225
+ t({ type: Boolean })
224
226
  ], r.prototype, "disabled", 2);
225
- t([
226
- o({ type: Boolean, reflect: !0 })
227
+ o([
228
+ t({ type: Boolean, reflect: !0 })
227
229
  ], r.prototype, "error", 2);
228
- t([
229
- o({ type: Boolean, reflect: !0 })
230
+ o([
231
+ t({ type: Boolean, reflect: !0 })
230
232
  ], r.prototype, "success", 2);
231
- t([
233
+ o([
232
234
  h()
233
235
  ], r.prototype, "_open", 2);
234
- r = t([
236
+ r = o([
235
237
  v("cg-date-picker")
236
238
  ], r);
237
239
  export {
@@ -1 +1 @@
1
- {"version":3,"file":"cg-date-picker.js","sources":["../../../src/components/cg-date-picker/cg-date-picker.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\nimport '../cg-calendar/cg-calendar.js';\n\n/**\n * @element cg-date-picker\n * Date picker trigger that opens a single-mode cg-calendar in a floating popover.\n *\n * @example\n * ```html\n * <cg-date-picker label=\"Start date\" placeholder=\"Pick a date\"></cg-date-picker>\n * <cg-date-picker label=\"Birthday\" value=\"2000-01-15\" min=\"1900-01-01\" max=\"2025-12-31\"></cg-date-picker>\n * ```\n *\n * @fires {CustomEvent<{value: string}>} cg-change - When a date is selected\n */\n@customElement('cg-date-picker')\nexport class CgDatePicker extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host { position: relative; }\n\n /* ── Trigger ── */\n .trigger {\n display: flex;\n align-items: center;\n gap: 0;\n padding: 0 var(--cg-spacing-4);\n height: var(--cg-component-input-height-md);\n border: var(--cg-border-width-50) solid var(--cg-color-input-border-default);\n border-radius: var(--cg-component-input-radius);\n background: var(--cg-color-input-background-default);\n color: var(--cg-color-input-text-default);\n font: inherit;\n font-size: var(--cg-font-size-sm);\n cursor: pointer;\n outline: none;\n transition:\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n box-shadow var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .trigger:hover:not(.disabled) { border-color: var(--cg-color-input-border-hover); }\n .trigger:focus-visible,\n .trigger.open {\n border-color: var(--cg-color-input-border-focus);\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n .trigger.disabled { opacity: 0.5; pointer-events: none; background: var(--cg-color-input-background-disabled); border-color: var(--cg-color-input-border-disabled); }\n\n :host([error]) .trigger { border-color: var(--cg-color-input-border-error); }\n :host([error]) .trigger:focus-visible,\n :host([error]) .trigger.open { border-color: var(--cg-color-status-error-text-default); box-shadow: 0 0 0 3px var(--cg-shadow-focus-error); }\n :host([success]) .trigger { border-color: var(--cg-color-input-icon-success); }\n :host([success]) .trigger:focus-visible,\n :host([success]) .trigger.open { border-color: var(--cg-color-status-success-text-default); box-shadow: 0 0 0 3px var(--cg-shadow-focus-success); }\n\n /* Size */\n :host([size=\"lg\"]) .trigger { height: var(--cg-component-input-height-lg); padding: 0 var(--cg-spacing-4); font-size: var(--cg-font-size-base); }\n\n /* Rounded */\n :host([rounded=\"none\"]) .trigger { border-radius: 0; }\n :host([rounded=\"sm\"]) .trigger { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .trigger { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .trigger { border-radius: var(--cg-component-input-radius); }\n\n .trigger-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--cg-color-input-icon-default);\n flex-shrink: 0;\n width: var(--cg-spacing-40);\n align-self: stretch;\n background: var(--cg-overlay-dark-subtle);\n border-right: var(--cg-border-width-50) solid var(--cg-color-input-border-default);\n border-radius: var(--cg-component-input-radius) 0 0 var(--cg-component-input-radius);\n margin-left: calc(-1 * var(--cg-spacing-4));\n }\n .trigger-icon svg {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n }\n .trigger-text {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n padding: 0 var(--cg-spacing-12);\n }\n .placeholder { color: var(--cg-color-input-text-placeholder); }\n\n .label {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-text);\n margin-bottom: var(--cg-spacing-4);\n font-weight: var(--cg-font-weight-medium);\n }\n\n /* ── Popover (positioning + animation only — cg-calendar owns the visual chrome) ── */\n .popover {\n position: absolute;\n top: 100%;\n left: 0;\n z-index: var(--cg-z-index-200);\n margin-top: var(--cg-spacing-4);\n border-radius: var(--cg-component-calendar-radius);\n box-shadow: var(--cg-shadow-elevation-xl);\n opacity: 0;\n transform: translateY(calc(-1 * var(--cg-spacing-4))) scale(0.98);\n pointer-events: none;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .popover.open {\n opacity: 1;\n transform: translateY(0) scale(1);\n pointer-events: auto;\n }\n\n /* ── Helper ── */\n .helper {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n padding: var(--cg-spacing-4) 0 0;\n }\n :host([error]) .helper { color: var(--cg-color-status-error-text-default); }\n :host([success]) .helper { color: var(--cg-color-status-success-text-default); }\n `];\n\n @property() label = '';\n @property() value = '';\n @property() placeholder = 'Select date';\n @property() name = '';\n @property() helper = '';\n @property() min = '';\n @property() max = '';\n @property({ reflect: true }) size: 'md' | 'lg' = 'md';\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' = 'lg';\n @property({ type: Boolean }) disabled = false;\n @property({ type: Boolean, reflect: true }) error = false;\n @property({ type: Boolean, reflect: true }) success = false;\n\n @state() private _open = false;\n\n private _toggle() {\n if (this.disabled) return;\n this._open = !this._open;\n }\n\n private _close() { this._open = false; }\n\n private _onCalendarChange(e: Event) {\n const ev = e as CustomEvent<{ value: string }>;\n e.stopPropagation();\n this.value = ev.detail.value || '';\n this._close();\n this.dispatchEvent(new CustomEvent('cg-change', { detail: { value: this.value }, bubbles: true, composed: true }));\n }\n\n private _formatDisplay(): string {\n if (!this.value) return '';\n const d = new Date(this.value + 'T00:00:00');\n if (isNaN(d.getTime())) return '';\n return d.toLocaleDateString(undefined, { year: 'numeric', month: 'short', day: 'numeric' });\n }\n\n private _handleClickOutside = (e: Event) => {\n if (!e.composedPath().includes(this)) this._close();\n };\n\n private _handleKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape') { this._close(); return; }\n if (e.key === 'Enter' || e.key === ' ') {\n if (!this._open) { e.preventDefault(); this._toggle(); }\n }\n }\n\n override connectedCallback() {\n super.connectedCallback();\n document.addEventListener('click', this._handleClickOutside);\n }\n override disconnectedCallback() {\n super.disconnectedCallback();\n document.removeEventListener('click', this._handleClickOutside);\n }\n\n override render() {\n const display = this._formatDisplay();\n\n return html`\n ${this.label ? html`<div class=\"label\">${this.label}</div>` : nothing}\n <div\n class=\"trigger ${this._open ? 'open' : ''} ${this.disabled ? 'disabled' : ''}\"\n tabindex=${this.disabled ? '-1' : '0'}\n role=\"combobox\"\n aria-expanded=${this._open}\n aria-haspopup=\"dialog\"\n aria-label=${this.label || 'Date picker'}\n @click=${this._toggle}\n @keydown=${this._handleKeydown}\n >\n <span class=\"trigger-icon\" aria-hidden=\"true\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <rect x=\"3\" y=\"4\" width=\"18\" height=\"18\" rx=\"2\" ry=\"2\"></rect>\n <line x1=\"16\" y1=\"2\" x2=\"16\" y2=\"6\"></line>\n <line x1=\"8\" y1=\"2\" x2=\"8\" y2=\"6\"></line>\n <line x1=\"3\" y1=\"10\" x2=\"21\" y2=\"10\"></line>\n </svg>\n </span>\n <span class=\"trigger-text ${!display ? 'placeholder' : ''}\">\n ${display || this.placeholder}\n </span>\n </div>\n\n <div class=\"popover ${this._open ? 'open' : ''}\" role=\"dialog\" aria-label=\"Calendar\">\n <cg-calendar\n mode=\"single\"\n .value=${this.value}\n .min=${this.min}\n .max=${this.max}\n @cg-calendar-change=${this._onCalendarChange}\n ></cg-calendar>\n </div>\n ${this.helper ? html`<div class=\"helper\">${this.helper}</div>` : nothing}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-date-picker': CgDatePicker; }\n}\n"],"names":["CgDatePicker","LitElement","ev","d","display","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"cg-date-picker.js","sources":["../../../src/components/cg-date-picker/cg-date-picker.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\nimport '../cg-calendar/cg-calendar.js';\n\n/**\n * @element cg-date-picker\n * Date picker trigger that opens a single-mode cg-calendar in a floating popover.\n *\n * @example\n * ```html\n * <cg-date-picker label=\"Start date\" placeholder=\"Pick a date\"></cg-date-picker>\n * <cg-date-picker label=\"Birthday\" value=\"2000-01-15\" min=\"1900-01-01\" max=\"2025-12-31\"></cg-date-picker>\n * ```\n *\n * @fires {CustomEvent<{value: string}>} cg-change - When a date is selected\n */\n@customElement('cg-date-picker')\nexport class CgDatePicker extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host { position: relative; }\n\n /* ── Trigger ── */\n .trigger {\n display: flex;\n align-items: center;\n gap: 0;\n padding: 0 var(--cg-spacing-4);\n height: var(--cg-component-input-height-md);\n border: var(--cg-border-width-50) solid var(--cg-color-input-border-default);\n border-radius: var(--cg-component-input-radius);\n background: var(--cg-color-input-background-default);\n color: var(--cg-color-input-text-default);\n font: inherit;\n font-size: var(--cg-font-size-sm);\n cursor: pointer;\n outline: none;\n transition:\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n box-shadow var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .trigger:hover:not(.disabled) { border-color: var(--cg-color-input-border-hover); }\n .trigger:focus-visible,\n .trigger.open {\n border-color: var(--cg-color-input-border-focus);\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n .trigger.disabled { opacity: 0.5; pointer-events: none; background: var(--cg-color-input-background-disabled); border-color: var(--cg-color-input-border-disabled); }\n\n :host([error]) .trigger { border-color: var(--cg-color-input-border-error); }\n :host([error]) .trigger:focus-visible,\n :host([error]) .trigger.open { border-color: var(--cg-color-status-error-text-default); box-shadow: 0 0 0 3px var(--cg-shadow-focus-error); }\n :host([success]) .trigger { border-color: var(--cg-color-input-icon-success); }\n :host([success]) .trigger:focus-visible,\n :host([success]) .trigger.open { border-color: var(--cg-color-status-success-text-default); box-shadow: 0 0 0 3px var(--cg-shadow-focus-success); }\n\n /* Size */\n :host([size=\"lg\"]) .trigger { height: var(--cg-component-input-height-lg); padding: 0 var(--cg-spacing-4); font-size: var(--cg-font-size-base); }\n\n /* Rounded */\n :host([rounded=\"none\"]) .trigger { border-radius: 0; }\n :host([rounded=\"sm\"]) .trigger { border-radius: var(--cg-border-radius-50); }\n :host([rounded=\"md\"]) .trigger { border-radius: var(--cg-border-radius-100); }\n :host([rounded=\"lg\"]) .trigger { border-radius: var(--cg-component-input-radius); }\n\n .trigger-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--cg-color-input-icon-default);\n flex-shrink: 0;\n width: var(--cg-spacing-40);\n align-self: stretch;\n background: var(--cg-overlay-dark-subtle);\n border-right: var(--cg-border-width-50) solid var(--cg-color-input-border-default);\n border-radius: var(--cg-component-input-radius) 0 0 var(--cg-component-input-radius);\n margin-left: calc(-1 * var(--cg-spacing-4));\n }\n .trigger-icon svg {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n }\n .trigger-text {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n padding: 0 var(--cg-spacing-12);\n }\n .placeholder { color: var(--cg-color-input-text-placeholder); }\n\n .label {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-text);\n margin-bottom: var(--cg-spacing-4);\n font-weight: var(--cg-font-weight-medium);\n }\n\n /* ── Popover (positioning + animation only — cg-calendar owns the visual chrome) ── */\n .popover {\n position: absolute;\n top: 100%;\n left: 0;\n z-index: var(--cg-z-index-200);\n margin-top: var(--cg-spacing-4);\n border-radius: var(--cg-component-calendar-radius);\n box-shadow: var(--cg-shadow-elevation-xl);\n opacity: 0;\n transform: translateY(calc(-1 * var(--cg-spacing-4))) scale(0.98);\n pointer-events: none;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .popover.open {\n opacity: 1;\n transform: translateY(0) scale(1);\n pointer-events: auto;\n }\n\n /* ── Helper ── */\n .helper {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n padding: var(--cg-spacing-4) 0 0;\n }\n :host([error]) .helper { color: var(--cg-color-status-error-text-default); }\n :host([success]) .helper { color: var(--cg-color-status-success-text-default); }\n `];\n\n @property() label = '';\n @property() value = '';\n @property() placeholder = 'Select date';\n @property() name = '';\n @property() helper = '';\n @property() min = '';\n @property() max = '';\n @property({ reflect: true }) size: 'md' | 'lg' = 'md';\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' = 'lg';\n @property({ type: Boolean }) disabled = false;\n @property({ type: Boolean, reflect: true }) error = false;\n @property({ type: Boolean, reflect: true }) success = false;\n\n @state() private _open = false;\n\n private _toggle() {\n if (this.disabled) return;\n this._open = !this._open;\n }\n\n private _close() { this._open = false; }\n\n private _onCalendarChange(e: Event) {\n const ev = e as CustomEvent<{ value: string }>;\n e.stopPropagation();\n this.value = ev.detail.value || '';\n this._close();\n this.dispatchEvent(new CustomEvent('cg-change', { detail: { value: this.value }, bubbles: true, composed: true }));\n }\n\n private _formatDisplay(): string {\n if (!this.value) return '';\n const d = new Date(this.value + 'T00:00:00');\n if (isNaN(d.getTime())) return '';\n return d.toLocaleDateString(undefined, { year: 'numeric', month: 'short', day: 'numeric' });\n }\n\n private _handleClickOutside = (e: Event) => {\n if (!e.composedPath().includes(this)) this._close();\n };\n\n private _handleKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape') { this._close(); return; }\n if (e.key === 'Enter' || e.key === ' ') {\n if (!this._open) { e.preventDefault(); this._toggle(); }\n }\n }\n\n override connectedCallback() {\n super.connectedCallback();\n document.addEventListener('click', this._handleClickOutside);\n }\n override disconnectedCallback() {\n super.disconnectedCallback();\n document.removeEventListener('click', this._handleClickOutside);\n }\n\n override render() {\n const display = this._formatDisplay();\n\n return html`\n ${this.label ? html`<div class=\"label\">${this.label}</div>` : nothing}\n <div\n class=\"trigger ${this._open ? 'open' : ''} ${this.disabled ? 'disabled' : ''}\"\n tabindex=${this.disabled ? '-1' : '0'}\n role=\"combobox\"\n aria-expanded=${this._open}\n aria-haspopup=\"dialog\"\n aria-controls=\"cg-dp-popover\"\n aria-invalid=${this.error ? 'true' : nothing}\n aria-label=${this.label || 'Date picker'}\n @click=${this._toggle}\n @keydown=${this._handleKeydown}\n >\n <span class=\"trigger-icon\" aria-hidden=\"true\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <rect x=\"3\" y=\"4\" width=\"18\" height=\"18\" rx=\"2\" ry=\"2\"></rect>\n <line x1=\"16\" y1=\"2\" x2=\"16\" y2=\"6\"></line>\n <line x1=\"8\" y1=\"2\" x2=\"8\" y2=\"6\"></line>\n <line x1=\"3\" y1=\"10\" x2=\"21\" y2=\"10\"></line>\n </svg>\n </span>\n <span class=\"trigger-text ${!display ? 'placeholder' : ''}\">\n ${display || this.placeholder}\n </span>\n </div>\n\n <div id=\"cg-dp-popover\" class=\"popover ${this._open ? 'open' : ''}\" role=\"dialog\" aria-label=\"Calendar\">\n <cg-calendar\n mode=\"single\"\n .value=${this.value}\n .min=${this.min}\n .max=${this.max}\n @cg-calendar-change=${this._onCalendarChange}\n ></cg-calendar>\n </div>\n ${this.helper ? html`<div class=\"helper\">${this.helper}</div>` : nothing}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-date-picker': CgDatePicker; }\n}\n"],"names":["CgDatePicker","LitElement","ev","d","display","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -21,6 +21,8 @@ export declare class CgDateRangePicker extends LitElement {
21
21
  min: string;
22
22
  max: string;
23
23
  placeholder: string;
24
+ /** Placeholder for the end-date segment (overridable / i18n-able). */
25
+ endPlaceholder: string;
24
26
  format: string;
25
27
  disabled: boolean;
26
28
  open: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"cg-date-range-picker.d.ts","sourceRoot":"","sources":["../../../src/components/cg-date-range-picker/cg-date-range-picker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAGrD,OAAO,+BAA+B,CAAC;AAEvC;;;;;;;;;;GAUG;AACH,qBACa,iBAAkB,SAAQ,UAAU;IAC/C,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,4BAwHnB;IAES,KAAK,SAAM;IACX,IAAI,SAAM;IACV,EAAE,SAAM;IACR,GAAG,SAAM;IACT,GAAG,SAAM;IACT,WAAW,SAAuB;IAClC,MAAM,SAAkB;IACP,QAAQ,UAAS;IACF,IAAI,UAAS;IAC7C,KAAK,SAAM;IAEd,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC;IAM9C,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,OAAO;IAKf,OAAO,CAAC,MAAM;IAId,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,iBAAiB;IAkBzB,OAAO,CAAC,mBAAmB,CAEzB;IAEO,iBAAiB;IAIjB,oBAAoB;IAK7B,OAAO,CAAC,cAAc;IAOb,MAAM;CAgDhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,sBAAsB,EAAE,iBAAiB,CAAC;KAC3C;CACF"}
1
+ {"version":3,"file":"cg-date-range-picker.d.ts","sourceRoot":"","sources":["../../../src/components/cg-date-range-picker/cg-date-range-picker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAGrD,OAAO,+BAA+B,CAAC;AAEvC;;;;;;;;;;GAUG;AACH,qBACa,iBAAkB,SAAQ,UAAU;IAC/C,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,4BAwHnB;IAES,KAAK,SAAM;IACX,IAAI,SAAM;IACV,EAAE,SAAM;IACR,GAAG,SAAM;IACT,GAAG,SAAM;IACT,WAAW,SAAuB;IAC9C,sEAAsE;IAC1B,cAAc,SAAc;IAC5D,MAAM,SAAkB;IACP,QAAQ,UAAS;IACF,IAAI,UAAS;IAC7C,KAAK,SAAM;IAEd,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC;IAM9C,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,OAAO;IAKf,OAAO,CAAC,MAAM;IAId,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,iBAAiB;IAkBzB,OAAO,CAAC,mBAAmB,CAEzB;IAEO,iBAAiB;IAIjB,oBAAoB;IAK7B,OAAO,CAAC,cAAc;IAOb,MAAM;CAiDhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,sBAAsB,EAAE,iBAAiB,CAAC;KAC3C;CACF"}
@@ -1,6 +1,6 @@
1
- import { css as p, LitElement as h, nothing as l, html as g } from "lit";
1
+ import { css as g, LitElement as h, nothing as l, html as p } from "lit";
2
2
  import { property as a, customElement as u } from "lit/decorators.js";
3
- import { h as f, r as v } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as f, r as v } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  import "../cg-calendar/cg-calendar.js";
5
5
  var m = Object.defineProperty, b = Object.getOwnPropertyDescriptor, o = (e, t, s, n) => {
6
6
  for (var i = n > 1 ? void 0 : n ? b(t, s) : t, c = e.length - 1, d; c >= 0; c--)
@@ -9,7 +9,7 @@ var m = Object.defineProperty, b = Object.getOwnPropertyDescriptor, o = (e, t, s
9
9
  };
10
10
  let r = class extends h {
11
11
  constructor() {
12
- super(), this.label = "", this.from = "", this.to = "", this.min = "", this.max = "", this.placeholder = "Select date range", this.format = "MMM dd, yyyy", this.disabled = !1, this.open = !1, this.error = "", this._handleClickOutside = (e) => {
12
+ super(), this.label = "", this.from = "", this.to = "", this.min = "", this.max = "", this.placeholder = "Select date range", this.endPlaceholder = "End date", this.format = "MMM dd, yyyy", this.disabled = !1, this.open = !1, this.error = "", this._handleClickOutside = (e) => {
13
13
  e.composedPath().includes(this) || this._close();
14
14
  }, "attachInternals" in this && (this._internals = this.attachInternals());
15
15
  }
@@ -59,13 +59,14 @@ let r = class extends h {
59
59
  }
60
60
  render() {
61
61
  const e = this._formatDisplay(this.from), t = this._formatDisplay(this.to);
62
- return g`
63
- ${this.label ? g`<label class="label">${this.label}</label>` : l}
62
+ return p`
63
+ ${this.label ? p`<label class="label">${this.label}</label>` : l}
64
64
  <div
65
65
  class="trigger ${this.open ? "open" : ""} ${this.disabled ? "disabled" : ""} ${this.error ? "invalid" : ""}"
66
66
  role="combobox"
67
67
  tabindex=${this.disabled ? "-1" : "0"}
68
68
  aria-expanded=${this.open ? "true" : "false"}
69
+ aria-disabled=${this.disabled ? "true" : l}
69
70
  aria-haspopup="dialog"
70
71
  aria-controls="cg-drp-dropdown"
71
72
  aria-label=${this.label || "Date range picker"}
@@ -88,7 +89,7 @@ let r = class extends h {
88
89
  <path d="M9 6l6 6-6 6"/>
89
90
  </svg>
90
91
  </span>
91
- <span class="segment ${t ? "" : "empty"}">${t || "End date"}</span>
92
+ <span class="segment ${t ? "" : "empty"}">${t || this.endPlaceholder}</span>
92
93
  </div>
93
94
 
94
95
  <div id="cg-drp-dropdown" class="dropdown ${this.open ? "open" : ""}" role="dialog" aria-label="Date range calendar">
@@ -101,12 +102,12 @@ let r = class extends h {
101
102
  @cg-calendar-change=${this._onCalendarChange}
102
103
  ></cg-calendar>
103
104
  </div>
104
- ${this.error ? g`<span id="cg-drp-error" class="error-message" role="alert">${this.error}</span>` : l}
105
+ ${this.error ? p`<span id="cg-drp-error" class="error-message" role="alert">${this.error}</span>` : l}
105
106
  `;
106
107
  }
107
108
  };
108
109
  r.formAssociated = !0;
109
- r.styles = [f, v, p`
110
+ r.styles = [f, v, g`
110
111
  :host { position: relative; font-family: var(--cg-font-family-primary); }
111
112
 
112
113
  .label {
@@ -245,6 +246,9 @@ o([
245
246
  o([
246
247
  a()
247
248
  ], r.prototype, "placeholder", 2);
249
+ o([
250
+ a({ attribute: "end-placeholder" })
251
+ ], r.prototype, "endPlaceholder", 2);
248
252
  o([
249
253
  a()
250
254
  ], r.prototype, "format", 2);
@@ -1 +1 @@
1
- {"version":3,"file":"cg-date-range-picker.js","sources":["../../../src/components/cg-date-range-picker/cg-date-range-picker.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\nimport '../cg-calendar/cg-calendar.js';\n\n/**\n * @element cg-date-range-picker\n * Dual-input date range picker that opens a range-mode cg-calendar.\n *\n * @example\n * ```html\n * <cg-date-range-picker label=\"Dates\" from=\"2026-04-01\" to=\"2026-04-10\"></cg-date-range-picker>\n * ```\n *\n * @fires {CustomEvent<{from: string, to: string}>} cg-date-range-change\n */\n@customElement('cg-date-range-picker')\nexport class CgDateRangePicker extends LitElement {\n static formAssociated = true;\n private _internals: ElementInternals | undefined;\n\n constructor() {\n super();\n if ('attachInternals' in this) {\n this._internals = this.attachInternals();\n }\n }\n\n static override styles = [hostBlock, reducedMotion, css`\n :host { position: relative; font-family: var(--cg-font-family-primary); }\n\n .label {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-text);\n margin-bottom: var(--cg-spacing-4);\n font-weight: var(--cg-font-weight-medium);\n display: block;\n }\n\n .trigger {\n display: flex;\n align-items: center;\n gap: 0;\n height: var(--cg-component-input-height-md);\n padding: 0 var(--cg-spacing-4);\n border: var(--cg-border-width-50) solid var(--cg-color-input-border-default);\n border-radius: var(--cg-component-input-radius);\n background: var(--cg-color-input-background-default);\n color: var(--cg-color-input-text-default);\n font-size: var(--cg-font-size-sm);\n cursor: pointer;\n outline: none;\n transition:\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n box-shadow var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .trigger-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--cg-color-input-icon-default);\n flex-shrink: 0;\n width: var(--cg-spacing-40);\n align-self: stretch;\n background: var(--cg-overlay-dark-subtle);\n border-right: var(--cg-border-width-50) solid var(--cg-color-input-border-default);\n border-radius: var(--cg-component-input-radius) 0 0 var(--cg-component-input-radius);\n margin-left: calc(-1 * var(--cg-spacing-4));\n }\n .trigger-icon svg {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n }\n\n .trigger:hover:not(.disabled) {\n border-color: var(--cg-color-input-border-hover);\n }\n\n .trigger.open,\n .trigger:focus-visible {\n border-color: var(--cg-color-input-border-focus);\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n .trigger.disabled {\n opacity: 0.5;\n pointer-events: none;\n background: var(--cg-color-input-background-disabled);\n }\n\n .trigger.invalid {\n border-color: var(--cg-color-status-error-border-default);\n }\n .trigger.invalid:focus-visible,\n .trigger.invalid.open {\n border-color: var(--cg-color-status-error-text-default);\n box-shadow: 0 0 0 3px var(--cg-shadow-focus-error);\n }\n\n .error-message {\n display: block;\n margin-top: var(--cg-spacing-4);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-status-error-text-default);\n }\n\n .segment {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n padding: 0 var(--cg-spacing-12);\n }\n .segment.empty { color: var(--cg-color-input-text-placeholder); }\n\n .arrow {\n flex-shrink: 0;\n color: var(--cg-color-input-text-placeholder);\n display: flex;\n align-items: center;\n padding: 0 var(--cg-spacing-2);\n }\n .arrow svg {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n }\n\n .dropdown {\n position: absolute;\n top: 100%;\n left: 0;\n z-index: var(--cg-z-index-200);\n margin-top: var(--cg-spacing-4);\n border-radius: var(--cg-component-calendar-radius);\n box-shadow: var(--cg-shadow-elevation-xl);\n opacity: 0;\n transform: translateY(calc(-1 * var(--cg-spacing-4))) scale(0.98);\n pointer-events: none;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .dropdown.open {\n opacity: 1;\n transform: translateY(0) scale(1);\n pointer-events: auto;\n }\n `];\n\n @property() label = '';\n @property() from = '';\n @property() to = '';\n @property() min = '';\n @property() max = '';\n @property() placeholder = 'Select date range';\n @property() format = 'MMM dd, yyyy';\n @property({ type: Boolean }) disabled = false;\n @property({ type: Boolean, reflect: true }) open = false;\n @property() error = '';\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('from') || changed.has('to')) {\n this._syncFormValue();\n }\n }\n\n private _syncFormValue() {\n if (!this._internals) return;\n const fd = new FormData();\n if (this.from) fd.append('from', this.from);\n if (this.to) fd.append('to', this.to);\n this._internals.setFormValue(fd);\n }\n\n private _toggle() {\n if (this.disabled) return;\n this.open = !this.open;\n }\n\n private _close() {\n this.open = false;\n }\n\n private _formatDisplay(iso: string): string {\n if (!iso) return '';\n const d = new Date(iso + 'T00:00:00');\n if (isNaN(d.getTime())) return '';\n return d.toLocaleDateString(undefined, { year: 'numeric', month: 'short', day: 'numeric' });\n }\n\n private _onCalendarChange(e: Event) {\n const ev = e as CustomEvent<{ value: string; rangeEnd?: string }>;\n e.stopPropagation();\n const { value, rangeEnd } = ev.detail;\n this.from = value || '';\n this.to = rangeEnd || '';\n\n if (this.from && this.to) {\n this.dispatchEvent(new CustomEvent('cg-date-range-change', {\n detail: { from: this.from, to: this.to },\n bubbles: true,\n composed: true,\n }));\n // Close after both picked\n setTimeout(() => { this.open = false; }, 120);\n }\n }\n\n private _handleClickOutside = (e: Event) => {\n if (!e.composedPath().includes(this)) this._close();\n };\n\n override connectedCallback() {\n super.connectedCallback();\n document.addEventListener('click', this._handleClickOutside);\n }\n override disconnectedCallback() {\n super.disconnectedCallback();\n document.removeEventListener('click', this._handleClickOutside);\n }\n\n private _handleKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape') { this._close(); return; }\n if (e.key === 'Enter' || e.key === ' ') {\n if (!this.open) { e.preventDefault(); this._toggle(); }\n }\n }\n\n override render() {\n const fromText = this._formatDisplay(this.from);\n const toText = this._formatDisplay(this.to);\n return html`\n ${this.label ? html`<label class=\"label\">${this.label}</label>` : nothing}\n <div\n class=\"trigger ${this.open ? 'open' : ''} ${this.disabled ? 'disabled' : ''} ${this.error ? 'invalid' : ''}\"\n role=\"combobox\"\n tabindex=${this.disabled ? '-1' : '0'}\n aria-expanded=${this.open ? 'true' : 'false'}\n aria-haspopup=\"dialog\"\n aria-controls=\"cg-drp-dropdown\"\n aria-label=${this.label || 'Date range picker'}\n aria-invalid=${this.error ? 'true' : nothing}\n aria-describedby=${this.error ? 'cg-drp-error' : nothing}\n @click=${this._toggle}\n @keydown=${this._handleKeydown}\n >\n <span class=\"trigger-icon\" aria-hidden=\"true\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <rect x=\"3\" y=\"4\" width=\"18\" height=\"18\" rx=\"2\" ry=\"2\"></rect>\n <line x1=\"16\" y1=\"2\" x2=\"16\" y2=\"6\"></line>\n <line x1=\"8\" y1=\"2\" x2=\"8\" y2=\"6\"></line>\n <line x1=\"3\" y1=\"10\" x2=\"21\" y2=\"10\"></line>\n </svg>\n </span>\n <span class=\"segment ${fromText ? '' : 'empty'}\">${fromText || this.placeholder}</span>\n <span class=\"arrow\" aria-hidden=\"true\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M9 6l6 6-6 6\"/>\n </svg>\n </span>\n <span class=\"segment ${toText ? '' : 'empty'}\">${toText || 'End date'}</span>\n </div>\n\n <div id=\"cg-drp-dropdown\" class=\"dropdown ${this.open ? 'open' : ''}\" role=\"dialog\" aria-label=\"Date range calendar\">\n <cg-calendar\n mode=\"range\"\n .value=${this.from}\n .rangeEnd=${this.to}\n .min=${this.min}\n .max=${this.max}\n @cg-calendar-change=${this._onCalendarChange}\n ></cg-calendar>\n </div>\n ${this.error ? html`<span id=\"cg-drp-error\" class=\"error-message\" role=\"alert\">${this.error}</span>` : nothing}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-date-range-picker': CgDateRangePicker;\n }\n}\n"],"names":["CgDateRangePicker","LitElement","changed","fd","iso","d","ev","value","rangeEnd","fromText","toText","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"cg-date-range-picker.js","sources":["../../../src/components/cg-date-range-picker/cg-date-range-picker.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\nimport '../cg-calendar/cg-calendar.js';\n\n/**\n * @element cg-date-range-picker\n * Dual-input date range picker that opens a range-mode cg-calendar.\n *\n * @example\n * ```html\n * <cg-date-range-picker label=\"Dates\" from=\"2026-04-01\" to=\"2026-04-10\"></cg-date-range-picker>\n * ```\n *\n * @fires {CustomEvent<{from: string, to: string}>} cg-date-range-change\n */\n@customElement('cg-date-range-picker')\nexport class CgDateRangePicker extends LitElement {\n static formAssociated = true;\n private _internals: ElementInternals | undefined;\n\n constructor() {\n super();\n if ('attachInternals' in this) {\n this._internals = this.attachInternals();\n }\n }\n\n static override styles = [hostBlock, reducedMotion, css`\n :host { position: relative; font-family: var(--cg-font-family-primary); }\n\n .label {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-text);\n margin-bottom: var(--cg-spacing-4);\n font-weight: var(--cg-font-weight-medium);\n display: block;\n }\n\n .trigger {\n display: flex;\n align-items: center;\n gap: 0;\n height: var(--cg-component-input-height-md);\n padding: 0 var(--cg-spacing-4);\n border: var(--cg-border-width-50) solid var(--cg-color-input-border-default);\n border-radius: var(--cg-component-input-radius);\n background: var(--cg-color-input-background-default);\n color: var(--cg-color-input-text-default);\n font-size: var(--cg-font-size-sm);\n cursor: pointer;\n outline: none;\n transition:\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n box-shadow var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .trigger-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--cg-color-input-icon-default);\n flex-shrink: 0;\n width: var(--cg-spacing-40);\n align-self: stretch;\n background: var(--cg-overlay-dark-subtle);\n border-right: var(--cg-border-width-50) solid var(--cg-color-input-border-default);\n border-radius: var(--cg-component-input-radius) 0 0 var(--cg-component-input-radius);\n margin-left: calc(-1 * var(--cg-spacing-4));\n }\n .trigger-icon svg {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n }\n\n .trigger:hover:not(.disabled) {\n border-color: var(--cg-color-input-border-hover);\n }\n\n .trigger.open,\n .trigger:focus-visible {\n border-color: var(--cg-color-input-border-focus);\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n .trigger.disabled {\n opacity: 0.5;\n pointer-events: none;\n background: var(--cg-color-input-background-disabled);\n }\n\n .trigger.invalid {\n border-color: var(--cg-color-status-error-border-default);\n }\n .trigger.invalid:focus-visible,\n .trigger.invalid.open {\n border-color: var(--cg-color-status-error-text-default);\n box-shadow: 0 0 0 3px var(--cg-shadow-focus-error);\n }\n\n .error-message {\n display: block;\n margin-top: var(--cg-spacing-4);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-status-error-text-default);\n }\n\n .segment {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n padding: 0 var(--cg-spacing-12);\n }\n .segment.empty { color: var(--cg-color-input-text-placeholder); }\n\n .arrow {\n flex-shrink: 0;\n color: var(--cg-color-input-text-placeholder);\n display: flex;\n align-items: center;\n padding: 0 var(--cg-spacing-2);\n }\n .arrow svg {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n }\n\n .dropdown {\n position: absolute;\n top: 100%;\n left: 0;\n z-index: var(--cg-z-index-200);\n margin-top: var(--cg-spacing-4);\n border-radius: var(--cg-component-calendar-radius);\n box-shadow: var(--cg-shadow-elevation-xl);\n opacity: 0;\n transform: translateY(calc(-1 * var(--cg-spacing-4))) scale(0.98);\n pointer-events: none;\n transition:\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .dropdown.open {\n opacity: 1;\n transform: translateY(0) scale(1);\n pointer-events: auto;\n }\n `];\n\n @property() label = '';\n @property() from = '';\n @property() to = '';\n @property() min = '';\n @property() max = '';\n @property() placeholder = 'Select date range';\n /** Placeholder for the end-date segment (overridable / i18n-able). */\n @property({ attribute: 'end-placeholder' }) endPlaceholder = 'End date';\n @property() format = 'MMM dd, yyyy';\n @property({ type: Boolean }) disabled = false;\n @property({ type: Boolean, reflect: true }) open = false;\n @property() error = '';\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('from') || changed.has('to')) {\n this._syncFormValue();\n }\n }\n\n private _syncFormValue() {\n if (!this._internals) return;\n const fd = new FormData();\n if (this.from) fd.append('from', this.from);\n if (this.to) fd.append('to', this.to);\n this._internals.setFormValue(fd);\n }\n\n private _toggle() {\n if (this.disabled) return;\n this.open = !this.open;\n }\n\n private _close() {\n this.open = false;\n }\n\n private _formatDisplay(iso: string): string {\n if (!iso) return '';\n const d = new Date(iso + 'T00:00:00');\n if (isNaN(d.getTime())) return '';\n return d.toLocaleDateString(undefined, { year: 'numeric', month: 'short', day: 'numeric' });\n }\n\n private _onCalendarChange(e: Event) {\n const ev = e as CustomEvent<{ value: string; rangeEnd?: string }>;\n e.stopPropagation();\n const { value, rangeEnd } = ev.detail;\n this.from = value || '';\n this.to = rangeEnd || '';\n\n if (this.from && this.to) {\n this.dispatchEvent(new CustomEvent('cg-date-range-change', {\n detail: { from: this.from, to: this.to },\n bubbles: true,\n composed: true,\n }));\n // Close after both picked\n setTimeout(() => { this.open = false; }, 120);\n }\n }\n\n private _handleClickOutside = (e: Event) => {\n if (!e.composedPath().includes(this)) this._close();\n };\n\n override connectedCallback() {\n super.connectedCallback();\n document.addEventListener('click', this._handleClickOutside);\n }\n override disconnectedCallback() {\n super.disconnectedCallback();\n document.removeEventListener('click', this._handleClickOutside);\n }\n\n private _handleKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape') { this._close(); return; }\n if (e.key === 'Enter' || e.key === ' ') {\n if (!this.open) { e.preventDefault(); this._toggle(); }\n }\n }\n\n override render() {\n const fromText = this._formatDisplay(this.from);\n const toText = this._formatDisplay(this.to);\n return html`\n ${this.label ? html`<label class=\"label\">${this.label}</label>` : nothing}\n <div\n class=\"trigger ${this.open ? 'open' : ''} ${this.disabled ? 'disabled' : ''} ${this.error ? 'invalid' : ''}\"\n role=\"combobox\"\n tabindex=${this.disabled ? '-1' : '0'}\n aria-expanded=${this.open ? 'true' : 'false'}\n aria-disabled=${this.disabled ? 'true' : nothing}\n aria-haspopup=\"dialog\"\n aria-controls=\"cg-drp-dropdown\"\n aria-label=${this.label || 'Date range picker'}\n aria-invalid=${this.error ? 'true' : nothing}\n aria-describedby=${this.error ? 'cg-drp-error' : nothing}\n @click=${this._toggle}\n @keydown=${this._handleKeydown}\n >\n <span class=\"trigger-icon\" aria-hidden=\"true\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <rect x=\"3\" y=\"4\" width=\"18\" height=\"18\" rx=\"2\" ry=\"2\"></rect>\n <line x1=\"16\" y1=\"2\" x2=\"16\" y2=\"6\"></line>\n <line x1=\"8\" y1=\"2\" x2=\"8\" y2=\"6\"></line>\n <line x1=\"3\" y1=\"10\" x2=\"21\" y2=\"10\"></line>\n </svg>\n </span>\n <span class=\"segment ${fromText ? '' : 'empty'}\">${fromText || this.placeholder}</span>\n <span class=\"arrow\" aria-hidden=\"true\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M9 6l6 6-6 6\"/>\n </svg>\n </span>\n <span class=\"segment ${toText ? '' : 'empty'}\">${toText || this.endPlaceholder}</span>\n </div>\n\n <div id=\"cg-drp-dropdown\" class=\"dropdown ${this.open ? 'open' : ''}\" role=\"dialog\" aria-label=\"Date range calendar\">\n <cg-calendar\n mode=\"range\"\n .value=${this.from}\n .rangeEnd=${this.to}\n .min=${this.min}\n .max=${this.max}\n @cg-calendar-change=${this._onCalendarChange}\n ></cg-calendar>\n </div>\n ${this.error ? html`<span id=\"cg-drp-error\" class=\"error-message\" role=\"alert\">${this.error}</span>` : nothing}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-date-range-picker': CgDateRangePicker;\n }\n}\n"],"names":["CgDateRangePicker","LitElement","changed","fd","iso","d","ev","value","rangeEnd","fromText","toText","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"cg-date-time-picker.d.ts","sourceRoot":"","sources":["../../../src/components/cg-date-time-picker/cg-date-time-picker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD;;;;;;;;;;;GAWG;AACH,qBACa,gBAAiB,SAAQ,UAAU;IAC9C,OAAgB,MAAM,4BA2NnB;IAES,KAAK,SAAM;IACX,KAAK,SAAM;IACX,WAAW,SAAwB;IACnC,MAAM,SAAM;IACZ,GAAG,SAAM;IACT,GAAG,SAAM;IACQ,IAAI,EAAE,IAAI,GAAG,IAAI,CAAQ;IACzB,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IAC5C,QAAQ,UAAS;IACF,KAAK,UAAS;IACd,OAAO,UAAS;IAC/B,MAAM,UAAS;IAChB,IAAI,SAAK;IAE5B,OAAO,CAAC,KAAK,CAAS;IACtB,OAAO,CAAC,SAAS,CAA4B;IAC7C,OAAO,CAAC,UAAU,CAAyB;IAC3C,OAAO,CAAC,aAAa,CAAM;IAC3B,OAAO,CAAC,eAAe,CAAM;IAC7B,OAAO,CAAC,OAAO,CAAqB;IAE7C,OAAO,CAAC,SAAS,CAA8C;IAC/D,OAAO,CAAC,WAAW,CAA8H;IAGjJ,OAAO,KAAK,KAAK,GAGhB;IACD,OAAO,KAAK,KAAK,GAGhB;IAED,OAAO,CAAC,OAAO;IAqBf,OAAO,CAAC,MAAM;IAGd,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,UAAU;IAElB,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,eAAe;IAOvB,OAAO,CAAC,QAAQ;IA8BhB,OAAO,CAAC,SAAS;IAGjB,OAAO,CAAC,WAAW;IAKnB,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,UAAU;IAElB,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,KAAK;IAQb,OAAO,CAAC,cAAc;IAoBtB,OAAO,CAAC,mBAAmB,CAA0E;IACrG,OAAO,CAAC,cAAc;IAKb,iBAAiB;IACjB,oBAAoB;IAEpB,MAAM;CAiGhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,qBAAqB,EAAE,gBAAgB,CAAC;KAAE;CAC7E"}
1
+ {"version":3,"file":"cg-date-time-picker.d.ts","sourceRoot":"","sources":["../../../src/components/cg-date-time-picker/cg-date-time-picker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD;;;;;;;;;;;GAWG;AACH,qBACa,gBAAiB,SAAQ,UAAU;IAC9C,OAAgB,MAAM,4BA2NnB;IAES,KAAK,SAAM;IACX,KAAK,SAAM;IACX,WAAW,SAAwB;IACnC,MAAM,SAAM;IACZ,GAAG,SAAM;IACT,GAAG,SAAM;IACQ,IAAI,EAAE,IAAI,GAAG,IAAI,CAAQ;IACzB,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IAC5C,QAAQ,UAAS;IACF,KAAK,UAAS;IACd,OAAO,UAAS;IAC/B,MAAM,UAAS;IAChB,IAAI,SAAK;IAE5B,OAAO,CAAC,KAAK,CAAS;IACtB,OAAO,CAAC,SAAS,CAA4B;IAC7C,OAAO,CAAC,UAAU,CAAyB;IAC3C,OAAO,CAAC,aAAa,CAAM;IAC3B,OAAO,CAAC,eAAe,CAAM;IAC7B,OAAO,CAAC,OAAO,CAAqB;IAE7C,OAAO,CAAC,SAAS,CAA8C;IAC/D,OAAO,CAAC,WAAW,CAA8H;IAGjJ,OAAO,KAAK,KAAK,GAGhB;IACD,OAAO,KAAK,KAAK,GAGhB;IAED,OAAO,CAAC,OAAO;IAqBf,OAAO,CAAC,MAAM;IAGd,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,UAAU;IAElB,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,eAAe;IAOvB,OAAO,CAAC,QAAQ;IA8BhB,OAAO,CAAC,SAAS;IAGjB,OAAO,CAAC,WAAW;IAKnB,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,UAAU;IAElB,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,KAAK;IAQb,OAAO,CAAC,cAAc;IAoBtB,OAAO,CAAC,mBAAmB,CAA0E;IACrG,OAAO,CAAC,cAAc;IAKb,iBAAiB;IACjB,oBAAoB;IAEpB,MAAM;CAmGhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,qBAAqB,EAAE,gBAAgB,CAAC;KAAE;CAC7E"}
@@ -1,6 +1,6 @@
1
1
  import { css as _, LitElement as w, nothing as b, html as g } from "lit";
2
2
  import { property as l, state as v, customElement as x } from "lit/decorators.js";
3
- import { h as $, r as k } from "../../chunks/premium.css-9I4kHrsl.js";
3
+ import { h as $, r as k } from "../../chunks/premium.css-DHekUEUt.js";
4
4
  var M = Object.defineProperty, S = Object.getOwnPropertyDescriptor, a = (t, r, o, s) => {
5
5
  for (var e = s > 1 ? void 0 : s ? S(r, o) : r, c = t.length - 1, p; c >= 0; c--)
6
6
  (p = t[c]) && (e = (s ? p(r, o, e) : p(e)) || e);
@@ -140,6 +140,8 @@ let i = class extends w {
140
140
  tabindex=${this.disabled ? "-1" : "0"}
141
141
  role="combobox"
142
142
  aria-expanded=${this._open}
143
+ aria-disabled=${this.disabled ? "true" : b}
144
+ aria-invalid=${this.error ? "true" : b}
143
145
  aria-haspopup="dialog"
144
146
  aria-label=${this.label || "Date and time picker"}
145
147
  @click=${this._toggle}