@cognivo/components 0.8.1 → 0.8.3

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 (235) hide show
  1. package/dist/chunks/{premium.css-DHekUEUt.js → premium.css-B0hBr_uS.js} +27 -27
  2. package/dist/chunks/{premium.css-DHekUEUt.js.map → premium.css-B0hBr_uS.js.map} +1 -1
  3. package/dist/cognivo.min.js +1876 -1227
  4. package/dist/cognivo.min.js.map +1 -1
  5. package/dist/components/ai-ab-test/ai-ab-test.js +1 -1
  6. package/dist/components/ai-accessibility-report/ai-accessibility-report.js +1 -1
  7. package/dist/components/ai-action-preview/ai-action-preview.js +1 -1
  8. package/dist/components/ai-agent-card/ai-agent-card.js +1 -1
  9. package/dist/components/ai-agent-steps/ai-agent-steps.js +1 -1
  10. package/dist/components/ai-alert-card/ai-alert-card.js +1 -1
  11. package/dist/components/ai-analytics-chart/ai-analytics-chart.js +1 -1
  12. package/dist/components/ai-annotation/ai-annotation.js +1 -1
  13. package/dist/components/ai-api-key-manager/ai-api-key-manager.js +1 -1
  14. package/dist/components/ai-app-sidebar/ai-app-sidebar.js +1 -1
  15. package/dist/components/ai-assistant-widget/ai-assistant-widget.js +1 -1
  16. package/dist/components/ai-audio-player/ai-audio-player.js +1 -1
  17. package/dist/components/ai-avatar/ai-avatar.js +1 -1
  18. package/dist/components/ai-badge/ai-badge.js +1 -1
  19. package/dist/components/ai-batch-progress/ai-batch-progress.js +1 -1
  20. package/dist/components/ai-cache-indicator/ai-cache-indicator.js +1 -1
  21. package/dist/components/ai-capture-flow/ai-capture-flow.js +1 -1
  22. package/dist/components/ai-changelog/ai-changelog.js +1 -1
  23. package/dist/components/ai-chart-summary/ai-chart-summary.js +1 -1
  24. package/dist/components/ai-chat/ai-chat.js +1 -1
  25. package/dist/components/ai-citation/ai-citation.js +1 -1
  26. package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js +1 -1
  27. package/dist/components/ai-command-palette/ai-command-palette.js +1 -1
  28. package/dist/components/ai-confidence-badge/ai-confidence-badge.js +1 -1
  29. package/dist/components/ai-confidence-slider/ai-confidence-slider.js +1 -1
  30. package/dist/components/ai-consent-manager/ai-consent-manager.js +1 -1
  31. package/dist/components/ai-context-window/ai-context-window.js +1 -1
  32. package/dist/components/ai-copy-button/ai-copy-button.js +1 -1
  33. package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js +1 -1
  34. package/dist/components/ai-data-card/ai-data-card.js +1 -1
  35. package/dist/components/ai-data-lineage/ai-data-lineage.js +1 -1
  36. package/dist/components/ai-data-preview/ai-data-preview.js +1 -1
  37. package/dist/components/ai-data-table/ai-data-table.js +1 -1
  38. package/dist/components/ai-debug-console/ai-debug-console.js +1 -1
  39. package/dist/components/ai-detection-canvas/ai-detection-canvas.js +1 -1
  40. package/dist/components/ai-diff-panel/ai-diff-panel.js +1 -1
  41. package/dist/components/ai-embedding-viz/ai-embedding-viz.js +1 -1
  42. package/dist/components/ai-empty-state/ai-empty-state.js +1 -1
  43. package/dist/components/ai-error-boundary/ai-error-boundary.js +1 -1
  44. package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js +1 -1
  45. package/dist/components/ai-feature-flag/ai-feature-flag.js +1 -1
  46. package/dist/components/ai-feedback/ai-feedback.js +1 -1
  47. package/dist/components/ai-file-upload/ai-file-upload.js +1 -1
  48. package/dist/components/ai-form-generator/ai-form-generator.js +1 -1
  49. package/dist/components/ai-guardrail/ai-guardrail.js +1 -1
  50. package/dist/components/ai-heatmap/ai-heatmap.js +1 -1
  51. package/dist/components/ai-insight-card/ai-insight-card.js +1 -1
  52. package/dist/components/ai-json-viewer/ai-json-viewer.js +1 -1
  53. package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js +1 -1
  54. package/dist/components/ai-kpi-grid/ai-kpi-grid.js +1 -1
  55. package/dist/components/ai-labeling-board/ai-labeling-board.js +1 -1
  56. package/dist/components/ai-memory-panel/ai-memory-panel.js +1 -1
  57. package/dist/components/ai-model-comparison/ai-model-comparison.js +1 -1
  58. package/dist/components/ai-model-selector/ai-model-selector.js +1 -1
  59. package/dist/components/ai-notification-center/ai-notification-center.js +1 -1
  60. package/dist/components/ai-onboarding/ai-onboarding.js +1 -1
  61. package/dist/components/ai-permission-gate/ai-permission-gate.js +1 -1
  62. package/dist/components/ai-personalization-dash/ai-personalization-dash.js +1 -1
  63. package/dist/components/ai-presence/ai-presence.js +1 -1
  64. package/dist/components/ai-progress-steps/ai-progress-steps.js +1 -1
  65. package/dist/components/ai-prompt-editor/ai-prompt-editor.js +1 -1
  66. package/dist/components/ai-prompt-template/ai-prompt-template.js +1 -1
  67. package/dist/components/ai-rag-panel/ai-rag-panel.js +1 -1
  68. package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js +1 -1
  69. package/dist/components/ai-result-panel/ai-result-panel.js +1 -1
  70. package/dist/components/ai-reveal-animation/ai-reveal-animation.js +1 -1
  71. package/dist/components/ai-reward-signal/ai-reward-signal.js +1 -1
  72. package/dist/components/ai-rich-message/ai-rich-message.js +1 -1
  73. package/dist/components/ai-scenario-panel/ai-scenario-panel.js +1 -1
  74. package/dist/components/ai-search/ai-search.js +1 -1
  75. package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js +1 -1
  76. package/dist/components/ai-sidebar/ai-sidebar.js +1 -1
  77. package/dist/components/ai-similarity-card/ai-similarity-card.js +1 -1
  78. package/dist/components/ai-source-graph/ai-source-graph.js +1 -1
  79. package/dist/components/ai-status-page/ai-status-page.js +1 -1
  80. package/dist/components/ai-streaming-text/ai-streaming-text.js +1 -1
  81. package/dist/components/ai-test-runner/ai-test-runner.js +1 -1
  82. package/dist/components/ai-thinking/ai-thinking.js +1 -1
  83. package/dist/components/ai-timeline/ai-timeline.js +1 -1
  84. package/dist/components/ai-token-tracker/ai-token-tracker.js +1 -1
  85. package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js +1 -1
  86. package/dist/components/ai-tool-indicator/ai-tool-indicator.js +1 -1
  87. package/dist/components/ai-transform-slider/ai-transform-slider.js +1 -1
  88. package/dist/components/ai-translation-panel/ai-translation-panel.js +1 -1
  89. package/dist/components/ai-usage-meter/ai-usage-meter.js +1 -1
  90. package/dist/components/ai-validation-checklist/ai-validation-checklist.js +1 -1
  91. package/dist/components/ai-version-selector/ai-version-selector.js +1 -1
  92. package/dist/components/ai-voice-panel/ai-voice-panel.js +1 -1
  93. package/dist/components/ai-webhook-config/ai-webhook-config.js +1 -1
  94. package/dist/components/ai-workflow-builder/ai-workflow-builder.js +1 -1
  95. package/dist/components/bias-anchoring/bias-anchoring.js +1 -1
  96. package/dist/components/bias-authority/bias-authority.js +1 -1
  97. package/dist/components/bias-commitment/bias-commitment.js +1 -1
  98. package/dist/components/bias-reciprocity/bias-reciprocity.js +1 -1
  99. package/dist/components/bias-scarcity/bias-scarcity.js +1 -1
  100. package/dist/components/bias-social-proof/bias-social-proof.js +1 -1
  101. package/dist/components/cg-accordion/cg-accordion.js +1 -1
  102. package/dist/components/cg-alert-dialog/cg-alert-dialog.js +1 -1
  103. package/dist/components/cg-app-shell/cg-app-shell.d.ts +43 -0
  104. package/dist/components/cg-app-shell/cg-app-shell.d.ts.map +1 -0
  105. package/dist/components/cg-app-shell/cg-app-shell.js +170 -0
  106. package/dist/components/cg-app-shell/cg-app-shell.js.map +1 -0
  107. package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js +1 -1
  108. package/dist/components/cg-autocomplete/cg-autocomplete.js +1 -1
  109. package/dist/components/cg-avatar/cg-avatar.js +1 -1
  110. package/dist/components/cg-avatar-group/cg-avatar-group.js +1 -1
  111. package/dist/components/cg-badge/cg-badge.js +1 -1
  112. package/dist/components/cg-badge-group/cg-badge-group.js +1 -1
  113. package/dist/components/cg-blockquote/cg-blockquote.d.ts +32 -0
  114. package/dist/components/cg-blockquote/cg-blockquote.d.ts.map +1 -0
  115. package/dist/components/cg-blockquote/cg-blockquote.js +108 -0
  116. package/dist/components/cg-blockquote/cg-blockquote.js.map +1 -0
  117. package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js +1 -1
  118. package/dist/components/cg-button/cg-button.js +8 -8
  119. package/dist/components/cg-button/cg-button.js.map +1 -1
  120. package/dist/components/cg-button-group/cg-button-group.js +1 -1
  121. package/dist/components/cg-calendar/cg-calendar.js +1 -1
  122. package/dist/components/cg-callout/cg-callout.js +1 -1
  123. package/dist/components/cg-card/cg-card.js +1 -1
  124. package/dist/components/cg-carousel/cg-carousel.js +1 -1
  125. package/dist/components/cg-center/cg-center.d.ts +37 -0
  126. package/dist/components/cg-center/cg-center.d.ts.map +1 -0
  127. package/dist/components/cg-center/cg-center.js +74 -0
  128. package/dist/components/cg-center/cg-center.js.map +1 -0
  129. package/dist/components/cg-chart/cg-chart.js +1 -1
  130. package/dist/components/cg-checkbox/cg-checkbox.js +1 -1
  131. package/dist/components/cg-chip/cg-chip.js +1 -1
  132. package/dist/components/cg-code-block/cg-code-block.js +1 -1
  133. package/dist/components/cg-collapsible/cg-collapsible.js +1 -1
  134. package/dist/components/cg-color-picker/cg-color-picker.js +1 -1
  135. package/dist/components/cg-combobox/cg-combobox.js +1 -1
  136. package/dist/components/cg-command/cg-command.js +1 -1
  137. package/dist/components/cg-context-menu/cg-context-menu.js +1 -1
  138. package/dist/components/cg-date-picker/cg-date-picker.js +1 -1
  139. package/dist/components/cg-date-range-picker/cg-date-range-picker.js +1 -1
  140. package/dist/components/cg-date-time-picker/cg-date-time-picker.js +1 -1
  141. package/dist/components/cg-drawer/cg-drawer.js +1 -1
  142. package/dist/components/cg-dropdown/cg-dropdown.js +1 -1
  143. package/dist/components/cg-empty-state/cg-empty-state.js +1 -1
  144. package/dist/components/cg-file-input/cg-file-input.js +1 -1
  145. package/dist/components/cg-follow-up/cg-follow-up.js +1 -1
  146. package/dist/components/cg-form/cg-form.js +1 -1
  147. package/dist/components/cg-grid/cg-grid.d.ts +39 -0
  148. package/dist/components/cg-grid/cg-grid.d.ts.map +1 -0
  149. package/dist/components/cg-grid/cg-grid.js +78 -0
  150. package/dist/components/cg-grid/cg-grid.js.map +1 -0
  151. package/dist/components/cg-hover-card/cg-hover-card.js +1 -1
  152. package/dist/components/cg-icon/cg-icon.js +1 -1
  153. package/dist/components/cg-image/cg-image.js +1 -1
  154. package/dist/components/cg-image-block/cg-image-block.js +1 -1
  155. package/dist/components/cg-image-gallery/cg-image-gallery.js +1 -1
  156. package/dist/components/cg-input/cg-input.js +1 -1
  157. package/dist/components/cg-kbd/cg-kbd.js +1 -1
  158. package/dist/components/cg-label/cg-label.js +1 -1
  159. package/dist/components/cg-lightbox/cg-lightbox.d.ts +49 -0
  160. package/dist/components/cg-lightbox/cg-lightbox.d.ts.map +1 -0
  161. package/dist/components/cg-lightbox/cg-lightbox.js +203 -0
  162. package/dist/components/cg-lightbox/cg-lightbox.js.map +1 -0
  163. package/dist/components/cg-link/cg-link.js +1 -1
  164. package/dist/components/cg-list/cg-list.js +1 -1
  165. package/dist/components/cg-listbox/cg-listbox.js +1 -1
  166. package/dist/components/cg-markdown/cg-markdown.js +1 -1
  167. package/dist/components/cg-menubar/cg-menubar.js +1 -1
  168. package/dist/components/cg-meter/cg-meter.js +1 -1
  169. package/dist/components/cg-metric-card/cg-metric-card.js +1 -1
  170. package/dist/components/cg-modal/cg-modal.js +1 -1
  171. package/dist/components/cg-navbar/cg-navbar.js +1 -1
  172. package/dist/components/cg-navigation-menu/cg-navigation-menu.js +1 -1
  173. package/dist/components/cg-number-input/cg-number-input.js +1 -1
  174. package/dist/components/cg-otp-input/cg-otp-input.js +1 -1
  175. package/dist/components/cg-overflow-list/cg-overflow-list.d.ts +51 -0
  176. package/dist/components/cg-overflow-list/cg-overflow-list.d.ts.map +1 -0
  177. package/dist/components/cg-overflow-list/cg-overflow-list.js +212 -0
  178. package/dist/components/cg-overflow-list/cg-overflow-list.js.map +1 -0
  179. package/dist/components/cg-pagination/cg-pagination.js +1 -1
  180. package/dist/components/cg-password-input/cg-password-input.js +1 -1
  181. package/dist/components/cg-phone-input/cg-phone-input.js +1 -1
  182. package/dist/components/cg-popover/cg-popover.js +1 -1
  183. package/dist/components/cg-progress-bar/cg-progress-bar.js +1 -1
  184. package/dist/components/cg-radio/cg-radio.js +1 -1
  185. package/dist/components/cg-radio-group/cg-radio-group.js +1 -1
  186. package/dist/components/cg-rating/cg-rating.js +1 -1
  187. package/dist/components/cg-resizable/cg-resizable.js +1 -1
  188. package/dist/components/cg-scroll-area/cg-scroll-area.js +1 -1
  189. package/dist/components/cg-segmented-control/cg-segmented-control.js +1 -1
  190. package/dist/components/cg-select/cg-select.js +1 -1
  191. package/dist/components/cg-separator/cg-separator.js +1 -1
  192. package/dist/components/cg-sheet/cg-sheet.js +1 -1
  193. package/dist/components/cg-sidebar/cg-sidebar.js +1 -1
  194. package/dist/components/cg-skeleton/cg-skeleton.js +1 -1
  195. package/dist/components/cg-slider/cg-slider.js +1 -1
  196. package/dist/components/cg-spinner/cg-spinner.js +1 -1
  197. package/dist/components/cg-split-button/cg-split-button.js +1 -1
  198. package/dist/components/cg-stack/cg-stack.js +1 -1
  199. package/dist/components/cg-status-dot/cg-status-dot.d.ts +31 -0
  200. package/dist/components/cg-status-dot/cg-status-dot.d.ts.map +1 -0
  201. package/dist/components/cg-status-dot/cg-status-dot.js +89 -0
  202. package/dist/components/cg-status-dot/cg-status-dot.js.map +1 -0
  203. package/dist/components/cg-steps/cg-steps.js +1 -1
  204. package/dist/components/cg-switch/cg-switch.js +1 -1
  205. package/dist/components/cg-table/cg-table.js +1 -1
  206. package/dist/components/cg-tabs/cg-tabs.js +1 -1
  207. package/dist/components/cg-tag-input/cg-tag-input.js +1 -1
  208. package/dist/components/cg-text/cg-text.js +1 -1
  209. package/dist/components/cg-textarea/cg-textarea.js +1 -1
  210. package/dist/components/cg-thumbnail/cg-thumbnail.d.ts +39 -0
  211. package/dist/components/cg-thumbnail/cg-thumbnail.d.ts.map +1 -0
  212. package/dist/components/cg-thumbnail/cg-thumbnail.js +134 -0
  213. package/dist/components/cg-thumbnail/cg-thumbnail.js.map +1 -0
  214. package/dist/components/cg-time-picker/cg-time-picker.js +1 -1
  215. package/dist/components/cg-timestamp/cg-timestamp.d.ts +41 -0
  216. package/dist/components/cg-timestamp/cg-timestamp.d.ts.map +1 -0
  217. package/dist/components/cg-timestamp/cg-timestamp.js +81 -0
  218. package/dist/components/cg-timestamp/cg-timestamp.js.map +1 -0
  219. package/dist/components/cg-toaster/cg-toaster.js +1 -1
  220. package/dist/components/cg-toggle/cg-toggle.js +1 -1
  221. package/dist/components/cg-toggle-group/cg-toggle-group.js +1 -1
  222. package/dist/components/cg-toolbar/cg-toolbar.d.ts +51 -0
  223. package/dist/components/cg-toolbar/cg-toolbar.d.ts.map +1 -0
  224. package/dist/components/cg-toolbar/cg-toolbar.js +130 -0
  225. package/dist/components/cg-toolbar/cg-toolbar.js.map +1 -0
  226. package/dist/components/cg-tree-view/cg-tree-view.js +1 -1
  227. package/dist/foundation.d.ts +11 -1
  228. package/dist/foundation.d.ts.map +1 -1
  229. package/dist/foundation.js +88 -68
  230. package/dist/foundation.js.map +1 -1
  231. package/dist/index.d.ts +11 -1
  232. package/dist/index.d.ts.map +1 -1
  233. package/dist/index.js +126 -106
  234. package/dist/index.js.map +1 -1
  235. package/package.json +13 -14
@@ -0,0 +1,51 @@
1
+ import { LitElement } from 'lit';
2
+ /**
3
+ * @element cg-overflow-list
4
+ * Lays out slotted items in a single row and collapses those that don't fit
5
+ * into a trailing "more" menu.
6
+ *
7
+ * @example
8
+ * ```html
9
+ * <cg-overflow-list more-label="More actions">
10
+ * <cg-button>Cut</cg-button>
11
+ * <cg-button>Copy</cg-button>
12
+ * <cg-button>Paste</cg-button>
13
+ * <cg-button>Delete</cg-button>
14
+ * </cg-overflow-list>
15
+ * ```
16
+ *
17
+ * @slot - Items to lay out.
18
+ * @slot more - Optional custom overflow trigger.
19
+ *
20
+ * @fires {CustomEvent<{hiddenCount: number, hiddenIndices: number[]}>} cg-overflow-change
21
+ * @fires {CustomEvent<{index: number}>} cg-overflow-select
22
+ */
23
+ export declare class CgOverflowList extends LitElement {
24
+ static styles: import('lit').CSSResult[];
25
+ gap: 'none' | 'xs' | 'sm' | 'md' | 'lg';
26
+ moreLabel: string;
27
+ minVisible: number;
28
+ private _hiddenIndices;
29
+ private _menuOpen;
30
+ private _rowEl;
31
+ private _moreEl?;
32
+ private _items;
33
+ private _resizeObserver;
34
+ connectedCallback(): void;
35
+ disconnectedCallback(): void;
36
+ firstUpdated(): void;
37
+ private _onDocClick;
38
+ /** Measure children and hide the trailing ones that overflow. */
39
+ private _measure;
40
+ private _onSlotChange;
41
+ private _toggleMenu;
42
+ private _selectHidden;
43
+ private _hiddenLabel;
44
+ render(): import('lit').TemplateResult<1>;
45
+ }
46
+ declare global {
47
+ interface HTMLElementTagNameMap {
48
+ 'cg-overflow-list': CgOverflowList;
49
+ }
50
+ }
51
+ //# sourceMappingURL=cg-overflow-list.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cg-overflow-list.d.ts","sourceRoot":"","sources":["../../../src/components/cg-overflow-list/cg-overflow-list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAC;AAIjD;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,qBACa,cAAe,SAAQ,UAAU;IAC5C,OAAgB,MAAM,4BA0EnB;IAE0B,GAAG,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IACrC,SAAS,SAAU;IACW,UAAU,SAAK;IAE3E,OAAO,CAAC,cAAc,CAAgB;IACtC,OAAO,CAAC,SAAS,CAAS;IAEpB,OAAO,CAAC,MAAM,CAAe;IAC5B,OAAO,CAAC,OAAO,CAAC,CAAc;IACJ,OAAO,CAAC,MAAM,CAAiB;IAEzE,OAAO,CAAC,eAAe,CAA6B;IAE3C,iBAAiB,IAAI,IAAI;IAOzB,oBAAoB,IAAI,IAAI;IAO5B,YAAY,IAAI,IAAI;IAI7B,OAAO,CAAC,WAAW,CAGjB;IAEF,iEAAiE;IACjE,OAAO,CAAC,QAAQ;IAkDhB,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,aAAa;IASrB,OAAO,CAAC,YAAY;IAKX,MAAM;CAgChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,kBAAkB,EAAE,cAAc,CAAC;KACpC;CACF"}
@@ -0,0 +1,212 @@
1
+ import { css as _, LitElement as w, svg as y, html as m } from "lit";
2
+ import { property as u, state as f, query as b, queryAssignedElements as E, customElement as O } from "lit/decorators.js";
3
+ import { h as C, r as x, j as v } from "../../chunks/premium.css-B0hBr_uS.js";
4
+ var k = Object.defineProperty, $ = Object.getOwnPropertyDescriptor, n = (e, t, a, l) => {
5
+ for (var s = l > 1 ? void 0 : l ? $(t, a) : t, o = e.length - 1, d; o >= 0; o--)
6
+ (d = e[o]) && (s = (l ? d(t, a, s) : d(s)) || s);
7
+ return l && s && k(t, a, s), s;
8
+ };
9
+ let i = class extends w {
10
+ constructor() {
11
+ super(...arguments), this.gap = "sm", this.moreLabel = "More", this.minVisible = 0, this._hiddenIndices = [], this._menuOpen = !1, this._onDocClick = (e) => {
12
+ this._menuOpen && (e.composedPath().includes(this) || (this._menuOpen = !1));
13
+ };
14
+ }
15
+ connectedCallback() {
16
+ super.connectedCallback(), this._resizeObserver = new ResizeObserver(() => this._measure()), this._resizeObserver.observe(this), document.addEventListener("click", this._onDocClick);
17
+ }
18
+ disconnectedCallback() {
19
+ super.disconnectedCallback(), this._resizeObserver?.disconnect(), this._resizeObserver = void 0, document.removeEventListener("click", this._onDocClick);
20
+ }
21
+ firstUpdated() {
22
+ this._measure();
23
+ }
24
+ /** Measure children and hide the trailing ones that overflow. */
25
+ _measure() {
26
+ const e = this._items ?? [];
27
+ if (e.length === 0 || !this._rowEl) return;
28
+ e.forEach((r) => {
29
+ r.hidden = !1, r.removeAttribute("aria-hidden");
30
+ });
31
+ const t = this._rowEl.clientWidth, a = parseFloat(getComputedStyle(this._rowEl).columnGap || "0") || 0, l = this._moreEl ? this._moreEl.offsetWidth + a : 0;
32
+ let s = 0;
33
+ e.forEach((r, c) => {
34
+ s += r.offsetWidth + (c > 0 ? a : 0);
35
+ });
36
+ const o = [];
37
+ if (s > t) {
38
+ let r = 0;
39
+ const c = t - l;
40
+ e.forEach((g, h) => {
41
+ const p = g.offsetWidth + (h > 0 ? a : 0);
42
+ if (h < this.minVisible) {
43
+ r += p;
44
+ return;
45
+ }
46
+ r + p <= c ? r += p : o.push(h);
47
+ });
48
+ }
49
+ e.forEach((r, c) => {
50
+ const g = o.includes(c);
51
+ r.hidden = g, g ? r.setAttribute("aria-hidden", "true") : r.removeAttribute("aria-hidden");
52
+ }), (o.length !== this._hiddenIndices.length || o.some((r, c) => r !== this._hiddenIndices[c])) && (this._hiddenIndices = o, this.dispatchEvent(new CustomEvent("cg-overflow-change", {
53
+ detail: { hiddenCount: o.length, hiddenIndices: o },
54
+ bubbles: !0,
55
+ composed: !0
56
+ })));
57
+ }
58
+ _onSlotChange() {
59
+ requestAnimationFrame(() => this._measure());
60
+ }
61
+ _toggleMenu() {
62
+ this._menuOpen = !this._menuOpen;
63
+ }
64
+ _selectHidden(e) {
65
+ this._menuOpen = !1, this.dispatchEvent(new CustomEvent("cg-overflow-select", {
66
+ detail: { index: e },
67
+ bubbles: !0,
68
+ composed: !0
69
+ }));
70
+ }
71
+ _hiddenLabel(e) {
72
+ return (this._items?.[e]?.textContent || "").trim() || `Item ${e + 1}`;
73
+ }
74
+ render() {
75
+ const e = this._hiddenIndices.length > 0;
76
+ return m`
77
+ <div class="row">
78
+ <slot @slotchange=${this._onSlotChange}></slot>
79
+ <span class="more-wrap">
80
+ <button
81
+ class="more"
82
+ type="button"
83
+ ?hidden=${!e}
84
+ aria-haspopup="menu"
85
+ aria-expanded=${this._menuOpen ? "true" : "false"}
86
+ aria-label=${this.moreLabel}
87
+ @click=${this._toggleMenu}
88
+ >
89
+ <slot name="more">
90
+ ${y`<svg viewBox="0 0 24 24" fill="none" aria-hidden="true"><circle cx="5" cy="12" r="1.6" fill="currentColor"/><circle cx="12" cy="12" r="1.6" fill="currentColor"/><circle cx="19" cy="12" r="1.6" fill="currentColor"/></svg>`}
91
+ </slot>
92
+ </button>
93
+ <ul class="menu" role="menu" ?hidden=${!this._menuOpen}>
94
+ ${this._hiddenIndices.map((t) => m`
95
+ <li role="none">
96
+ <button class="menu-item" role="menuitem" type="button" @click=${() => this._selectHidden(t)}>
97
+ ${this._hiddenLabel(t)}
98
+ </button>
99
+ </li>
100
+ `)}
101
+ </ul>
102
+ </span>
103
+ </div>
104
+ `;
105
+ }
106
+ };
107
+ i.styles = [C, x, _`
108
+ :host { display: block; }
109
+
110
+ .row {
111
+ display: flex;
112
+ align-items: center;
113
+ gap: var(--_cg-of-gap, var(--cg-spacing-8));
114
+ flex-wrap: nowrap;
115
+ overflow: hidden;
116
+ }
117
+
118
+ :host([gap="none"]) .row { --_cg-of-gap: 0; }
119
+ :host([gap="xs"]) .row { --_cg-of-gap: var(--cg-spacing-4); }
120
+ :host([gap="sm"]) .row { --_cg-of-gap: var(--cg-spacing-8); }
121
+ :host([gap="md"]) .row { --_cg-of-gap: var(--cg-spacing-16); }
122
+ :host([gap="lg"]) .row { --_cg-of-gap: var(--cg-spacing-24); }
123
+
124
+ ::slotted([hidden]) { display: none !important; }
125
+
126
+ .more-wrap { position: relative; flex: 0 0 auto; }
127
+
128
+ .more {
129
+ display: inline-flex;
130
+ align-items: center;
131
+ justify-content: center;
132
+ height: var(--cg-spacing-32);
133
+ min-width: var(--cg-spacing-32);
134
+ padding: 0 var(--cg-spacing-8);
135
+ border-radius: var(--cg-border-radius-150);
136
+ background: var(--cg-color-surface-cards-background);
137
+ border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
138
+ color: var(--cg-color-surface-cards-text);
139
+ cursor: pointer;
140
+ transition:
141
+ border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
142
+ transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
143
+ }
144
+ .more:hover { border-color: var(--cg-color-action-primary-border-default); }
145
+ .more:active { transform: scale(var(--cg-interaction-press-scale)); }
146
+ .more:focus-visible { ${v} }
147
+ .more svg { width: var(--cg-spacing-16); height: var(--cg-spacing-16); }
148
+ .more[hidden] { display: none; }
149
+
150
+ .menu {
151
+ position: absolute;
152
+ top: calc(100% + var(--cg-spacing-4));
153
+ right: 0;
154
+ min-width: var(--cg-spacing-160);
155
+ padding: var(--cg-spacing-4);
156
+ background: var(--cg-color-surface-popover-background);
157
+ border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
158
+ border-radius: var(--cg-border-radius-150);
159
+ box-shadow: var(--cg-shadow-elevation-lg);
160
+ z-index: var(--cg-z-index-300);
161
+ list-style: none;
162
+ margin: 0;
163
+ }
164
+ .menu[hidden] { display: none; }
165
+
166
+ .menu-item {
167
+ display: block;
168
+ width: 100%;
169
+ text-align: left;
170
+ padding: var(--cg-spacing-8) var(--cg-spacing-12);
171
+ border: none;
172
+ background: transparent;
173
+ color: var(--cg-color-surface-popover-text);
174
+ border-radius: var(--cg-border-radius-100);
175
+ cursor: pointer;
176
+ font-family: var(--cg-font-family-primary);
177
+ font-size: var(--cg-font-size-sm);
178
+ }
179
+ .menu-item:hover { background: var(--cg-color-action-tertiary-background-hover); }
180
+ .menu-item:focus-visible { ${v} }
181
+ `];
182
+ n([
183
+ u({ reflect: !0 })
184
+ ], i.prototype, "gap", 2);
185
+ n([
186
+ u({ attribute: "more-label" })
187
+ ], i.prototype, "moreLabel", 2);
188
+ n([
189
+ u({ type: Number, reflect: !0, attribute: "min-visible" })
190
+ ], i.prototype, "minVisible", 2);
191
+ n([
192
+ f()
193
+ ], i.prototype, "_hiddenIndices", 2);
194
+ n([
195
+ f()
196
+ ], i.prototype, "_menuOpen", 2);
197
+ n([
198
+ b(".row")
199
+ ], i.prototype, "_rowEl", 2);
200
+ n([
201
+ b(".more")
202
+ ], i.prototype, "_moreEl", 2);
203
+ n([
204
+ E({ flatten: !0 })
205
+ ], i.prototype, "_items", 2);
206
+ i = n([
207
+ O("cg-overflow-list")
208
+ ], i);
209
+ export {
210
+ i as CgOverflowList
211
+ };
212
+ //# sourceMappingURL=cg-overflow-list.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cg-overflow-list.js","sources":["../../../src/components/cg-overflow-list/cg-overflow-list.ts"],"sourcesContent":["import { LitElement, html, css, svg } from 'lit';\nimport { customElement, property, state, query, queryAssignedElements } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, focusRingDual } from '../../styles/index.js';\n\n/**\n * @element cg-overflow-list\n * Lays out slotted items in a single row and collapses those that don't fit\n * into a trailing \"more\" menu.\n *\n * @example\n * ```html\n * <cg-overflow-list more-label=\"More actions\">\n * <cg-button>Cut</cg-button>\n * <cg-button>Copy</cg-button>\n * <cg-button>Paste</cg-button>\n * <cg-button>Delete</cg-button>\n * </cg-overflow-list>\n * ```\n *\n * @slot - Items to lay out.\n * @slot more - Optional custom overflow trigger.\n *\n * @fires {CustomEvent<{hiddenCount: number, hiddenIndices: number[]}>} cg-overflow-change\n * @fires {CustomEvent<{index: number}>} cg-overflow-select\n */\n@customElement('cg-overflow-list')\nexport class CgOverflowList extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host { display: block; }\n\n .row {\n display: flex;\n align-items: center;\n gap: var(--_cg-of-gap, var(--cg-spacing-8));\n flex-wrap: nowrap;\n overflow: hidden;\n }\n\n :host([gap=\"none\"]) .row { --_cg-of-gap: 0; }\n :host([gap=\"xs\"]) .row { --_cg-of-gap: var(--cg-spacing-4); }\n :host([gap=\"sm\"]) .row { --_cg-of-gap: var(--cg-spacing-8); }\n :host([gap=\"md\"]) .row { --_cg-of-gap: var(--cg-spacing-16); }\n :host([gap=\"lg\"]) .row { --_cg-of-gap: var(--cg-spacing-24); }\n\n ::slotted([hidden]) { display: none !important; }\n\n .more-wrap { position: relative; flex: 0 0 auto; }\n\n .more {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n height: var(--cg-spacing-32);\n min-width: var(--cg-spacing-32);\n padding: 0 var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-150);\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n color: var(--cg-color-surface-cards-text);\n cursor: pointer;\n transition:\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .more:hover { border-color: var(--cg-color-action-primary-border-default); }\n .more:active { transform: scale(var(--cg-interaction-press-scale)); }\n .more:focus-visible { ${focusRingDual} }\n .more svg { width: var(--cg-spacing-16); height: var(--cg-spacing-16); }\n .more[hidden] { display: none; }\n\n .menu {\n position: absolute;\n top: calc(100% + var(--cg-spacing-4));\n right: 0;\n min-width: var(--cg-spacing-160);\n padding: var(--cg-spacing-4);\n background: var(--cg-color-surface-popover-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n box-shadow: var(--cg-shadow-elevation-lg);\n z-index: var(--cg-z-index-300);\n list-style: none;\n margin: 0;\n }\n .menu[hidden] { display: none; }\n\n .menu-item {\n display: block;\n width: 100%;\n text-align: left;\n padding: var(--cg-spacing-8) var(--cg-spacing-12);\n border: none;\n background: transparent;\n color: var(--cg-color-surface-popover-text);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n font-family: var(--cg-font-family-primary);\n font-size: var(--cg-font-size-sm);\n }\n .menu-item:hover { background: var(--cg-color-action-tertiary-background-hover); }\n .menu-item:focus-visible { ${focusRingDual} }\n `];\n\n @property({ reflect: true }) gap: 'none' | 'xs' | 'sm' | 'md' | 'lg' = 'sm';\n @property({ attribute: 'more-label' }) moreLabel = 'More';\n @property({ type: Number, reflect: true, attribute: 'min-visible' }) minVisible = 0;\n\n @state() private _hiddenIndices: number[] = [];\n @state() private _menuOpen = false;\n\n @query('.row') private _rowEl!: HTMLElement;\n @query('.more') private _moreEl?: HTMLElement;\n @queryAssignedElements({ flatten: true }) private _items!: HTMLElement[];\n\n private _resizeObserver: ResizeObserver | undefined;\n\n override connectedCallback(): void {\n super.connectedCallback();\n this._resizeObserver = new ResizeObserver(() => this._measure());\n this._resizeObserver.observe(this);\n document.addEventListener('click', this._onDocClick);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this._resizeObserver?.disconnect();\n this._resizeObserver = undefined;\n document.removeEventListener('click', this._onDocClick);\n }\n\n override firstUpdated(): void {\n this._measure();\n }\n\n private _onDocClick = (e: MouseEvent): void => {\n if (!this._menuOpen) return;\n if (!e.composedPath().includes(this)) this._menuOpen = false;\n };\n\n /** Measure children and hide the trailing ones that overflow. */\n private _measure(): void {\n const items = this._items ?? [];\n if (items.length === 0 || !this._rowEl) return;\n\n // Reset: show everything, then measure.\n items.forEach((el) => { el.hidden = false; el.removeAttribute('aria-hidden'); });\n\n const available = this._rowEl.clientWidth;\n const gap = parseFloat(getComputedStyle(this._rowEl).columnGap || '0') || 0;\n const moreWidth = this._moreEl ? this._moreEl.offsetWidth + gap : 0;\n\n // First pass: does everything fit without a more button?\n let total = 0;\n items.forEach((el, i) => { total += el.offsetWidth + (i > 0 ? gap : 0); });\n\n const hidden: number[] = [];\n if (total > available) {\n // Reserve space for the more button and fit as many leading items as possible.\n let used = 0;\n const budget = available - moreWidth;\n items.forEach((el, i) => {\n const w = el.offsetWidth + (i > 0 ? gap : 0);\n if (i < this.minVisible) { used += w; return; }\n if (used + w <= budget) { used += w; }\n else { hidden.push(i); }\n });\n }\n\n // Apply visibility.\n items.forEach((el, i) => {\n const isHidden = hidden.includes(i);\n el.hidden = isHidden;\n if (isHidden) el.setAttribute('aria-hidden', 'true');\n else el.removeAttribute('aria-hidden');\n });\n\n const changed =\n hidden.length !== this._hiddenIndices.length ||\n hidden.some((v, i) => v !== this._hiddenIndices[i]);\n\n if (changed) {\n this._hiddenIndices = hidden;\n this.dispatchEvent(new CustomEvent('cg-overflow-change', {\n detail: { hiddenCount: hidden.length, hiddenIndices: hidden },\n bubbles: true,\n composed: true,\n }));\n }\n }\n\n private _onSlotChange(): void {\n // Re-measure after DOM settles.\n requestAnimationFrame(() => this._measure());\n }\n\n private _toggleMenu(): void {\n this._menuOpen = !this._menuOpen;\n }\n\n private _selectHidden(index: number): void {\n this._menuOpen = false;\n this.dispatchEvent(new CustomEvent('cg-overflow-select', {\n detail: { index },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _hiddenLabel(index: number): string {\n const el = this._items?.[index];\n return (el?.textContent || '').trim() || `Item ${index + 1}`;\n }\n\n override render() {\n const hasOverflow = this._hiddenIndices.length > 0;\n return html`\n <div class=\"row\">\n <slot @slotchange=${this._onSlotChange}></slot>\n <span class=\"more-wrap\">\n <button\n class=\"more\"\n type=\"button\"\n ?hidden=${!hasOverflow}\n aria-haspopup=\"menu\"\n aria-expanded=${this._menuOpen ? 'true' : 'false'}\n aria-label=${this.moreLabel}\n @click=${this._toggleMenu}\n >\n <slot name=\"more\">\n ${svg`<svg viewBox=\"0 0 24 24\" fill=\"none\" aria-hidden=\"true\"><circle cx=\"5\" cy=\"12\" r=\"1.6\" fill=\"currentColor\"/><circle cx=\"12\" cy=\"12\" r=\"1.6\" fill=\"currentColor\"/><circle cx=\"19\" cy=\"12\" r=\"1.6\" fill=\"currentColor\"/></svg>`}\n </slot>\n </button>\n <ul class=\"menu\" role=\"menu\" ?hidden=${!this._menuOpen}>\n ${this._hiddenIndices.map((i) => html`\n <li role=\"none\">\n <button class=\"menu-item\" role=\"menuitem\" type=\"button\" @click=${() => this._selectHidden(i)}>\n ${this._hiddenLabel(i)}\n </button>\n </li>\n `)}\n </ul>\n </span>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-overflow-list': CgOverflowList;\n }\n}\n"],"names":["CgOverflowList","LitElement","items","el","available","gap","moreWidth","total","i","hidden","used","budget","w","isHidden","v","index","hasOverflow","html","svg","hostBlock","reducedMotion","css","focusRingDual","__decorateClass","property","state","query","queryAssignedElements","customElement"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { css as d, LitElement as p, html as l, nothing as h } from "lit";
2
2
  import { property as c, customElement as b } from "lit/decorators.js";
3
- import { h as v, r as f } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as v, r as f } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var m = Object.defineProperty, w = Object.getOwnPropertyDescriptor, o = (t, a, n, r) => {
5
5
  for (var i = r > 1 ? void 0 : r ? w(a, n) : a, g = t.length - 1, s; g >= 0; g--)
6
6
  (s = t[g]) && (i = (r ? s(a, n, i) : s(i)) || i);
@@ -1,6 +1,6 @@
1
1
  import { css as g, LitElement as h, nothing as n, html as o } from "lit";
2
2
  import { property as s, state as p, customElement as v } from "lit/decorators.js";
3
- import { h as f, r as b } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as f, r as b } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var m = Object.defineProperty, y = Object.getOwnPropertyDescriptor, r = (t, a, c, l) => {
5
5
  for (var i = l > 1 ? void 0 : l ? y(a, c) : a, u = t.length - 1, d; u >= 0; u--)
6
6
  (d = t[u]) && (i = (l ? d(a, c, i) : d(i)) || i);
@@ -1,6 +1,6 @@
1
1
  import { css as w, LitElement as x, html as p, nothing as g } from "lit";
2
2
  import { property as d, state as f, query as y, customElement as S } from "lit/decorators.js";
3
- import { h as I, r as M } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as I, r as M } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  import { b as k } from "../../chunks/outside-click-CP1P1fK3.js";
5
5
  const e = (t, a, s, n, c, l) => {
6
6
  const i = t.toUpperCase().split("").map((_) => 127462 + _.charCodeAt(0) - 65), u = String.fromCodePoint(...i), h = { iso2: t, name: a, dialCode: s, flag: u };
@@ -1,6 +1,6 @@
1
1
  import { css as g, LitElement as v, nothing as c, html as d } from "lit";
2
2
  import { property as i, state as h, query as u, customElement as m } from "lit/decorators.js";
3
- import { h as f, r as _ } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as f, r as _ } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  import { b, a as w } from "../../chunks/floating-DfsaYJnh.js";
5
5
  import { b as y } from "../../chunks/outside-click-CP1P1fK3.js";
6
6
  import { F as E } from "../../chunks/focus-trap-vlQwKK-3.js";
@@ -1,6 +1,6 @@
1
1
  import { css as g, LitElement as u, nothing as r, html as s } from "lit";
2
2
  import { property as a, customElement as h } from "lit/decorators.js";
3
- import { h as f, r as m } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as f, r as m } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var v = Object.defineProperty, b = Object.getOwnPropertyDescriptor, e = (l, n, o, c) => {
5
5
  for (var i = c > 1 ? void 0 : c ? b(n, o) : n, p = l.length - 1, d; p >= 0; p--)
6
6
  (d = l[p]) && (i = (c ? d(n, o, i) : d(i)) || i);
@@ -1,6 +1,6 @@
1
1
  import { LitElement as h, css as g, nothing as u, html as s } from "lit";
2
2
  import { property as o, customElement as p } from "lit/decorators.js";
3
- import { h as f, r as v } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as f, r as v } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var b = Object.defineProperty, k = Object.getOwnPropertyDescriptor, t = (r, i, l, c) => {
5
5
  for (var a = c > 1 ? void 0 : c ? k(i, l) : i, n = r.length - 1, d; n >= 0; n--)
6
6
  (d = r[n]) && (a = (c ? d(i, l, a) : d(a)) || a);
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as f, nothing as c, html as u } from "lit";
2
2
  import { property as d, customElement as g } from "lit/decorators.js";
3
- import { h as b, r as v } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as b, r as v } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var _ = Object.defineProperty, m = Object.getOwnPropertyDescriptor, n = (e, t, o, s) => {
5
5
  for (var a = s > 1 ? void 0 : s ? m(t, o) : t, r = e.length - 1, l; r >= 0; r--)
6
6
  (l = e[r]) && (a = (s ? l(t, o, a) : l(a)) || a);
@@ -1,6 +1,6 @@
1
1
  import { css as d, LitElement as v, nothing as c, html as u } from "lit";
2
2
  import { property as n, state as g, customElement as f } from "lit/decorators.js";
3
- import { a as p, r as m } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { a as p, r as m } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var y = Object.defineProperty, w = Object.getOwnPropertyDescriptor, o = (t, r, e, i) => {
5
5
  for (var a = i > 1 ? void 0 : i ? w(r, e) : r, l = t.length - 1, h; l >= 0; l--)
6
6
  (h = t[l]) && (a = (i ? h(r, e, a) : h(a)) || a);
@@ -1,6 +1,6 @@
1
1
  import { css as h, LitElement as v, html as g } from "lit";
2
2
  import { property as l, state as u, customElement as p } from "lit/decorators.js";
3
- import { h as b, r as f } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as b, r as f } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var m = Object.defineProperty, w = Object.getOwnPropertyDescriptor, c = (e, t, o, i) => {
5
5
  for (var r = i > 1 ? void 0 : i ? w(t, o) : t, a = e.length - 1, s; a >= 0; a--)
6
6
  (s = e[a]) && (r = (i ? s(t, o, r) : s(r)) || r);
@@ -1,6 +1,6 @@
1
1
  import { css as b, LitElement as d, nothing as v, html as h } from "lit";
2
2
  import { property as n, state as p, customElement as u } from "lit/decorators.js";
3
- import { h as w, r as g } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as w, r as g } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var f = Object.defineProperty, y = Object.getOwnPropertyDescriptor, t = (r, l, s, a) => {
5
5
  for (var o = a > 1 ? void 0 : a ? y(l, s) : l, c = r.length - 1, i; c >= 0; c--)
6
6
  (i = r[c]) && (o = (a ? i(l, s, o) : i(o)) || o);
@@ -1,6 +1,6 @@
1
1
  import { css as u, LitElement as h, nothing as g, html as d } from "lit";
2
2
  import { property as a, customElement as p } from "lit/decorators.js";
3
- import { a as f, r as v } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { a as f, r as v } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var m = Object.defineProperty, b = Object.getOwnPropertyDescriptor, r = (e, i, s, t) => {
5
5
  for (var o = t > 1 ? void 0 : t ? b(i, s) : i, c = e.length - 1, l; c >= 0; c--)
6
6
  (l = e[c]) && (o = (t ? l(i, s, o) : l(o)) || o);
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as u, nothing as c, html as l } from "lit";
2
2
  import { property as s, state as g, customElement as v } from "lit/decorators.js";
3
- import { h as b, r as f } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as b, r as f } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  import { b as m } from "../../chunks/outside-click-CP1P1fK3.js";
5
5
  var _ = Object.defineProperty, y = Object.getOwnPropertyDescriptor, t = (e, i, o, n) => {
6
6
  for (var a = n > 1 ? void 0 : n ? y(i, o) : i, d = e.length - 1, h; d >= 0; d--)
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as h, html as g } from "lit";
2
2
  import { property as o, customElement as v } from "lit/decorators.js";
3
- import { h as d, r as u } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as d, r as u } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var m = Object.defineProperty, f = Object.getOwnPropertyDescriptor, i = (e, a, s, n) => {
5
5
  for (var t = n > 1 ? void 0 : n ? f(a, s) : a, c = e.length - 1, l; c >= 0; c--)
6
6
  (l = e[c]) && (t = (n ? l(a, s, t) : l(t)) || t);
@@ -1,6 +1,6 @@
1
1
  import { css as c, LitElement as g, nothing as n, html as p } from "lit";
2
2
  import { property as h, state as f, customElement as u } from "lit/decorators.js";
3
- import { r as v } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { r as v } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  import { F as b } from "../../chunks/focus-trap-vlQwKK-3.js";
5
5
  var m = Object.defineProperty, _ = Object.getOwnPropertyDescriptor, a = (t, e, s, o) => {
6
6
  for (var r = o > 1 ? void 0 : o ? _(e, s) : e, d = t.length - 1, l; d >= 0; d--)
@@ -1,6 +1,6 @@
1
1
  import { css as h, LitElement as p, nothing as u, html as d } from "lit";
2
2
  import { property as i, state as g, customElement as f } from "lit/decorators.js";
3
- import { r as v } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { r as v } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var b = Object.defineProperty, m = Object.getOwnPropertyDescriptor, a = (t, o, n, s) => {
5
5
  for (var r = s > 1 ? void 0 : s ? m(o, n) : o, l = t.length - 1, c; l >= 0; l--)
6
6
  (c = t[l]) && (r = (s ? c(o, n, r) : c(r)) || r);
@@ -1,6 +1,6 @@
1
1
  import { css as c, LitElement as h, html as u } from "lit";
2
2
  import { property as o, customElement as g } from "lit/decorators.js";
3
- import { h as p, r as m, p as v } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as p, r as m, p as v } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var f = Object.defineProperty, b = Object.getOwnPropertyDescriptor, a = (n, e, s, i) => {
5
5
  for (var t = i > 1 ? void 0 : i ? b(e, s) : e, d = n.length - 1, l; d >= 0; d--)
6
6
  (l = n[d]) && (t = (i ? l(e, s, t) : l(t)) || t);
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as u, nothing as o, html as n } from "lit";
2
2
  import { property as i, state as d, customElement as v } from "lit/decorators.js";
3
- import { h as b, r as m } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as b, r as m } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var f = Object.defineProperty, w = Object.getOwnPropertyDescriptor, a = (e, r, c, l) => {
5
5
  for (var s = l > 1 ? void 0 : l ? w(r, c) : r, g = e.length - 1, h; g >= 0; g--)
6
6
  (h = e[g]) && (s = (l ? h(r, c, s) : h(s)) || s);
@@ -1,6 +1,6 @@
1
1
  import { css as d, LitElement as l, html as h } from "lit";
2
2
  import { property as a, customElement as g } from "lit/decorators.js";
3
- import { a as m, r as v, c as b, p as w } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { a as m, r as v, c as b, p as w } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var u = Object.defineProperty, y = Object.getOwnPropertyDescriptor, n = (c, o, t, i) => {
5
5
  for (var e = i > 1 ? void 0 : i ? y(o, t) : o, s = c.length - 1, p; s >= 0; s--)
6
6
  (p = c[s]) && (e = (i ? p(o, t, e) : p(e)) || e);
@@ -1,6 +1,6 @@
1
1
  import { css as g, LitElement as h, nothing as d, html as c } from "lit";
2
2
  import { property as a, state as b, query as p, customElement as v } from "lit/decorators.js";
3
- import { a as m, r as f, e as y, m as k } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { a as m, r as f, e as y, m as k } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  import { a as _ } from "../../chunks/floating-DfsaYJnh.js";
5
5
  import { b as x } from "../../chunks/outside-click-CP1P1fK3.js";
6
6
  import { h as w } from "../../chunks/roving-index-BuO0tTba.js";
@@ -1,6 +1,6 @@
1
1
  import { css as p, LitElement as g, html as f } from "lit";
2
2
  import { property as s, customElement as h } from "lit/decorators.js";
3
- import { h as u, r as y } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h as u, r as y } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var m = Object.defineProperty, d = Object.getOwnPropertyDescriptor, r = (c, o, n, i) => {
5
5
  for (var e = i > 1 ? void 0 : i ? d(o, n) : o, a = c.length - 1, l; a >= 0; a--)
6
6
  (l = c[a]) && (e = (i ? l(o, n, e) : l(e)) || e);
@@ -0,0 +1,31 @@
1
+ import { LitElement } from 'lit';
2
+ export type CgStatusDotStatus = 'online' | 'away' | 'busy' | 'offline' | 'success' | 'warning' | 'error' | 'info' | 'neutral';
3
+ /**
4
+ * @element cg-status-dot
5
+ * A small colored dot indicating status/presence, with an optional pulse
6
+ * animation and accessible label.
7
+ *
8
+ * @example
9
+ * ```html
10
+ * <cg-status-dot status="online" label="Online"></cg-status-dot>
11
+ * ```
12
+ *
13
+ * @example Decorative dot next to text
14
+ * ```html
15
+ * <cg-status-dot status="busy" pulse></cg-status-dot> <span>Busy</span>
16
+ * ```
17
+ */
18
+ export declare class CgStatusDot extends LitElement {
19
+ static styles: import('lit').CSSResult[];
20
+ status: CgStatusDotStatus;
21
+ size: 'sm' | 'md' | 'lg';
22
+ pulse: boolean;
23
+ label: string;
24
+ render(): import('lit').TemplateResult<1>;
25
+ }
26
+ declare global {
27
+ interface HTMLElementTagNameMap {
28
+ 'cg-status-dot': CgStatusDot;
29
+ }
30
+ }
31
+ //# sourceMappingURL=cg-status-dot.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cg-status-dot.d.ts","sourceRoot":"","sources":["../../../src/components/cg-status-dot/cg-status-dot.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD,MAAM,MAAM,iBAAiB,GACzB,QAAQ,GAAG,MAAM,GAAG,MAAM,GAAG,SAAS,GACtC,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,MAAM,GAAG,SAAS,CAAC;AAEzD;;;;;;;;;;;;;;GAcG;AACH,qBACa,WAAY,SAAQ,UAAU;IACzC,OAAgB,MAAM,4BA8CnB;IAE0B,MAAM,EAAE,iBAAiB,CAAa;IACtC,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IACjB,KAAK,UAAS;IAC9C,KAAK,SAAM;IAEd,MAAM;CAUhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,eAAe,EAAE,WAAW,CAAC;KAC9B;CACF"}
@@ -0,0 +1,89 @@
1
+ import { css as d, LitElement as g, nothing as u, html as p } from "lit";
2
+ import { property as a, customElement as h } from "lit/decorators.js";
3
+ import { a as f, r as v } from "../../chunks/premium.css-B0hBr_uS.js";
4
+ var m = Object.defineProperty, b = Object.getOwnPropertyDescriptor, o = (n, e, i, r) => {
5
+ for (var t = r > 1 ? void 0 : r ? b(e, i) : e, c = n.length - 1, l; c >= 0; c--)
6
+ (l = n[c]) && (t = (r ? l(e, i, t) : l(t)) || t);
7
+ return r && t && m(e, i, t), t;
8
+ };
9
+ let s = class extends g {
10
+ constructor() {
11
+ super(...arguments), this.status = "neutral", this.size = "md", this.pulse = !1, this.label = "";
12
+ }
13
+ render() {
14
+ return p`
15
+ <span
16
+ class="dot"
17
+ role=${this.label ? "status" : u}
18
+ aria-label=${this.label || u}
19
+ aria-hidden=${this.label ? u : "true"}
20
+ ></span>
21
+ `;
22
+ }
23
+ };
24
+ s.styles = [f, v, d`
25
+ :host {
26
+ display: inline-block;
27
+ vertical-align: middle;
28
+ line-height: 0;
29
+ }
30
+
31
+ .dot {
32
+ display: inline-block;
33
+ width: var(--_cg-dot-size, 8px);
34
+ height: var(--_cg-dot-size, 8px);
35
+ border-radius: var(--cg-border-radius-full);
36
+ background: var(--_cg-dot-color, var(--cg-color-surface-base-icon));
37
+ position: relative;
38
+ }
39
+
40
+ /* Sizes */
41
+ :host([size="sm"]) .dot { --_cg-dot-size: var(--cg-spacing-6); }
42
+ :host([size="md"]) .dot { --_cg-dot-size: var(--cg-spacing-8); }
43
+ :host([size="lg"]) .dot { --_cg-dot-size: var(--cg-spacing-12); }
44
+
45
+ /* Status → semantic color */
46
+ :host([status="online"]) .dot,
47
+ :host([status="success"]) .dot { --_cg-dot-color: var(--cg-color-status-success-text-default); }
48
+ :host([status="away"]) .dot,
49
+ :host([status="warning"]) .dot { --_cg-dot-color: var(--cg-color-status-warning-text-default); }
50
+ :host([status="busy"]) .dot,
51
+ :host([status="error"]) .dot { --_cg-dot-color: var(--cg-color-status-error-text-default); }
52
+ :host([status="info"]) .dot { --_cg-dot-color: var(--cg-color-status-info-text-default); }
53
+ :host([status="offline"]) .dot,
54
+ :host([status="neutral"]) .dot { --_cg-dot-color: var(--cg-color-surface-base-icon); }
55
+
56
+ /* Pulse ring */
57
+ :host([pulse]) .dot::after {
58
+ content: '';
59
+ position: absolute;
60
+ inset: 0;
61
+ border-radius: var(--cg-border-radius-full);
62
+ background: inherit;
63
+ animation: cg-dot-pulse var(--cg-ai-effect-shimmer-duration) var(--cg-transition-easing-default) infinite;
64
+ }
65
+
66
+ @keyframes cg-dot-pulse {
67
+ 0% { transform: scale(1); opacity: 0.6; }
68
+ 100% { transform: scale(2.4); opacity: 0; }
69
+ }
70
+ `];
71
+ o([
72
+ a({ reflect: !0 })
73
+ ], s.prototype, "status", 2);
74
+ o([
75
+ a({ reflect: !0 })
76
+ ], s.prototype, "size", 2);
77
+ o([
78
+ a({ type: Boolean, reflect: !0 })
79
+ ], s.prototype, "pulse", 2);
80
+ o([
81
+ a()
82
+ ], s.prototype, "label", 2);
83
+ s = o([
84
+ h("cg-status-dot")
85
+ ], s);
86
+ export {
87
+ s as CgStatusDot
88
+ };
89
+ //# sourceMappingURL=cg-status-dot.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cg-status-dot.js","sources":["../../../src/components/cg-status-dot/cg-status-dot.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBase, reducedMotion } from '../../styles/index.js';\n\nexport type CgStatusDotStatus =\n | 'online' | 'away' | 'busy' | 'offline'\n | 'success' | 'warning' | 'error' | 'info' | 'neutral';\n\n/**\n * @element cg-status-dot\n * A small colored dot indicating status/presence, with an optional pulse\n * animation and accessible label.\n *\n * @example\n * ```html\n * <cg-status-dot status=\"online\" label=\"Online\"></cg-status-dot>\n * ```\n *\n * @example Decorative dot next to text\n * ```html\n * <cg-status-dot status=\"busy\" pulse></cg-status-dot> <span>Busy</span>\n * ```\n */\n@customElement('cg-status-dot')\nexport class CgStatusDot extends LitElement {\n static override styles = [hostBase, reducedMotion, css`\n :host {\n display: inline-block;\n vertical-align: middle;\n line-height: 0;\n }\n\n .dot {\n display: inline-block;\n width: var(--_cg-dot-size, 8px);\n height: var(--_cg-dot-size, 8px);\n border-radius: var(--cg-border-radius-full);\n background: var(--_cg-dot-color, var(--cg-color-surface-base-icon));\n position: relative;\n }\n\n /* Sizes */\n :host([size=\"sm\"]) .dot { --_cg-dot-size: var(--cg-spacing-6); }\n :host([size=\"md\"]) .dot { --_cg-dot-size: var(--cg-spacing-8); }\n :host([size=\"lg\"]) .dot { --_cg-dot-size: var(--cg-spacing-12); }\n\n /* Status → semantic color */\n :host([status=\"online\"]) .dot,\n :host([status=\"success\"]) .dot { --_cg-dot-color: var(--cg-color-status-success-text-default); }\n :host([status=\"away\"]) .dot,\n :host([status=\"warning\"]) .dot { --_cg-dot-color: var(--cg-color-status-warning-text-default); }\n :host([status=\"busy\"]) .dot,\n :host([status=\"error\"]) .dot { --_cg-dot-color: var(--cg-color-status-error-text-default); }\n :host([status=\"info\"]) .dot { --_cg-dot-color: var(--cg-color-status-info-text-default); }\n :host([status=\"offline\"]) .dot,\n :host([status=\"neutral\"]) .dot { --_cg-dot-color: var(--cg-color-surface-base-icon); }\n\n /* Pulse ring */\n :host([pulse]) .dot::after {\n content: '';\n position: absolute;\n inset: 0;\n border-radius: var(--cg-border-radius-full);\n background: inherit;\n animation: cg-dot-pulse var(--cg-ai-effect-shimmer-duration) var(--cg-transition-easing-default) infinite;\n }\n\n @keyframes cg-dot-pulse {\n 0% { transform: scale(1); opacity: 0.6; }\n 100% { transform: scale(2.4); opacity: 0; }\n }\n `];\n\n @property({ reflect: true }) status: CgStatusDotStatus = 'neutral';\n @property({ reflect: true }) size: 'sm' | 'md' | 'lg' = 'md';\n @property({ type: Boolean, reflect: true }) pulse = false;\n @property() label = '';\n\n override render() {\n return html`\n <span\n class=\"dot\"\n role=${this.label ? 'status' : nothing}\n aria-label=${this.label || nothing}\n aria-hidden=${this.label ? nothing : 'true'}\n ></span>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-status-dot': CgStatusDot;\n }\n}\n"],"names":["CgStatusDot","LitElement","html","nothing","hostBase","reducedMotion","css","__decorateClass","property","customElement"],"mappings":";;;;;;;;AAwBO,IAAMA,IAAN,cAA0BC,EAAW;AAAA,EAArC,cAAA;AAAA,UAAA,GAAA,SAAA,GAiDwB,KAAA,SAA4B,WAC5B,KAAA,OAA2B,MACZ,KAAA,QAAQ,IACxC,KAAA,QAAQ;AAAA,EAAA;AAAA,EAEX,SAAS;AAChB,WAAOC;AAAA;AAAA;AAAA,eAGI,KAAK,QAAQ,WAAWC,CAAO;AAAA,qBACzB,KAAK,SAASA,CAAO;AAAA,sBACpB,KAAK,QAAQA,IAAU,MAAM;AAAA;AAAA;AAAA,EAGjD;AACF;AAhEaH,EACK,SAAS,CAACI,GAAUC,GAAeC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GA8ClD;AAE4BC,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GAjDhBR,EAiDkB,WAAA,UAAA,CAAA;AACAO,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GAlDhBR,EAkDkB,WAAA,QAAA,CAAA;AACeO,EAAA;AAAA,EAA3CC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAnD/BR,EAmDiC,WAAA,SAAA,CAAA;AAChCO,EAAA;AAAA,EAAXC,EAAA;AAAS,GApDCR,EAoDC,WAAA,SAAA,CAAA;AApDDA,IAANO,EAAA;AAAA,EADNE,EAAc,eAAe;AAAA,GACjBT,CAAA;"}
@@ -1,6 +1,6 @@
1
1
  import { css as v, LitElement as u, html as c, nothing as s } from "lit";
2
2
  import { property as n, customElement as p } from "lit/decorators.js";
3
- import { h, r as f } from "../../chunks/premium.css-DHekUEUt.js";
3
+ import { h, r as f } from "../../chunks/premium.css-B0hBr_uS.js";
4
4
  var b = Object.defineProperty, m = Object.getOwnPropertyDescriptor, l = (e, t, r, i) => {
5
5
  for (var a = i > 1 ? void 0 : i ? m(t, r) : t, d = e.length - 1, g; d >= 0; d--)
6
6
  (g = e[d]) && (a = (i ? g(t, r, a) : g(a)) || a);