@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-navbar.js","sources":["../../../src/components/cg-navbar/cg-navbar.ts"],"sourcesContent":["import { LitElement, html, css, nothing, type PropertyValues } from 'lit';\nimport { customElement, property, state, query } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\nexport interface NavItem {\n /** Stable identifier — what `active` matches against. */\n value: string;\n /** Visible text. */\n label: string;\n /** Href for the underlying anchor. */\n href: string;\n /** Optional leading icon (SVG markup string). */\n icon?: string;\n /** Keyboard hint, rendered as a small `cg-kbd` chip on the right. */\n kbd?: string;\n /** Marks the item disabled. */\n disabled?: boolean;\n /** Optional badge text (e.g., \"New\"). */\n badge?: string;\n /** Open in a new tab. */\n external?: boolean;\n}\n\n/**\n * @element cg-navbar\n * Top navigation bar with animated sliding active indicator, programmatic\n * items API, three coherent variants (`solid` / `glass` / `floating`),\n * mobile responsive panel, scroll-aware compact mode, and full keyboard\n * navigation (arrow keys, Home, End, Escape).\n *\n * @example\n * ```html\n * <cg-navbar\n * variant=\"glass\"\n * sticky\n * active=\"docs\"\n * .items=${[\n * { value: 'docs', label: 'Docs', href: '/docs' },\n * { value: 'components', label: 'Components', href: '/components' },\n * { value: 'tokens', label: 'Tokens', href: '/tokens', badge: 'New' },\n * ]}\n * >\n * <span slot=\"brand\">Cognivo</span>\n * <cg-button slot=\"end\" variant=\"primary\">Sign in</cg-button>\n * </cg-navbar>\n * ```\n *\n * @slot brand - Brand area (leftmost). Logo + name.\n * @slot center - Optional center content (search, breadcrumbs). Hidden below mobileBreakpoint.\n * @slot end - Right region for actions, profile, theme toggle.\n * @slot mobile-menu - Optional override for the mobile panel content.\n *\n * @fires {CustomEvent<{open: boolean}>} cg-navbar-toggle - Mobile menu toggled\n * @fires {CustomEvent<{value: string, item: NavItem}>} cg-navbar-select - A nav item activated\n */\n@customElement('cg-navbar')\nexport class CgNavbar extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: block;\n width: 100%;\n }\n\n /* ── Outer nav container ─────────────────────────────────────── */\n nav {\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-24);\n height: var(--cg-component-navbar-height);\n padding: 0 var(--cg-component-navbar-padding-x);\n background: var(--cg-color-surface-base-background);\n color: var(--cg-color-surface-base-text);\n transition:\n height var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n background var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n box-shadow var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n backdrop-filter var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n\n :host([sticky]) nav {\n position: sticky;\n top: 0;\n z-index: var(--cg-z-index-500);\n }\n\n :host([bordered]) nav {\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n }\n\n /* Compact-on-scroll — applied via JS toggling the [data-compact] attribute */\n nav[data-compact=\"true\"] {\n height: var(--cg-component-navbar-height-compact);\n box-shadow: var(--cg-shadow-elevation-md);\n }\n\n /* Variant: glass — translucent + blur */\n :host([variant=\"glass\"]) nav {\n background: color-mix(in srgb, var(--cg-color-surface-base-background) 72%, transparent);\n backdrop-filter: saturate(180%) blur(20px);\n -webkit-backdrop-filter: saturate(180%) blur(20px);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n }\n\n /* Variant: floating — detached pill */\n :host([variant=\"floating\"]) nav {\n margin: var(--cg-component-navbar-floating-margin);\n height: calc(var(--cg-component-navbar-height) - 2 * var(--cg-component-navbar-floating-margin));\n padding: 0 var(--cg-spacing-20);\n background: color-mix(in srgb, var(--cg-color-surface-base-background) 80%, transparent);\n backdrop-filter: saturate(180%) blur(20px);\n -webkit-backdrop-filter: saturate(180%) blur(20px);\n border: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-radius: var(--cg-border-radius-full);\n box-shadow: var(--cg-shadow-elevation-lg);\n }\n :host([variant=\"floating\"]) nav[data-compact=\"true\"] {\n height: calc(var(--cg-component-navbar-height-compact) - 2 * var(--cg-component-navbar-floating-margin));\n }\n\n /* ── Brand ───────────────────────────────────────────────────── */\n .brand {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n font-size: var(--cg-font-size-base);\n font-weight: var(--cg-font-weight-semibold);\n letter-spacing: -0.01em;\n flex-shrink: 0;\n color: var(--cg-color-surface-base-text);\n text-decoration: none;\n transition: opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .brand:hover { opacity: 0.8; }\n\n /* ── Items list (tablist with sliding indicator) ─────────────── */\n .items {\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--cg-component-navbar-item-gap);\n padding: var(--cg-spacing-4);\n background: color-mix(in srgb, var(--cg-color-surface-container-background) 50%, transparent);\n border: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-radius: var(--cg-border-radius-full);\n }\n\n /* Floating variant strips the inner pill chrome (avoid card-in-card). */\n :host([variant=\"floating\"]) .items {\n background: transparent;\n border: none;\n padding: 0;\n }\n\n /* Sliding active indicator */\n .indicator {\n position: absolute;\n top: var(--cg-spacing-4);\n left: 0;\n height: calc(100% - 2 * var(--cg-spacing-4));\n box-sizing: border-box;\n background: var(--cg-color-surface-container-background);\n border: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-radius: var(--cg-border-radius-full);\n box-shadow: var(--cg-shadow-elevation-sm);\n transition:\n transform var(--cg-transition-duration-default) var(--cg-transition-easing-ease-in-out),\n width var(--cg-transition-duration-default) var(--cg-transition-easing-ease-in-out),\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n pointer-events: none;\n z-index: 0;\n opacity: 0;\n }\n .indicator[data-ready=\"true\"] { opacity: 1; }\n\n :host([variant=\"floating\"]) .indicator {\n top: 0;\n height: 100%;\n }\n\n /* Per-item anchor */\n .item {\n position: relative;\n z-index: 1;\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n padding: var(--cg-component-navbar-item-padding-y) var(--cg-component-navbar-item-padding-x);\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n text-decoration: none;\n border-radius: var(--cg-border-radius-full);\n cursor: pointer;\n transition:\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .item:hover:not([aria-disabled=\"true\"]) {\n color: var(--cg-color-surface-base-text);\n background: var(--cg-color-action-tertiary-background-hover);\n transform: translateY(calc(var(--cg-spacing-1) * -1));\n }\n .item:active:not([aria-disabled=\"true\"]) {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .item[aria-selected=\"true\"] {\n color: var(--cg-color-surface-base-text);\n }\n .item[aria-disabled=\"true\"] {\n opacity: 0.5;\n pointer-events: none;\n cursor: not-allowed;\n }\n .item:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n\n .item-icon {\n display: inline-flex;\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n }\n .item-icon svg { width: 100%; height: 100%; }\n\n .item-badge {\n display: inline-flex;\n align-items: center;\n padding: 0 var(--cg-spacing-6);\n height: var(--cg-spacing-16);\n background: var(--cg-color-accent-text);\n color: var(--cg-color-action-primary-text-default);\n border-radius: var(--cg-border-radius-full);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n letter-spacing: 0.02em;\n }\n\n .item-kbd {\n font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-outlined);\n padding: 0 var(--cg-spacing-4);\n border: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-radius: var(--cg-border-radius-50);\n line-height: var(--cg-spacing-16);\n }\n\n /* ── Center / End ────────────────────────────────────────────── */\n .center {\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n min-width: 0;\n }\n .end {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n flex-shrink: 0;\n margin-left: auto;\n }\n\n /* ── Mobile menu button ──────────────────────────────────────── */\n .menu-btn {\n display: none;\n align-items: center;\n justify-content: center;\n width: var(--cg-spacing-40);\n height: var(--cg-spacing-40);\n padding: 0;\n border: none;\n background: transparent;\n color: var(--cg-color-surface-base-text);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .menu-btn:hover { background: var(--cg-color-action-tertiary-background-hover); }\n .menu-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .menu-btn:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n\n /* ── Mobile slide-down panel ─────────────────────────────────── */\n .mobile-panel {\n display: none;\n position: absolute;\n top: 100%;\n left: 0;\n right: 0;\n padding: var(--cg-spacing-12);\n background: var(--cg-color-surface-base-background);\n border-top: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n box-shadow: var(--cg-shadow-elevation-xl);\n flex-direction: column;\n gap: var(--cg-spacing-2);\n animation: slideDown var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n :host([mobile-open]) .mobile-panel { display: flex; }\n\n .mobile-item {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-12) var(--cg-spacing-16);\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n text-decoration: none;\n border-radius: var(--cg-border-radius-100);\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n animation: itemIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) backwards;\n }\n .mobile-item:hover { background: var(--cg-color-action-tertiary-background-hover); }\n .mobile-item[aria-selected=\"true\"] {\n background: var(--cg-color-surface-container-background);\n box-shadow: var(--cg-shadow-elevation-sm);\n }\n .mobile-item[aria-disabled=\"true\"] {\n opacity: 0.5;\n pointer-events: none;\n }\n\n @keyframes slideDown {\n from { opacity: 0; transform: translateY(calc(-1 * var(--cg-spacing-8))); }\n to { opacity: 1; transform: translateY(0); }\n }\n @keyframes itemIn {\n from { opacity: 0; transform: translateX(calc(-1 * var(--cg-spacing-12))); }\n to { opacity: 1; transform: translateX(0); }\n }\n\n /* Responsive — collapse below the breakpoint */\n @media (max-width: 768px) {\n .items, .center { display: none; }\n .menu-btn { display: inline-flex; }\n }\n `];\n\n // ─── Public API ─────────────────────────────────────────────────\n\n @property({ type: Array }) items: NavItem[] = [];\n @property() active = '';\n @property({ reflect: true }) variant: 'solid' | 'glass' | 'floating' = 'solid';\n @property({ type: Boolean, reflect: true }) sticky = false;\n @property({ type: Boolean, reflect: true }) bordered = false;\n @property({ type: Boolean, reflect: true, attribute: 'compact-on-scroll' }) compactOnScroll = false;\n @property({ type: Boolean, reflect: true, attribute: 'mobile-open' }) mobileOpen = false;\n @property() brandHref = '';\n\n // ─── Internal state ─────────────────────────────────────────────\n\n @state() private _scrolled = false;\n\n @query('.items') private _itemsEl?: HTMLElement;\n @query('.indicator') private _indicatorEl?: HTMLElement;\n @query('nav') private _navEl?: HTMLElement;\n\n private _resizeObserver: ResizeObserver | null = null;\n private _onScroll = (): void => {\n if (!this.compactOnScroll) return;\n const next = window.scrollY > 16;\n if (next !== this._scrolled) {\n this._scrolled = next;\n if (this._navEl) this._navEl.dataset.compact = String(this._scrolled);\n }\n };\n private _onDocClick = (e: MouseEvent): void => {\n if (!this.mobileOpen) return;\n if (!e.composedPath().includes(this)) this.closeMobileMenu();\n };\n private _onKeydown = (e: KeyboardEvent): void => {\n if (e.key === 'Escape' && this.mobileOpen) {\n this.closeMobileMenu();\n }\n };\n\n // ─── Lifecycle ──────────────────────────────────────────────────\n\n override connectedCallback(): void {\n super.connectedCallback();\n window.addEventListener('scroll', this._onScroll, { passive: true });\n document.addEventListener('click', this._onDocClick);\n document.addEventListener('keydown', this._onKeydown);\n this._resizeObserver = new ResizeObserver(() => this._updateIndicator());\n requestAnimationFrame(() => {\n if (this._itemsEl && this._resizeObserver) this._resizeObserver.observe(this._itemsEl);\n });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n window.removeEventListener('scroll', this._onScroll);\n document.removeEventListener('click', this._onDocClick);\n document.removeEventListener('keydown', this._onKeydown);\n this._resizeObserver?.disconnect();\n this._resizeObserver = null;\n }\n\n override updated(changed: PropertyValues): void {\n if (changed.has('active') || changed.has('items') || changed.has('variant')) {\n requestAnimationFrame(() => this._updateIndicator());\n }\n }\n\n override firstUpdated(): void {\n requestAnimationFrame(() => this._updateIndicator());\n }\n\n // ─── Public methods ─────────────────────────────────────────────\n\n closeMobileMenu(): void {\n if (!this.mobileOpen) return;\n this.mobileOpen = false;\n this.dispatchEvent(new CustomEvent('cg-navbar-toggle', {\n detail: { open: false }, bubbles: true, composed: true,\n }));\n }\n\n // ─── Internals ──────────────────────────────────────────────────\n\n private _updateIndicator(): void {\n const idx = this.items.findIndex(i => i.value === this.active);\n if (idx < 0 || !this._itemsEl || !this._indicatorEl) {\n if (this._indicatorEl) this._indicatorEl.dataset.ready = 'false';\n return;\n }\n const itemEl = this._itemsEl.querySelectorAll<HTMLElement>('.item')[idx];\n if (!itemEl) return;\n this._indicatorEl.style.width = `${itemEl.offsetWidth}px`;\n this._indicatorEl.style.transform = `translateX(${itemEl.offsetLeft}px)`;\n this._indicatorEl.dataset.ready = 'true';\n }\n\n private _selectItem(item: NavItem, e?: MouseEvent | KeyboardEvent): void {\n if (item.disabled) {\n e?.preventDefault();\n return;\n }\n this.active = item.value;\n this.dispatchEvent(new CustomEvent('cg-navbar-select', {\n detail: { value: item.value, item },\n bubbles: true,\n composed: true,\n }));\n if (this.mobileOpen) this.closeMobileMenu();\n }\n\n private _toggleMobile(): void {\n this.mobileOpen = !this.mobileOpen;\n this.dispatchEvent(new CustomEvent('cg-navbar-toggle', {\n detail: { open: this.mobileOpen },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _onItemKeydown(e: KeyboardEvent, idx: number): void {\n const enabled = this.items.map((it, i) => ({ it, i })).filter(({ it }) => !it.disabled);\n const enabledIdx = enabled.findIndex(({ i }) => i === idx);\n let next = enabledIdx;\n if (e.key === 'ArrowLeft' || e.key === 'ArrowUp') {\n e.preventDefault();\n next = (enabledIdx - 1 + enabled.length) % enabled.length;\n } else if (e.key === 'ArrowRight' || e.key === 'ArrowDown') {\n e.preventDefault();\n next = (enabledIdx + 1) % enabled.length;\n } else if (e.key === 'Home') {\n e.preventDefault();\n next = 0;\n } else if (e.key === 'End') {\n e.preventDefault();\n next = enabled.length - 1;\n }\n if (next !== enabledIdx) {\n const target = enabled[next];\n if (target) {\n this._selectItem(target.it, e);\n this.updateComplete.then(() => {\n const items = this._itemsEl?.querySelectorAll<HTMLElement>('.item');\n items?.[target.i]?.focus();\n });\n }\n }\n }\n\n // ─── Render helpers ─────────────────────────────────────────────\n\n private _renderItem(item: NavItem, idx: number, mobile = false) {\n const selected = item.value === this.active;\n const cls = mobile ? 'mobile-item' : 'item';\n const styleVar = mobile ? `--idx:${idx};animation-delay:calc(${idx} * 50ms);` : '';\n return html`\n <a\n class=${cls}\n href=${item.href}\n target=${item.external ? '_blank' : nothing}\n rel=${item.external ? 'noopener noreferrer' : nothing}\n role=${mobile ? 'menuitem' : 'tab'}\n aria-selected=${selected ? 'true' : 'false'}\n aria-disabled=${item.disabled ? 'true' : 'false'}\n tabindex=${selected || mobile ? '0' : '-1'}\n style=${styleVar}\n @click=${(e: MouseEvent) => this._selectItem(item, e)}\n @keydown=${(e: KeyboardEvent) => !mobile && this._onItemKeydown(e, idx)}\n >\n ${item.icon ? html`<span class=\"item-icon\" aria-hidden=\"true\" .innerHTML=${item.icon}></span>` : nothing}\n <span>${item.label}</span>\n ${item.badge ? html`<span class=\"item-badge\">${item.badge}</span>` : nothing}\n ${item.kbd ? html`<span class=\"item-kbd\">${item.kbd}</span>` : nothing}\n </a>\n `;\n }\n\n override render() {\n const hasItems = this.items.length > 0;\n return html`\n <nav role=\"navigation\" aria-label=\"Main navigation\">\n ${this.brandHref\n ? html`<a class=\"brand\" href=${this.brandHref}><slot name=\"brand\"></slot></a>`\n : html`<div class=\"brand\"><slot name=\"brand\"></slot></div>`}\n ${hasItems ? html`\n <div class=\"items\" role=\"tablist\">\n <span class=\"indicator\" data-ready=\"false\"></span>\n ${this.items.map((item, idx) => this._renderItem(item, idx, false))}\n </div>\n ` : nothing}\n <div class=\"center\"><slot name=\"center\"></slot></div>\n <div class=\"end\">\n <slot name=\"end\"></slot>\n <button\n class=\"menu-btn\"\n type=\"button\"\n aria-label=\"Toggle menu\"\n aria-expanded=${this.mobileOpen ? 'true' : 'false'}\n aria-controls=\"cg-navbar-mobile-panel\"\n @click=${this._toggleMobile}\n >\n ${this.mobileOpen\n ? html`<svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg>`\n : html`<svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"><path d=\"M3 12h18M3 6h18M3 18h18\"/></svg>`\n }\n </button>\n </div>\n <div id=\"cg-navbar-mobile-panel\" class=\"mobile-panel\" role=\"menu\">\n <slot name=\"mobile-menu\">\n ${hasItems ? this.items.map((item, idx) => this._renderItem(item, idx, true)) : nothing}\n </slot>\n </div>\n </nav>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-navbar': CgNavbar;\n }\n}\n"],"names":["CgNavbar","LitElement","next","changed","idx","i","itemEl","item","e","enabled","it","enabledIdx","target","mobile","selected","cls","styleVar","html","nothing","hasItems","hostBlock","reducedMotion","css","__decorateClass","property","state","query","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"cg-navbar.js","sources":["../../../src/components/cg-navbar/cg-navbar.ts"],"sourcesContent":["import { LitElement, html, css, nothing, type PropertyValues } from 'lit';\nimport { customElement, property, state, query } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\nexport interface NavItem {\n /** Stable identifier — what `active` matches against. */\n value: string;\n /** Visible text. */\n label: string;\n /** Href for the underlying anchor. */\n href: string;\n /** Optional leading icon (SVG markup string). */\n icon?: string;\n /** Keyboard hint, rendered as a small `cg-kbd` chip on the right. */\n kbd?: string;\n /** Marks the item disabled. */\n disabled?: boolean;\n /** Optional badge text (e.g., \"New\"). */\n badge?: string;\n /** Open in a new tab. */\n external?: boolean;\n}\n\n/**\n * @element cg-navbar\n * Top navigation bar with animated sliding active indicator, programmatic\n * items API, three coherent variants (`solid` / `glass` / `floating`),\n * mobile responsive panel, scroll-aware compact mode, and full keyboard\n * navigation (arrow keys, Home, End, Escape).\n *\n * @example\n * ```html\n * <cg-navbar\n * variant=\"glass\"\n * sticky\n * active=\"docs\"\n * .items=${[\n * { value: 'docs', label: 'Docs', href: '/docs' },\n * { value: 'components', label: 'Components', href: '/components' },\n * { value: 'tokens', label: 'Tokens', href: '/tokens', badge: 'New' },\n * ]}\n * >\n * <span slot=\"brand\">Cognivo</span>\n * <cg-button slot=\"end\" variant=\"primary\">Sign in</cg-button>\n * </cg-navbar>\n * ```\n *\n * @slot brand - Brand area (leftmost). Logo + name.\n * @slot center - Optional center content (search, breadcrumbs). Hidden below 768px.\n * @slot end - Right region for actions, profile, theme toggle.\n * @slot mobile-menu - Optional override for the mobile panel content.\n *\n * @fires {CustomEvent<{open: boolean}>} cg-navbar-toggle - Mobile menu toggled\n * @fires {CustomEvent<{value: string, item: NavItem}>} cg-navbar-select - A nav item activated\n */\n@customElement('cg-navbar')\nexport class CgNavbar extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: block;\n width: 100%;\n }\n\n /* ── Outer nav container ─────────────────────────────────────── */\n nav {\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-24);\n height: var(--cg-component-navbar-height);\n padding: 0 var(--cg-component-navbar-padding-x);\n background: var(--cg-color-surface-base-background);\n color: var(--cg-color-surface-base-text);\n transition:\n height var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n background var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n box-shadow var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n backdrop-filter var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n\n :host([sticky]) nav {\n position: sticky;\n top: 0;\n z-index: var(--cg-z-index-500);\n }\n\n :host([bordered]) nav {\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n }\n\n /* Compact-on-scroll — applied via JS toggling the [data-compact] attribute */\n nav[data-compact=\"true\"] {\n height: var(--cg-component-navbar-height-compact);\n box-shadow: var(--cg-shadow-elevation-md);\n }\n\n /* Variant: glass — translucent + blur */\n :host([variant=\"glass\"]) nav {\n background: color-mix(in srgb, var(--cg-color-surface-base-background) 72%, transparent);\n backdrop-filter: saturate(180%) blur(var(--cg-blur-backdrop));\n -webkit-backdrop-filter: saturate(180%) blur(var(--cg-blur-backdrop));\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n }\n\n /* Variant: floating — detached pill */\n :host([variant=\"floating\"]) nav {\n margin: var(--cg-component-navbar-floating-margin);\n height: calc(var(--cg-component-navbar-height) - 2 * var(--cg-component-navbar-floating-margin));\n padding: 0 var(--cg-spacing-20);\n background: color-mix(in srgb, var(--cg-color-surface-base-background) 80%, transparent);\n backdrop-filter: saturate(180%) blur(var(--cg-blur-backdrop));\n -webkit-backdrop-filter: saturate(180%) blur(var(--cg-blur-backdrop));\n border: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-radius: var(--cg-border-radius-full);\n box-shadow: var(--cg-shadow-elevation-lg);\n }\n :host([variant=\"floating\"]) nav[data-compact=\"true\"] {\n height: calc(var(--cg-component-navbar-height-compact) - 2 * var(--cg-component-navbar-floating-margin));\n }\n\n /* ── Brand ───────────────────────────────────────────────────── */\n .brand {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n font-size: var(--cg-font-size-base);\n font-weight: var(--cg-font-weight-semibold);\n letter-spacing: var(--cg-letter-spacing-tight);\n flex-shrink: 0;\n color: var(--cg-color-surface-base-text);\n text-decoration: none;\n transition: opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .brand:hover { opacity: 0.8; }\n\n /* ── Items list (tablist with sliding indicator) ─────────────── */\n .items {\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--cg-component-navbar-item-gap);\n padding: var(--cg-spacing-4);\n background: color-mix(in srgb, var(--cg-color-surface-container-background) 50%, transparent);\n border: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-radius: var(--cg-border-radius-full);\n }\n\n /* Floating variant strips the inner pill chrome (avoid card-in-card). */\n :host([variant=\"floating\"]) .items {\n background: transparent;\n border: none;\n padding: 0;\n }\n\n /* Sliding active indicator */\n .indicator {\n position: absolute;\n top: var(--cg-spacing-4);\n left: 0;\n height: calc(100% - 2 * var(--cg-spacing-4));\n box-sizing: border-box;\n background: var(--cg-color-surface-container-background);\n border: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-radius: var(--cg-border-radius-full);\n box-shadow: var(--cg-shadow-elevation-sm);\n transition:\n transform var(--cg-transition-duration-default) var(--cg-transition-easing-ease-in-out),\n width var(--cg-transition-duration-default) var(--cg-transition-easing-ease-in-out),\n opacity var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n pointer-events: none;\n z-index: 0;\n opacity: 0;\n }\n .indicator[data-ready=\"true\"] { opacity: 1; }\n\n :host([variant=\"floating\"]) .indicator {\n top: 0;\n height: 100%;\n }\n\n /* Per-item anchor */\n .item {\n position: relative;\n z-index: 1;\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n padding: var(--cg-component-navbar-item-padding-y) var(--cg-component-navbar-item-padding-x);\n color: var(--cg-color-surface-container-outlined);\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n text-decoration: none;\n border-radius: var(--cg-border-radius-full);\n cursor: pointer;\n transition:\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .item:hover:not([aria-disabled=\"true\"]) {\n color: var(--cg-color-surface-base-text);\n background: var(--cg-color-action-tertiary-background-hover);\n transform: translateY(calc(var(--cg-spacing-1) * -1));\n }\n .item:active:not([aria-disabled=\"true\"]) {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .item[aria-selected=\"true\"] {\n color: var(--cg-color-surface-base-text);\n }\n .item[aria-disabled=\"true\"] {\n opacity: 0.5;\n pointer-events: none;\n cursor: not-allowed;\n }\n .item:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n\n .item-icon {\n display: inline-flex;\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n }\n .item-icon svg { width: 100%; height: 100%; }\n\n .item-badge {\n display: inline-flex;\n align-items: center;\n padding: 0 var(--cg-spacing-6);\n height: var(--cg-spacing-16);\n background: var(--cg-color-accent-text);\n color: var(--cg-color-action-primary-text-default);\n border-radius: var(--cg-border-radius-full);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n letter-spacing: var(--cg-letter-spacing-wide);\n }\n\n .item-kbd {\n font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-outlined);\n padding: 0 var(--cg-spacing-4);\n border: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-radius: var(--cg-border-radius-50);\n line-height: var(--cg-spacing-16);\n }\n\n /* ── Center / End ────────────────────────────────────────────── */\n .center {\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n min-width: 0;\n }\n .end {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n flex-shrink: 0;\n margin-left: auto;\n }\n\n /* ── Mobile menu button ──────────────────────────────────────── */\n .menu-btn {\n display: none;\n align-items: center;\n justify-content: center;\n width: var(--cg-spacing-40);\n height: var(--cg-spacing-40);\n padding: 0;\n border: none;\n background: transparent;\n color: var(--cg-color-surface-base-text);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .menu-btn:hover { background: var(--cg-color-action-tertiary-background-hover); }\n .menu-btn:active { transform: scale(var(--cg-interaction-press-scale)); }\n .menu-btn:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n\n /* ── Mobile slide-down panel ─────────────────────────────────── */\n .mobile-panel {\n display: none;\n position: absolute;\n top: 100%;\n left: 0;\n right: 0;\n padding: var(--cg-spacing-12);\n background: var(--cg-color-surface-base-background);\n border-top: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n border-bottom: var(--cg-border-width-50) solid var(--cg-color-action-secondary-border-default);\n box-shadow: var(--cg-shadow-elevation-xl);\n flex-direction: column;\n gap: var(--cg-spacing-2);\n animation: slideDown var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n :host([mobile-open]) .mobile-panel { display: flex; }\n\n .mobile-item {\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-12);\n padding: var(--cg-spacing-12) var(--cg-spacing-16);\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n text-decoration: none;\n border-radius: var(--cg-border-radius-100);\n transition:\n background var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n animation: itemIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) backwards;\n }\n .mobile-item:hover { background: var(--cg-color-action-tertiary-background-hover); }\n .mobile-item:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n .mobile-item:active:not([aria-disabled=\"true\"]) {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .mobile-item[aria-selected=\"true\"] {\n background: var(--cg-color-surface-container-background);\n box-shadow: var(--cg-shadow-elevation-sm);\n }\n .mobile-item[aria-disabled=\"true\"] {\n opacity: 0.5;\n pointer-events: none;\n }\n\n @keyframes slideDown {\n from { opacity: 0; transform: translateY(calc(-1 * var(--cg-spacing-8))); }\n to { opacity: 1; transform: translateY(0); }\n }\n @keyframes itemIn {\n from { opacity: 0; transform: translateX(calc(-1 * var(--cg-spacing-12))); }\n to { opacity: 1; transform: translateX(0); }\n }\n\n /* Responsive — collapse below the breakpoint */\n @media (max-width: 768px) {\n .items, .center { display: none; }\n .menu-btn { display: inline-flex; }\n }\n `];\n\n // ─── Public API ─────────────────────────────────────────────────\n\n @property({ type: Array }) items: NavItem[] = [];\n @property() active = '';\n @property({ reflect: true }) variant: 'solid' | 'glass' | 'floating' = 'solid';\n @property({ type: Boolean, reflect: true }) sticky = false;\n @property({ type: Boolean, reflect: true }) bordered = false;\n @property({ type: Boolean, reflect: true, attribute: 'compact-on-scroll' }) compactOnScroll = false;\n @property({ type: Boolean, reflect: true, attribute: 'mobile-open' }) mobileOpen = false;\n @property() brandHref = '';\n\n // ─── Internal state ─────────────────────────────────────────────\n\n @state() private _scrolled = false;\n\n @query('.items') private _itemsEl?: HTMLElement;\n @query('.indicator') private _indicatorEl?: HTMLElement;\n @query('nav') private _navEl?: HTMLElement;\n\n private _resizeObserver: ResizeObserver | null = null;\n private _onScroll = (): void => {\n if (!this.compactOnScroll) return;\n const next = window.scrollY > 16;\n if (next !== this._scrolled) {\n this._scrolled = next;\n if (this._navEl) this._navEl.dataset.compact = String(this._scrolled);\n }\n };\n private _onDocClick = (e: MouseEvent): void => {\n if (!this.mobileOpen) return;\n if (!e.composedPath().includes(this)) this.closeMobileMenu();\n };\n private _onKeydown = (e: KeyboardEvent): void => {\n if (e.key === 'Escape' && this.mobileOpen) {\n this.closeMobileMenu();\n // The panel goes display:none — restore focus to the toggle so\n // keyboard users aren't stranded on <body>.\n this.updateComplete.then(() =>\n this.renderRoot.querySelector<HTMLElement>('.menu-btn')?.focus());\n }\n };\n\n // ─── Lifecycle ──────────────────────────────────────────────────\n\n override connectedCallback(): void {\n super.connectedCallback();\n window.addEventListener('scroll', this._onScroll, { passive: true });\n document.addEventListener('click', this._onDocClick);\n document.addEventListener('keydown', this._onKeydown);\n this._resizeObserver = new ResizeObserver(() => this._updateIndicator());\n requestAnimationFrame(() => {\n if (this._itemsEl && this._resizeObserver) this._resizeObserver.observe(this._itemsEl);\n });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n window.removeEventListener('scroll', this._onScroll);\n document.removeEventListener('click', this._onDocClick);\n document.removeEventListener('keydown', this._onKeydown);\n this._resizeObserver?.disconnect();\n this._resizeObserver = null;\n }\n\n override updated(changed: PropertyValues): void {\n if (changed.has('active') || changed.has('items') || changed.has('variant')) {\n requestAnimationFrame(() => this._updateIndicator());\n }\n }\n\n override firstUpdated(): void {\n requestAnimationFrame(() => this._updateIndicator());\n }\n\n // ─── Public methods ─────────────────────────────────────────────\n\n closeMobileMenu(): void {\n if (!this.mobileOpen) return;\n this.mobileOpen = false;\n this.dispatchEvent(new CustomEvent('cg-navbar-toggle', {\n detail: { open: false }, bubbles: true, composed: true,\n }));\n }\n\n // ─── Internals ──────────────────────────────────────────────────\n\n private _updateIndicator(): void {\n const idx = this.items.findIndex(i => i.value === this.active);\n if (idx < 0 || !this._itemsEl || !this._indicatorEl) {\n if (this._indicatorEl) this._indicatorEl.dataset.ready = 'false';\n return;\n }\n const itemEl = this._itemsEl.querySelectorAll<HTMLElement>('.item')[idx];\n if (!itemEl) return;\n this._indicatorEl.style.width = `${itemEl.offsetWidth}px`;\n this._indicatorEl.style.transform = `translateX(${itemEl.offsetLeft}px)`;\n this._indicatorEl.dataset.ready = 'true';\n }\n\n private _selectItem(item: NavItem, e?: MouseEvent | KeyboardEvent): void {\n if (item.disabled) {\n e?.preventDefault();\n return;\n }\n this.active = item.value;\n this.dispatchEvent(new CustomEvent('cg-navbar-select', {\n detail: { value: item.value, item },\n bubbles: true,\n composed: true,\n }));\n if (this.mobileOpen) this.closeMobileMenu();\n }\n\n private _toggleMobile(): void {\n this.mobileOpen = !this.mobileOpen;\n this.dispatchEvent(new CustomEvent('cg-navbar-toggle', {\n detail: { open: this.mobileOpen },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _onItemKeydown(e: KeyboardEvent, idx: number): void {\n const enabled = this.items.map((it, i) => ({ it, i })).filter(({ it }) => !it.disabled);\n const enabledIdx = enabled.findIndex(({ i }) => i === idx);\n let next = enabledIdx;\n if (e.key === 'ArrowLeft' || e.key === 'ArrowUp') {\n e.preventDefault();\n next = (enabledIdx - 1 + enabled.length) % enabled.length;\n } else if (e.key === 'ArrowRight' || e.key === 'ArrowDown') {\n e.preventDefault();\n next = (enabledIdx + 1) % enabled.length;\n } else if (e.key === 'Home') {\n e.preventDefault();\n next = 0;\n } else if (e.key === 'End') {\n e.preventDefault();\n next = enabled.length - 1;\n }\n if (next !== enabledIdx) {\n const target = enabled[next];\n if (target) {\n // Roving focus only — arrowing must not select/navigate. Activation\n // stays on Enter/click via the anchor's native behavior.\n const items = this._itemsEl?.querySelectorAll<HTMLElement>('.item');\n items?.[target.i]?.focus();\n }\n }\n }\n\n // ─── Render helpers ─────────────────────────────────────────────\n\n private _renderItem(item: NavItem, idx: number, mobile = false) {\n const selected = item.value === this.active;\n const cls = mobile ? 'mobile-item' : 'item';\n const styleVar = mobile ? `animation-delay:calc(${idx} * var(--cg-transition-duration-fast) / 2);` : '';\n return html`\n <a\n class=${cls}\n href=${item.href}\n target=${item.external ? '_blank' : nothing}\n rel=${item.external ? 'noopener noreferrer' : nothing}\n role=${mobile ? nothing : 'tab'}\n aria-selected=${selected ? 'true' : 'false'}\n aria-disabled=${item.disabled ? 'true' : 'false'}\n tabindex=${selected || mobile ? '0' : '-1'}\n style=${styleVar}\n @click=${(e: MouseEvent) => this._selectItem(item, e)}\n @keydown=${(e: KeyboardEvent) => !mobile && this._onItemKeydown(e, idx)}\n >\n ${item.icon ? html`<span class=\"item-icon\" aria-hidden=\"true\" .innerHTML=${item.icon}></span>` : nothing}\n <span>${item.label}</span>\n ${item.badge ? html`<span class=\"item-badge\">${item.badge}</span>` : nothing}\n ${item.kbd ? html`<span class=\"item-kbd\">${item.kbd}</span>` : nothing}\n </a>\n `;\n }\n\n override render() {\n const hasItems = this.items.length > 0;\n return html`\n <nav role=\"navigation\" aria-label=\"Main navigation\">\n ${this.brandHref\n ? html`<a class=\"brand\" href=${this.brandHref}><slot name=\"brand\"></slot></a>`\n : html`<div class=\"brand\"><slot name=\"brand\"></slot></div>`}\n ${hasItems ? html`\n <div class=\"items\" role=\"tablist\">\n <span class=\"indicator\" data-ready=\"false\"></span>\n ${this.items.map((item, idx) => this._renderItem(item, idx, false))}\n </div>\n ` : nothing}\n <div class=\"center\"><slot name=\"center\"></slot></div>\n <div class=\"end\">\n <slot name=\"end\"></slot>\n <button\n class=\"menu-btn\"\n type=\"button\"\n aria-label=\"Toggle menu\"\n aria-expanded=${this.mobileOpen ? 'true' : 'false'}\n aria-controls=\"cg-navbar-mobile-panel\"\n @click=${this._toggleMobile}\n >\n ${this.mobileOpen\n ? html`<svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"><path d=\"M18 6L6 18M6 6l12 12\"/></svg>`\n : html`<svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"><path d=\"M3 12h18M3 6h18M3 18h18\"/></svg>`\n }\n </button>\n </div>\n <div id=\"cg-navbar-mobile-panel\" class=\"mobile-panel\">\n <slot name=\"mobile-menu\">\n ${hasItems ? this.items.map((item, idx) => this._renderItem(item, idx, true)) : nothing}\n </slot>\n </div>\n </nav>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-navbar': CgNavbar;\n }\n}\n"],"names":["CgNavbar","LitElement","next","changed","idx","i","itemEl","item","e","enabled","it","enabledIdx","target","mobile","selected","cls","styleVar","html","nothing","hasItems","hostBlock","reducedMotion","css","__decorateClass","property","state","query","customElement"],"mappings":"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"}
@@ -23,6 +23,8 @@ export interface NavMenuItem {
23
23
  export declare class CgNavigationMenu extends LitElement {
24
24
  static styles: import('lit').CSSResult[];
25
25
  items: NavMenuItem[];
26
+ /** Accessible name for the navigation landmark. */
27
+ label: string;
26
28
  openDelay: number;
27
29
  closeDelay: number;
28
30
  /** Panel grid column count. Default 2. */
@@ -35,6 +37,7 @@ export declare class CgNavigationMenu extends LitElement {
35
37
  private _scheduleClose;
36
38
  disconnectedCallback(): void;
37
39
  private _onKeydown;
40
+ private _onFocusOut;
38
41
  private _selectLink;
39
42
  render(): import('lit').TemplateResult<1>;
40
43
  }
@@ -1 +1 @@
1
- {"version":3,"file":"cg-navigation-menu.d.ts","sourceRoot":"","sources":["../../../src/components/cg-navigation-menu/cg-navigation-menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,WAAW,EAAE,CAAC;CACtB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,cAAc,EAAE,CAAC;CAC5B;AAED;;;;;GAKG;AACH,qBACa,gBAAiB,SAAQ,UAAU;IAC9C,OAAgB,MAAM,4BA8InB;IAEwB,KAAK,EAAE,WAAW,EAAE,CAAM;IACzB,SAAS,SAAM;IACf,UAAU,SAAO;IAC7C,0CAA0C;IACd,OAAO,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAK;IAE9C,OAAO,CAAC,UAAU,CAAM;IACjC,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAuB;IAE1C,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,cAAc;IAKb,oBAAoB,IAAI,IAAI;IAKrC,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,WAAW;IAQV,MAAM;CA+ChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,oBAAoB,EAAE,gBAAgB,CAAC;KACxC;CACF"}
1
+ {"version":3,"file":"cg-navigation-menu.d.ts","sourceRoot":"","sources":["../../../src/components/cg-navigation-menu/cg-navigation-menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,WAAW,EAAE,CAAC;CACtB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,cAAc,EAAE,CAAC;CAC5B;AAED;;;;;GAKG;AACH,qBACa,gBAAiB,SAAQ,UAAU;IAC9C,OAAgB,MAAM,4BAkJnB;IAEwB,KAAK,EAAE,WAAW,EAAE,CAAM;IACrD,mDAAmD;IACvC,KAAK,SAAqB;IACV,SAAS,SAAM;IACf,UAAU,SAAO;IAC7C,0CAA0C;IACd,OAAO,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAK;IAE9C,OAAO,CAAC,UAAU,CAAM;IACjC,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAuB;IAE1C,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,cAAc;IAKb,oBAAoB,IAAI,IAAI;IAKrC,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,WAAW;IAKnB,OAAO,CAAC,WAAW;IAQV,MAAM;CAkDhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,oBAAoB,EAAE,gBAAgB,CAAC;KACxC;CACF"}
@@ -1,14 +1,14 @@
1
- import { css as p, LitElement as u, nothing as s, html as n } from "lit";
2
- import { property as c, state as v, customElement as h } from "lit/decorators.js";
3
- import { h as m, r as f } from "../../chunks/premium.css-9I4kHrsl.js";
4
- var b = Object.defineProperty, _ = Object.getOwnPropertyDescriptor, o = (r, e, l, a) => {
5
- for (var t = a > 1 ? void 0 : a ? _(e, l) : e, g = r.length - 1, d; g >= 0; g--)
6
- (d = r[g]) && (t = (a ? d(e, l, t) : d(t)) || t);
7
- return a && t && b(e, l, t), t;
1
+ import { css as p, LitElement as u, nothing as a, html as n } from "lit";
2
+ import { property as s, state as v, customElement as h } from "lit/decorators.js";
3
+ import { h as f, r as m } from "../../chunks/premium.css-DHekUEUt.js";
4
+ var b = Object.defineProperty, _ = Object.getOwnPropertyDescriptor, o = (r, e, l, c) => {
5
+ for (var t = c > 1 ? void 0 : c ? _(e, l) : e, g = r.length - 1, d; g >= 0; g--)
6
+ (d = r[g]) && (t = (c ? d(e, l, t) : d(t)) || t);
7
+ return c && t && b(e, l, t), t;
8
8
  };
9
9
  let i = class extends u {
10
10
  constructor() {
11
- super(...arguments), this.items = [], this.openDelay = 80, this.closeDelay = 120, this.columns = 2, this._openIndex = -1, this._openTimer = null, this._closeTimer = null;
11
+ super(...arguments), this.items = [], this.label = "Main navigation", this.openDelay = 80, this.closeDelay = 120, this.columns = 2, this._openIndex = -1, this._openTimer = null, this._closeTimer = null;
12
12
  }
13
13
  _clearTimers() {
14
14
  this._openTimer && (clearTimeout(this._openTimer), this._openTimer = null), this._closeTimer && (clearTimeout(this._closeTimer), this._closeTimer = null);
@@ -29,6 +29,10 @@ let i = class extends u {
29
29
  _onKeydown(r) {
30
30
  r.key === "Escape" && this._openIndex !== -1 && (r.preventDefault(), this._openIndex = -1);
31
31
  }
32
+ _onFocusOut(r) {
33
+ const e = r.relatedTarget;
34
+ (!e || !this.renderRoot.contains(e)) && this._scheduleClose();
35
+ }
32
36
  _selectLink(r, e) {
33
37
  this.dispatchEvent(new CustomEvent("cg-navigation-menu-select", {
34
38
  bubbles: !0,
@@ -38,19 +42,21 @@ let i = class extends u {
38
42
  }
39
43
  render() {
40
44
  return n`
41
- <nav role="navigation" @mouseleave=${this._scheduleClose} @keydown=${this._onKeydown}>
45
+ <nav
46
+ role="navigation"
47
+ aria-label=${this.label}
48
+ @mouseleave=${this._scheduleClose}
49
+ @keydown=${this._onKeydown}
50
+ @focusout=${this._onFocusOut}
51
+ >
42
52
  ${this.items.map((r, e) => n`
43
53
  <button
44
54
  class="trigger ${this._openIndex === e ? "open" : ""}"
45
- aria-haspopup="menu"
46
55
  aria-expanded=${this._openIndex === e ? "true" : "false"}
47
- aria-controls="cg-navigation-menu-panel"
56
+ aria-controls=${this._openIndex === e ? "cg-navigation-menu-panel" : a}
48
57
  @mouseenter=${() => this._scheduleOpen(e)}
49
- @focus=${() => {
50
- this._openIndex = e;
51
- }}
52
58
  @click=${() => {
53
- this._openIndex = this._openIndex === e ? -1 : e;
59
+ this._clearTimers(), this._openIndex = this._openIndex === e ? -1 : e;
54
60
  }}
55
61
  >
56
62
  <span>${r.label}</span>
@@ -65,7 +71,6 @@ let i = class extends u {
65
71
  <div
66
72
  id="cg-navigation-menu-panel"
67
73
  class="panel"
68
- role="menu"
69
74
  style=${`--cg-nm-columns: ${this.columns};`}
70
75
  @mouseenter=${() => {
71
76
  this._clearTimers();
@@ -74,23 +79,23 @@ let i = class extends u {
74
79
  >
75
80
  ${this.items[this._openIndex].sections.map((r) => n`
76
81
  <div>
77
- ${r.heading ? n`<h4 class="section-heading">${r.heading}</h4>` : s}
82
+ ${r.heading ? n`<h4 class="section-heading">${r.heading}</h4>` : a}
78
83
  ${r.links.map((e) => n`
79
- <button class="link" role="menuitem" @click=${() => this._selectLink(this.items[this._openIndex], e)}>
80
- ${e.icon ? n`<span class="link-icon" aria-hidden="true" .innerHTML=${e.icon}></span>` : s}
84
+ <button class="link" @click=${() => this._selectLink(this.items[this._openIndex], e)}>
85
+ ${e.icon ? n`<span class="link-icon" aria-hidden="true" .innerHTML=${e.icon}></span>` : a}
81
86
  <span class="link-title">${e.title}</span>
82
- ${e.description ? n`<span class="link-desc">${e.description}</span>` : s}
87
+ ${e.description ? n`<span class="link-desc">${e.description}</span>` : a}
83
88
  </button>
84
89
  `)}
85
90
  </div>
86
91
  `)}
87
92
  </div>
88
- ` : s}
93
+ ` : a}
89
94
  </nav>
90
95
  `;
91
96
  }
92
97
  };
93
- i.styles = [m, f, p`
98
+ i.styles = [f, m, p`
94
99
  :host {
95
100
  display: block;
96
101
  font-family: var(--cg-font-family-primary);
@@ -123,6 +128,10 @@ i.styles = [m, f, p`
123
128
  .trigger.open {
124
129
  background: var(--cg-color-action-tertiary-background-hover);
125
130
  }
131
+ /* Distinct open indicator: accent underline so open != hover. */
132
+ .trigger.open:not(:focus-visible) {
133
+ box-shadow: inset 0 calc(-1 * var(--cg-border-width-100)) 0 var(--cg-color-action-primary-border-default);
134
+ }
126
135
  .trigger:active { transform: scale(var(--cg-interaction-press-scale)); }
127
136
  .trigger:focus-visible {
128
137
  outline: none;
@@ -234,16 +243,19 @@ i.styles = [m, f, p`
234
243
  }
235
244
  `];
236
245
  o([
237
- c({ type: Array })
246
+ s({ type: Array })
238
247
  ], i.prototype, "items", 2);
239
248
  o([
240
- c({ type: Number })
249
+ s()
250
+ ], i.prototype, "label", 2);
251
+ o([
252
+ s({ type: Number })
241
253
  ], i.prototype, "openDelay", 2);
242
254
  o([
243
- c({ type: Number })
255
+ s({ type: Number })
244
256
  ], i.prototype, "closeDelay", 2);
245
257
  o([
246
- c({ type: Number })
258
+ s({ type: Number })
247
259
  ], i.prototype, "columns", 2);
248
260
  o([
249
261
  v()
@@ -1 +1 @@
1
- {"version":3,"file":"cg-navigation-menu.js","sources":["../../../src/components/cg-navigation-menu/cg-navigation-menu.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\nexport interface NavMenuLink {\n title: string;\n description?: string;\n icon?: string;\n href?: string;\n}\n\nexport interface NavMenuSection {\n heading?: string;\n links: NavMenuLink[];\n}\n\nexport interface NavMenuItem {\n label: string;\n id?: string;\n sections: NavMenuSection[];\n}\n\n/**\n * @element cg-navigation-menu\n * Horizontal mega-menu with large panel drop-downs grouped by section.\n *\n * @fires {CustomEvent<{menu:string,link:string}>} cg-navigation-menu-select\n */\n@customElement('cg-navigation-menu')\nexport class CgNavigationMenu extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: block;\n font-family: var(--cg-font-family-primary);\n color: var(--cg-color-surface-container-text);\n }\n\n [role=\"navigation\"] {\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n }\n\n .trigger {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-4);\n padding: var(--cg-spacing-8) var(--cg-spacing-12);\n background: transparent;\n border: none;\n color: inherit;\n font: inherit;\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n transition: background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .trigger:hover,\n .trigger.open {\n background: var(--cg-color-action-tertiary-background-hover);\n }\n .trigger:active { transform: scale(var(--cg-interaction-press-scale)); }\n .trigger:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n\n /* Caret indicator on triggers — rotates 180° when open. */\n .trigger-caret {\n display: inline-flex;\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n color: var(--cg-color-surface-container-outlined);\n transition:\n transform var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .trigger:hover .trigger-caret,\n .trigger.open .trigger-caret { color: var(--cg-color-surface-base-text); }\n .trigger.open .trigger-caret { transform: rotate(180deg); }\n\n .panel {\n position: absolute;\n top: calc(100% + var(--cg-spacing-8));\n left: 0;\n z-index: var(--cg-z-index-500);\n min-width: var(--cg-component-navigation-menu-panel-min-width);\n padding: var(--cg-spacing-24);\n background: var(--cg-color-modal-container-background);\n border: var(--cg-border-width-50) solid var(--cg-color-modal-container-border);\n border-radius: var(--cg-border-radius-200);\n box-shadow: var(--cg-shadow-elevation-xl);\n display: grid;\n grid-template-columns: repeat(var(--cg-nm-columns), minmax(0, 1fr));\n gap: var(--cg-spacing-20);\n transform-origin: top;\n animation: navMenuPanelIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n @keyframes navMenuPanelIn {\n from { opacity: 0; transform: translateY(calc(-1 * var(--cg-spacing-6))) scale(0.98); }\n to { opacity: 1; transform: translateY(0) scale(1); }\n }\n\n .section-heading {\n margin: 0 0 var(--cg-spacing-12) var(--cg-spacing-12);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wider);\n color: var(--cg-color-surface-container-outlined);\n }\n\n .link {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: var(--cg-spacing-4);\n padding: var(--cg-spacing-12);\n background: transparent;\n border: none;\n text-align: left;\n color: inherit;\n font: inherit;\n font-size: var(--cg-font-size-sm);\n text-decoration: none;\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n transition:\n background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n width: 100%;\n box-sizing: border-box;\n }\n /* Optional leading icon — stacks above the title (vertical rhythm). */\n .link-icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--cg-spacing-32);\n height: var(--cg-spacing-32);\n margin-bottom: var(--cg-spacing-4);\n background: var(--cg-color-action-tertiary-background-hover);\n border-radius: var(--cg-border-radius-100);\n color: var(--cg-color-accent-text);\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .link-icon svg { width: var(--cg-icon-size-100); height: var(--cg-icon-size-100); }\n .link:hover .link-icon { background: var(--cg-color-surface-container-background); }\n .link:hover {\n background: var(--cg-color-action-tertiary-background-hover);\n }\n .link:active {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .link:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n .link-title {\n font-weight: var(--cg-font-weight-medium);\n }\n .link-desc {\n font-size: var(--cg-font-size-xs);\n line-height: var(--cg-line-height-relaxed);\n color: var(--cg-color-surface-container-outlined);\n }\n `];\n\n @property({ type: Array }) items: NavMenuItem[] = [];\n @property({ type: Number }) openDelay = 80;\n @property({ type: Number }) closeDelay = 120;\n /** Panel grid column count. Default 2. */\n @property({ type: Number }) columns: 1 | 2 | 3 | 4 = 2;\n\n @state() private _openIndex = -1;\n private _openTimer: number | null = null;\n private _closeTimer: number | null = null;\n\n private _clearTimers() {\n if (this._openTimer) { clearTimeout(this._openTimer); this._openTimer = null; }\n if (this._closeTimer) { clearTimeout(this._closeTimer); this._closeTimer = null; }\n }\n\n private _scheduleOpen(i: number): void {\n this._clearTimers();\n this._openTimer = window.setTimeout(() => { this._openIndex = i; }, this.openDelay);\n }\n\n private _scheduleClose(): void {\n this._clearTimers();\n this._closeTimer = window.setTimeout(() => { this._openIndex = -1; }, this.closeDelay);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this._clearTimers();\n }\n\n private _onKeydown(e: KeyboardEvent): void {\n if (e.key === 'Escape' && this._openIndex !== -1) {\n e.preventDefault();\n this._openIndex = -1;\n }\n }\n\n private _selectLink(menu: NavMenuItem, link: NavMenuLink): void {\n this.dispatchEvent(new CustomEvent('cg-navigation-menu-select', {\n bubbles: true, composed: true,\n detail: { menu: menu.id ?? menu.label, link: link.title, href: link.href },\n }));\n this._openIndex = -1;\n }\n\n override render() {\n return html`\n <nav role=\"navigation\" @mouseleave=${this._scheduleClose} @keydown=${this._onKeydown}>\n ${this.items.map((menu, i) => html`\n <button\n class=\"trigger ${this._openIndex === i ? 'open' : ''}\"\n aria-haspopup=\"menu\"\n aria-expanded=${this._openIndex === i ? 'true' : 'false'}\n aria-controls=\"cg-navigation-menu-panel\"\n @mouseenter=${() => this._scheduleOpen(i)}\n @focus=${() => { this._openIndex = i; }}\n @click=${() => { this._openIndex = this._openIndex === i ? -1 : i; }}\n >\n <span>${menu.label}</span>\n <span class=\"trigger-caret\" aria-hidden=\"true\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <polyline points=\"6 9 12 15 18 9\"/>\n </svg>\n </span>\n </button>\n `)}\n ${this._openIndex >= 0 && this.items[this._openIndex] ? html`\n <div\n id=\"cg-navigation-menu-panel\"\n class=\"panel\"\n role=\"menu\"\n style=${`--cg-nm-columns: ${this.columns};`}\n @mouseenter=${() => { this._clearTimers(); }}\n @mouseleave=${this._scheduleClose}\n >\n ${this.items[this._openIndex]!.sections.map(section => html`\n <div>\n ${section.heading ? html`<h4 class=\"section-heading\">${section.heading}</h4>` : nothing}\n ${section.links.map(link => html`\n <button class=\"link\" role=\"menuitem\" @click=${() => this._selectLink(this.items[this._openIndex]!, link)}>\n ${link.icon ? html`<span class=\"link-icon\" aria-hidden=\"true\" .innerHTML=${link.icon}></span>` : nothing}\n <span class=\"link-title\">${link.title}</span>\n ${link.description ? html`<span class=\"link-desc\">${link.description}</span>` : nothing}\n </button>\n `)}\n </div>\n `)}\n </div>\n ` : nothing}\n </nav>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-navigation-menu': CgNavigationMenu;\n }\n}\n"],"names":["CgNavigationMenu","LitElement","i","e","menu","link","html","section","nothing","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"cg-navigation-menu.js","sources":["../../../src/components/cg-navigation-menu/cg-navigation-menu.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\nexport interface NavMenuLink {\n title: string;\n description?: string;\n icon?: string;\n href?: string;\n}\n\nexport interface NavMenuSection {\n heading?: string;\n links: NavMenuLink[];\n}\n\nexport interface NavMenuItem {\n label: string;\n id?: string;\n sections: NavMenuSection[];\n}\n\n/**\n * @element cg-navigation-menu\n * Horizontal mega-menu with large panel drop-downs grouped by section.\n *\n * @fires {CustomEvent<{menu:string,link:string}>} cg-navigation-menu-select\n */\n@customElement('cg-navigation-menu')\nexport class CgNavigationMenu extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: block;\n font-family: var(--cg-font-family-primary);\n color: var(--cg-color-surface-container-text);\n }\n\n [role=\"navigation\"] {\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n }\n\n .trigger {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-4);\n padding: var(--cg-spacing-8) var(--cg-spacing-12);\n background: transparent;\n border: none;\n color: inherit;\n font: inherit;\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n transition: background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .trigger:hover,\n .trigger.open {\n background: var(--cg-color-action-tertiary-background-hover);\n }\n /* Distinct open indicator: accent underline so open != hover. */\n .trigger.open:not(:focus-visible) {\n box-shadow: inset 0 calc(-1 * var(--cg-border-width-100)) 0 var(--cg-color-action-primary-border-default);\n }\n .trigger:active { transform: scale(var(--cg-interaction-press-scale)); }\n .trigger:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n\n /* Caret indicator on triggers — rotates 180° when open. */\n .trigger-caret {\n display: inline-flex;\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n color: var(--cg-color-surface-container-outlined);\n transition:\n transform var(--cg-transition-duration-default) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .trigger:hover .trigger-caret,\n .trigger.open .trigger-caret { color: var(--cg-color-surface-base-text); }\n .trigger.open .trigger-caret { transform: rotate(180deg); }\n\n .panel {\n position: absolute;\n top: calc(100% + var(--cg-spacing-8));\n left: 0;\n z-index: var(--cg-z-index-500);\n min-width: var(--cg-component-navigation-menu-panel-min-width);\n padding: var(--cg-spacing-24);\n background: var(--cg-color-modal-container-background);\n border: var(--cg-border-width-50) solid var(--cg-color-modal-container-border);\n border-radius: var(--cg-border-radius-200);\n box-shadow: var(--cg-shadow-elevation-xl);\n display: grid;\n grid-template-columns: repeat(var(--cg-nm-columns), minmax(0, 1fr));\n gap: var(--cg-spacing-20);\n transform-origin: top;\n animation: navMenuPanelIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n @keyframes navMenuPanelIn {\n from { opacity: 0; transform: translateY(calc(-1 * var(--cg-spacing-6))) scale(0.98); }\n to { opacity: 1; transform: translateY(0) scale(1); }\n }\n\n .section-heading {\n margin: 0 0 var(--cg-spacing-12) var(--cg-spacing-12);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n text-transform: uppercase;\n letter-spacing: var(--cg-letter-spacing-wider);\n color: var(--cg-color-surface-container-outlined);\n }\n\n .link {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: var(--cg-spacing-4);\n padding: var(--cg-spacing-12);\n background: transparent;\n border: none;\n text-align: left;\n color: inherit;\n font: inherit;\n font-size: var(--cg-font-size-sm);\n text-decoration: none;\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n transition:\n background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n width: 100%;\n box-sizing: border-box;\n }\n /* Optional leading icon — stacks above the title (vertical rhythm). */\n .link-icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--cg-spacing-32);\n height: var(--cg-spacing-32);\n margin-bottom: var(--cg-spacing-4);\n background: var(--cg-color-action-tertiary-background-hover);\n border-radius: var(--cg-border-radius-100);\n color: var(--cg-color-accent-text);\n transition: background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .link-icon svg { width: var(--cg-icon-size-100); height: var(--cg-icon-size-100); }\n .link:hover .link-icon { background: var(--cg-color-surface-container-background); }\n .link:hover {\n background: var(--cg-color-action-tertiary-background-hover);\n }\n .link:active {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .link:focus-visible {\n outline: none;\n box-shadow:\n 0 0 0 var(--cg-focus-ring-offset) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-focus-ring-offset) + var(--cg-focus-ring-width)) var(--cg-color-focus-ring);\n }\n .link-title {\n font-weight: var(--cg-font-weight-medium);\n }\n .link-desc {\n font-size: var(--cg-font-size-xs);\n line-height: var(--cg-line-height-relaxed);\n color: var(--cg-color-surface-container-outlined);\n }\n `];\n\n @property({ type: Array }) items: NavMenuItem[] = [];\n /** Accessible name for the navigation landmark. */\n @property() label = 'Main navigation';\n @property({ type: Number }) openDelay = 80;\n @property({ type: Number }) closeDelay = 120;\n /** Panel grid column count. Default 2. */\n @property({ type: Number }) columns: 1 | 2 | 3 | 4 = 2;\n\n @state() private _openIndex = -1;\n private _openTimer: number | null = null;\n private _closeTimer: number | null = null;\n\n private _clearTimers() {\n if (this._openTimer) { clearTimeout(this._openTimer); this._openTimer = null; }\n if (this._closeTimer) { clearTimeout(this._closeTimer); this._closeTimer = null; }\n }\n\n private _scheduleOpen(i: number): void {\n this._clearTimers();\n this._openTimer = window.setTimeout(() => { this._openIndex = i; }, this.openDelay);\n }\n\n private _scheduleClose(): void {\n this._clearTimers();\n this._closeTimer = window.setTimeout(() => { this._openIndex = -1; }, this.closeDelay);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this._clearTimers();\n }\n\n private _onKeydown(e: KeyboardEvent): void {\n if (e.key === 'Escape' && this._openIndex !== -1) {\n e.preventDefault();\n this._openIndex = -1;\n }\n }\n\n private _onFocusOut(e: FocusEvent): void {\n const target = e.relatedTarget as Node | null;\n if (!target || !this.renderRoot.contains(target)) this._scheduleClose();\n }\n\n private _selectLink(menu: NavMenuItem, link: NavMenuLink): void {\n this.dispatchEvent(new CustomEvent('cg-navigation-menu-select', {\n bubbles: true, composed: true,\n detail: { menu: menu.id ?? menu.label, link: link.title, href: link.href },\n }));\n this._openIndex = -1;\n }\n\n override render() {\n return html`\n <nav\n role=\"navigation\"\n aria-label=${this.label}\n @mouseleave=${this._scheduleClose}\n @keydown=${this._onKeydown}\n @focusout=${this._onFocusOut}\n >\n ${this.items.map((menu, i) => html`\n <button\n class=\"trigger ${this._openIndex === i ? 'open' : ''}\"\n aria-expanded=${this._openIndex === i ? 'true' : 'false'}\n aria-controls=${this._openIndex === i ? 'cg-navigation-menu-panel' : nothing}\n @mouseenter=${() => this._scheduleOpen(i)}\n @click=${() => { this._clearTimers(); this._openIndex = this._openIndex === i ? -1 : i; }}\n >\n <span>${menu.label}</span>\n <span class=\"trigger-caret\" aria-hidden=\"true\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <polyline points=\"6 9 12 15 18 9\"/>\n </svg>\n </span>\n </button>\n `)}\n ${this._openIndex >= 0 && this.items[this._openIndex] ? html`\n <div\n id=\"cg-navigation-menu-panel\"\n class=\"panel\"\n style=${`--cg-nm-columns: ${this.columns};`}\n @mouseenter=${() => { this._clearTimers(); }}\n @mouseleave=${this._scheduleClose}\n >\n ${this.items[this._openIndex]!.sections.map(section => html`\n <div>\n ${section.heading ? html`<h4 class=\"section-heading\">${section.heading}</h4>` : nothing}\n ${section.links.map(link => html`\n <button class=\"link\" @click=${() => this._selectLink(this.items[this._openIndex]!, link)}>\n ${link.icon ? html`<span class=\"link-icon\" aria-hidden=\"true\" .innerHTML=${link.icon}></span>` : nothing}\n <span class=\"link-title\">${link.title}</span>\n ${link.description ? html`<span class=\"link-desc\">${link.description}</span>` : nothing}\n </button>\n `)}\n </div>\n `)}\n </div>\n ` : nothing}\n </nav>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-navigation-menu': CgNavigationMenu;\n }\n}\n"],"names":["CgNavigationMenu","LitElement","i","e","target","menu","link","html","nothing","section","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -35,6 +35,7 @@ export declare class CgNumberInput extends LitElement {
35
35
  private _startRepeat;
36
36
  private _stopRepeat;
37
37
  private _onInput;
38
+ private _commitInput;
38
39
  private _onKeyDown;
39
40
  disconnectedCallback(): void;
40
41
  render(): import('lit').TemplateResult<1>;
@@ -1 +1 @@
1
- {"version":3,"file":"cg-number-input.d.ts","sourceRoot":"","sources":["../../../src/components/cg-number-input/cg-number-input.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E;;;;GAIG;AACH,qBACa,aAAc,SAAQ,UAAU;IAC3C,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,4BA2GnB;IAEyB,KAAK,SAAK;IACV,GAAG,SAAa;IAChB,GAAG,SAAY;IACf,IAAI,SAAK;IACzB,KAAK,SAAM;IACqB,QAAQ,UAAS;IACjB,KAAK,UAAS;IACd,OAAO,UAAS;IAChB,OAAO,UAAS;IAC/B,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IAChC,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAQ;IACtE,IAAI,SAAM;IACO,QAAQ,UAAS;IAErC,OAAO,CAAC,OAAO,EAAE,cAAc;IAcxC,iBAAiB;IAKjB,wBAAwB,CAAC,KAAK,EAAE,MAAM;IAI7B,OAAO,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,YAAY,CAAK;IAET,OAAO,CAAC,MAAM,CAAoB;IAElD,OAAO,CAAC,MAAM;IAId,OAAO,CAAC,SAAS;IAQjB,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,UAAU;IAElB,OAAO,CAAC,YAAY;IAUpB,OAAO,CAAC,WAAW;IAEnB,OAAO,CAAC,QAAQ;IAMhB,OAAO,CAAC,UAAU;IAKT,oBAAoB;IAEpB,MAAM;CAyChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,iBAAiB,EAAE,aAAa,CAAC;KAClC;CACF"}
1
+ {"version":3,"file":"cg-number-input.d.ts","sourceRoot":"","sources":["../../../src/components/cg-number-input/cg-number-input.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E;;;;GAIG;AACH,qBACa,aAAc,SAAQ,UAAU;IAC3C,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,4BA+GnB;IAEyB,KAAK,SAAK;IACV,GAAG,SAAa;IAChB,GAAG,SAAY;IACf,IAAI,SAAK;IACzB,KAAK,SAAM;IACqB,QAAQ,UAAS;IACjB,KAAK,UAAS;IACd,OAAO,UAAS;IAChB,OAAO,UAAS;IAC/B,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IAChC,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAQ;IACtE,IAAI,SAAM;IACO,QAAQ,UAAS;IAErC,OAAO,CAAC,OAAO,EAAE,cAAc;IAcxC,iBAAiB;IAKjB,wBAAwB,CAAC,KAAK,EAAE,MAAM;IAI7B,OAAO,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,YAAY,CAAK;IAET,OAAO,CAAC,MAAM,CAAoB;IAElD,OAAO,CAAC,MAAM;IAId,OAAO,CAAC,SAAS;IAQjB,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,UAAU;IAElB,OAAO,CAAC,YAAY;IAiBpB,OAAO,CAAC,WAAW,CAA8C;IAEjE,OAAO,CAAC,QAAQ;IAKhB,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,UAAU;IAQT,oBAAoB;IAEpB,MAAM;CA4ChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,iBAAiB,EAAE,aAAa,CAAC;KAClC;CACF"}