@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
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as l, LitElement as u, nothing as b, html as i } from "lit";
|
|
2
2
|
import { property as o, customElement as p } from "lit/decorators.js";
|
|
3
|
-
import { a as v, r as f, e as h, d as m } from "../../chunks/premium.css-
|
|
3
|
+
import { a as v, r as f, e as h, d as m } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var y = Object.defineProperty, x = Object.getOwnPropertyDescriptor, e = (g, t, d, s) => {
|
|
5
5
|
for (var a = s > 1 ? void 0 : s ? x(t, d) : t, n = g.length - 1, c; n >= 0; n--)
|
|
6
6
|
(c = g[n]) && (a = (s ? c(t, d, a) : c(a)) || a);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as d, LitElement as f, nothing as n, html as p } from "lit";
|
|
2
2
|
import { property as l, customElement as h } from "lit/decorators.js";
|
|
3
|
-
import { h as m, r as v } from "../../chunks/premium.css-
|
|
3
|
+
import { h as m, r as v } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var b = Object.defineProperty, u = Object.getOwnPropertyDescriptor, r = (t, o, g, s) => {
|
|
5
5
|
for (var a = s > 1 ? void 0 : s ? u(o, g) : o, i = t.length - 1, c; i >= 0; i--)
|
|
6
6
|
(c = t[i]) && (a = (s ? c(o, g, a) : c(a)) || a);
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { LitElement } from 'lit';
|
|
2
|
+
/**
|
|
3
|
+
* @element cg-blockquote
|
|
4
|
+
* An editorial quotation primitive: a semantic `<blockquote>` anchored by an
|
|
5
|
+
* oversized decorative quotation mark (magazine/pull-quote style), with an
|
|
6
|
+
* optional attribution footer. No left rule — the glyph carries the emphasis.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```html
|
|
10
|
+
* <cg-blockquote variant="accent">
|
|
11
|
+
* Design tokens are the contract between design and code.
|
|
12
|
+
* <span slot="footer">Cognivo docs</span>
|
|
13
|
+
* </cg-blockquote>
|
|
14
|
+
* ```
|
|
15
|
+
*
|
|
16
|
+
* @slot - Quote content.
|
|
17
|
+
* @slot footer - Attribution / source.
|
|
18
|
+
*/
|
|
19
|
+
export declare class CgBlockquote extends LitElement {
|
|
20
|
+
static styles: import('lit').CSSResult[];
|
|
21
|
+
cite: string;
|
|
22
|
+
variant: 'default' | 'accent' | 'muted';
|
|
23
|
+
private _hasFooter;
|
|
24
|
+
private _onFooterSlotChange;
|
|
25
|
+
render(): import('lit').TemplateResult<1>;
|
|
26
|
+
}
|
|
27
|
+
declare global {
|
|
28
|
+
interface HTMLElementTagNameMap {
|
|
29
|
+
'cg-blockquote': CgBlockquote;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=cg-blockquote.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cg-blockquote.d.ts","sourceRoot":"","sources":["../../../src/components/cg-blockquote/cg-blockquote.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,MAAM,KAAK,CAAC;AAK5C;;;;;;;;;;;;;;;;GAgBG;AACH,qBACa,YAAa,SAAQ,UAAU;IAC1C,OAAgB,MAAM,4BAkEnB;IAES,IAAI,SAAM;IACO,OAAO,EAAE,SAAS,GAAG,QAAQ,GAAG,OAAO,CAAa;IAEjF,OAAO,CAAC,UAAU,CAAS;IAE3B,OAAO,CAAC,mBAAmB;IASlB,MAAM;CAUhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,eAAe,EAAE,YAAY,CAAC;KAC/B;CACF"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { css as g, LitElement as f, html as p } from "lit";
|
|
2
|
+
import { property as l, customElement as v } from "lit/decorators.js";
|
|
3
|
+
import { ifDefined as d } from "lit/directives/if-defined.js";
|
|
4
|
+
import { h, r as u } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
5
|
+
var b = Object.defineProperty, m = Object.getOwnPropertyDescriptor, n = (a, e, o, s) => {
|
|
6
|
+
for (var t = s > 1 ? void 0 : s ? m(e, o) : e, c = a.length - 1, i; c >= 0; c--)
|
|
7
|
+
(i = a[c]) && (t = (s ? i(e, o, t) : i(t)) || t);
|
|
8
|
+
return s && t && b(e, o, t), t;
|
|
9
|
+
};
|
|
10
|
+
let r = class extends f {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments), this.cite = "", this.variant = "default", this._hasFooter = !1;
|
|
13
|
+
}
|
|
14
|
+
_onFooterSlotChange(a) {
|
|
15
|
+
const o = a.target.assignedNodes({ flatten: !0 }).length > 0;
|
|
16
|
+
o !== this._hasFooter && (this._hasFooter = o, this.requestUpdate());
|
|
17
|
+
}
|
|
18
|
+
render() {
|
|
19
|
+
return p`
|
|
20
|
+
<blockquote cite=${d(this.cite || void 0)}>
|
|
21
|
+
<span class="content"><slot></slot></span>
|
|
22
|
+
<footer class=${this._hasFooter ? "" : "empty"}>
|
|
23
|
+
<slot name="footer" @slotchange=${this._onFooterSlotChange}></slot>
|
|
24
|
+
</footer>
|
|
25
|
+
</blockquote>
|
|
26
|
+
`;
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
r.styles = [h, u, g`
|
|
30
|
+
:host { display: block; font-family: var(--cg-font-family-primary); }
|
|
31
|
+
|
|
32
|
+
blockquote {
|
|
33
|
+
position: relative;
|
|
34
|
+
margin: 0;
|
|
35
|
+
padding: var(--cg-spacing-8) 0 var(--cg-spacing-8) var(--cg-spacing-40);
|
|
36
|
+
color: var(--cg-color-surface-base-text);
|
|
37
|
+
font-size: var(--cg-font-size-lg);
|
|
38
|
+
line-height: var(--cg-line-height-relaxed);
|
|
39
|
+
font-weight: var(--cg-font-weight-medium);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/* Oversized decorative opening quote — the editorial anchor, not a border. */
|
|
43
|
+
blockquote::before {
|
|
44
|
+
content: '\\201C';
|
|
45
|
+
position: absolute;
|
|
46
|
+
top: calc(-1 * var(--cg-spacing-8));
|
|
47
|
+
left: calc(-1 * var(--cg-spacing-4));
|
|
48
|
+
font-size: var(--cg-font-size-5xl);
|
|
49
|
+
line-height: 1;
|
|
50
|
+
font-weight: var(--cg-font-weight-bold);
|
|
51
|
+
color: var(--cg-color-surface-base-divider);
|
|
52
|
+
pointer-events: none;
|
|
53
|
+
user-select: none;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.content { display: block; }
|
|
57
|
+
|
|
58
|
+
/* Accent: the glyph adopts the brand accent, quote gains slight scale. */
|
|
59
|
+
:host([variant="accent"]) blockquote::before {
|
|
60
|
+
color: var(--cg-color-action-primary-background-default);
|
|
61
|
+
}
|
|
62
|
+
:host([variant="accent"]) blockquote {
|
|
63
|
+
font-size: var(--cg-font-size-xl);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/* Muted: soft filled card treatment — quote sits inside a panel. */
|
|
67
|
+
:host([variant="muted"]) blockquote {
|
|
68
|
+
padding: var(--cg-spacing-20) var(--cg-spacing-24) var(--cg-spacing-20) var(--cg-spacing-48);
|
|
69
|
+
background: var(--cg-color-surface-inset-background);
|
|
70
|
+
color: var(--cg-color-surface-inset-text);
|
|
71
|
+
border-radius: var(--cg-border-radius-200);
|
|
72
|
+
font-size: var(--cg-font-size-base);
|
|
73
|
+
}
|
|
74
|
+
:host([variant="muted"]) blockquote::before {
|
|
75
|
+
top: var(--cg-spacing-4);
|
|
76
|
+
left: var(--cg-spacing-16);
|
|
77
|
+
color: var(--cg-color-surface-base-divider);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
footer {
|
|
81
|
+
display: block;
|
|
82
|
+
margin-top: var(--cg-spacing-12);
|
|
83
|
+
font-size: var(--cg-font-size-sm);
|
|
84
|
+
font-weight: var(--cg-font-weight-semibold);
|
|
85
|
+
color: var(--cg-color-surface-base-text);
|
|
86
|
+
}
|
|
87
|
+
/* Em-dash lead-in for attribution, so authors slot just the name. */
|
|
88
|
+
footer::before {
|
|
89
|
+
content: '\\2014\\00A0';
|
|
90
|
+
color: var(--cg-color-surface-base-divider);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
/* Hide footer wrapper when nothing is slotted */
|
|
94
|
+
footer.empty { display: none; }
|
|
95
|
+
`];
|
|
96
|
+
n([
|
|
97
|
+
l()
|
|
98
|
+
], r.prototype, "cite", 2);
|
|
99
|
+
n([
|
|
100
|
+
l({ reflect: !0 })
|
|
101
|
+
], r.prototype, "variant", 2);
|
|
102
|
+
r = n([
|
|
103
|
+
v("cg-blockquote")
|
|
104
|
+
], r);
|
|
105
|
+
export {
|
|
106
|
+
r as CgBlockquote
|
|
107
|
+
};
|
|
108
|
+
//# sourceMappingURL=cg-blockquote.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cg-blockquote.js","sources":["../../../src/components/cg-blockquote/cg-blockquote.ts"],"sourcesContent":["import { LitElement, html, css } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/**\n * @element cg-blockquote\n * An editorial quotation primitive: a semantic `<blockquote>` anchored by an\n * oversized decorative quotation mark (magazine/pull-quote style), with an\n * optional attribution footer. No left rule — the glyph carries the emphasis.\n *\n * @example\n * ```html\n * <cg-blockquote variant=\"accent\">\n * Design tokens are the contract between design and code.\n * <span slot=\"footer\">Cognivo docs</span>\n * </cg-blockquote>\n * ```\n *\n * @slot - Quote content.\n * @slot footer - Attribution / source.\n */\n@customElement('cg-blockquote')\nexport class CgBlockquote extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host { display: block; font-family: var(--cg-font-family-primary); }\n\n blockquote {\n position: relative;\n margin: 0;\n padding: var(--cg-spacing-8) 0 var(--cg-spacing-8) var(--cg-spacing-40);\n color: var(--cg-color-surface-base-text);\n font-size: var(--cg-font-size-lg);\n line-height: var(--cg-line-height-relaxed);\n font-weight: var(--cg-font-weight-medium);\n }\n\n /* Oversized decorative opening quote — the editorial anchor, not a border. */\n blockquote::before {\n content: '\\\\201C';\n position: absolute;\n top: calc(-1 * var(--cg-spacing-8));\n left: calc(-1 * var(--cg-spacing-4));\n font-size: var(--cg-font-size-5xl);\n line-height: 1;\n font-weight: var(--cg-font-weight-bold);\n color: var(--cg-color-surface-base-divider);\n pointer-events: none;\n user-select: none;\n }\n\n .content { display: block; }\n\n /* Accent: the glyph adopts the brand accent, quote gains slight scale. */\n :host([variant=\"accent\"]) blockquote::before {\n color: var(--cg-color-action-primary-background-default);\n }\n :host([variant=\"accent\"]) blockquote {\n font-size: var(--cg-font-size-xl);\n }\n\n /* Muted: soft filled card treatment — quote sits inside a panel. */\n :host([variant=\"muted\"]) blockquote {\n padding: var(--cg-spacing-20) var(--cg-spacing-24) var(--cg-spacing-20) var(--cg-spacing-48);\n background: var(--cg-color-surface-inset-background);\n color: var(--cg-color-surface-inset-text);\n border-radius: var(--cg-border-radius-200);\n font-size: var(--cg-font-size-base);\n }\n :host([variant=\"muted\"]) blockquote::before {\n top: var(--cg-spacing-4);\n left: var(--cg-spacing-16);\n color: var(--cg-color-surface-base-divider);\n }\n\n footer {\n display: block;\n margin-top: var(--cg-spacing-12);\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n /* Em-dash lead-in for attribution, so authors slot just the name. */\n footer::before {\n content: '\\\\2014\\\\00A0';\n color: var(--cg-color-surface-base-divider);\n }\n\n /* Hide footer wrapper when nothing is slotted */\n footer.empty { display: none; }\n `];\n\n @property() cite = '';\n @property({ reflect: true }) variant: 'default' | 'accent' | 'muted' = 'default';\n\n private _hasFooter = false;\n\n private _onFooterSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n const has = slot.assignedNodes({ flatten: true }).length > 0;\n if (has !== this._hasFooter) {\n this._hasFooter = has;\n this.requestUpdate();\n }\n }\n\n override render() {\n return html`\n <blockquote cite=${ifDefined(this.cite || undefined)}>\n <span class=\"content\"><slot></slot></span>\n <footer class=${this._hasFooter ? '' : 'empty'}>\n <slot name=\"footer\" @slotchange=${this._onFooterSlotChange}></slot>\n </footer>\n </blockquote>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-blockquote': CgBlockquote;\n }\n}\n"],"names":["CgBlockquote","LitElement","e","has","html","ifDefined","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":";;;;;;;;;AAuBO,IAAMA,IAAN,cAA2BC,EAAW;AAAA,EAAtC,cAAA;AAAA,UAAA,GAAA,SAAA,GAqEO,KAAA,OAAO,IACU,KAAA,UAA0C,WAEvE,KAAQ,aAAa;AAAA,EAAA;AAAA,EAEb,oBAAoBC,GAAgB;AAE1C,UAAMC,IADOD,EAAE,OACE,cAAc,EAAE,SAAS,GAAA,CAAM,EAAE,SAAS;AAC3D,IAAIC,MAAQ,KAAK,eACf,KAAK,aAAaA,GAClB,KAAK,cAAA;AAAA,EAET;AAAA,EAES,SAAS;AAChB,WAAOC;AAAA,yBACcC,EAAU,KAAK,QAAQ,MAAS,CAAC;AAAA;AAAA,wBAElC,KAAK,aAAa,KAAK,OAAO;AAAA,4CACV,KAAK,mBAAmB;AAAA;AAAA;AAAA;AAAA,EAIlE;AACF;AA7FaL,EACK,SAAS,CAACM,GAAWC,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;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAkEnD;AAEWC,EAAA;AAAA,EAAXC,EAAA;AAAS,GArECV,EAqEC,WAAA,QAAA,CAAA;AACiBS,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GAtEhBV,EAsEkB,WAAA,WAAA,CAAA;AAtElBA,IAANS,EAAA;AAAA,EADNE,EAAc,eAAe;AAAA,GACjBX,CAAA;"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as m, LitElement as b, nothing as c, html as t } from "lit";
|
|
2
2
|
import { property as d, state as f, customElement as v } from "lit/decorators.js";
|
|
3
|
-
import { h as x, r as z } from "../../chunks/premium.css-
|
|
3
|
+
import { h as x, r as z } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var w = Object.defineProperty, y = Object.getOwnPropertyDescriptor, p = (e, i, a, r) => {
|
|
5
5
|
for (var s = r > 1 ? void 0 : r ? y(i, a) : i, n = e.length - 1, l; n >= 0; n--)
|
|
6
6
|
(l = e[n]) && (s = (r ? l(i, a, s) : l(s)) || s);
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { css as
|
|
1
|
+
import { css as g, LitElement as b, nothing as l, html as u } from "lit";
|
|
2
2
|
import { property as t, customElement as v } from "lit/decorators.js";
|
|
3
|
-
import { a as h, r as p, c as f } from "../../chunks/premium.css-
|
|
3
|
+
import { a as h, r as p, c as f } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var y = Object.defineProperty, m = Object.getOwnPropertyDescriptor, o = (d, e, n, s) => {
|
|
5
5
|
for (var a = s > 1 ? void 0 : s ? m(e, n) : e, c = d.length - 1, i; c >= 0; c--)
|
|
6
6
|
(i = d[c]) && (a = (s ? i(e, n, a) : i(a)) || a);
|
|
7
7
|
return s && a && y(e, n, a), a;
|
|
8
8
|
};
|
|
9
|
-
let r = class extends
|
|
9
|
+
let r = class extends b {
|
|
10
10
|
constructor() {
|
|
11
11
|
super(...arguments), this.variant = "primary", this.size = "md", this.rounded = "lg", this.type = "normal", this.disabled = !1, this.loading = !1, this.full = !1, this.status = "idle", this.label = "";
|
|
12
12
|
}
|
|
@@ -26,7 +26,7 @@ let r = class extends g {
|
|
|
26
26
|
`;
|
|
27
27
|
}
|
|
28
28
|
};
|
|
29
|
-
r.styles = [h, p, f,
|
|
29
|
+
r.styles = [h, p, f, g`
|
|
30
30
|
button {
|
|
31
31
|
display: inline-flex;
|
|
32
32
|
align-items: center;
|
|
@@ -40,10 +40,10 @@ r.styles = [h, p, f, b`
|
|
|
40
40
|
white-space: nowrap;
|
|
41
41
|
text-decoration: none;
|
|
42
42
|
transition:
|
|
43
|
-
background-color var(--cg-transition-duration-fast)
|
|
44
|
-
border-color var(--cg-transition-duration-fast)
|
|
45
|
-
box-shadow var(--cg-transition-duration-fast)
|
|
46
|
-
transform var(--cg-transition-duration-fast)
|
|
43
|
+
background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
|
|
44
|
+
border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
|
|
45
|
+
box-shadow var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
|
|
46
|
+
transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
|
|
47
47
|
-webkit-font-smoothing: antialiased;
|
|
48
48
|
position: relative;
|
|
49
49
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-button.js","sources":["../../../src/components/cg-button/cg-button.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBase, reducedMotion, spinKeyframes } from '../../styles/index.js';\n\n/**\n * @element cg-button\n * A button with variants, sizes, loading state, and press feedback.\n *\n * @example\n * ```html\n * <cg-button variant=\"primary\" size=\"md\">Click me</cg-button>\n * <cg-button variant=\"secondary\" loading>Saving...</cg-button>\n * <cg-button type=\"danger\"><span slot=\"prefix\">[trash icon]</span>Delete</cg-button>\n * ```\n *\n * @slot - Default slot for button text/content\n * @slot prefix - Icon or content before the label\n * @slot suffix - Icon or content after the label\n *\n * @cssprop --cg-color-action-primary-background-default - Primary button background color\n * @cssprop --cg-component-button-height-md - Button height (md size, 48px)\n * @cssprop --cg-interaction-press-scale - Scale on press/active (0.97)\n * @cssprop --cg-transition-duration-fast - Color transition speed\n */\n@customElement('cg-button')\nexport class CgButton extends LitElement {\n static override styles = [hostBase, reducedMotion, spinKeyframes, css`\n button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n gap: var(--cg-spacing-8);\n border: var(--cg-border-width-50) solid transparent;\n cursor: pointer;\n font-family: inherit;\n font-weight: var(--cg-font-weight-medium);\n line-height: 1;\n white-space: nowrap;\n text-decoration: none;\n transition:\n background-color var(--cg-transition-duration-fast) ease,\n border-color var(--cg-transition-duration-fast) ease,\n box-shadow var(--cg-transition-duration-fast) ease,\n transform var(--cg-transition-duration-fast) ease;\n -webkit-font-smoothing: antialiased;\n position: relative;\n }\n\n /* Press scale */\n button:active:not(:disabled) {\n transform: scale(var(--cg-interaction-press-scale));\n }\n\n /* Focus ring — dual-layer */\n button:focus-visible {\n box-shadow:\n 0 0 0 var(--cg-border-width-100) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-border-width-100) * 2) var(--cg-color-focus-ring);\n outline: none;\n }\n\n /* ── Sizes ── */\n :host([size=\"sm\"]) button {\n padding: 0 var(--cg-spacing-12);\n font-size: var(--cg-font-size-xs);\n border-radius: var(--cg-component-button-radius-sm);\n height: var(--cg-component-button-height-sm);\n }\n :host([size=\"md\"]) button {\n padding: 0 var(--cg-spacing-16);\n font-size: var(--cg-font-size-sm);\n border-radius: var(--cg-component-button-radius-md);\n height: var(--cg-component-button-height-md);\n }\n :host([size=\"lg\"]) button {\n padding: 0 var(--cg-spacing-24);\n font-size: var(--cg-font-size-base);\n border-radius: var(--cg-component-button-radius-lg);\n height: var(--cg-component-button-height-lg);\n }\n\n /* ── Rounded overrides ── */\n :host([rounded=\"none\"]) button { border-radius: 0; }\n :host([rounded=\"sm\"]) button { border-radius: var(--cg-component-button-radius-sm); }\n :host([rounded=\"md\"]) button { border-radius: var(--cg-component-button-radius-md); }\n :host([rounded=\"lg\"]) button { border-radius: var(--cg-component-button-radius-lg); }\n :host([rounded=\"full\"]) button { border-radius: var(--cg-border-radius-full); }\n\n /* ── Primary variant ── */\n :host([variant=\"primary\"]) button {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n border-color: var(--cg-color-action-primary-border-default);\n }\n :host([variant=\"primary\"]) button:not(:disabled):hover {\n background: var(--cg-color-action-primary-background-hover);\n }\n\n /* ── Secondary variant ── */\n :host([variant=\"secondary\"]) button {\n background: var(--cg-color-action-secondary-background-default);\n color: var(--cg-color-action-secondary-text-default);\n border-color: var(--cg-color-action-secondary-border-default);\n }\n :host([variant=\"secondary\"]) button:not(:disabled):hover {\n background: var(--cg-color-action-secondary-background-hover);\n }\n\n /* ── Tertiary (ghost) variant ── */\n :host([variant=\"tertiary\"]) button {\n background: transparent;\n color: var(--cg-color-action-tertiary-text-default);\n border-color: transparent;\n }\n :host([variant=\"tertiary\"]) button:not(:disabled):hover {\n background: var(--cg-color-action-tertiary-background-hover);\n }\n\n /* ── Danger type ── */\n :host([type=\"danger\"]) button {\n background: var(--cg-color-status-error-background-default);\n color: var(--cg-color-status-error-text-default);\n border-color: var(--cg-color-status-error-border-default);\n }\n :host([type=\"danger\"][variant=\"primary\"]) button {\n background: var(--cg-color-status-error-text-default);\n color: var(--cg-color-status-error-text-inverse);\n border-color: transparent;\n }\n :host([type=\"danger\"]) button:not(:disabled):hover {\n background: var(--cg-color-status-error-background-hover);\n }\n :host([type=\"danger\"][variant=\"primary\"]) button:not(:disabled):hover {\n background: var(--cg-color-status-error-background-hover);\n }\n\n /* ── Disabled ──\n Themeable per-variant disabled colors (no opacity smudge on re-pointed brands).\n Scoped with :host so these win over the variant/type/status background rules. */\n button:disabled {\n pointer-events: none;\n }\n :host([variant=\"primary\"]) button:disabled,\n :host([type=\"danger\"][variant=\"primary\"]) button:disabled,\n :host([status=\"error\"]) button:disabled,\n :host([status=\"success\"]) button:disabled {\n background: var(--cg-color-action-primary-background-disable);\n color: var(--cg-color-action-primary-text-disable);\n border-color: var(--cg-color-action-primary-border-disable);\n }\n :host([variant=\"secondary\"]) button:disabled {\n background: var(--cg-color-action-secondary-background-disable);\n color: var(--cg-color-action-secondary-text-disable);\n border-color: var(--cg-color-action-secondary-border-disable);\n }\n :host([variant=\"tertiary\"]) button:disabled {\n background: var(--cg-color-action-tertiary-background-disable);\n color: var(--cg-color-action-tertiary-text-disable);\n border-color: var(--cg-color-action-tertiary-border-disable);\n }\n\n /* ── Loading ── */\n :host([loading]) button {\n color: transparent;\n pointer-events: none;\n }\n .spinner {\n position: absolute;\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n border: var(--cg-border-width-100) solid currentColor;\n border-right-color: transparent;\n border-radius: var(--cg-border-radius-full);\n animation: spin var(--cg-transition-duration-slow) linear infinite;\n }\n :host([loading]) .spinner { color: var(--cg-color-action-primary-text-default); }\n :host([loading][variant=\"secondary\"]) .spinner { color: var(--cg-color-action-secondary-text-default); }\n :host([loading][variant=\"tertiary\"]) .spinner { color: var(--cg-color-action-tertiary-text-default); }\n\n /* ── Error state ── */\n :host([status=\"error\"]) button {\n background: var(--cg-color-status-error-background-default);\n color: var(--cg-color-status-error-text-default);\n border-color: var(--cg-color-status-error-border-default);\n }\n :host([status=\"error\"]) button:not(:disabled):hover {\n background: var(--cg-color-status-error-background-hover);\n }\n :host([status=\"error\"]) .spinner { color: var(--cg-color-status-error-text-default); }\n\n /* ── Success state ── */\n :host([status=\"success\"]) button {\n background: var(--cg-color-status-success-background-default);\n color: var(--cg-color-status-success-text-default);\n border-color: var(--cg-color-status-success-border-default);\n }\n :host([status=\"success\"]) button:not(:disabled):hover {\n background: var(--cg-color-status-success-background-hover);\n }\n :host([status=\"success\"]) .spinner { color: var(--cg-color-status-success-text-default); }\n\n /* ── Full width ── */\n :host([full]) {\n display: block;\n width: 100%;\n }\n :host([full]) button {\n width: 100%;\n }\n `];\n\n @property({ reflect: true }) variant: 'primary' | 'secondary' | 'tertiary' = 'primary';\n @property({ reflect: true }) size: 'sm' | 'md' | 'lg' = 'md';\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ reflect: true }) type: 'normal' | 'danger' = 'normal';\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: Boolean, reflect: true }) loading = false;\n @property({ type: Boolean, reflect: true }) full = false;\n @property({ reflect: true }) status: 'idle' | 'error' | 'success' = 'idle';\n @property() label = '';\n\n override render() {\n return html`\n <button\n part=\"button\"\n ?disabled=${this.disabled || this.loading}\n aria-busy=${this.loading ? 'true' : 'false'}\n aria-label=${this.label || nothing}\n >\n ${this.loading ? html`<span class=\"spinner\"></span>` : nothing}\n <slot name=\"prefix\"></slot>\n <slot>${this.label}</slot>\n <slot name=\"suffix\"></slot>\n </button>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-button': CgButton;\n }\n}\n// touch Mon Apr 13 18:29:50 AEST 2026\n"],"names":["CgButton","LitElement","html","nothing","hostBase","reducedMotion","spinKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cg-button.js","sources":["../../../src/components/cg-button/cg-button.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBase, reducedMotion, spinKeyframes } from '../../styles/index.js';\n\n/**\n * @element cg-button\n * A button with variants, sizes, loading state, and press feedback.\n *\n * @example\n * ```html\n * <cg-button variant=\"primary\" size=\"md\">Click me</cg-button>\n * <cg-button variant=\"secondary\" loading>Saving...</cg-button>\n * <cg-button type=\"danger\"><span slot=\"prefix\">[trash icon]</span>Delete</cg-button>\n * ```\n *\n * @slot - Default slot for button text/content\n * @slot prefix - Icon or content before the label\n * @slot suffix - Icon or content after the label\n *\n * @cssprop --cg-color-action-primary-background-default - Primary button background color\n * @cssprop --cg-component-button-height-md - Button height (md size, 48px)\n * @cssprop --cg-interaction-press-scale - Scale on press/active (0.97)\n * @cssprop --cg-transition-duration-fast - Color transition speed\n */\n@customElement('cg-button')\nexport class CgButton extends LitElement {\n static override styles = [hostBase, reducedMotion, spinKeyframes, css`\n button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n gap: var(--cg-spacing-8);\n border: var(--cg-border-width-50) solid transparent;\n cursor: pointer;\n font-family: inherit;\n font-weight: var(--cg-font-weight-medium);\n line-height: 1;\n white-space: nowrap;\n text-decoration: none;\n transition:\n background-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n box-shadow var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n -webkit-font-smoothing: antialiased;\n position: relative;\n }\n\n /* Press scale */\n button:active:not(:disabled) {\n transform: scale(var(--cg-interaction-press-scale));\n }\n\n /* Focus ring — dual-layer */\n button:focus-visible {\n box-shadow:\n 0 0 0 var(--cg-border-width-100) var(--cg-color-focus-ring-offset),\n 0 0 0 calc(var(--cg-border-width-100) * 2) var(--cg-color-focus-ring);\n outline: none;\n }\n\n /* ── Sizes ── */\n :host([size=\"sm\"]) button {\n padding: 0 var(--cg-spacing-12);\n font-size: var(--cg-font-size-xs);\n border-radius: var(--cg-component-button-radius-sm);\n height: var(--cg-component-button-height-sm);\n }\n :host([size=\"md\"]) button {\n padding: 0 var(--cg-spacing-16);\n font-size: var(--cg-font-size-sm);\n border-radius: var(--cg-component-button-radius-md);\n height: var(--cg-component-button-height-md);\n }\n :host([size=\"lg\"]) button {\n padding: 0 var(--cg-spacing-24);\n font-size: var(--cg-font-size-base);\n border-radius: var(--cg-component-button-radius-lg);\n height: var(--cg-component-button-height-lg);\n }\n\n /* ── Rounded overrides ── */\n :host([rounded=\"none\"]) button { border-radius: 0; }\n :host([rounded=\"sm\"]) button { border-radius: var(--cg-component-button-radius-sm); }\n :host([rounded=\"md\"]) button { border-radius: var(--cg-component-button-radius-md); }\n :host([rounded=\"lg\"]) button { border-radius: var(--cg-component-button-radius-lg); }\n :host([rounded=\"full\"]) button { border-radius: var(--cg-border-radius-full); }\n\n /* ── Primary variant ── */\n :host([variant=\"primary\"]) button {\n background: var(--cg-color-action-primary-background-default);\n color: var(--cg-color-action-primary-text-default);\n border-color: var(--cg-color-action-primary-border-default);\n }\n :host([variant=\"primary\"]) button:not(:disabled):hover {\n background: var(--cg-color-action-primary-background-hover);\n }\n\n /* ── Secondary variant ── */\n :host([variant=\"secondary\"]) button {\n background: var(--cg-color-action-secondary-background-default);\n color: var(--cg-color-action-secondary-text-default);\n border-color: var(--cg-color-action-secondary-border-default);\n }\n :host([variant=\"secondary\"]) button:not(:disabled):hover {\n background: var(--cg-color-action-secondary-background-hover);\n }\n\n /* ── Tertiary (ghost) variant ── */\n :host([variant=\"tertiary\"]) button {\n background: transparent;\n color: var(--cg-color-action-tertiary-text-default);\n border-color: transparent;\n }\n :host([variant=\"tertiary\"]) button:not(:disabled):hover {\n background: var(--cg-color-action-tertiary-background-hover);\n }\n\n /* ── Danger type ── */\n :host([type=\"danger\"]) button {\n background: var(--cg-color-status-error-background-default);\n color: var(--cg-color-status-error-text-default);\n border-color: var(--cg-color-status-error-border-default);\n }\n :host([type=\"danger\"][variant=\"primary\"]) button {\n background: var(--cg-color-status-error-text-default);\n color: var(--cg-color-status-error-text-inverse);\n border-color: transparent;\n }\n :host([type=\"danger\"]) button:not(:disabled):hover {\n background: var(--cg-color-status-error-background-hover);\n }\n :host([type=\"danger\"][variant=\"primary\"]) button:not(:disabled):hover {\n background: var(--cg-color-status-error-background-hover);\n }\n\n /* ── Disabled ──\n Themeable per-variant disabled colors (no opacity smudge on re-pointed brands).\n Scoped with :host so these win over the variant/type/status background rules. */\n button:disabled {\n pointer-events: none;\n }\n :host([variant=\"primary\"]) button:disabled,\n :host([type=\"danger\"][variant=\"primary\"]) button:disabled,\n :host([status=\"error\"]) button:disabled,\n :host([status=\"success\"]) button:disabled {\n background: var(--cg-color-action-primary-background-disable);\n color: var(--cg-color-action-primary-text-disable);\n border-color: var(--cg-color-action-primary-border-disable);\n }\n :host([variant=\"secondary\"]) button:disabled {\n background: var(--cg-color-action-secondary-background-disable);\n color: var(--cg-color-action-secondary-text-disable);\n border-color: var(--cg-color-action-secondary-border-disable);\n }\n :host([variant=\"tertiary\"]) button:disabled {\n background: var(--cg-color-action-tertiary-background-disable);\n color: var(--cg-color-action-tertiary-text-disable);\n border-color: var(--cg-color-action-tertiary-border-disable);\n }\n\n /* ── Loading ── */\n :host([loading]) button {\n color: transparent;\n pointer-events: none;\n }\n .spinner {\n position: absolute;\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n border: var(--cg-border-width-100) solid currentColor;\n border-right-color: transparent;\n border-radius: var(--cg-border-radius-full);\n animation: spin var(--cg-transition-duration-slow) linear infinite;\n }\n :host([loading]) .spinner { color: var(--cg-color-action-primary-text-default); }\n :host([loading][variant=\"secondary\"]) .spinner { color: var(--cg-color-action-secondary-text-default); }\n :host([loading][variant=\"tertiary\"]) .spinner { color: var(--cg-color-action-tertiary-text-default); }\n\n /* ── Error state ── */\n :host([status=\"error\"]) button {\n background: var(--cg-color-status-error-background-default);\n color: var(--cg-color-status-error-text-default);\n border-color: var(--cg-color-status-error-border-default);\n }\n :host([status=\"error\"]) button:not(:disabled):hover {\n background: var(--cg-color-status-error-background-hover);\n }\n :host([status=\"error\"]) .spinner { color: var(--cg-color-status-error-text-default); }\n\n /* ── Success state ── */\n :host([status=\"success\"]) button {\n background: var(--cg-color-status-success-background-default);\n color: var(--cg-color-status-success-text-default);\n border-color: var(--cg-color-status-success-border-default);\n }\n :host([status=\"success\"]) button:not(:disabled):hover {\n background: var(--cg-color-status-success-background-hover);\n }\n :host([status=\"success\"]) .spinner { color: var(--cg-color-status-success-text-default); }\n\n /* ── Full width ── */\n :host([full]) {\n display: block;\n width: 100%;\n }\n :host([full]) button {\n width: 100%;\n }\n `];\n\n @property({ reflect: true }) variant: 'primary' | 'secondary' | 'tertiary' = 'primary';\n @property({ reflect: true }) size: 'sm' | 'md' | 'lg' = 'md';\n @property({ reflect: true }) rounded: 'none' | 'sm' | 'md' | 'lg' | 'full' = 'lg';\n @property({ reflect: true }) type: 'normal' | 'danger' = 'normal';\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: Boolean, reflect: true }) loading = false;\n @property({ type: Boolean, reflect: true }) full = false;\n @property({ reflect: true }) status: 'idle' | 'error' | 'success' = 'idle';\n @property() label = '';\n\n override render() {\n return html`\n <button\n part=\"button\"\n ?disabled=${this.disabled || this.loading}\n aria-busy=${this.loading ? 'true' : 'false'}\n aria-label=${this.label || nothing}\n >\n ${this.loading ? html`<span class=\"spinner\"></span>` : nothing}\n <slot name=\"prefix\"></slot>\n <slot>${this.label}</slot>\n <slot name=\"suffix\"></slot>\n </button>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-button': CgButton;\n }\n}\n// touch Mon Apr 13 18:29:50 AEST 2026\n"],"names":["CgButton","LitElement","html","nothing","hostBase","reducedMotion","spinKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as c, LitElement as p, nothing as u, html as h } from "lit";
|
|
2
2
|
import { property as r, customElement as g } from "lit/decorators.js";
|
|
3
|
-
import { a as m, r as v } from "../../chunks/premium.css-
|
|
3
|
+
import { a as m, r as v } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var f = Object.defineProperty, b = Object.getOwnPropertyDescriptor, o = (l, a, s, i) => {
|
|
5
5
|
for (var e = i > 1 ? void 0 : i ? b(a, s) : a, n = l.length - 1, d; n >= 0; n--)
|
|
6
6
|
(d = l[n]) && (e = (i ? d(a, s, e) : d(e)) || e);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as g, LitElement as u, html as d } from "lit";
|
|
2
2
|
import { property as c, state as h, 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 y = Object.defineProperty, m = Object.getOwnPropertyDescriptor, i = (t, e, s, r) => {
|
|
5
5
|
for (var a = r > 1 ? void 0 : r ? m(e, s) : e, o = t.length - 1, l; o >= 0; o--)
|
|
6
6
|
(l = t[o]) && (a = (r ? l(e, s, a) : l(a)) || a);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as v, LitElement as h, nothing as n, html as c } from "lit";
|
|
2
2
|
import { property as a, state as u, customElement as m } from "lit/decorators.js";
|
|
3
|
-
import { h as f, r as p, f as b } from "../../chunks/premium.css-
|
|
3
|
+
import { h as f, r as p, f as b } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var w = Object.defineProperty, y = Object.getOwnPropertyDescriptor, i = (s, t, l, e) => {
|
|
5
5
|
for (var o = e > 1 ? void 0 : e ? y(t, l) : t, d = s.length - 1, g; d >= 0; d--)
|
|
6
6
|
(g = s[d]) && (o = (e ? g(t, l, o) : g(o)) || o);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as h, LitElement as u, nothing as d, html as v } from "lit";
|
|
2
2
|
import { property as s, state as g, customElement as b } from "lit/decorators.js";
|
|
3
|
-
import { h as f, r as p, f as m } from "../../chunks/premium.css-
|
|
3
|
+
import { h as f, r as p, f as m } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var k = Object.defineProperty, y = Object.getOwnPropertyDescriptor, o = (r, e, c, n) => {
|
|
5
5
|
for (var t = n > 1 ? void 0 : n ? y(e, c) : e, i = r.length - 1, l; i >= 0; i--)
|
|
6
6
|
(l = r[i]) && (t = (n ? l(e, c, t) : l(t)) || t);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as p, LitElement as g, nothing as h, html as l } from "lit";
|
|
2
2
|
import { property as n, state as u, query as v, customElement as f } from "lit/decorators.js";
|
|
3
|
-
import { h as _, r as b } from "../../chunks/premium.css-
|
|
3
|
+
import { h as _, r as b } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var y = Object.defineProperty, m = Object.getOwnPropertyDescriptor, e = (t, r, s, a) => {
|
|
5
5
|
for (var i = a > 1 ? void 0 : a ? m(r, s) : r, c = t.length - 1, d; c >= 0; c--)
|
|
6
6
|
(d = t[c]) && (i = (a ? d(r, s, i) : d(i)) || i);
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { LitElement } from 'lit';
|
|
2
|
+
/**
|
|
3
|
+
* @element cg-center
|
|
4
|
+
* Centers its content on both axes, with an optional max-width for
|
|
5
|
+
* constraining readable content blocks.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```html
|
|
9
|
+
* <cg-center full>
|
|
10
|
+
* <cg-spinner></cg-spinner>
|
|
11
|
+
* </cg-center>
|
|
12
|
+
* ```
|
|
13
|
+
*
|
|
14
|
+
* @example Constrained content column
|
|
15
|
+
* ```html
|
|
16
|
+
* <cg-center max-width="640px" inline>
|
|
17
|
+
* <cg-markdown>…</cg-markdown>
|
|
18
|
+
* </cg-center>
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
* @slot - Content to center.
|
|
22
|
+
*/
|
|
23
|
+
export declare class CgCenter extends LitElement {
|
|
24
|
+
static styles: import('lit').CSSResult[];
|
|
25
|
+
inline: boolean;
|
|
26
|
+
maxWidth: string;
|
|
27
|
+
full: boolean;
|
|
28
|
+
gap: 'none' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl';
|
|
29
|
+
updated(changed: Map<string, unknown>): void;
|
|
30
|
+
render(): import('lit').TemplateResult<1>;
|
|
31
|
+
}
|
|
32
|
+
declare global {
|
|
33
|
+
interface HTMLElementTagNameMap {
|
|
34
|
+
'cg-center': CgCenter;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=cg-center.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cg-center.d.ts","sourceRoot":"","sources":["../../../src/components/cg-center/cg-center.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,MAAM,KAAK,CAAC;AAI5C;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,qBACa,QAAS,SAAQ,UAAU;IACtC,OAAgB,MAAM,4BAmCnB;IAEyC,MAAM,UAAS;IACN,QAAQ,SAAM;IACvB,IAAI,UAAS;IAC5B,GAAG,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,KAAK,CAAU;IAEpF,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM5C,MAAM;CAGhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,WAAW,EAAE,QAAQ,CAAC;KACvB;CACF"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { css as p, LitElement as g, html as h } from "lit";
|
|
2
|
+
import { property as s, customElement as m } from "lit/decorators.js";
|
|
3
|
+
import { h as f, r as u } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
|
+
var d = Object.defineProperty, x = Object.getOwnPropertyDescriptor, n = (o, a, l, r) => {
|
|
5
|
+
for (var t = r > 1 ? void 0 : r ? x(a, l) : a, c = o.length - 1, i; c >= 0; c--)
|
|
6
|
+
(i = o[c]) && (t = (r ? i(a, l, t) : i(t)) || t);
|
|
7
|
+
return r && t && d(a, l, t), t;
|
|
8
|
+
};
|
|
9
|
+
let e = class extends g {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments), this.inline = !1, this.maxWidth = "", this.full = !1, this.gap = "none";
|
|
12
|
+
}
|
|
13
|
+
updated(o) {
|
|
14
|
+
o.has("maxWidth") && this.style.setProperty("--_cg-center-max", this.maxWidth || "none");
|
|
15
|
+
}
|
|
16
|
+
render() {
|
|
17
|
+
return h`<div class="content"><slot></slot></div>`;
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
e.styles = [f, u, p`
|
|
21
|
+
:host {
|
|
22
|
+
display: flex;
|
|
23
|
+
flex-direction: column;
|
|
24
|
+
align-items: center;
|
|
25
|
+
justify-content: center;
|
|
26
|
+
text-align: center;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/* Inline-only: center horizontally, keep normal block flow vertically */
|
|
30
|
+
:host([inline]) {
|
|
31
|
+
display: block;
|
|
32
|
+
}
|
|
33
|
+
:host([inline]) .content {
|
|
34
|
+
margin-inline: auto;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
:host([full]) { min-height: 100%; }
|
|
38
|
+
|
|
39
|
+
.content {
|
|
40
|
+
display: flex;
|
|
41
|
+
flex-direction: column;
|
|
42
|
+
align-items: center;
|
|
43
|
+
max-width: var(--_cg-center-max, none);
|
|
44
|
+
width: 100%;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/* Gap — same scale as cg-stack */
|
|
48
|
+
:host([gap="none"]) .content { gap: 0; }
|
|
49
|
+
:host([gap="xs"]) .content { gap: var(--cg-spacing-4); }
|
|
50
|
+
:host([gap="sm"]) .content { gap: var(--cg-spacing-8); }
|
|
51
|
+
:host([gap="md"]) .content { gap: var(--cg-spacing-16); }
|
|
52
|
+
:host([gap="lg"]) .content { gap: var(--cg-spacing-24); }
|
|
53
|
+
:host([gap="xl"]) .content { gap: var(--cg-spacing-32); }
|
|
54
|
+
:host([gap="2xl"]) .content { gap: var(--cg-spacing-48); }
|
|
55
|
+
`];
|
|
56
|
+
n([
|
|
57
|
+
s({ type: Boolean, reflect: !0 })
|
|
58
|
+
], e.prototype, "inline", 2);
|
|
59
|
+
n([
|
|
60
|
+
s({ attribute: "max-width", reflect: !0 })
|
|
61
|
+
], e.prototype, "maxWidth", 2);
|
|
62
|
+
n([
|
|
63
|
+
s({ type: Boolean, reflect: !0 })
|
|
64
|
+
], e.prototype, "full", 2);
|
|
65
|
+
n([
|
|
66
|
+
s({ reflect: !0 })
|
|
67
|
+
], e.prototype, "gap", 2);
|
|
68
|
+
e = n([
|
|
69
|
+
m("cg-center")
|
|
70
|
+
], e);
|
|
71
|
+
export {
|
|
72
|
+
e as CgCenter
|
|
73
|
+
};
|
|
74
|
+
//# sourceMappingURL=cg-center.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cg-center.js","sources":["../../../src/components/cg-center/cg-center.ts"],"sourcesContent":["import { LitElement, html, css } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/**\n * @element cg-center\n * Centers its content on both axes, with an optional max-width for\n * constraining readable content blocks.\n *\n * @example\n * ```html\n * <cg-center full>\n * <cg-spinner></cg-spinner>\n * </cg-center>\n * ```\n *\n * @example Constrained content column\n * ```html\n * <cg-center max-width=\"640px\" inline>\n * <cg-markdown>…</cg-markdown>\n * </cg-center>\n * ```\n *\n * @slot - Content to center.\n */\n@customElement('cg-center')\nexport class CgCenter extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n }\n\n /* Inline-only: center horizontally, keep normal block flow vertically */\n :host([inline]) {\n display: block;\n }\n :host([inline]) .content {\n margin-inline: auto;\n }\n\n :host([full]) { min-height: 100%; }\n\n .content {\n display: flex;\n flex-direction: column;\n align-items: center;\n max-width: var(--_cg-center-max, none);\n width: 100%;\n }\n\n /* Gap — same scale as cg-stack */\n :host([gap=\"none\"]) .content { gap: 0; }\n :host([gap=\"xs\"]) .content { gap: var(--cg-spacing-4); }\n :host([gap=\"sm\"]) .content { gap: var(--cg-spacing-8); }\n :host([gap=\"md\"]) .content { gap: var(--cg-spacing-16); }\n :host([gap=\"lg\"]) .content { gap: var(--cg-spacing-24); }\n :host([gap=\"xl\"]) .content { gap: var(--cg-spacing-32); }\n :host([gap=\"2xl\"]) .content { gap: var(--cg-spacing-48); }\n `];\n\n @property({ type: Boolean, reflect: true }) inline = false;\n @property({ attribute: 'max-width', reflect: true }) maxWidth = '';\n @property({ type: Boolean, reflect: true }) full = false;\n @property({ reflect: true }) gap: 'none' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' = 'none';\n\n override updated(changed: Map<string, unknown>): void {\n if (changed.has('maxWidth')) {\n this.style.setProperty('--_cg-center-max', this.maxWidth || 'none');\n }\n }\n\n override render() {\n return html`<div class=\"content\"><slot></slot></div>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-center': CgCenter;\n }\n}\n"],"names":["CgCenter","LitElement","changed","html","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":";;;;;;;;AA0BO,IAAMA,IAAN,cAAuBC,EAAW;AAAA,EAAlC,cAAA;AAAA,UAAA,GAAA,SAAA,GAsCuC,KAAA,SAAS,IACA,KAAA,WAAW,IACpB,KAAA,OAAO,IACtB,KAAA,MAAyD;AAAA,EAAA;AAAA,EAE7E,QAAQC,GAAqC;AACpD,IAAIA,EAAQ,IAAI,UAAU,KACxB,KAAK,MAAM,YAAY,oBAAoB,KAAK,YAAY,MAAM;AAAA,EAEtE;AAAA,EAES,SAAS;AAChB,WAAOC;AAAA,EACT;AACF;AApDaH,EACK,SAAS,CAACI,GAAWC,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,GAmCnD;AAE2CC,EAAA;AAAA,EAA3CC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAtC/BR,EAsCiC,WAAA,UAAA,CAAA;AACSO,EAAA;AAAA,EAApDC,EAAS,EAAE,WAAW,aAAa,SAAS,IAAM;AAAA,GAvCxCR,EAuC0C,WAAA,YAAA,CAAA;AACTO,EAAA;AAAA,EAA3CC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAxC/BR,EAwCiC,WAAA,QAAA,CAAA;AACfO,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GAzChBR,EAyCkB,WAAA,OAAA,CAAA;AAzClBA,IAANO,EAAA;AAAA,EADNE,EAAc,WAAW;AAAA,GACbT,CAAA;"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as N, LitElement as I, nothing as v, svg as f, html as _ } from "lit";
|
|
2
2
|
import { property as b, state as z, customElement as C } from "lit/decorators.js";
|
|
3
|
-
import { h as E, r as W } from "../../chunks/premium.css-
|
|
3
|
+
import { h as E, r as W } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var Y = Object.defineProperty, q = Object.getOwnPropertyDescriptor, x = (t, a, r, s) => {
|
|
5
5
|
for (var e = s > 1 ? void 0 : s ? q(a, r) : a, n = t.length - 1, o; n >= 0; n--)
|
|
6
6
|
(o = t[n]) && (e = (s ? o(a, r, e) : o(e)) || e);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as u, LitElement as g, nothing as n, html as i } from "lit";
|
|
2
2
|
import { property as o, customElement as b } from "lit/decorators.js";
|
|
3
|
-
import { h as p, r as f } from "../../chunks/premium.css-
|
|
3
|
+
import { h as p, r as f } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var v = Object.defineProperty, k = Object.getOwnPropertyDescriptor, t = (r, a, d, c) => {
|
|
5
5
|
for (var s = c > 1 ? void 0 : c ? k(a, d) : a, l = r.length - 1, h; l >= 0; l--)
|
|
6
6
|
(h = r[l]) && (s = (c ? h(a, d, s) : h(s)) || s);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as u, LitElement as h, nothing as n, html as g } from "lit";
|
|
2
2
|
import { property as t, customElement as v } from "lit/decorators.js";
|
|
3
|
-
import { a as p, r as b } from "../../chunks/premium.css-
|
|
3
|
+
import { a as p, r as b } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var f = Object.defineProperty, m = Object.getOwnPropertyDescriptor, a = (r, i, c, s) => {
|
|
5
5
|
for (var o = s > 1 ? void 0 : s ? m(i, c) : i, l = r.length - 1, d; l >= 0; l--)
|
|
6
6
|
(d = r[l]) && (o = (s ? d(i, c, o) : d(o)) || o);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as v, LitElement as f, nothing as p, html as c } from "lit";
|
|
2
2
|
import { property as l, state as h, customElement as b } from "lit/decorators.js";
|
|
3
|
-
import { h as m, r as y } from "../../chunks/premium.css-
|
|
3
|
+
import { h as m, r as y } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var w = Object.defineProperty, x = Object.getOwnPropertyDescriptor, n = (o, e, i, a) => {
|
|
5
5
|
for (var r = a > 1 ? void 0 : a ? x(e, i) : e, s = o.length - 1, g; s >= 0; s--)
|
|
6
6
|
(g = o[s]) && (r = (a ? g(e, i, r) : g(r)) || r);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as l, LitElement as g, html as p } from "lit";
|
|
2
2
|
import { property as i, customElement as v } from "lit/decorators.js";
|
|
3
|
-
import { h as b, r as u } from "../../chunks/premium.css-
|
|
3
|
+
import { h as b, r as u } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var f = Object.defineProperty, h = Object.getOwnPropertyDescriptor, e = (c, t, n, a) => {
|
|
5
5
|
for (var r = a > 1 ? void 0 : a ? h(t, n) : t, s = c.length - 1, d; s >= 0; s--)
|
|
6
6
|
(d = c[s]) && (r = (a ? d(t, n, r) : d(r)) || r);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as k, LitElement as x, nothing as u, html as h } from "lit";
|
|
2
2
|
import { property as p, state as b, customElement as y } from "lit/decorators.js";
|
|
3
|
-
import { h as $, r as M } from "../../chunks/premium.css-
|
|
3
|
+
import { h as $, r as M } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var A = Object.defineProperty, P = Object.getOwnPropertyDescriptor, l = (t, r, a, e) => {
|
|
5
5
|
for (var o = e > 1 ? void 0 : e ? P(r, a) : r, i = t.length - 1, d; i >= 0; i--)
|
|
6
6
|
(d = t[i]) && (o = (e ? d(r, a, o) : d(o)) || o);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as h, LitElement as g, nothing as p, html as c } from "lit";
|
|
2
2
|
import { property as i, state as u, query as v, customElement as b } 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 y = Object.defineProperty, _ = Object.getOwnPropertyDescriptor, a = (e, t, n, o) => {
|
|
5
5
|
for (var s = o > 1 ? void 0 : o ? _(t, n) : t, l = e.length - 1, d; l >= 0; l--)
|
|
6
6
|
(d = e[l]) && (s = (o ? d(t, n, s) : d(s)) || s);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as u, LitElement as m, nothing as p, html as c } from "lit";
|
|
2
2
|
import { property as d, state as v, query as g, customElement as h } 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
|
import { F as y } from "../../chunks/focus-trap-vlQwKK-3.js";
|
|
5
5
|
import { h as x } from "../../chunks/roving-index-BuO0tTba.js";
|
|
6
6
|
var _ = Object.defineProperty, w = Object.getOwnPropertyDescriptor, n = (e, t, a, o) => {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as p, LitElement as u, html as l, nothing as d } from "lit";
|
|
2
2
|
import { property as h, state as _, query as m, customElement as v } from "lit/decorators.js";
|
|
3
|
-
import { h as f, r as b, m as E } from "../../chunks/premium.css-
|
|
3
|
+
import { h as f, r as b, m as E } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
import { a as g } from "../../chunks/floating-DfsaYJnh.js";
|
|
5
5
|
import { b as L } from "../../chunks/outside-click-CP1P1fK3.js";
|
|
6
6
|
import { h as x } from "../../chunks/roving-index-BuO0tTba.js";
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as p, LitElement as u, nothing as d, html as g } from "lit";
|
|
2
2
|
import { property as t, state as h, customElement as v } from "lit/decorators.js";
|
|
3
|
-
import { h as f, r as b } from "../../chunks/premium.css-
|
|
3
|
+
import { h as f, r as b } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
import "../cg-calendar/cg-calendar.js";
|
|
5
5
|
var m = Object.defineProperty, y = Object.getOwnPropertyDescriptor, o = (e, a, n, s) => {
|
|
6
6
|
for (var i = s > 1 ? void 0 : s ? y(a, n) : a, c = e.length - 1, l; c >= 0; c--)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as g, LitElement as h, nothing as l, html as p } from "lit";
|
|
2
2
|
import { property as a, customElement as u } from "lit/decorators.js";
|
|
3
|
-
import { h as f, r as v } from "../../chunks/premium.css-
|
|
3
|
+
import { h as f, r as v } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
import "../cg-calendar/cg-calendar.js";
|
|
5
5
|
var m = Object.defineProperty, b = Object.getOwnPropertyDescriptor, o = (e, t, s, n) => {
|
|
6
6
|
for (var i = n > 1 ? void 0 : n ? b(t, s) : t, c = e.length - 1, d; c >= 0; c--)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as _, LitElement as w, nothing as b, html as g } from "lit";
|
|
2
2
|
import { property as l, state as v, customElement as x } from "lit/decorators.js";
|
|
3
|
-
import { h as $, r as k } from "../../chunks/premium.css-
|
|
3
|
+
import { h as $, r as k } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var M = Object.defineProperty, S = Object.getOwnPropertyDescriptor, a = (t, r, o, s) => {
|
|
5
5
|
for (var e = s > 1 ? void 0 : s ? S(r, o) : r, c = t.length - 1, p; c >= 0; c--)
|
|
6
6
|
(p = t[c]) && (e = (s ? p(r, o, e) : p(e)) || e);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as u, LitElement as h, nothing as o, html as s } from "lit";
|
|
2
2
|
import { property as a, state as p, customElement as v } from "lit/decorators.js";
|
|
3
|
-
import { c as f, r as b } from "../../chunks/premium.css-
|
|
3
|
+
import { c as f, r as b } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
import { F as m } from "../../chunks/focus-trap-vlQwKK-3.js";
|
|
5
5
|
var w = Object.defineProperty, y = Object.getOwnPropertyDescriptor, e = (t, n, c, d) => {
|
|
6
6
|
for (var i = d > 1 ? void 0 : d ? y(n, c) : n, l = t.length - 1, g; l >= 0; l--)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as g, LitElement as h, nothing as c, html as a } from "lit";
|
|
2
2
|
import { property as l, state as u, query as m, customElement as f } from "lit/decorators.js";
|
|
3
|
-
import { e as v, m as b } from "../../chunks/premium.css-
|
|
3
|
+
import { e as v, m as b } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
import { b as _ } from "../../chunks/outside-click-CP1P1fK3.js";
|
|
5
5
|
import { h as y } from "../../chunks/roving-index-BuO0tTba.js";
|
|
6
6
|
var x = Object.defineProperty, w = Object.getOwnPropertyDescriptor, n = (e, s, o, t) => {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as h, LitElement as v, svg as n, nothing as c, html as g } from "lit";
|
|
2
2
|
import { property as l, state as u, customElement as f } from "lit/decorators.js";
|
|
3
|
-
import { h as y, r as m } from "../../chunks/premium.css-
|
|
3
|
+
import { h as y, r as m } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var x = Object.defineProperty, w = Object.getOwnPropertyDescriptor, s = (r, e, i, a) => {
|
|
5
5
|
for (var o = a > 1 ? void 0 : a ? w(e, i) : e, d = r.length - 1, p; d >= 0; d--)
|
|
6
6
|
(p = r[d]) && (o = (a ? p(e, i, o) : p(o)) || o);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { css as p, LitElement as f, svg as g, nothing as d, html as c } from "lit";
|
|
2
2
|
import { property as l, state as h, query as v, customElement as b } from "lit/decorators.js";
|
|
3
|
-
import { h as m, r as _, g as w } from "../../chunks/premium.css-
|
|
3
|
+
import { h as m, r as _, g as w } from "../../chunks/premium.css-B0hBr_uS.js";
|
|
4
4
|
var y = Object.defineProperty, x = Object.getOwnPropertyDescriptor, n = (e, t, a, s) => {
|
|
5
5
|
for (var r = s > 1 ? void 0 : s ? x(t, a) : t, i = e.length - 1, u; i >= 0; i--)
|
|
6
6
|
(u = e[i]) && (r = (s ? u(t, a, r) : u(r)) || r);
|