@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.
- package/dist/chunks/{premium.css-DHekUEUt.js → premium.css-B0hBr_uS.js} +27 -27
- package/dist/chunks/{premium.css-DHekUEUt.js.map → premium.css-B0hBr_uS.js.map} +1 -1
- package/dist/cognivo.min.js +1876 -1227
- package/dist/cognivo.min.js.map +1 -1
- package/dist/components/ai-ab-test/ai-ab-test.js +1 -1
- package/dist/components/ai-accessibility-report/ai-accessibility-report.js +1 -1
- package/dist/components/ai-action-preview/ai-action-preview.js +1 -1
- package/dist/components/ai-agent-card/ai-agent-card.js +1 -1
- package/dist/components/ai-agent-steps/ai-agent-steps.js +1 -1
- package/dist/components/ai-alert-card/ai-alert-card.js +1 -1
- package/dist/components/ai-analytics-chart/ai-analytics-chart.js +1 -1
- package/dist/components/ai-annotation/ai-annotation.js +1 -1
- package/dist/components/ai-api-key-manager/ai-api-key-manager.js +1 -1
- package/dist/components/ai-app-sidebar/ai-app-sidebar.js +1 -1
- package/dist/components/ai-assistant-widget/ai-assistant-widget.js +1 -1
- package/dist/components/ai-audio-player/ai-audio-player.js +1 -1
- package/dist/components/ai-avatar/ai-avatar.js +1 -1
- package/dist/components/ai-badge/ai-badge.js +1 -1
- package/dist/components/ai-batch-progress/ai-batch-progress.js +1 -1
- package/dist/components/ai-cache-indicator/ai-cache-indicator.js +1 -1
- package/dist/components/ai-capture-flow/ai-capture-flow.js +1 -1
- package/dist/components/ai-changelog/ai-changelog.js +1 -1
- package/dist/components/ai-chart-summary/ai-chart-summary.js +1 -1
- package/dist/components/ai-chat/ai-chat.js +1 -1
- package/dist/components/ai-citation/ai-citation.js +1 -1
- package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js +1 -1
- package/dist/components/ai-command-palette/ai-command-palette.js +1 -1
- package/dist/components/ai-confidence-badge/ai-confidence-badge.js +1 -1
- package/dist/components/ai-confidence-slider/ai-confidence-slider.js +1 -1
- package/dist/components/ai-consent-manager/ai-consent-manager.js +1 -1
- package/dist/components/ai-context-window/ai-context-window.js +1 -1
- package/dist/components/ai-copy-button/ai-copy-button.js +1 -1
- package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js +1 -1
- package/dist/components/ai-data-card/ai-data-card.js +1 -1
- package/dist/components/ai-data-lineage/ai-data-lineage.js +1 -1
- package/dist/components/ai-data-preview/ai-data-preview.js +1 -1
- package/dist/components/ai-data-table/ai-data-table.js +1 -1
- package/dist/components/ai-debug-console/ai-debug-console.js +1 -1
- package/dist/components/ai-detection-canvas/ai-detection-canvas.js +1 -1
- package/dist/components/ai-diff-panel/ai-diff-panel.js +1 -1
- package/dist/components/ai-embedding-viz/ai-embedding-viz.js +1 -1
- package/dist/components/ai-empty-state/ai-empty-state.js +1 -1
- package/dist/components/ai-error-boundary/ai-error-boundary.js +1 -1
- package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js +1 -1
- package/dist/components/ai-feature-flag/ai-feature-flag.js +1 -1
- package/dist/components/ai-feedback/ai-feedback.js +1 -1
- package/dist/components/ai-file-upload/ai-file-upload.js +1 -1
- package/dist/components/ai-form-generator/ai-form-generator.js +1 -1
- package/dist/components/ai-guardrail/ai-guardrail.js +1 -1
- package/dist/components/ai-heatmap/ai-heatmap.js +1 -1
- package/dist/components/ai-insight-card/ai-insight-card.js +1 -1
- package/dist/components/ai-json-viewer/ai-json-viewer.js +1 -1
- package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js +1 -1
- package/dist/components/ai-kpi-grid/ai-kpi-grid.js +1 -1
- package/dist/components/ai-labeling-board/ai-labeling-board.js +1 -1
- package/dist/components/ai-memory-panel/ai-memory-panel.js +1 -1
- package/dist/components/ai-model-comparison/ai-model-comparison.js +1 -1
- package/dist/components/ai-model-selector/ai-model-selector.js +1 -1
- package/dist/components/ai-notification-center/ai-notification-center.js +1 -1
- package/dist/components/ai-onboarding/ai-onboarding.js +1 -1
- package/dist/components/ai-permission-gate/ai-permission-gate.js +1 -1
- package/dist/components/ai-personalization-dash/ai-personalization-dash.js +1 -1
- package/dist/components/ai-presence/ai-presence.js +1 -1
- package/dist/components/ai-progress-steps/ai-progress-steps.js +1 -1
- package/dist/components/ai-prompt-editor/ai-prompt-editor.js +1 -1
- package/dist/components/ai-prompt-template/ai-prompt-template.js +1 -1
- package/dist/components/ai-rag-panel/ai-rag-panel.js +1 -1
- package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js +1 -1
- package/dist/components/ai-result-panel/ai-result-panel.js +1 -1
- package/dist/components/ai-reveal-animation/ai-reveal-animation.js +1 -1
- package/dist/components/ai-reward-signal/ai-reward-signal.js +1 -1
- package/dist/components/ai-rich-message/ai-rich-message.js +1 -1
- package/dist/components/ai-scenario-panel/ai-scenario-panel.js +1 -1
- package/dist/components/ai-search/ai-search.js +1 -1
- package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js +1 -1
- package/dist/components/ai-sidebar/ai-sidebar.js +1 -1
- package/dist/components/ai-similarity-card/ai-similarity-card.js +1 -1
- package/dist/components/ai-source-graph/ai-source-graph.js +1 -1
- package/dist/components/ai-status-page/ai-status-page.js +1 -1
- package/dist/components/ai-streaming-text/ai-streaming-text.js +1 -1
- package/dist/components/ai-test-runner/ai-test-runner.js +1 -1
- package/dist/components/ai-thinking/ai-thinking.js +1 -1
- package/dist/components/ai-timeline/ai-timeline.js +1 -1
- package/dist/components/ai-token-tracker/ai-token-tracker.js +1 -1
- package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js +1 -1
- package/dist/components/ai-tool-indicator/ai-tool-indicator.js +1 -1
- package/dist/components/ai-transform-slider/ai-transform-slider.js +1 -1
- package/dist/components/ai-translation-panel/ai-translation-panel.js +1 -1
- package/dist/components/ai-usage-meter/ai-usage-meter.js +1 -1
- package/dist/components/ai-validation-checklist/ai-validation-checklist.js +1 -1
- package/dist/components/ai-version-selector/ai-version-selector.js +1 -1
- package/dist/components/ai-voice-panel/ai-voice-panel.js +1 -1
- package/dist/components/ai-webhook-config/ai-webhook-config.js +1 -1
- package/dist/components/ai-workflow-builder/ai-workflow-builder.js +1 -1
- package/dist/components/bias-anchoring/bias-anchoring.js +1 -1
- package/dist/components/bias-authority/bias-authority.js +1 -1
- package/dist/components/bias-commitment/bias-commitment.js +1 -1
- package/dist/components/bias-reciprocity/bias-reciprocity.js +1 -1
- package/dist/components/bias-scarcity/bias-scarcity.js +1 -1
- package/dist/components/bias-social-proof/bias-social-proof.js +1 -1
- package/dist/components/cg-accordion/cg-accordion.js +1 -1
- package/dist/components/cg-alert-dialog/cg-alert-dialog.js +1 -1
- package/dist/components/cg-app-shell/cg-app-shell.d.ts +43 -0
- package/dist/components/cg-app-shell/cg-app-shell.d.ts.map +1 -0
- package/dist/components/cg-app-shell/cg-app-shell.js +170 -0
- package/dist/components/cg-app-shell/cg-app-shell.js.map +1 -0
- package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js +1 -1
- package/dist/components/cg-autocomplete/cg-autocomplete.js +1 -1
- package/dist/components/cg-avatar/cg-avatar.js +1 -1
- package/dist/components/cg-avatar-group/cg-avatar-group.js +1 -1
- package/dist/components/cg-badge/cg-badge.js +1 -1
- package/dist/components/cg-badge-group/cg-badge-group.js +1 -1
- package/dist/components/cg-blockquote/cg-blockquote.d.ts +32 -0
- package/dist/components/cg-blockquote/cg-blockquote.d.ts.map +1 -0
- package/dist/components/cg-blockquote/cg-blockquote.js +108 -0
- package/dist/components/cg-blockquote/cg-blockquote.js.map +1 -0
- package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js +1 -1
- package/dist/components/cg-button/cg-button.js +8 -8
- package/dist/components/cg-button/cg-button.js.map +1 -1
- package/dist/components/cg-button-group/cg-button-group.js +1 -1
- package/dist/components/cg-calendar/cg-calendar.js +1 -1
- package/dist/components/cg-callout/cg-callout.js +1 -1
- package/dist/components/cg-card/cg-card.js +1 -1
- package/dist/components/cg-carousel/cg-carousel.js +1 -1
- package/dist/components/cg-center/cg-center.d.ts +37 -0
- package/dist/components/cg-center/cg-center.d.ts.map +1 -0
- package/dist/components/cg-center/cg-center.js +74 -0
- package/dist/components/cg-center/cg-center.js.map +1 -0
- package/dist/components/cg-chart/cg-chart.js +1 -1
- package/dist/components/cg-checkbox/cg-checkbox.js +1 -1
- package/dist/components/cg-chip/cg-chip.js +1 -1
- package/dist/components/cg-code-block/cg-code-block.js +1 -1
- package/dist/components/cg-collapsible/cg-collapsible.js +1 -1
- package/dist/components/cg-color-picker/cg-color-picker.js +1 -1
- package/dist/components/cg-combobox/cg-combobox.js +1 -1
- package/dist/components/cg-command/cg-command.js +1 -1
- package/dist/components/cg-context-menu/cg-context-menu.js +1 -1
- package/dist/components/cg-date-picker/cg-date-picker.js +1 -1
- package/dist/components/cg-date-range-picker/cg-date-range-picker.js +1 -1
- package/dist/components/cg-date-time-picker/cg-date-time-picker.js +1 -1
- package/dist/components/cg-drawer/cg-drawer.js +1 -1
- package/dist/components/cg-dropdown/cg-dropdown.js +1 -1
- package/dist/components/cg-empty-state/cg-empty-state.js +1 -1
- package/dist/components/cg-file-input/cg-file-input.js +1 -1
- package/dist/components/cg-follow-up/cg-follow-up.js +1 -1
- package/dist/components/cg-form/cg-form.js +1 -1
- package/dist/components/cg-grid/cg-grid.d.ts +39 -0
- package/dist/components/cg-grid/cg-grid.d.ts.map +1 -0
- package/dist/components/cg-grid/cg-grid.js +78 -0
- package/dist/components/cg-grid/cg-grid.js.map +1 -0
- package/dist/components/cg-hover-card/cg-hover-card.js +1 -1
- package/dist/components/cg-icon/cg-icon.js +1 -1
- package/dist/components/cg-image/cg-image.js +1 -1
- package/dist/components/cg-image-block/cg-image-block.js +1 -1
- package/dist/components/cg-image-gallery/cg-image-gallery.js +1 -1
- package/dist/components/cg-input/cg-input.js +1 -1
- package/dist/components/cg-kbd/cg-kbd.js +1 -1
- package/dist/components/cg-label/cg-label.js +1 -1
- package/dist/components/cg-lightbox/cg-lightbox.d.ts +49 -0
- package/dist/components/cg-lightbox/cg-lightbox.d.ts.map +1 -0
- package/dist/components/cg-lightbox/cg-lightbox.js +203 -0
- package/dist/components/cg-lightbox/cg-lightbox.js.map +1 -0
- package/dist/components/cg-link/cg-link.js +1 -1
- package/dist/components/cg-list/cg-list.js +1 -1
- package/dist/components/cg-listbox/cg-listbox.js +1 -1
- package/dist/components/cg-markdown/cg-markdown.js +1 -1
- package/dist/components/cg-menubar/cg-menubar.js +1 -1
- package/dist/components/cg-meter/cg-meter.js +1 -1
- package/dist/components/cg-metric-card/cg-metric-card.js +1 -1
- package/dist/components/cg-modal/cg-modal.js +1 -1
- package/dist/components/cg-navbar/cg-navbar.js +1 -1
- package/dist/components/cg-navigation-menu/cg-navigation-menu.js +1 -1
- package/dist/components/cg-number-input/cg-number-input.js +1 -1
- package/dist/components/cg-otp-input/cg-otp-input.js +1 -1
- package/dist/components/cg-overflow-list/cg-overflow-list.d.ts +51 -0
- package/dist/components/cg-overflow-list/cg-overflow-list.d.ts.map +1 -0
- package/dist/components/cg-overflow-list/cg-overflow-list.js +212 -0
- package/dist/components/cg-overflow-list/cg-overflow-list.js.map +1 -0
- package/dist/components/cg-pagination/cg-pagination.js +1 -1
- package/dist/components/cg-password-input/cg-password-input.js +1 -1
- package/dist/components/cg-phone-input/cg-phone-input.js +1 -1
- package/dist/components/cg-popover/cg-popover.js +1 -1
- package/dist/components/cg-progress-bar/cg-progress-bar.js +1 -1
- package/dist/components/cg-radio/cg-radio.js +1 -1
- package/dist/components/cg-radio-group/cg-radio-group.js +1 -1
- package/dist/components/cg-rating/cg-rating.js +1 -1
- package/dist/components/cg-resizable/cg-resizable.js +1 -1
- package/dist/components/cg-scroll-area/cg-scroll-area.js +1 -1
- package/dist/components/cg-segmented-control/cg-segmented-control.js +1 -1
- package/dist/components/cg-select/cg-select.js +1 -1
- package/dist/components/cg-separator/cg-separator.js +1 -1
- package/dist/components/cg-sheet/cg-sheet.js +1 -1
- package/dist/components/cg-sidebar/cg-sidebar.js +1 -1
- package/dist/components/cg-skeleton/cg-skeleton.js +1 -1
- package/dist/components/cg-slider/cg-slider.js +1 -1
- package/dist/components/cg-spinner/cg-spinner.js +1 -1
- package/dist/components/cg-split-button/cg-split-button.js +1 -1
- package/dist/components/cg-stack/cg-stack.js +1 -1
- package/dist/components/cg-status-dot/cg-status-dot.d.ts +31 -0
- package/dist/components/cg-status-dot/cg-status-dot.d.ts.map +1 -0
- package/dist/components/cg-status-dot/cg-status-dot.js +89 -0
- package/dist/components/cg-status-dot/cg-status-dot.js.map +1 -0
- package/dist/components/cg-steps/cg-steps.js +1 -1
- package/dist/components/cg-switch/cg-switch.js +1 -1
- package/dist/components/cg-table/cg-table.js +1 -1
- package/dist/components/cg-tabs/cg-tabs.js +1 -1
- package/dist/components/cg-tag-input/cg-tag-input.js +1 -1
- package/dist/components/cg-text/cg-text.js +1 -1
- package/dist/components/cg-textarea/cg-textarea.js +1 -1
- package/dist/components/cg-thumbnail/cg-thumbnail.d.ts +39 -0
- package/dist/components/cg-thumbnail/cg-thumbnail.d.ts.map +1 -0
- package/dist/components/cg-thumbnail/cg-thumbnail.js +134 -0
- package/dist/components/cg-thumbnail/cg-thumbnail.js.map +1 -0
- package/dist/components/cg-time-picker/cg-time-picker.js +1 -1
- package/dist/components/cg-timestamp/cg-timestamp.d.ts +41 -0
- package/dist/components/cg-timestamp/cg-timestamp.d.ts.map +1 -0
- package/dist/components/cg-timestamp/cg-timestamp.js +81 -0
- package/dist/components/cg-timestamp/cg-timestamp.js.map +1 -0
- package/dist/components/cg-toaster/cg-toaster.js +1 -1
- package/dist/components/cg-toggle/cg-toggle.js +1 -1
- package/dist/components/cg-toggle-group/cg-toggle-group.js +1 -1
- package/dist/components/cg-toolbar/cg-toolbar.d.ts +51 -0
- package/dist/components/cg-toolbar/cg-toolbar.d.ts.map +1 -0
- package/dist/components/cg-toolbar/cg-toolbar.js +130 -0
- package/dist/components/cg-toolbar/cg-toolbar.js.map +1 -0
- package/dist/components/cg-tree-view/cg-tree-view.js +1 -1
- package/dist/foundation.d.ts +11 -1
- package/dist/foundation.d.ts.map +1 -1
- package/dist/foundation.js +88 -68
- package/dist/foundation.js.map +1 -1
- package/dist/index.d.ts +11 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +126 -106
- package/dist/index.js.map +1 -1
- 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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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);
|