@cognivo/components 0.8.0 → 0.8.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunks/focus-trap-vlQwKK-3.js +82 -0
- package/dist/chunks/focus-trap-vlQwKK-3.js.map +1 -0
- package/dist/chunks/{premium.css-9I4kHrsl.js → premium.css-DHekUEUt.js} +25 -25
- package/dist/chunks/{premium.css-9I4kHrsl.js.map → premium.css-DHekUEUt.js.map} +1 -1
- package/dist/cognivo.min.js +3375 -5270
- 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.d.ts.map +1 -1
- package/dist/components/ai-accessibility-report/ai-accessibility-report.js +14 -13
- package/dist/components/ai-accessibility-report/ai-accessibility-report.js.map +1 -1
- package/dist/components/ai-action-preview/ai-action-preview.d.ts.map +1 -1
- package/dist/components/ai-action-preview/ai-action-preview.js +15 -14
- package/dist/components/ai-action-preview/ai-action-preview.js.map +1 -1
- package/dist/components/ai-agent-card/ai-agent-card.js +1 -1
- package/dist/components/ai-agent-steps/ai-agent-steps.d.ts +8 -21
- package/dist/components/ai-agent-steps/ai-agent-steps.d.ts.map +1 -1
- package/dist/components/ai-agent-steps/ai-agent-steps.js +85 -139
- package/dist/components/ai-agent-steps/ai-agent-steps.js.map +1 -1
- package/dist/components/ai-alert-card/ai-alert-card.js +5 -5
- package/dist/components/ai-alert-card/ai-alert-card.js.map +1 -1
- package/dist/components/ai-analytics-chart/ai-analytics-chart.d.ts +0 -13
- package/dist/components/ai-analytics-chart/ai-analytics-chart.d.ts.map +1 -1
- package/dist/components/ai-analytics-chart/ai-analytics-chart.js +75 -125
- package/dist/components/ai-analytics-chart/ai-analytics-chart.js.map +1 -1
- package/dist/components/ai-annotation/ai-annotation.js +2 -2
- package/dist/components/ai-annotation/ai-annotation.js.map +1 -1
- package/dist/components/ai-api-key-manager/ai-api-key-manager.d.ts +0 -9
- package/dist/components/ai-api-key-manager/ai-api-key-manager.d.ts.map +1 -1
- package/dist/components/ai-api-key-manager/ai-api-key-manager.js +115 -276
- package/dist/components/ai-api-key-manager/ai-api-key-manager.js.map +1 -1
- package/dist/components/ai-app-sidebar/ai-app-sidebar.js +13 -13
- package/dist/components/ai-app-sidebar/ai-app-sidebar.js.map +1 -1
- package/dist/components/ai-assistant-widget/ai-assistant-widget.d.ts.map +1 -1
- package/dist/components/ai-assistant-widget/ai-assistant-widget.js +5 -2
- package/dist/components/ai-assistant-widget/ai-assistant-widget.js.map +1 -1
- package/dist/components/ai-audio-player/ai-audio-player.d.ts.map +1 -1
- package/dist/components/ai-audio-player/ai-audio-player.js +23 -19
- package/dist/components/ai-audio-player/ai-audio-player.js.map +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 +6 -6
- package/dist/components/ai-batch-progress/ai-batch-progress.js.map +1 -1
- package/dist/components/ai-cache-indicator/ai-cache-indicator.d.ts +0 -13
- package/dist/components/ai-cache-indicator/ai-cache-indicator.d.ts.map +1 -1
- package/dist/components/ai-cache-indicator/ai-cache-indicator.js +90 -185
- package/dist/components/ai-cache-indicator/ai-cache-indicator.js.map +1 -1
- package/dist/components/ai-capture-flow/ai-capture-flow.js +21 -21
- package/dist/components/ai-capture-flow/ai-capture-flow.js.map +1 -1
- package/dist/components/ai-changelog/ai-changelog.js +26 -26
- package/dist/components/ai-changelog/ai-changelog.js.map +1 -1
- package/dist/components/ai-chart-summary/ai-chart-summary.d.ts +0 -6
- package/dist/components/ai-chart-summary/ai-chart-summary.d.ts.map +1 -1
- package/dist/components/ai-chart-summary/ai-chart-summary.js +100 -103
- package/dist/components/ai-chart-summary/ai-chart-summary.js.map +1 -1
- package/dist/components/ai-chat/ai-chat.d.ts.map +1 -1
- package/dist/components/ai-chat/ai-chat.js +9 -3
- package/dist/components/ai-chat/ai-chat.js.map +1 -1
- package/dist/components/ai-citation/ai-citation.d.ts +0 -6
- package/dist/components/ai-citation/ai-citation.d.ts.map +1 -1
- package/dist/components/ai-citation/ai-citation.js +64 -90
- package/dist/components/ai-citation/ai-citation.js.map +1 -1
- package/dist/components/ai-collaborative-editor/ai-collaborative-editor.d.ts +1 -27
- package/dist/components/ai-collaborative-editor/ai-collaborative-editor.d.ts.map +1 -1
- package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js +114 -260
- package/dist/components/ai-collaborative-editor/ai-collaborative-editor.js.map +1 -1
- package/dist/components/ai-command-palette/ai-command-palette.js +1 -1
- package/dist/components/ai-confidence-badge/ai-confidence-badge.d.ts +11 -9
- package/dist/components/ai-confidence-badge/ai-confidence-badge.d.ts.map +1 -1
- package/dist/components/ai-confidence-badge/ai-confidence-badge.js +183 -101
- package/dist/components/ai-confidence-badge/ai-confidence-badge.js.map +1 -1
- package/dist/components/ai-confidence-slider/ai-confidence-slider.js +27 -27
- package/dist/components/ai-confidence-slider/ai-confidence-slider.js.map +1 -1
- package/dist/components/ai-consent-manager/ai-consent-manager.js +2 -2
- package/dist/components/ai-consent-manager/ai-consent-manager.js.map +1 -1
- package/dist/components/ai-context-window/ai-context-window.js +19 -19
- package/dist/components/ai-context-window/ai-context-window.js.map +1 -1
- package/dist/components/ai-copy-button/ai-copy-button.js +4 -4
- package/dist/components/ai-copy-button/ai-copy-button.js.map +1 -1
- package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js +14 -14
- package/dist/components/ai-cost-dashboard/ai-cost-dashboard.js.map +1 -1
- package/dist/components/ai-data-card/ai-data-card.js +2 -2
- package/dist/components/ai-data-card/ai-data-card.js.map +1 -1
- package/dist/components/ai-data-lineage/ai-data-lineage.js +6 -6
- package/dist/components/ai-data-lineage/ai-data-lineage.js.map +1 -1
- package/dist/components/ai-data-preview/ai-data-preview.d.ts +0 -7
- package/dist/components/ai-data-preview/ai-data-preview.d.ts.map +1 -1
- package/dist/components/ai-data-preview/ai-data-preview.js +130 -267
- package/dist/components/ai-data-preview/ai-data-preview.js.map +1 -1
- package/dist/components/ai-data-table/ai-data-table.js +9 -9
- package/dist/components/ai-data-table/ai-data-table.js.map +1 -1
- package/dist/components/ai-debug-console/ai-debug-console.d.ts +1 -13
- package/dist/components/ai-debug-console/ai-debug-console.d.ts.map +1 -1
- package/dist/components/ai-debug-console/ai-debug-console.js +134 -340
- package/dist/components/ai-debug-console/ai-debug-console.js.map +1 -1
- package/dist/components/ai-detection-canvas/ai-detection-canvas.js +2 -2
- package/dist/components/ai-detection-canvas/ai-detection-canvas.js.map +1 -1
- package/dist/components/ai-diff-panel/ai-diff-panel.js +1 -1
- package/dist/components/ai-embedding-viz/ai-embedding-viz.js +4 -4
- package/dist/components/ai-embedding-viz/ai-embedding-viz.js.map +1 -1
- package/dist/components/ai-empty-state/ai-empty-state.js +1 -1
- package/dist/components/ai-error-boundary/ai-error-boundary.d.ts.map +1 -1
- package/dist/components/ai-error-boundary/ai-error-boundary.js +26 -21
- package/dist/components/ai-error-boundary/ai-error-boundary.js.map +1 -1
- package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js +5 -5
- package/dist/components/ai-eval-scorecard/ai-eval-scorecard.js.map +1 -1
- package/dist/components/ai-feature-flag/ai-feature-flag.d.ts +0 -14
- package/dist/components/ai-feature-flag/ai-feature-flag.d.ts.map +1 -1
- package/dist/components/ai-feature-flag/ai-feature-flag.js +181 -322
- package/dist/components/ai-feature-flag/ai-feature-flag.js.map +1 -1
- package/dist/components/ai-feedback/ai-feedback.d.ts.map +1 -1
- package/dist/components/ai-feedback/ai-feedback.js +10 -5
- package/dist/components/ai-feedback/ai-feedback.js.map +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 +2 -2
- package/dist/components/ai-guardrail/ai-guardrail.js.map +1 -1
- package/dist/components/ai-heatmap/ai-heatmap.js +1 -1
- package/dist/components/ai-insight-card/ai-insight-card.js +4 -4
- package/dist/components/ai-insight-card/ai-insight-card.js.map +1 -1
- package/dist/components/ai-json-viewer/ai-json-viewer.js +13 -13
- package/dist/components/ai-json-viewer/ai-json-viewer.js.map +1 -1
- package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js +24 -24
- package/dist/components/ai-keyboard-shortcuts/ai-keyboard-shortcuts.js.map +1 -1
- package/dist/components/ai-kpi-grid/ai-kpi-grid.js +2 -2
- package/dist/components/ai-kpi-grid/ai-kpi-grid.js.map +1 -1
- package/dist/components/ai-labeling-board/ai-labeling-board.js +11 -11
- package/dist/components/ai-labeling-board/ai-labeling-board.js.map +1 -1
- package/dist/components/ai-memory-panel/ai-memory-panel.js +7 -7
- package/dist/components/ai-memory-panel/ai-memory-panel.js.map +1 -1
- package/dist/components/ai-model-comparison/ai-model-comparison.js +2 -2
- package/dist/components/ai-model-comparison/ai-model-comparison.js.map +1 -1
- package/dist/components/ai-model-selector/ai-model-selector.js +7 -7
- package/dist/components/ai-model-selector/ai-model-selector.js.map +1 -1
- package/dist/components/ai-notification-center/ai-notification-center.js +27 -27
- package/dist/components/ai-notification-center/ai-notification-center.js.map +1 -1
- package/dist/components/ai-onboarding/ai-onboarding.js +5 -5
- package/dist/components/ai-onboarding/ai-onboarding.js.map +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 +25 -25
- package/dist/components/ai-presence/ai-presence.js.map +1 -1
- package/dist/components/ai-progress-steps/ai-progress-steps.js +11 -11
- package/dist/components/ai-progress-steps/ai-progress-steps.js.map +1 -1
- package/dist/components/ai-prompt-editor/ai-prompt-editor.js +1 -1
- package/dist/components/ai-prompt-template/ai-prompt-template.js +29 -29
- package/dist/components/ai-prompt-template/ai-prompt-template.js.map +1 -1
- package/dist/components/ai-rag-panel/ai-rag-panel.js +4 -4
- package/dist/components/ai-rag-panel/ai-rag-panel.js.map +1 -1
- package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js +16 -16
- package/dist/components/ai-reasoning-tree/ai-reasoning-tree.js.map +1 -1
- package/dist/components/ai-result-panel/ai-result-panel.js +1 -1
- package/dist/components/ai-reveal-animation/ai-reveal-animation.js +3 -3
- package/dist/components/ai-reveal-animation/ai-reveal-animation.js.map +1 -1
- package/dist/components/ai-reward-signal/ai-reward-signal.js +1 -1
- package/dist/components/ai-rich-message/ai-rich-message.d.ts.map +1 -1
- package/dist/components/ai-rich-message/ai-rich-message.js +37 -30
- package/dist/components/ai-rich-message/ai-rich-message.js.map +1 -1
- package/dist/components/ai-scenario-panel/ai-scenario-panel.js +10 -10
- package/dist/components/ai-scenario-panel/ai-scenario-panel.js.map +1 -1
- package/dist/components/ai-search/ai-search.js +1 -1
- package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js +3 -3
- package/dist/components/ai-segmentation-viewer/ai-segmentation-viewer.js.map +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 +2 -2
- package/dist/components/ai-source-graph/ai-source-graph.js.map +1 -1
- package/dist/components/ai-status-page/ai-status-page.js +15 -15
- package/dist/components/ai-status-page/ai-status-page.js.map +1 -1
- package/dist/components/ai-streaming-text/ai-streaming-text.js +1 -1
- package/dist/components/ai-test-runner/ai-test-runner.d.ts +0 -8
- package/dist/components/ai-test-runner/ai-test-runner.d.ts.map +1 -1
- package/dist/components/ai-test-runner/ai-test-runner.js +100 -257
- package/dist/components/ai-test-runner/ai-test-runner.js.map +1 -1
- package/dist/components/ai-thinking/ai-thinking.js +1 -1
- package/dist/components/ai-timeline/ai-timeline.js +2 -2
- package/dist/components/ai-timeline/ai-timeline.js.map +1 -1
- package/dist/components/ai-token-tracker/ai-token-tracker.js +3 -3
- package/dist/components/ai-token-tracker/ai-token-tracker.js.map +1 -1
- package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js +23 -23
- package/dist/components/ai-tool-card-resolver/ai-tool-card-resolver.js.map +1 -1
- package/dist/components/ai-tool-indicator/ai-tool-indicator.js +3 -3
- package/dist/components/ai-tool-indicator/ai-tool-indicator.js.map +1 -1
- package/dist/components/ai-transform-slider/ai-transform-slider.js +1 -1
- package/dist/components/ai-translation-panel/ai-translation-panel.js +2 -2
- package/dist/components/ai-translation-panel/ai-translation-panel.js.map +1 -1
- package/dist/components/ai-usage-meter/ai-usage-meter.js +1 -1
- package/dist/components/ai-validation-checklist/ai-validation-checklist.d.ts +1 -11
- package/dist/components/ai-validation-checklist/ai-validation-checklist.d.ts.map +1 -1
- package/dist/components/ai-validation-checklist/ai-validation-checklist.js +133 -187
- package/dist/components/ai-validation-checklist/ai-validation-checklist.js.map +1 -1
- package/dist/components/ai-version-selector/ai-version-selector.d.ts +0 -4
- package/dist/components/ai-version-selector/ai-version-selector.d.ts.map +1 -1
- package/dist/components/ai-version-selector/ai-version-selector.js +189 -210
- package/dist/components/ai-version-selector/ai-version-selector.js.map +1 -1
- package/dist/components/ai-voice-panel/ai-voice-panel.js +28 -28
- package/dist/components/ai-voice-panel/ai-voice-panel.js.map +1 -1
- package/dist/components/ai-webhook-config/ai-webhook-config.d.ts +0 -17
- package/dist/components/ai-webhook-config/ai-webhook-config.d.ts.map +1 -1
- package/dist/components/ai-webhook-config/ai-webhook-config.js +281 -221
- package/dist/components/ai-webhook-config/ai-webhook-config.js.map +1 -1
- package/dist/components/ai-workflow-builder/ai-workflow-builder.js +2 -2
- package/dist/components/ai-workflow-builder/ai-workflow-builder.js.map +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.d.ts.map +1 -1
- package/dist/components/cg-accordion/cg-accordion.js +51 -43
- package/dist/components/cg-accordion/cg-accordion.js.map +1 -1
- package/dist/components/cg-alert-dialog/cg-alert-dialog.js +18 -18
- package/dist/components/cg-alert-dialog/cg-alert-dialog.js.map +1 -1
- package/dist/components/cg-aspect-ratio/cg-aspect-ratio.d.ts.map +1 -1
- package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js +25 -21
- package/dist/components/cg-aspect-ratio/cg-aspect-ratio.js.map +1 -1
- package/dist/components/cg-autocomplete/cg-autocomplete.d.ts +1 -0
- package/dist/components/cg-autocomplete/cg-autocomplete.d.ts.map +1 -1
- package/dist/components/cg-autocomplete/cg-autocomplete.js +59 -43
- package/dist/components/cg-autocomplete/cg-autocomplete.js.map +1 -1
- package/dist/components/cg-avatar/cg-avatar.d.ts.map +1 -1
- package/dist/components/cg-avatar/cg-avatar.js +24 -24
- package/dist/components/cg-avatar/cg-avatar.js.map +1 -1
- package/dist/components/cg-avatar-group/cg-avatar-group.d.ts.map +1 -1
- package/dist/components/cg-avatar-group/cg-avatar-group.js +18 -12
- package/dist/components/cg-avatar-group/cg-avatar-group.js.map +1 -1
- package/dist/components/cg-badge/cg-badge.d.ts.map +1 -1
- package/dist/components/cg-badge/cg-badge.js +26 -20
- package/dist/components/cg-badge/cg-badge.js.map +1 -1
- package/dist/components/cg-badge-group/cg-badge-group.d.ts +0 -1
- package/dist/components/cg-badge-group/cg-badge-group.d.ts.map +1 -1
- package/dist/components/cg-badge-group/cg-badge-group.js +31 -29
- package/dist/components/cg-badge-group/cg-badge-group.js.map +1 -1
- package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js +21 -21
- package/dist/components/cg-breadcrumbs/cg-breadcrumbs.js.map +1 -1
- package/dist/components/cg-button/cg-button.d.ts +5 -71
- package/dist/components/cg-button/cg-button.d.ts.map +1 -1
- package/dist/components/cg-button/cg-button.js +63 -172
- package/dist/components/cg-button/cg-button.js.map +1 -1
- package/dist/components/cg-button-group/cg-button-group.d.ts +2 -0
- package/dist/components/cg-button-group/cg-button-group.d.ts.map +1 -1
- package/dist/components/cg-button-group/cg-button-group.js +43 -29
- package/dist/components/cg-button-group/cg-button-group.js.map +1 -1
- package/dist/components/cg-calendar/cg-calendar.d.ts +4 -0
- package/dist/components/cg-calendar/cg-calendar.d.ts.map +1 -1
- package/dist/components/cg-calendar/cg-calendar.js +28 -12
- package/dist/components/cg-calendar/cg-calendar.js.map +1 -1
- package/dist/components/cg-callout/cg-callout.d.ts.map +1 -1
- package/dist/components/cg-callout/cg-callout.js +49 -48
- package/dist/components/cg-callout/cg-callout.js.map +1 -1
- package/dist/components/cg-card/cg-card.d.ts +9 -22
- package/dist/components/cg-card/cg-card.d.ts.map +1 -1
- package/dist/components/cg-card/cg-card.js +28 -56
- package/dist/components/cg-card/cg-card.js.map +1 -1
- package/dist/components/cg-carousel/cg-carousel.d.ts.map +1 -1
- package/dist/components/cg-carousel/cg-carousel.js +19 -13
- package/dist/components/cg-carousel/cg-carousel.js.map +1 -1
- package/dist/components/cg-chart/cg-chart.d.ts.map +1 -1
- package/dist/components/cg-chart/cg-chart.js +63 -58
- package/dist/components/cg-chart/cg-chart.js.map +1 -1
- package/dist/components/cg-checkbox/cg-checkbox.d.ts +0 -6
- package/dist/components/cg-checkbox/cg-checkbox.d.ts.map +1 -1
- package/dist/components/cg-checkbox/cg-checkbox.js +51 -51
- package/dist/components/cg-checkbox/cg-checkbox.js.map +1 -1
- package/dist/components/cg-chip/cg-chip.js +31 -31
- package/dist/components/cg-chip/cg-chip.js.map +1 -1
- package/dist/components/cg-code-block/cg-code-block.d.ts.map +1 -1
- package/dist/components/cg-code-block/cg-code-block.js +36 -34
- package/dist/components/cg-code-block/cg-code-block.js.map +1 -1
- package/dist/components/cg-collapsible/cg-collapsible.d.ts.map +1 -1
- package/dist/components/cg-collapsible/cg-collapsible.js +23 -18
- package/dist/components/cg-collapsible/cg-collapsible.js.map +1 -1
- package/dist/components/cg-color-picker/cg-color-picker.d.ts +3 -0
- package/dist/components/cg-color-picker/cg-color-picker.d.ts.map +1 -1
- package/dist/components/cg-color-picker/cg-color-picker.js +189 -91
- package/dist/components/cg-color-picker/cg-color-picker.js.map +1 -1
- package/dist/components/cg-combobox/cg-combobox.d.ts.map +1 -1
- package/dist/components/cg-combobox/cg-combobox.js +13 -6
- package/dist/components/cg-combobox/cg-combobox.js.map +1 -1
- package/dist/components/cg-command/cg-command.d.ts.map +1 -1
- package/dist/components/cg-command/cg-command.js +52 -45
- package/dist/components/cg-command/cg-command.js.map +1 -1
- package/dist/components/cg-context-menu/cg-context-menu.js +1 -1
- package/dist/components/cg-date-picker/cg-date-picker.d.ts.map +1 -1
- package/dist/components/cg-date-picker/cg-date-picker.js +36 -34
- package/dist/components/cg-date-picker/cg-date-picker.js.map +1 -1
- package/dist/components/cg-date-range-picker/cg-date-range-picker.d.ts +2 -0
- package/dist/components/cg-date-range-picker/cg-date-range-picker.d.ts.map +1 -1
- package/dist/components/cg-date-range-picker/cg-date-range-picker.js +12 -8
- package/dist/components/cg-date-range-picker/cg-date-range-picker.js.map +1 -1
- package/dist/components/cg-date-time-picker/cg-date-time-picker.d.ts.map +1 -1
- package/dist/components/cg-date-time-picker/cg-date-time-picker.js +3 -1
- package/dist/components/cg-date-time-picker/cg-date-time-picker.js.map +1 -1
- package/dist/components/cg-drawer/cg-drawer.js +3 -3
- package/dist/components/cg-drawer/cg-drawer.js.map +1 -1
- package/dist/components/cg-dropdown/cg-dropdown.d.ts.map +1 -1
- package/dist/components/cg-dropdown/cg-dropdown.js +1 -2
- package/dist/components/cg-dropdown/cg-dropdown.js.map +1 -1
- package/dist/components/cg-empty-state/cg-empty-state.d.ts +3 -24
- package/dist/components/cg-empty-state/cg-empty-state.d.ts.map +1 -1
- package/dist/components/cg-empty-state/cg-empty-state.js +51 -74
- package/dist/components/cg-empty-state/cg-empty-state.js.map +1 -1
- package/dist/components/cg-file-input/cg-file-input.d.ts.map +1 -1
- package/dist/components/cg-file-input/cg-file-input.js +9 -10
- package/dist/components/cg-file-input/cg-file-input.js.map +1 -1
- package/dist/components/cg-focus-scope/cg-focus-scope.js +1 -1
- package/dist/components/cg-follow-up/cg-follow-up.d.ts.map +1 -1
- package/dist/components/cg-follow-up/cg-follow-up.js +6 -7
- package/dist/components/cg-follow-up/cg-follow-up.js.map +1 -1
- package/dist/components/cg-form/cg-form.js +17 -17
- package/dist/components/cg-form/cg-form.js.map +1 -1
- package/dist/components/cg-hover-card/cg-hover-card.d.ts +1 -0
- package/dist/components/cg-hover-card/cg-hover-card.d.ts.map +1 -1
- package/dist/components/cg-hover-card/cg-hover-card.js +37 -32
- package/dist/components/cg-hover-card/cg-hover-card.js.map +1 -1
- package/dist/components/cg-icon/cg-icon.d.ts.map +1 -1
- package/dist/components/cg-icon/cg-icon.js +44 -37
- package/dist/components/cg-icon/cg-icon.js.map +1 -1
- package/dist/components/cg-image/cg-image.js +2 -2
- package/dist/components/cg-image/cg-image.js.map +1 -1
- package/dist/components/cg-image-block/cg-image-block.js +3 -3
- package/dist/components/cg-image-block/cg-image-block.js.map +1 -1
- package/dist/components/cg-image-gallery/cg-image-gallery.js +20 -20
- package/dist/components/cg-image-gallery/cg-image-gallery.js.map +1 -1
- package/dist/components/cg-input/cg-input.js +3 -3
- package/dist/components/cg-input/cg-input.js.map +1 -1
- package/dist/components/cg-kbd/cg-kbd.d.ts.map +1 -1
- package/dist/components/cg-kbd/cg-kbd.js +26 -24
- package/dist/components/cg-kbd/cg-kbd.js.map +1 -1
- package/dist/components/cg-label/cg-label.d.ts +4 -1
- package/dist/components/cg-label/cg-label.d.ts.map +1 -1
- package/dist/components/cg-label/cg-label.js +44 -41
- package/dist/components/cg-label/cg-label.js.map +1 -1
- package/dist/components/cg-link/cg-link.js +23 -23
- package/dist/components/cg-link/cg-link.js.map +1 -1
- package/dist/components/cg-list/cg-list.js +5 -5
- package/dist/components/cg-list/cg-list.js.map +1 -1
- package/dist/components/cg-listbox/cg-listbox.d.ts.map +1 -1
- package/dist/components/cg-listbox/cg-listbox.js +46 -40
- package/dist/components/cg-listbox/cg-listbox.js.map +1 -1
- package/dist/components/cg-markdown/cg-markdown.d.ts +2 -0
- package/dist/components/cg-markdown/cg-markdown.d.ts.map +1 -1
- package/dist/components/cg-markdown/cg-markdown.js +171 -121
- package/dist/components/cg-markdown/cg-markdown.js.map +1 -1
- package/dist/components/cg-menubar/cg-menubar.d.ts +6 -0
- package/dist/components/cg-menubar/cg-menubar.d.ts.map +1 -1
- package/dist/components/cg-menubar/cg-menubar.js +59 -47
- package/dist/components/cg-menubar/cg-menubar.js.map +1 -1
- package/dist/components/cg-meter/cg-meter.d.ts.map +1 -1
- package/dist/components/cg-meter/cg-meter.js +76 -76
- package/dist/components/cg-meter/cg-meter.js.map +1 -1
- package/dist/components/cg-metric-card/cg-metric-card.d.ts.map +1 -1
- package/dist/components/cg-metric-card/cg-metric-card.js +65 -68
- package/dist/components/cg-metric-card/cg-metric-card.js.map +1 -1
- package/dist/components/cg-modal/cg-modal.d.ts +3 -0
- package/dist/components/cg-modal/cg-modal.d.ts.map +1 -1
- package/dist/components/cg-modal/cg-modal.js +82 -83
- package/dist/components/cg-modal/cg-modal.js.map +1 -1
- package/dist/components/cg-navbar/cg-navbar.d.ts +1 -1
- package/dist/components/cg-navbar/cg-navbar.d.ts.map +1 -1
- package/dist/components/cg-navbar/cg-navbar.js +64 -55
- package/dist/components/cg-navbar/cg-navbar.js.map +1 -1
- package/dist/components/cg-navigation-menu/cg-navigation-menu.d.ts +3 -0
- package/dist/components/cg-navigation-menu/cg-navigation-menu.d.ts.map +1 -1
- package/dist/components/cg-navigation-menu/cg-navigation-menu.js +38 -26
- package/dist/components/cg-navigation-menu/cg-navigation-menu.js.map +1 -1
- package/dist/components/cg-number-input/cg-number-input.d.ts +1 -0
- package/dist/components/cg-number-input/cg-number-input.d.ts.map +1 -1
- package/dist/components/cg-number-input/cg-number-input.js +90 -77
- package/dist/components/cg-number-input/cg-number-input.js.map +1 -1
- package/dist/components/cg-otp-input/cg-otp-input.d.ts.map +1 -1
- package/dist/components/cg-otp-input/cg-otp-input.js +70 -60
- package/dist/components/cg-otp-input/cg-otp-input.js.map +1 -1
- package/dist/components/cg-pagination/cg-pagination.d.ts +2 -0
- package/dist/components/cg-pagination/cg-pagination.d.ts.map +1 -1
- package/dist/components/cg-pagination/cg-pagination.js +50 -49
- package/dist/components/cg-pagination/cg-pagination.js.map +1 -1
- package/dist/components/cg-password-input/cg-password-input.d.ts.map +1 -1
- package/dist/components/cg-password-input/cg-password-input.js +42 -34
- package/dist/components/cg-password-input/cg-password-input.js.map +1 -1
- package/dist/components/cg-phone-input/cg-phone-input.d.ts.map +1 -1
- package/dist/components/cg-phone-input/cg-phone-input.js +18 -14
- package/dist/components/cg-phone-input/cg-phone-input.js.map +1 -1
- package/dist/components/cg-popover/cg-popover.d.ts +12 -2
- package/dist/components/cg-popover/cg-popover.d.ts.map +1 -1
- package/dist/components/cg-popover/cg-popover.js +90 -63
- package/dist/components/cg-popover/cg-popover.js.map +1 -1
- package/dist/components/cg-portal/cg-portal.d.ts.map +1 -1
- package/dist/components/cg-portal/cg-portal.js +42 -41
- package/dist/components/cg-portal/cg-portal.js.map +1 -1
- package/dist/components/cg-progress-bar/cg-progress-bar.d.ts.map +1 -1
- package/dist/components/cg-progress-bar/cg-progress-bar.js +25 -25
- package/dist/components/cg-progress-bar/cg-progress-bar.js.map +1 -1
- package/dist/components/cg-radio/cg-radio.d.ts +10 -0
- package/dist/components/cg-radio/cg-radio.d.ts.map +1 -1
- package/dist/components/cg-radio/cg-radio.js +59 -48
- package/dist/components/cg-radio/cg-radio.js.map +1 -1
- package/dist/components/cg-radio-group/cg-radio-group.d.ts +6 -0
- package/dist/components/cg-radio-group/cg-radio-group.d.ts.map +1 -1
- package/dist/components/cg-radio-group/cg-radio-group.js +50 -37
- package/dist/components/cg-radio-group/cg-radio-group.js.map +1 -1
- package/dist/components/cg-rating/cg-rating.d.ts.map +1 -1
- package/dist/components/cg-rating/cg-rating.js +56 -54
- package/dist/components/cg-rating/cg-rating.js.map +1 -1
- package/dist/components/cg-resizable/cg-resizable.d.ts +4 -1
- package/dist/components/cg-resizable/cg-resizable.d.ts.map +1 -1
- package/dist/components/cg-resizable/cg-resizable.js +45 -35
- package/dist/components/cg-resizable/cg-resizable.js.map +1 -1
- package/dist/components/cg-scroll-area/cg-scroll-area.d.ts +8 -0
- package/dist/components/cg-scroll-area/cg-scroll-area.d.ts.map +1 -1
- package/dist/components/cg-scroll-area/cg-scroll-area.js +64 -21
- package/dist/components/cg-scroll-area/cg-scroll-area.js.map +1 -1
- package/dist/components/cg-segmented-control/cg-segmented-control.d.ts +4 -0
- package/dist/components/cg-segmented-control/cg-segmented-control.d.ts.map +1 -1
- package/dist/components/cg-segmented-control/cg-segmented-control.js +75 -39
- package/dist/components/cg-segmented-control/cg-segmented-control.js.map +1 -1
- package/dist/components/cg-select/cg-select.d.ts +4 -2
- package/dist/components/cg-select/cg-select.d.ts.map +1 -1
- package/dist/components/cg-select/cg-select.js +96 -58
- package/dist/components/cg-select/cg-select.js.map +1 -1
- package/dist/components/cg-separator/cg-separator.d.ts +1 -2
- package/dist/components/cg-separator/cg-separator.d.ts.map +1 -1
- package/dist/components/cg-separator/cg-separator.js +5 -8
- package/dist/components/cg-separator/cg-separator.js.map +1 -1
- package/dist/components/cg-sheet/cg-sheet.d.ts +4 -0
- package/dist/components/cg-sheet/cg-sheet.d.ts.map +1 -1
- package/dist/components/cg-sheet/cg-sheet.js +80 -43
- package/dist/components/cg-sheet/cg-sheet.js.map +1 -1
- package/dist/components/cg-sidebar/cg-sidebar.d.ts.map +1 -1
- package/dist/components/cg-sidebar/cg-sidebar.js +82 -19
- package/dist/components/cg-sidebar/cg-sidebar.js.map +1 -1
- package/dist/components/cg-skeleton/cg-skeleton.d.ts +7 -1
- package/dist/components/cg-skeleton/cg-skeleton.d.ts.map +1 -1
- package/dist/components/cg-skeleton/cg-skeleton.js +61 -63
- package/dist/components/cg-skeleton/cg-skeleton.js.map +1 -1
- package/dist/components/cg-slider/cg-slider.d.ts.map +1 -1
- package/dist/components/cg-slider/cg-slider.js +80 -73
- package/dist/components/cg-slider/cg-slider.js.map +1 -1
- package/dist/components/cg-spinner/cg-spinner.d.ts.map +1 -1
- package/dist/components/cg-spinner/cg-spinner.js +10 -19
- package/dist/components/cg-spinner/cg-spinner.js.map +1 -1
- package/dist/components/cg-split-button/cg-split-button.d.ts.map +1 -1
- package/dist/components/cg-split-button/cg-split-button.js +64 -50
- package/dist/components/cg-split-button/cg-split-button.js.map +1 -1
- package/dist/components/cg-stack/cg-stack.js +1 -1
- package/dist/components/cg-steps/cg-steps.js +1 -1
- package/dist/components/cg-switch/cg-switch.d.ts +3 -0
- package/dist/components/cg-switch/cg-switch.d.ts.map +1 -1
- package/dist/components/cg-switch/cg-switch.js +39 -47
- package/dist/components/cg-switch/cg-switch.js.map +1 -1
- package/dist/components/cg-table/cg-table.d.ts +0 -7
- package/dist/components/cg-table/cg-table.d.ts.map +1 -1
- package/dist/components/cg-table/cg-table.js +50 -47
- package/dist/components/cg-table/cg-table.js.map +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-time-picker/cg-time-picker.js +1 -1
- package/dist/components/cg-toaster/cg-toaster.js +3 -3
- package/dist/components/cg-toaster/cg-toaster.js.map +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-tree-view/cg-tree-view.js +1 -1
- package/dist/foundation.d.ts +0 -16
- package/dist/foundation.d.ts.map +1 -1
- package/dist/foundation.js +174 -206
- package/dist/foundation.js.map +1 -1
- package/dist/index.d.ts +1 -17
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +100 -132
- package/dist/index.js.map +1 -1
- package/dist/utils/focus-trap.d.ts +19 -2
- package/dist/utils/focus-trap.d.ts.map +1 -1
- package/package.json +6 -810
- package/dist/chunks/focus-trap-BdRNhSPD.js +0 -53
- package/dist/chunks/focus-trap-BdRNhSPD.js.map +0 -1
- package/dist/components/cg-app-shell/cg-app-shell.d.ts +0 -54
- package/dist/components/cg-app-shell/cg-app-shell.d.ts.map +0 -1
- package/dist/components/cg-app-shell/cg-app-shell.js +0 -135
- package/dist/components/cg-app-shell/cg-app-shell.js.map +0 -1
- package/dist/components/cg-auth-shell/cg-auth-shell.d.ts +0 -61
- package/dist/components/cg-auth-shell/cg-auth-shell.d.ts.map +0 -1
- package/dist/components/cg-auth-shell/cg-auth-shell.js +0 -163
- package/dist/components/cg-auth-shell/cg-auth-shell.js.map +0 -1
- package/dist/components/cg-definition-list/cg-definition-list.d.ts +0 -99
- package/dist/components/cg-definition-list/cg-definition-list.d.ts.map +0 -1
- package/dist/components/cg-definition-list/cg-definition-list.js +0 -332
- package/dist/components/cg-definition-list/cg-definition-list.js.map +0 -1
- package/dist/components/cg-draggable/cg-draggable.d.ts +0 -53
- package/dist/components/cg-draggable/cg-draggable.d.ts.map +0 -1
- package/dist/components/cg-draggable/cg-draggable.js +0 -136
- package/dist/components/cg-draggable/cg-draggable.js.map +0 -1
- package/dist/components/cg-droppable/cg-droppable.d.ts +0 -57
- package/dist/components/cg-droppable/cg-droppable.d.ts.map +0 -1
- package/dist/components/cg-droppable/cg-droppable.js +0 -114
- package/dist/components/cg-droppable/cg-droppable.js.map +0 -1
- package/dist/components/cg-filter-bar/cg-filter-bar.d.ts +0 -50
- package/dist/components/cg-filter-bar/cg-filter-bar.d.ts.map +0 -1
- package/dist/components/cg-filter-bar/cg-filter-bar.js +0 -115
- package/dist/components/cg-filter-bar/cg-filter-bar.js.map +0 -1
- package/dist/components/cg-filter-chip/cg-filter-chip.d.ts +0 -55
- package/dist/components/cg-filter-chip/cg-filter-chip.d.ts.map +0 -1
- package/dist/components/cg-filter-chip/cg-filter-chip.js +0 -213
- package/dist/components/cg-filter-chip/cg-filter-chip.js.map +0 -1
- package/dist/components/cg-kanban/cg-kanban.d.ts +0 -44
- package/dist/components/cg-kanban/cg-kanban.d.ts.map +0 -1
- package/dist/components/cg-kanban/cg-kanban.js +0 -86
- package/dist/components/cg-kanban/cg-kanban.js.map +0 -1
- package/dist/components/cg-kanban-column/cg-kanban-column.d.ts +0 -58
- package/dist/components/cg-kanban-column/cg-kanban-column.d.ts.map +0 -1
- package/dist/components/cg-kanban-column/cg-kanban-column.js +0 -144
- package/dist/components/cg-kanban-column/cg-kanban-column.js.map +0 -1
- package/dist/components/cg-mfa-prompt/cg-mfa-prompt.d.ts +0 -77
- package/dist/components/cg-mfa-prompt/cg-mfa-prompt.d.ts.map +0 -1
- package/dist/components/cg-mfa-prompt/cg-mfa-prompt.js +0 -245
- package/dist/components/cg-mfa-prompt/cg-mfa-prompt.js.map +0 -1
- package/dist/components/cg-search-input/cg-search-input.d.ts +0 -62
- package/dist/components/cg-search-input/cg-search-input.d.ts.map +0 -1
- package/dist/components/cg-search-input/cg-search-input.js +0 -106
- package/dist/components/cg-search-input/cg-search-input.js.map +0 -1
- package/dist/components/cg-sortable/cg-sortable.d.ts +0 -72
- package/dist/components/cg-sortable/cg-sortable.d.ts.map +0 -1
- package/dist/components/cg-sortable/cg-sortable.js +0 -177
- package/dist/components/cg-sortable/cg-sortable.js.map +0 -1
- package/dist/components/cg-theme/cg-theme.d.ts +0 -82
- package/dist/components/cg-theme/cg-theme.d.ts.map +0 -1
- package/dist/components/cg-theme/cg-theme.js +0 -91
- package/dist/components/cg-theme/cg-theme.js.map +0 -1
- package/dist/components/cg-theme-editor/cg-theme-editor.d.ts +0 -98
- package/dist/components/cg-theme-editor/cg-theme-editor.d.ts.map +0 -1
- package/dist/components/cg-theme-editor/cg-theme-editor.js +0 -341
- package/dist/components/cg-theme-editor/cg-theme-editor.js.map +0 -1
- package/dist/components/cg-timeline/cg-timeline.d.ts +0 -70
- package/dist/components/cg-timeline/cg-timeline.d.ts.map +0 -1
- package/dist/components/cg-timeline/cg-timeline.js +0 -131
- package/dist/components/cg-timeline/cg-timeline.js.map +0 -1
- package/dist/components/cg-timeline-event/cg-timeline-event.d.ts +0 -59
- package/dist/components/cg-timeline-event/cg-timeline-event.d.ts.map +0 -1
- package/dist/components/cg-timeline-event/cg-timeline-event.js +0 -190
- package/dist/components/cg-timeline-event/cg-timeline-event.js.map +0 -1
- package/dist/utils/drag-manager.d.ts +0 -40
- package/dist/utils/drag-manager.d.ts.map +0 -1
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { css as N, LitElement as I, nothing as v, svg as
|
|
2
|
-
import { property as
|
|
3
|
-
import { h as
|
|
4
|
-
var
|
|
5
|
-
for (var e = s > 1 ? void 0 : s ?
|
|
1
|
+
import { css as N, LitElement as I, nothing as v, svg as f, html as _ } from "lit";
|
|
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-DHekUEUt.js";
|
|
4
|
+
var Y = Object.defineProperty, q = Object.getOwnPropertyDescriptor, x = (t, a, r, s) => {
|
|
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);
|
|
7
|
-
return s && e &&
|
|
7
|
+
return s && e && Y(a, r, e), e;
|
|
8
8
|
};
|
|
9
9
|
const P = [
|
|
10
10
|
"#dfff61",
|
|
@@ -23,7 +23,7 @@ let u = class extends I {
|
|
|
23
23
|
_resolve() {
|
|
24
24
|
if (this._resolved) return;
|
|
25
25
|
const t = getComputedStyle(this);
|
|
26
|
-
this._grid = t.getPropertyValue("--cg-color-chart-grid").trim() || t.getPropertyValue("--cg-color-border
|
|
26
|
+
this._grid = t.getPropertyValue("--cg-color-chart-grid").trim() || t.getPropertyValue("--cg-color-surface-cards-border").trim(), this._axis = t.getPropertyValue("--cg-color-chart-axis").trim() || t.getPropertyValue("--cg-color-input-text-placeholder").trim(), this._text = t.getPropertyValue("--cg-color-surface-base-text").trim() || t.getPropertyValue("--cg-color-surface-base-text").trim(), this._bg = t.getPropertyValue("--cg-color-surface-container-background").trim() || t.getPropertyValue("--cg-color-surface-base-background").trim();
|
|
27
27
|
for (let a = 0; a < 8; a++) {
|
|
28
28
|
const r = t.getPropertyValue(`--cg-color-chart-${a + 1}`).trim();
|
|
29
29
|
r && (P[a] = r);
|
|
@@ -84,22 +84,22 @@ let u = class extends I {
|
|
|
84
84
|
// ═══ BAR ═══
|
|
85
85
|
_bar() {
|
|
86
86
|
const { data: t, height: a } = this, r = 400, s = 20, e = 16, n = 28, o = 44, l = r - o - e, m = a - s - n, i = Math.max(...t.map((h) => h.value), 1), c = t.length, p = l / c * 0.6, $ = l / c;
|
|
87
|
-
return
|
|
87
|
+
return f`
|
|
88
88
|
${this.showGrid ? [0.25, 0.5, 0.75, 1].map((h) => {
|
|
89
89
|
const y = s + m - m * h;
|
|
90
|
-
return
|
|
90
|
+
return f`
|
|
91
91
|
<line x1="${o}" y1="${y}" x2="${r - e}" y2="${y}" stroke="${this._grid}" stroke-width="0.5" stroke-dasharray="3,3" />
|
|
92
92
|
<text x="${o - 6}" y="${y + 4}" text-anchor="end" fill="${this._axis}" font-size="10">${this._fmt(i * h)}</text>
|
|
93
93
|
`;
|
|
94
94
|
}) : v}
|
|
95
95
|
${t.map((h, y) => {
|
|
96
96
|
const g = h.value / i * m, d = o + y * $ + ($ - p) / 2, w = s + m - g, F = s + m, k = this._color(y, h);
|
|
97
|
-
return
|
|
97
|
+
return f`
|
|
98
98
|
<rect class="bar-anim" x="${d}" y="${F}" width="${p}" height="0" rx="4" fill="${k}" style="cursor:pointer"
|
|
99
99
|
data-y="${w}" data-h="${g}" data-delay="${y * 50}"
|
|
100
100
|
@mouseenter=${(M) => this._tip(M, h.label, h.value)}
|
|
101
101
|
@mouseleave=${this._untip} />
|
|
102
|
-
${this.showValues ?
|
|
102
|
+
${this.showValues ? f`<text class="val-anim" x="${d + p / 2}" y="${w - 6}" text-anchor="middle" fill="${this._text}" font-size="10" font-weight="600" opacity="0" data-delay="${y * 50 + 300}">${this._fmt(h.value)}</text>` : v}
|
|
103
103
|
<text x="${d + p / 2}" y="${a - 6}" text-anchor="middle" fill="${this._axis}" font-size="10">${h.label}</text>
|
|
104
104
|
`;
|
|
105
105
|
})}
|
|
@@ -110,10 +110,10 @@ let u = class extends I {
|
|
|
110
110
|
const { data: t } = this, a = 400, r = 72, s = 8, e = 28;
|
|
111
111
|
t.length * (e + s);
|
|
112
112
|
const n = Math.max(...t.map((o) => o.value), 1);
|
|
113
|
-
return
|
|
113
|
+
return f`
|
|
114
114
|
${t.map((o, l) => {
|
|
115
115
|
const m = l * (e + s), i = o.value / n * (a - r - 60), c = this._color(l, o);
|
|
116
|
-
return
|
|
116
|
+
return f`
|
|
117
117
|
<text x="${r - 6}" y="${m + e / 2 + 4}" text-anchor="end" fill="${this._axis}" font-size="11">${o.label}</text>
|
|
118
118
|
<rect class="hbar-anim" x="${r}" y="${m}" width="0" height="${e}" rx="4" fill="${c}" style="cursor:pointer"
|
|
119
119
|
data-w="${i}" data-delay="${l * 50}"
|
|
@@ -130,22 +130,22 @@ let u = class extends I {
|
|
|
130
130
|
x: l + d / Math.max(a.length - 1, 1) * m,
|
|
131
131
|
y: e + i - g.value / c * i
|
|
132
132
|
})), h = $.map((g, d) => `${d ? "L" : "M"}${g.x.toFixed(1)},${g.y.toFixed(1)}`).join(" "), y = `${h} L${$.at(-1).x.toFixed(1)},${(e + i).toFixed(1)} L${$[0].x.toFixed(1)},${(e + i).toFixed(1)} Z`;
|
|
133
|
-
return
|
|
133
|
+
return f`
|
|
134
134
|
${this.showGrid ? [0.25, 0.5, 0.75, 1].map((g) => {
|
|
135
135
|
const d = e + i - i * g;
|
|
136
|
-
return
|
|
136
|
+
return f`
|
|
137
137
|
<line x1="${l}" y1="${d}" x2="${s - n}" y2="${d}" stroke="${this._grid}" stroke-width="0.5" stroke-dasharray="3,3" />
|
|
138
138
|
<text x="${l - 6}" y="${d + 4}" text-anchor="end" fill="${this._axis}" font-size="10">${this._fmt(c * g)}</text>
|
|
139
139
|
`;
|
|
140
140
|
}) : v}
|
|
141
|
-
${t ?
|
|
141
|
+
${t ? f`<path d="${y}" fill="${p}" opacity="0.2" />` : v}
|
|
142
142
|
<path class="anim-line" d="${h}" fill="none" stroke="${p}" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round" style="--dash:2000" />
|
|
143
|
-
${$.map((g, d) =>
|
|
143
|
+
${$.map((g, d) => f`
|
|
144
144
|
<circle class="anim-dot" cx="${g.x}" cy="${g.y}" r="4" fill="${p}" stroke="${this._bg}" stroke-width="2" style="cursor:pointer; animation-delay:${400 + d * 50}ms"
|
|
145
145
|
@mouseenter=${(w) => this._tip(w, a[d].label, a[d].value)}
|
|
146
146
|
@mouseleave=${this._untip} />
|
|
147
147
|
`)}
|
|
148
|
-
${a.map((g, d) =>
|
|
148
|
+
${a.map((g, d) => f`
|
|
149
149
|
<text x="${$[d].x}" y="${r - 6}" text-anchor="middle" fill="${this._axis}" font-size="10">${g.label}</text>
|
|
150
150
|
`)}
|
|
151
151
|
`;
|
|
@@ -156,16 +156,16 @@ let u = class extends I {
|
|
|
156
156
|
let m = -90;
|
|
157
157
|
const i = a.map((c, p) => {
|
|
158
158
|
const $ = c.value / r * 360, h = m + $, y = $ > 180 ? 1 : 0, g = n + e * Math.cos(l(m)), d = o + e * Math.sin(l(m)), w = n + e * Math.cos(l(h)), F = o + e * Math.sin(l(h)), k = m + $ / 2, M = e * (t ? 1.2 : 0.6), A = n + M * Math.cos(l(k)), S = o + M * Math.sin(l(k)), T = Math.round(c.value / r * 100), B = this._color(p, c), L = `M${n},${o} L${g.toFixed(1)},${d.toFixed(1)} A${e},${e} 0 ${y} 1 ${w.toFixed(1)},${F.toFixed(1)} Z`;
|
|
159
|
-
return m = h,
|
|
159
|
+
return m = h, f`
|
|
160
160
|
<path class="anim-slice" d="${L}" fill="${B}" style="cursor:pointer; animation-delay:${p * 60}ms"
|
|
161
161
|
@mouseenter=${(V) => this._tip(V, c.label, c.value)}
|
|
162
162
|
@mouseleave=${this._untip} />
|
|
163
|
-
${T >= 5 ?
|
|
163
|
+
${T >= 5 ? f`<text x="${A}" y="${S}" text-anchor="middle" dominant-baseline="central" fill="${t ? this._axis : this._text}" font-size="10" font-weight="600">${T}%</text>` : v}
|
|
164
164
|
`;
|
|
165
165
|
});
|
|
166
|
-
return
|
|
166
|
+
return f`
|
|
167
167
|
${i}
|
|
168
|
-
${t ?
|
|
168
|
+
${t ? f`
|
|
169
169
|
<circle cx="${n}" cy="${o}" r="${e * 0.55}" fill="${this._bg}" />
|
|
170
170
|
<text x="${n}" y="${o - 4}" text-anchor="middle" fill="${this._text}" font-size="16" font-weight="700">${this._fmt(r)}</text>
|
|
171
171
|
<text x="${n}" y="${o + 12}" text-anchor="middle" fill="${this._axis}" font-size="9">Total</text>
|
|
@@ -179,7 +179,7 @@ let u = class extends I {
|
|
|
179
179
|
return this.type === "pie" || this.type === "donut" ? Math.min(this.height, 240) : 400;
|
|
180
180
|
}
|
|
181
181
|
render() {
|
|
182
|
-
if (!this.data.length) return
|
|
182
|
+
if (!this.data.length) return _`<div class="wrap ${this.contained ? "contained" : ""}"><div class="empty">${this.emptyText}</div></div>`;
|
|
183
183
|
const t = this._svgWidth(), a = this._svgHeight(), r = this.type === "pie" || this.type === "donut";
|
|
184
184
|
let s;
|
|
185
185
|
switch (this.type) {
|
|
@@ -202,17 +202,22 @@ let u = class extends I {
|
|
|
202
202
|
s = this._pie(!0);
|
|
203
203
|
break;
|
|
204
204
|
}
|
|
205
|
-
return
|
|
205
|
+
return _`
|
|
206
206
|
<div class="wrap ${this.contained ? "contained" : ""}">
|
|
207
|
-
${this.title || this.subtitle ?
|
|
207
|
+
${this.title || this.subtitle ? _`
|
|
208
208
|
<div class="header">
|
|
209
|
-
${this.title ?
|
|
210
|
-
${this.subtitle ?
|
|
209
|
+
${this.title ? _`<div class="title">${this.title}</div>` : v}
|
|
210
|
+
${this.subtitle ? _`<div class="subtitle">${this.subtitle}</div>` : v}
|
|
211
211
|
</div>
|
|
212
212
|
` : v}
|
|
213
213
|
|
|
214
214
|
<div class="svg-wrap">
|
|
215
|
-
<svg
|
|
215
|
+
<svg
|
|
216
|
+
role="img"
|
|
217
|
+
aria-label=${`${this.title || "Chart"}: ${this.data.map((e) => `${e.label} ${this._fmt(e.value)}`).join(", ")}`}
|
|
218
|
+
viewBox="0 0 ${t} ${a}"
|
|
219
|
+
style="${r ? `max-width:${t}px; margin:0 auto;` : ""}"
|
|
220
|
+
>
|
|
216
221
|
${s}
|
|
217
222
|
</svg>
|
|
218
223
|
<div class="tip ${this._tipShow ? "show" : ""}" style="left:${this._tipX}px;top:${this._tipY}px;">
|
|
@@ -220,9 +225,9 @@ let u = class extends I {
|
|
|
220
225
|
</div>
|
|
221
226
|
</div>
|
|
222
227
|
|
|
223
|
-
${this.showLegend ?
|
|
228
|
+
${this.showLegend ? _`
|
|
224
229
|
<div class="legend">
|
|
225
|
-
${this.data.map((e, n) =>
|
|
230
|
+
${this.data.map((e, n) => _`
|
|
226
231
|
<span class="legend-item anim-legend" style="animation-delay:${300 + n * 40}ms">
|
|
227
232
|
<span class="legend-dot" style="background:${this._color(n, e)}"></span>
|
|
228
233
|
<span>${e.label}</span>
|
|
@@ -235,7 +240,7 @@ let u = class extends I {
|
|
|
235
240
|
`;
|
|
236
241
|
}
|
|
237
242
|
};
|
|
238
|
-
u.styles = [
|
|
243
|
+
u.styles = [E, W, N`
|
|
239
244
|
:host { display: block; }
|
|
240
245
|
|
|
241
246
|
.wrap { position: relative; }
|
|
@@ -299,7 +304,7 @@ u.styles = [W, Y, N`
|
|
|
299
304
|
pointer-events: none;
|
|
300
305
|
white-space: nowrap;
|
|
301
306
|
transform: translate(-50%, -100%);
|
|
302
|
-
margin-top: -
|
|
307
|
+
margin-top: calc(var(--cg-spacing-8) * -1);
|
|
303
308
|
z-index: 10;
|
|
304
309
|
display: none;
|
|
305
310
|
}
|
|
@@ -330,50 +335,50 @@ u.styles = [W, Y, N`
|
|
|
330
335
|
font-size: var(--cg-font-size-sm); min-height: 120px;
|
|
331
336
|
}
|
|
332
337
|
`];
|
|
333
|
-
|
|
334
|
-
|
|
338
|
+
x([
|
|
339
|
+
b({ type: Array })
|
|
335
340
|
], u.prototype, "data", 2);
|
|
336
|
-
|
|
337
|
-
|
|
341
|
+
x([
|
|
342
|
+
b()
|
|
338
343
|
], u.prototype, "type", 2);
|
|
339
|
-
|
|
340
|
-
|
|
344
|
+
x([
|
|
345
|
+
b()
|
|
341
346
|
], u.prototype, "title", 2);
|
|
342
|
-
|
|
343
|
-
|
|
347
|
+
x([
|
|
348
|
+
b()
|
|
344
349
|
], u.prototype, "subtitle", 2);
|
|
345
|
-
|
|
346
|
-
|
|
350
|
+
x([
|
|
351
|
+
b({ type: Number })
|
|
347
352
|
], u.prototype, "height", 2);
|
|
348
|
-
|
|
349
|
-
|
|
353
|
+
x([
|
|
354
|
+
b({ type: Boolean })
|
|
350
355
|
], u.prototype, "showLegend", 2);
|
|
351
|
-
|
|
352
|
-
|
|
356
|
+
x([
|
|
357
|
+
b({ type: Boolean })
|
|
353
358
|
], u.prototype, "showValues", 2);
|
|
354
|
-
|
|
355
|
-
|
|
359
|
+
x([
|
|
360
|
+
b({ type: Boolean })
|
|
356
361
|
], u.prototype, "contained", 2);
|
|
357
|
-
|
|
358
|
-
|
|
362
|
+
x([
|
|
363
|
+
b({ type: Boolean })
|
|
359
364
|
], u.prototype, "showGrid", 2);
|
|
360
|
-
|
|
361
|
-
|
|
365
|
+
x([
|
|
366
|
+
b()
|
|
362
367
|
], u.prototype, "emptyText", 2);
|
|
363
|
-
|
|
368
|
+
x([
|
|
364
369
|
z()
|
|
365
370
|
], u.prototype, "_tipX", 2);
|
|
366
|
-
|
|
371
|
+
x([
|
|
367
372
|
z()
|
|
368
373
|
], u.prototype, "_tipY", 2);
|
|
369
|
-
|
|
374
|
+
x([
|
|
370
375
|
z()
|
|
371
376
|
], u.prototype, "_tipText", 2);
|
|
372
|
-
|
|
377
|
+
x([
|
|
373
378
|
z()
|
|
374
379
|
], u.prototype, "_tipShow", 2);
|
|
375
|
-
u =
|
|
376
|
-
|
|
380
|
+
u = x([
|
|
381
|
+
C("cg-chart")
|
|
377
382
|
], u);
|
|
378
383
|
export {
|
|
379
384
|
u as CgChart
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-chart.js","sources":["../../../src/components/cg-chart/cg-chart.ts"],"sourcesContent":["import { LitElement, html, css, nothing, svg } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/** Data point for cg-chart */\nexport interface ChartSeries {\n label: string;\n value: number;\n color?: string;\n}\n\n/** Default palette — hex colors that work directly in SVG fill/stroke attributes */\nconst PALETTE = [\n '#dfff61', '#14b8a6', '#22c55e', '#f59e0b',\n '#f97316', '#ec4899', '#8b5cf6', '#ef4444',\n];\n\n@customElement('cg-chart')\nexport class CgChart extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host { display: block; }\n\n .wrap { position: relative; }\n .wrap.contained {\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-component-card-radius);\n padding: var(--cg-spacing-20);\n }\n\n .header { margin-bottom: var(--cg-spacing-12); }\n .title {\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 .subtitle {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n margin-top: var(--cg-spacing-2);\n }\n\n .svg-wrap { position: relative; }\n svg { display: block; width: 100%; }\n\n /* ── Entrance animations ── */\n @keyframes fadeIn {\n from { opacity: 0; }\n to { opacity: 1; }\n }\n @keyframes lineTrace {\n from { stroke-dashoffset: var(--dash); }\n to { stroke-dashoffset: 0; }\n }\n\n .anim-line {\n stroke-dasharray: var(--dash);\n stroke-dashoffset: var(--dash);\n animation: lineTrace 900ms var(--cg-transition-easing-ease-out) forwards;\n }\n .anim-dot {\n animation: fadeIn 200ms var(--cg-transition-easing-ease-out) both;\n }\n .anim-slice {\n animation: fadeIn 400ms var(--cg-transition-easing-ease-out) both;\n }\n .anim-legend {\n animation: fadeIn 200ms var(--cg-transition-easing-ease-out) both;\n }\n\n /* Tooltip */\n .tip {\n position: absolute;\n background: var(--cg-color-surface-container-background);\n color: var(--cg-color-surface-base-text);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n padding: var(--cg-spacing-4) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-50);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-medium);\n pointer-events: none;\n white-space: nowrap;\n transform: translate(-50%, -100%);\n margin-top: -8px;\n z-index: 10;\n display: none;\n }\n .tip.show { display: block; }\n\n /* Legend */\n .legend {\n display: flex; flex-wrap: wrap; gap: var(--cg-spacing-12);\n margin-top: var(--cg-spacing-16); padding-top: var(--cg-spacing-12);\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n .legend-item {\n display: inline-flex; align-items: center; gap: var(--cg-spacing-4);\n font-size: var(--cg-font-size-xs); color: var(--cg-color-input-text-placeholder);\n }\n .legend-dot {\n width: var(--cg-spacing-8); height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full); flex-shrink: 0;\n }\n .legend-val {\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n\n .empty {\n display: flex; align-items: center; justify-content: center;\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-sm); min-height: 120px;\n }\n `];\n\n @property({ type: Array }) data: ChartSeries[] = [];\n @property() type: 'bar' | 'horizontal-bar' | 'line' | 'area' | 'pie' | 'donut' = 'bar';\n @property() override title = '';\n @property() subtitle = '';\n @property({ type: Number }) height = 200;\n @property({ type: Boolean }) showLegend = true;\n @property({ type: Boolean }) showValues = true;\n /** Wrap chart in a card container */\n @property({ type: Boolean }) contained = false;\n @property({ type: Boolean }) showGrid = true;\n @property() emptyText = 'No data';\n\n @state() private _tipX = 0;\n @state() private _tipY = 0;\n @state() private _tipText = '';\n @state() private _tipShow = false;\n\n // Resolved theme colors for SVG — pulled from CSS custom properties at runtime\n private _grid = '';\n private _axis = '';\n private _text = '';\n private _bg = '';\n private _resolved = false;\n\n private _resolve() {\n if (this._resolved) return;\n const s = getComputedStyle(this);\n this._grid = s.getPropertyValue('--cg-color-chart-grid').trim() || s.getPropertyValue('--cg-color-border-default').trim();\n this._axis = s.getPropertyValue('--cg-color-chart-axis').trim() || s.getPropertyValue('--cg-color-text-muted').trim();\n this._text = s.getPropertyValue('--cg-color-surface-base-text').trim() || s.getPropertyValue('--cg-color-text-default').trim();\n this._bg = s.getPropertyValue('--cg-color-surface-container-background').trim() || s.getPropertyValue('--cg-color-surface-base').trim();\n for (let i = 0; i < 8; i++) {\n const v = s.getPropertyValue(`--cg-color-chart-${i + 1}`).trim();\n if (v) PALETTE[i] = v;\n }\n this._resolved = true;\n }\n\n override firstUpdated() {\n this._resolve();\n this.requestUpdate();\n }\n\n private _animId = 0;\n private _animated = false;\n\n override updated(changed: Map<string, unknown>) {\n if (!this._animated && this.data.length > 0) {\n this._animated = true;\n this._animateBars();\n }\n if (changed.has('data') || changed.has('type')) {\n this._animated = false;\n cancelAnimationFrame(this._animId);\n // Re-animate on next frame after render\n requestAnimationFrame(() => {\n this._animated = true;\n this._animateBars();\n });\n }\n }\n\n private _easeOut(t: number) { return 1 - (1 - t) * (1 - t); }\n\n private _animateBars() {\n const bars = this.shadowRoot?.querySelectorAll<SVGRectElement>('.bar-anim');\n const hbars = this.shadowRoot?.querySelectorAll<SVGRectElement>('.hbar-anim');\n const vals = this.shadowRoot?.querySelectorAll<SVGElement>('.val-anim');\n if (!bars?.length && !hbars?.length) return;\n\n const dur = 500;\n const start = performance.now();\n\n const tick = (now: number) => {\n const elapsed = now - start;\n\n bars?.forEach(rect => {\n const delay = Number(rect.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / dur));\n const p = this._easeOut(t);\n const targetH = Number(rect.dataset.h);\n const targetY = Number(rect.dataset.y);\n const baseY = targetY + targetH;\n const h = targetH * p;\n rect.setAttribute('height', String(h));\n rect.setAttribute('y', String(baseY - h));\n });\n\n hbars?.forEach(rect => {\n const delay = Number(rect.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / dur));\n const p = this._easeOut(t);\n const targetW = Number(rect.dataset.w);\n rect.setAttribute('width', String(targetW * p));\n });\n\n vals?.forEach(el => {\n const delay = Number(el.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / 200));\n el.setAttribute('opacity', String(t));\n });\n\n const maxDelay = Math.max(\n ...[...bars || []].map(r => Number(r.dataset.delay) || 0),\n ...[...hbars || []].map(r => Number(r.dataset.delay) || 0),\n ...[...vals || []].map(r => Number(r.dataset.delay) || 0),\n );\n if (elapsed < maxDelay + dur + 200) {\n this._animId = requestAnimationFrame(tick);\n }\n };\n\n this._animId = requestAnimationFrame(tick);\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n cancelAnimationFrame(this._animId);\n }\n\n private _color(i: number, d: ChartSeries) { return d.color || PALETTE[i % PALETTE.length]!; }\n\n private _fmt(v: number) {\n if (Math.abs(v) >= 1e6) return (v / 1e6).toFixed(1) + 'M';\n if (Math.abs(v) >= 1e3) return (v / 1e3).toFixed(1) + 'K';\n return v % 1 === 0 ? String(v) : v.toFixed(1);\n }\n\n private _tip(e: MouseEvent, label: string, value: number) {\n const r = (e.currentTarget as Element).closest('.svg-wrap')!.getBoundingClientRect();\n this._tipX = e.clientX - r.left;\n this._tipY = e.clientY - r.top;\n this._tipText = `${label}: ${this._fmt(value)}`;\n this._tipShow = true;\n }\n private _untip() { this._tipShow = false; }\n\n // ═══ BAR ═══\n private _bar() {\n const { data, height: H } = this;\n const W = 400, T = 20, R = 16, B = 28, L = 44;\n const pw = W - L - R, ph = H - T - B;\n const max = Math.max(...data.map(d => d.value), 1);\n const n = data.length;\n const bw = (pw / n) * 0.6;\n const step = pw / n;\n\n return svg`\n ${this.showGrid ? [0.25, 0.5, 0.75, 1].map(p => {\n const y = T + ph - ph * p;\n return svg`\n <line x1=\"${L}\" y1=\"${y}\" x2=\"${W - R}\" y2=\"${y}\" stroke=\"${this._grid}\" stroke-width=\"0.5\" stroke-dasharray=\"3,3\" />\n <text x=\"${L - 6}\" y=\"${y + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"10\">${this._fmt(max * p)}</text>\n `;\n }) : nothing}\n ${data.map((d, i) => {\n const bh = (d.value / max) * ph;\n const x = L + i * step + (step - bw) / 2;\n const yFinal = T + ph - bh;\n const yBase = T + ph;\n const c = this._color(i, d);\n return svg`\n <rect class=\"bar-anim\" x=\"${x}\" y=\"${yBase}\" width=\"${bw}\" height=\"0\" rx=\"4\" fill=\"${c}\" style=\"cursor:pointer\"\n data-y=\"${yFinal}\" data-h=\"${bh}\" data-delay=\"${i * 50}\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n ${this.showValues ? svg`<text class=\"val-anim\" x=\"${x + bw / 2}\" y=\"${yFinal - 6}\" text-anchor=\"middle\" fill=\"${this._text}\" font-size=\"10\" font-weight=\"600\" opacity=\"0\" data-delay=\"${i * 50 + 300}\">${this._fmt(d.value)}</text>` : nothing}\n <text x=\"${x + bw / 2}\" y=\"${H - 6}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"10\">${d.label}</text>\n `;\n })}\n `;\n }\n\n // ═══ HORIZONTAL BAR ═══\n private _hbar() {\n const { data } = this;\n const W = 400, lW = 72, gap = 8, bH = 28;\n const H = data.length * (bH + gap);\n const max = Math.max(...data.map(d => d.value), 1);\n\n return svg`\n ${data.map((d, i) => {\n const y = i * (bH + gap);\n const bW = (d.value / max) * (W - lW - 60);\n const c = this._color(i, d);\n return svg`\n <text x=\"${lW - 6}\" y=\"${y + bH / 2 + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"11\">${d.label}</text>\n <rect class=\"hbar-anim\" x=\"${lW}\" y=\"${y}\" width=\"0\" height=\"${bH}\" rx=\"4\" fill=\"${c}\" style=\"cursor:pointer\"\n data-w=\"${bW}\" data-delay=\"${i * 50}\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n <text class=\"val-anim\" x=\"${lW + bW + 8}\" y=\"${y + bH / 2 + 4}\" fill=\"${this._text}\" font-size=\"11\" font-weight=\"600\" opacity=\"0\" data-delay=\"${i * 50 + 300}\">${this._fmt(d.value)}</text>\n `;\n })}\n `;\n }\n\n // ═══ LINE / AREA ═══\n private _line(area: boolean) {\n const { data, height: H } = this;\n const W = 400, T = 12, R = 16, B = 28, L = 44;\n const pw = W - L - R, ph = H - T - B;\n const max = Math.max(...data.map(d => d.value), 1);\n const c = this._color(0, data[0]!);\n\n const pts = data.map((d, i) => ({\n x: L + (i / Math.max(data.length - 1, 1)) * pw,\n y: T + ph - (d.value / max) * ph,\n }));\n const line = pts.map((p, i) => `${i ? 'L' : 'M'}${p.x.toFixed(1)},${p.y.toFixed(1)}`).join(' ');\n const areaD = `${line} L${pts.at(-1)!.x.toFixed(1)},${(T + ph).toFixed(1)} L${pts[0]!.x.toFixed(1)},${(T + ph).toFixed(1)} Z`;\n\n return svg`\n ${this.showGrid ? [0.25, 0.5, 0.75, 1].map(p => {\n const y = T + ph - ph * p;\n return svg`\n <line x1=\"${L}\" y1=\"${y}\" x2=\"${W - R}\" y2=\"${y}\" stroke=\"${this._grid}\" stroke-width=\"0.5\" stroke-dasharray=\"3,3\" />\n <text x=\"${L - 6}\" y=\"${y + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"10\">${this._fmt(max * p)}</text>\n `;\n }) : nothing}\n ${area ? svg`<path d=\"${areaD}\" fill=\"${c}\" opacity=\"0.2\" />` : nothing}\n <path class=\"anim-line\" d=\"${line}\" fill=\"none\" stroke=\"${c}\" stroke-width=\"2.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" style=\"--dash:2000\" />\n ${pts.map((p, i) => svg`\n <circle class=\"anim-dot\" cx=\"${p.x}\" cy=\"${p.y}\" r=\"4\" fill=\"${c}\" stroke=\"${this._bg}\" stroke-width=\"2\" style=\"cursor:pointer; animation-delay:${400 + i * 50}ms\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, data[i]!.label, data[i]!.value)}\n @mouseleave=${this._untip} />\n `)}\n ${data.map((d, i) => svg`\n <text x=\"${pts[i]!.x}\" y=\"${H - 6}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"10\">${d.label}</text>\n `)}\n `;\n }\n\n // ═══ PIE / DONUT ═══\n private _pie(donut: boolean) {\n const { data } = this;\n const total = data.reduce((s, d) => s + d.value, 0) || 1;\n const sz = Math.min(this.height, 240);\n const r = sz * 0.4;\n const cx = sz / 2, cy = sz / 2;\n const rad = (a: number) => a * Math.PI / 180;\n let ang = -90;\n\n const slices = data.map((d, i) => {\n const sw = (d.value / total) * 360;\n const end = ang + sw;\n const lg = sw > 180 ? 1 : 0;\n const x1 = cx + r * Math.cos(rad(ang));\n const y1 = cy + r * Math.sin(rad(ang));\n const x2 = cx + r * Math.cos(rad(end));\n const y2 = cy + r * Math.sin(rad(end));\n const mid = ang + sw / 2;\n const lr = r * (donut ? 1.2 : 0.6);\n const lx = cx + lr * Math.cos(rad(mid));\n const ly = cy + lr * Math.sin(rad(mid));\n const pct = Math.round((d.value / total) * 100);\n const c = this._color(i, d);\n const p = `M${cx},${cy} L${x1.toFixed(1)},${y1.toFixed(1)} A${r},${r} 0 ${lg} 1 ${x2.toFixed(1)},${y2.toFixed(1)} Z`;\n ang = end;\n\n return svg`\n <path class=\"anim-slice\" d=\"${p}\" fill=\"${c}\" style=\"cursor:pointer; animation-delay:${i * 60}ms\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n ${pct >= 5 ? svg`<text x=\"${lx}\" y=\"${ly}\" text-anchor=\"middle\" dominant-baseline=\"central\" fill=\"${donut ? this._axis : this._text}\" font-size=\"10\" font-weight=\"600\">${pct}%</text>` : nothing}\n `;\n });\n\n return svg`\n ${slices}\n ${donut ? svg`\n <circle cx=\"${cx}\" cy=\"${cy}\" r=\"${r * 0.55}\" fill=\"${this._bg}\" />\n <text x=\"${cx}\" y=\"${cy - 4}\" text-anchor=\"middle\" fill=\"${this._text}\" font-size=\"16\" font-weight=\"700\">${this._fmt(total)}</text>\n <text x=\"${cx}\" y=\"${cy + 12}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"9\">Total</text>\n ` : nothing}\n `;\n }\n\n private _svgHeight() {\n if (this.type === 'horizontal-bar') return this.data.length * 36;\n if (this.type === 'pie' || this.type === 'donut') return Math.min(this.height, 240);\n return this.height;\n }\n\n private _svgWidth() {\n if (this.type === 'pie' || this.type === 'donut') return Math.min(this.height, 240);\n return 400;\n }\n\n override render() {\n if (!this.data.length) return html`<div class=\"wrap ${this.contained ? 'contained' : ''}\"><div class=\"empty\">${this.emptyText}</div></div>`;\n\n const vw = this._svgWidth();\n const vh = this._svgHeight();\n const isPie = this.type === 'pie' || this.type === 'donut';\n\n let chartSvg;\n switch (this.type) {\n case 'bar': chartSvg = this._bar(); break;\n case 'horizontal-bar': chartSvg = this._hbar(); break;\n case 'line': chartSvg = this._line(false); break;\n case 'area': chartSvg = this._line(true); break;\n case 'pie': chartSvg = this._pie(false); break;\n case 'donut': chartSvg = this._pie(true); break;\n }\n\n return html`\n <div class=\"wrap ${this.contained ? 'contained' : ''}\">\n ${this.title || this.subtitle ? html`\n <div class=\"header\">\n ${this.title ? html`<div class=\"title\">${this.title}</div>` : nothing}\n ${this.subtitle ? html`<div class=\"subtitle\">${this.subtitle}</div>` : nothing}\n </div>\n ` : nothing}\n\n <div class=\"svg-wrap\">\n <svg viewBox=\"0 0 ${vw} ${vh}\" style=\"${isPie ? `max-width:${vw}px; margin:0 auto;` : ''}\">\n ${chartSvg}\n </svg>\n <div class=\"tip ${this._tipShow ? 'show' : ''}\" style=\"left:${this._tipX}px;top:${this._tipY}px;\">\n ${this._tipText}\n </div>\n </div>\n\n ${this.showLegend ? html`\n <div class=\"legend\">\n ${this.data.map((d, i) => html`\n <span class=\"legend-item anim-legend\" style=\"animation-delay:${300 + i * 40}ms\">\n <span class=\"legend-dot\" style=\"background:${this._color(i, d)}\"></span>\n <span>${d.label}</span>\n <span class=\"legend-val\">${this._fmt(d.value)}</span>\n </span>\n `)}\n </div>\n ` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-chart': CgChart; }\n}\n"],"names":["PALETTE","CgChart","LitElement","s","i","v","changed","bars","hbars","vals","dur","start","tick","now","elapsed","rect","delay","t","p","targetH","baseY","h","targetW","el","maxDelay","r","d","e","label","value","data","H","W","T","R","B","L","pw","ph","max","n","bw","step","svg","nothing","bh","x","yFinal","yBase","c","lW","gap","bH","y","bW","area","pts","line","areaD","donut","total","sz","cx","cy","rad","a","ang","slices","sw","end","lg","x1","y1","x2","y2","mid","lr","lx","ly","pct","html","vw","vh","isPie","chartSvg","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cg-chart.js","sources":["../../../src/components/cg-chart/cg-chart.ts"],"sourcesContent":["import { LitElement, html, css, nothing, svg } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/** Data point for cg-chart */\nexport interface ChartSeries {\n label: string;\n value: number;\n color?: string;\n}\n\n/** Default palette — hex colors that work directly in SVG fill/stroke attributes */\nconst PALETTE = [\n '#dfff61', '#14b8a6', '#22c55e', '#f59e0b',\n '#f97316', '#ec4899', '#8b5cf6', '#ef4444',\n];\n\n@customElement('cg-chart')\nexport class CgChart extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host { display: block; }\n\n .wrap { position: relative; }\n .wrap.contained {\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-component-card-radius);\n padding: var(--cg-spacing-20);\n }\n\n .header { margin-bottom: var(--cg-spacing-12); }\n .title {\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 .subtitle {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n margin-top: var(--cg-spacing-2);\n }\n\n .svg-wrap { position: relative; }\n svg { display: block; width: 100%; }\n\n /* ── Entrance animations ── */\n @keyframes fadeIn {\n from { opacity: 0; }\n to { opacity: 1; }\n }\n @keyframes lineTrace {\n from { stroke-dashoffset: var(--dash); }\n to { stroke-dashoffset: 0; }\n }\n\n .anim-line {\n stroke-dasharray: var(--dash);\n stroke-dashoffset: var(--dash);\n animation: lineTrace 900ms var(--cg-transition-easing-ease-out) forwards;\n }\n .anim-dot {\n animation: fadeIn 200ms var(--cg-transition-easing-ease-out) both;\n }\n .anim-slice {\n animation: fadeIn 400ms var(--cg-transition-easing-ease-out) both;\n }\n .anim-legend {\n animation: fadeIn 200ms var(--cg-transition-easing-ease-out) both;\n }\n\n /* Tooltip */\n .tip {\n position: absolute;\n background: var(--cg-color-surface-container-background);\n color: var(--cg-color-surface-base-text);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n padding: var(--cg-spacing-4) var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-50);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-medium);\n pointer-events: none;\n white-space: nowrap;\n transform: translate(-50%, -100%);\n margin-top: calc(var(--cg-spacing-8) * -1);\n z-index: 10;\n display: none;\n }\n .tip.show { display: block; }\n\n /* Legend */\n .legend {\n display: flex; flex-wrap: wrap; gap: var(--cg-spacing-12);\n margin-top: var(--cg-spacing-16); padding-top: var(--cg-spacing-12);\n border-top: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n }\n .legend-item {\n display: inline-flex; align-items: center; gap: var(--cg-spacing-4);\n font-size: var(--cg-font-size-xs); color: var(--cg-color-input-text-placeholder);\n }\n .legend-dot {\n width: var(--cg-spacing-8); height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full); flex-shrink: 0;\n }\n .legend-val {\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-base-text);\n }\n\n .empty {\n display: flex; align-items: center; justify-content: center;\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-sm); min-height: 120px;\n }\n `];\n\n @property({ type: Array }) data: ChartSeries[] = [];\n @property() type: 'bar' | 'horizontal-bar' | 'line' | 'area' | 'pie' | 'donut' = 'bar';\n @property() override title = '';\n @property() subtitle = '';\n @property({ type: Number }) height = 200;\n @property({ type: Boolean }) showLegend = true;\n @property({ type: Boolean }) showValues = true;\n /** Wrap chart in a card container */\n @property({ type: Boolean }) contained = false;\n @property({ type: Boolean }) showGrid = true;\n @property() emptyText = 'No data';\n\n @state() private _tipX = 0;\n @state() private _tipY = 0;\n @state() private _tipText = '';\n @state() private _tipShow = false;\n\n // Resolved theme colors for SVG — pulled from CSS custom properties at runtime\n private _grid = '';\n private _axis = '';\n private _text = '';\n private _bg = '';\n private _resolved = false;\n\n private _resolve() {\n if (this._resolved) return;\n const s = getComputedStyle(this);\n this._grid = s.getPropertyValue('--cg-color-chart-grid').trim() || s.getPropertyValue('--cg-color-surface-cards-border').trim();\n this._axis = s.getPropertyValue('--cg-color-chart-axis').trim() || s.getPropertyValue('--cg-color-input-text-placeholder').trim();\n this._text = s.getPropertyValue('--cg-color-surface-base-text').trim() || s.getPropertyValue('--cg-color-surface-base-text').trim();\n this._bg = s.getPropertyValue('--cg-color-surface-container-background').trim() || s.getPropertyValue('--cg-color-surface-base-background').trim();\n for (let i = 0; i < 8; i++) {\n const v = s.getPropertyValue(`--cg-color-chart-${i + 1}`).trim();\n if (v) PALETTE[i] = v;\n }\n this._resolved = true;\n }\n\n override firstUpdated() {\n this._resolve();\n this.requestUpdate();\n }\n\n private _animId = 0;\n private _animated = false;\n\n override updated(changed: Map<string, unknown>) {\n if (!this._animated && this.data.length > 0) {\n this._animated = true;\n this._animateBars();\n }\n if (changed.has('data') || changed.has('type')) {\n this._animated = false;\n cancelAnimationFrame(this._animId);\n // Re-animate on next frame after render\n requestAnimationFrame(() => {\n this._animated = true;\n this._animateBars();\n });\n }\n }\n\n private _easeOut(t: number) { return 1 - (1 - t) * (1 - t); }\n\n private _animateBars() {\n const bars = this.shadowRoot?.querySelectorAll<SVGRectElement>('.bar-anim');\n const hbars = this.shadowRoot?.querySelectorAll<SVGRectElement>('.hbar-anim');\n const vals = this.shadowRoot?.querySelectorAll<SVGElement>('.val-anim');\n if (!bars?.length && !hbars?.length) return;\n\n const dur = 500;\n const start = performance.now();\n\n const tick = (now: number) => {\n const elapsed = now - start;\n\n bars?.forEach(rect => {\n const delay = Number(rect.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / dur));\n const p = this._easeOut(t);\n const targetH = Number(rect.dataset.h);\n const targetY = Number(rect.dataset.y);\n const baseY = targetY + targetH;\n const h = targetH * p;\n rect.setAttribute('height', String(h));\n rect.setAttribute('y', String(baseY - h));\n });\n\n hbars?.forEach(rect => {\n const delay = Number(rect.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / dur));\n const p = this._easeOut(t);\n const targetW = Number(rect.dataset.w);\n rect.setAttribute('width', String(targetW * p));\n });\n\n vals?.forEach(el => {\n const delay = Number(el.dataset.delay) || 0;\n const t = Math.min(1, Math.max(0, (elapsed - delay) / 200));\n el.setAttribute('opacity', String(t));\n });\n\n const maxDelay = Math.max(\n ...[...bars || []].map(r => Number(r.dataset.delay) || 0),\n ...[...hbars || []].map(r => Number(r.dataset.delay) || 0),\n ...[...vals || []].map(r => Number(r.dataset.delay) || 0),\n );\n if (elapsed < maxDelay + dur + 200) {\n this._animId = requestAnimationFrame(tick);\n }\n };\n\n this._animId = requestAnimationFrame(tick);\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n cancelAnimationFrame(this._animId);\n }\n\n private _color(i: number, d: ChartSeries) { return d.color || PALETTE[i % PALETTE.length]!; }\n\n private _fmt(v: number) {\n if (Math.abs(v) >= 1e6) return (v / 1e6).toFixed(1) + 'M';\n if (Math.abs(v) >= 1e3) return (v / 1e3).toFixed(1) + 'K';\n return v % 1 === 0 ? String(v) : v.toFixed(1);\n }\n\n private _tip(e: MouseEvent, label: string, value: number) {\n const r = (e.currentTarget as Element).closest('.svg-wrap')!.getBoundingClientRect();\n this._tipX = e.clientX - r.left;\n this._tipY = e.clientY - r.top;\n this._tipText = `${label}: ${this._fmt(value)}`;\n this._tipShow = true;\n }\n private _untip() { this._tipShow = false; }\n\n // ═══ BAR ═══\n private _bar() {\n const { data, height: H } = this;\n const W = 400, T = 20, R = 16, B = 28, L = 44;\n const pw = W - L - R, ph = H - T - B;\n const max = Math.max(...data.map(d => d.value), 1);\n const n = data.length;\n const bw = (pw / n) * 0.6;\n const step = pw / n;\n\n return svg`\n ${this.showGrid ? [0.25, 0.5, 0.75, 1].map(p => {\n const y = T + ph - ph * p;\n return svg`\n <line x1=\"${L}\" y1=\"${y}\" x2=\"${W - R}\" y2=\"${y}\" stroke=\"${this._grid}\" stroke-width=\"0.5\" stroke-dasharray=\"3,3\" />\n <text x=\"${L - 6}\" y=\"${y + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"10\">${this._fmt(max * p)}</text>\n `;\n }) : nothing}\n ${data.map((d, i) => {\n const bh = (d.value / max) * ph;\n const x = L + i * step + (step - bw) / 2;\n const yFinal = T + ph - bh;\n const yBase = T + ph;\n const c = this._color(i, d);\n return svg`\n <rect class=\"bar-anim\" x=\"${x}\" y=\"${yBase}\" width=\"${bw}\" height=\"0\" rx=\"4\" fill=\"${c}\" style=\"cursor:pointer\"\n data-y=\"${yFinal}\" data-h=\"${bh}\" data-delay=\"${i * 50}\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n ${this.showValues ? svg`<text class=\"val-anim\" x=\"${x + bw / 2}\" y=\"${yFinal - 6}\" text-anchor=\"middle\" fill=\"${this._text}\" font-size=\"10\" font-weight=\"600\" opacity=\"0\" data-delay=\"${i * 50 + 300}\">${this._fmt(d.value)}</text>` : nothing}\n <text x=\"${x + bw / 2}\" y=\"${H - 6}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"10\">${d.label}</text>\n `;\n })}\n `;\n }\n\n // ═══ HORIZONTAL BAR ═══\n private _hbar() {\n const { data } = this;\n const W = 400, lW = 72, gap = 8, bH = 28;\n const H = data.length * (bH + gap);\n const max = Math.max(...data.map(d => d.value), 1);\n\n return svg`\n ${data.map((d, i) => {\n const y = i * (bH + gap);\n const bW = (d.value / max) * (W - lW - 60);\n const c = this._color(i, d);\n return svg`\n <text x=\"${lW - 6}\" y=\"${y + bH / 2 + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"11\">${d.label}</text>\n <rect class=\"hbar-anim\" x=\"${lW}\" y=\"${y}\" width=\"0\" height=\"${bH}\" rx=\"4\" fill=\"${c}\" style=\"cursor:pointer\"\n data-w=\"${bW}\" data-delay=\"${i * 50}\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n <text class=\"val-anim\" x=\"${lW + bW + 8}\" y=\"${y + bH / 2 + 4}\" fill=\"${this._text}\" font-size=\"11\" font-weight=\"600\" opacity=\"0\" data-delay=\"${i * 50 + 300}\">${this._fmt(d.value)}</text>\n `;\n })}\n `;\n }\n\n // ═══ LINE / AREA ═══\n private _line(area: boolean) {\n const { data, height: H } = this;\n const W = 400, T = 12, R = 16, B = 28, L = 44;\n const pw = W - L - R, ph = H - T - B;\n const max = Math.max(...data.map(d => d.value), 1);\n const c = this._color(0, data[0]!);\n\n const pts = data.map((d, i) => ({\n x: L + (i / Math.max(data.length - 1, 1)) * pw,\n y: T + ph - (d.value / max) * ph,\n }));\n const line = pts.map((p, i) => `${i ? 'L' : 'M'}${p.x.toFixed(1)},${p.y.toFixed(1)}`).join(' ');\n const areaD = `${line} L${pts.at(-1)!.x.toFixed(1)},${(T + ph).toFixed(1)} L${pts[0]!.x.toFixed(1)},${(T + ph).toFixed(1)} Z`;\n\n return svg`\n ${this.showGrid ? [0.25, 0.5, 0.75, 1].map(p => {\n const y = T + ph - ph * p;\n return svg`\n <line x1=\"${L}\" y1=\"${y}\" x2=\"${W - R}\" y2=\"${y}\" stroke=\"${this._grid}\" stroke-width=\"0.5\" stroke-dasharray=\"3,3\" />\n <text x=\"${L - 6}\" y=\"${y + 4}\" text-anchor=\"end\" fill=\"${this._axis}\" font-size=\"10\">${this._fmt(max * p)}</text>\n `;\n }) : nothing}\n ${area ? svg`<path d=\"${areaD}\" fill=\"${c}\" opacity=\"0.2\" />` : nothing}\n <path class=\"anim-line\" d=\"${line}\" fill=\"none\" stroke=\"${c}\" stroke-width=\"2.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" style=\"--dash:2000\" />\n ${pts.map((p, i) => svg`\n <circle class=\"anim-dot\" cx=\"${p.x}\" cy=\"${p.y}\" r=\"4\" fill=\"${c}\" stroke=\"${this._bg}\" stroke-width=\"2\" style=\"cursor:pointer; animation-delay:${400 + i * 50}ms\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, data[i]!.label, data[i]!.value)}\n @mouseleave=${this._untip} />\n `)}\n ${data.map((d, i) => svg`\n <text x=\"${pts[i]!.x}\" y=\"${H - 6}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"10\">${d.label}</text>\n `)}\n `;\n }\n\n // ═══ PIE / DONUT ═══\n private _pie(donut: boolean) {\n const { data } = this;\n const total = data.reduce((s, d) => s + d.value, 0) || 1;\n const sz = Math.min(this.height, 240);\n const r = sz * 0.4;\n const cx = sz / 2, cy = sz / 2;\n const rad = (a: number) => a * Math.PI / 180;\n let ang = -90;\n\n const slices = data.map((d, i) => {\n const sw = (d.value / total) * 360;\n const end = ang + sw;\n const lg = sw > 180 ? 1 : 0;\n const x1 = cx + r * Math.cos(rad(ang));\n const y1 = cy + r * Math.sin(rad(ang));\n const x2 = cx + r * Math.cos(rad(end));\n const y2 = cy + r * Math.sin(rad(end));\n const mid = ang + sw / 2;\n const lr = r * (donut ? 1.2 : 0.6);\n const lx = cx + lr * Math.cos(rad(mid));\n const ly = cy + lr * Math.sin(rad(mid));\n const pct = Math.round((d.value / total) * 100);\n const c = this._color(i, d);\n const p = `M${cx},${cy} L${x1.toFixed(1)},${y1.toFixed(1)} A${r},${r} 0 ${lg} 1 ${x2.toFixed(1)},${y2.toFixed(1)} Z`;\n ang = end;\n\n return svg`\n <path class=\"anim-slice\" d=\"${p}\" fill=\"${c}\" style=\"cursor:pointer; animation-delay:${i * 60}ms\"\n @mouseenter=${(e: MouseEvent) => this._tip(e, d.label, d.value)}\n @mouseleave=${this._untip} />\n ${pct >= 5 ? svg`<text x=\"${lx}\" y=\"${ly}\" text-anchor=\"middle\" dominant-baseline=\"central\" fill=\"${donut ? this._axis : this._text}\" font-size=\"10\" font-weight=\"600\">${pct}%</text>` : nothing}\n `;\n });\n\n return svg`\n ${slices}\n ${donut ? svg`\n <circle cx=\"${cx}\" cy=\"${cy}\" r=\"${r * 0.55}\" fill=\"${this._bg}\" />\n <text x=\"${cx}\" y=\"${cy - 4}\" text-anchor=\"middle\" fill=\"${this._text}\" font-size=\"16\" font-weight=\"700\">${this._fmt(total)}</text>\n <text x=\"${cx}\" y=\"${cy + 12}\" text-anchor=\"middle\" fill=\"${this._axis}\" font-size=\"9\">Total</text>\n ` : nothing}\n `;\n }\n\n private _svgHeight() {\n if (this.type === 'horizontal-bar') return this.data.length * 36;\n if (this.type === 'pie' || this.type === 'donut') return Math.min(this.height, 240);\n return this.height;\n }\n\n private _svgWidth() {\n if (this.type === 'pie' || this.type === 'donut') return Math.min(this.height, 240);\n return 400;\n }\n\n override render() {\n if (!this.data.length) return html`<div class=\"wrap ${this.contained ? 'contained' : ''}\"><div class=\"empty\">${this.emptyText}</div></div>`;\n\n const vw = this._svgWidth();\n const vh = this._svgHeight();\n const isPie = this.type === 'pie' || this.type === 'donut';\n\n let chartSvg;\n switch (this.type) {\n case 'bar': chartSvg = this._bar(); break;\n case 'horizontal-bar': chartSvg = this._hbar(); break;\n case 'line': chartSvg = this._line(false); break;\n case 'area': chartSvg = this._line(true); break;\n case 'pie': chartSvg = this._pie(false); break;\n case 'donut': chartSvg = this._pie(true); break;\n }\n\n return html`\n <div class=\"wrap ${this.contained ? 'contained' : ''}\">\n ${this.title || this.subtitle ? html`\n <div class=\"header\">\n ${this.title ? html`<div class=\"title\">${this.title}</div>` : nothing}\n ${this.subtitle ? html`<div class=\"subtitle\">${this.subtitle}</div>` : nothing}\n </div>\n ` : nothing}\n\n <div class=\"svg-wrap\">\n <svg\n role=\"img\"\n aria-label=${`${this.title || 'Chart'}: ${this.data.map((d) => `${d.label} ${this._fmt(d.value)}`).join(', ')}`}\n viewBox=\"0 0 ${vw} ${vh}\"\n style=\"${isPie ? `max-width:${vw}px; margin:0 auto;` : ''}\"\n >\n ${chartSvg}\n </svg>\n <div class=\"tip ${this._tipShow ? 'show' : ''}\" style=\"left:${this._tipX}px;top:${this._tipY}px;\">\n ${this._tipText}\n </div>\n </div>\n\n ${this.showLegend ? html`\n <div class=\"legend\">\n ${this.data.map((d, i) => html`\n <span class=\"legend-item anim-legend\" style=\"animation-delay:${300 + i * 40}ms\">\n <span class=\"legend-dot\" style=\"background:${this._color(i, d)}\"></span>\n <span>${d.label}</span>\n <span class=\"legend-val\">${this._fmt(d.value)}</span>\n </span>\n `)}\n </div>\n ` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-chart': CgChart; }\n}\n"],"names":["PALETTE","CgChart","LitElement","s","i","v","changed","bars","hbars","vals","dur","start","tick","now","elapsed","rect","delay","t","p","targetH","baseY","h","targetW","el","maxDelay","r","d","e","label","value","data","H","W","T","R","B","L","pw","ph","max","n","bw","step","svg","nothing","bh","x","yFinal","yBase","c","lW","gap","bH","y","bW","area","pts","line","areaD","donut","total","sz","cx","cy","rad","a","ang","slices","sw","end","lg","x1","y1","x2","y2","mid","lr","lx","ly","pct","html","vw","vh","isPie","chartSvg","hostBlock","reducedMotion","css","__decorateClass","property","state","customElement"],"mappings":"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"}
|
|
@@ -2,8 +2,6 @@ import { LitElement, PropertyValues } from 'lit';
|
|
|
2
2
|
/**
|
|
3
3
|
* @element cg-checkbox
|
|
4
4
|
* Checkbox with animated tick draw, spring bounce, and indeterminate state.
|
|
5
|
-
* Supports rich label content via the default slot — links and other
|
|
6
|
-
* interactive elements inside the label do not toggle the checkbox.
|
|
7
5
|
*
|
|
8
6
|
* @example
|
|
9
7
|
* ```html
|
|
@@ -11,12 +9,8 @@ import { LitElement, PropertyValues } from 'lit';
|
|
|
11
9
|
* <cg-checkbox checked label="Notifications"></cg-checkbox>
|
|
12
10
|
* <cg-checkbox indeterminate label="Select all"></cg-checkbox>
|
|
13
11
|
* <cg-checkbox rounded="full" checked label="Round checkbox"></cg-checkbox>
|
|
14
|
-
* <cg-checkbox>I agree to the <a href="/terms">terms</a></cg-checkbox>
|
|
15
12
|
* ```
|
|
16
13
|
*
|
|
17
|
-
* @slot - Default slot for label content (overrides `label` prop)
|
|
18
|
-
* @slot description - Description content (overrides `description` prop)
|
|
19
|
-
*
|
|
20
14
|
* @fires {CustomEvent<{checked: boolean, value: string}>} cg-change - When toggled
|
|
21
15
|
*/
|
|
22
16
|
export declare class CgCheckbox extends LitElement {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-checkbox.d.ts","sourceRoot":"","sources":["../../../src/components/cg-checkbox/cg-checkbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E
|
|
1
|
+
{"version":3,"file":"cg-checkbox.d.ts","sourceRoot":"","sources":["../../../src/components/cg-checkbox/cg-checkbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E;;;;;;;;;;;;;GAaG;AACH,qBACa,UAAW,SAAQ,UAAU;IACxC,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,4BAiLnB;IAES,KAAK,SAAM;IACX,WAAW,SAAM;IACjB,IAAI,SAAM;IACV,KAAK,SAAM;IACM,OAAO,UAAS;IAChB,aAAa,UAAS;IACP,QAAQ,UAAS;IACjB,KAAK,UAAS;IACd,OAAO,UAAS;IAChB,OAAO,UAAS;IAC/B,QAAQ,UAAS;IACjB,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAQ;IAEzE,OAAO,CAAC,OAAO,EAAE,cAAc;IAcxC,iBAAiB;IAIjB,wBAAwB,CAAC,KAAK,EAAE,MAAM;IAItC,OAAO,CAAC,OAAO;IAWN,MAAM;CA0ChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,aAAa,EAAE,UAAU,CAAC;KAAE;CAC/D"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { css as u, LitElement as g,
|
|
2
|
-
import { property as
|
|
3
|
-
import { h as p, r as f } from "../../chunks/premium.css-
|
|
4
|
-
var v = Object.defineProperty, k = Object.getOwnPropertyDescriptor,
|
|
5
|
-
for (var s =
|
|
6
|
-
(
|
|
7
|
-
return
|
|
1
|
+
import { css as u, LitElement as g, nothing as n, html as i } from "lit";
|
|
2
|
+
import { property as o, customElement as b } from "lit/decorators.js";
|
|
3
|
+
import { h as p, r as f } from "../../chunks/premium.css-DHekUEUt.js";
|
|
4
|
+
var v = Object.defineProperty, k = Object.getOwnPropertyDescriptor, t = (r, a, d, c) => {
|
|
5
|
+
for (var s = c > 1 ? void 0 : c ? k(a, d) : a, l = r.length - 1, h; l >= 0; l--)
|
|
6
|
+
(h = r[l]) && (s = (c ? h(a, d, s) : h(s)) || s);
|
|
7
|
+
return c && s && v(a, d, s), s;
|
|
8
8
|
};
|
|
9
9
|
let e = class extends g {
|
|
10
10
|
constructor() {
|
|
@@ -20,11 +20,7 @@ let e = class extends g {
|
|
|
20
20
|
this.checked = r === (this.value || "on");
|
|
21
21
|
}
|
|
22
22
|
_toggle(r) {
|
|
23
|
-
|
|
24
|
-
const t = r.target;
|
|
25
|
-
t && t !== this && t.closest(
|
|
26
|
-
'a, button, [role="button"], [role="link"], input:not([type="checkbox"]), select, textarea'
|
|
27
|
-
) || (this.checked = !this.checked, this.indeterminate = !1, this.dispatchEvent(new CustomEvent("cg-change", {
|
|
23
|
+
r.preventDefault(), !(this.disabled || this.loading) && (this.checked = !this.checked, this.indeterminate = !1, this.dispatchEvent(new CustomEvent("cg-change", {
|
|
28
24
|
detail: { checked: this.checked, value: this.value },
|
|
29
25
|
bubbles: !0,
|
|
30
26
|
composed: !0
|
|
@@ -42,32 +38,34 @@ let e = class extends g {
|
|
|
42
38
|
aria-invalid=${this.error ? "true" : "false"}
|
|
43
39
|
aria-busy=${this.loading ? "true" : "false"}
|
|
44
40
|
@click=${this._toggle}
|
|
45
|
-
@keydown=${(
|
|
46
|
-
(
|
|
41
|
+
@keydown=${(a) => {
|
|
42
|
+
(a.key === " " || a.key === "Enter") && (a.preventDefault(), this._toggle(a));
|
|
47
43
|
}}
|
|
48
44
|
>
|
|
49
45
|
<input type="checkbox" .checked=${this.checked} .indeterminate=${this.indeterminate}
|
|
50
46
|
?disabled=${this.disabled} name=${this.name} value=${this.value}
|
|
51
47
|
tabindex="-1" aria-hidden="true"
|
|
52
|
-
@click=${(
|
|
48
|
+
@click=${(a) => a.stopPropagation()} />
|
|
53
49
|
|
|
54
50
|
${this.loading ? i`<span class="loading-spinner" aria-hidden="true"></span>` : i`<span class="box ${r}">
|
|
55
51
|
${this.checked ? i`
|
|
56
52
|
<svg class="check-icon" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="3" stroke-linecap="round" stroke-linejoin="round">
|
|
57
53
|
<path class="tick" d="M4 12L9 17L20 6"></path>
|
|
58
54
|
</svg>
|
|
59
|
-
` :
|
|
55
|
+
` : n}
|
|
60
56
|
${this.indeterminate ? i`
|
|
61
57
|
<svg class="check-icon" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="3" stroke-linecap="round">
|
|
62
58
|
<path class="dash" d="M5 12h14"></path>
|
|
63
59
|
</svg>
|
|
64
|
-
` :
|
|
60
|
+
` : n}
|
|
65
61
|
</span>`}
|
|
66
62
|
|
|
67
|
-
|
|
68
|
-
<span class="
|
|
69
|
-
|
|
70
|
-
|
|
63
|
+
${this.label ? i`
|
|
64
|
+
<span class="text-group">
|
|
65
|
+
<span class="label-text">${this.label}</span>
|
|
66
|
+
${this.description ? i`<span class="description">${this.description}</span>` : n}
|
|
67
|
+
</span>
|
|
68
|
+
` : n}
|
|
71
69
|
</label>
|
|
72
70
|
`;
|
|
73
71
|
}
|
|
@@ -119,9 +117,10 @@ e.styles = [p, f, u`
|
|
|
119
117
|
:host([rounded="lg"]) .box { border-radius: var(--cg-border-radius-150); }
|
|
120
118
|
:host([rounded="full"]) .box { border-radius: var(--cg-border-radius-full); }
|
|
121
119
|
|
|
122
|
-
/* Hover
|
|
123
|
-
|
|
124
|
-
|
|
120
|
+
/* Hover — scoped so it doesn't override the error/success border, and
|
|
121
|
+
uses the accent BORDER token (not a -background- fill) for the edge. */
|
|
122
|
+
:host(:not([disabled]):not([error]):not([success])) label:hover .box {
|
|
123
|
+
border-color: var(--cg-color-checkbox-border-checked);
|
|
125
124
|
}
|
|
126
125
|
|
|
127
126
|
/* Pressed */
|
|
@@ -132,7 +131,7 @@ e.styles = [p, f, u`
|
|
|
132
131
|
/* Focus ring */
|
|
133
132
|
label:focus-visible .box {
|
|
134
133
|
border-color: var(--cg-color-checkbox-border-focus);
|
|
135
|
-
box-shadow: 0 0 0
|
|
134
|
+
box-shadow: 0 0 0 var(--cg-border-width-100) var(--cg-color-focus-ring-offset), 0 0 0 calc(var(--cg-border-width-100) * 2) var(--cg-color-focus-ring);
|
|
136
135
|
}
|
|
137
136
|
|
|
138
137
|
/* ── Checked state ── */
|
|
@@ -142,10 +141,11 @@ e.styles = [p, f, u`
|
|
|
142
141
|
animation: boxPop var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);
|
|
143
142
|
}
|
|
144
143
|
|
|
145
|
-
/* Indeterminate */
|
|
144
|
+
/* Indeterminate — same spring entry as checked for consistent feedback. */
|
|
146
145
|
.box.indeterminate {
|
|
147
146
|
background: var(--cg-color-checkbox-background-checked);
|
|
148
147
|
border-color: var(--cg-color-checkbox-border-checked);
|
|
148
|
+
animation: boxPop var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out);
|
|
149
149
|
}
|
|
150
150
|
|
|
151
151
|
/* ── Animated tick — stroke reveal ── */
|
|
@@ -249,43 +249,43 @@ e.styles = [p, f, u`
|
|
|
249
249
|
line-height: var(--cg-line-height-snug);
|
|
250
250
|
}
|
|
251
251
|
`];
|
|
252
|
-
|
|
253
|
-
|
|
252
|
+
t([
|
|
253
|
+
o()
|
|
254
254
|
], e.prototype, "label", 2);
|
|
255
|
-
|
|
256
|
-
|
|
255
|
+
t([
|
|
256
|
+
o()
|
|
257
257
|
], e.prototype, "description", 2);
|
|
258
|
-
|
|
259
|
-
|
|
258
|
+
t([
|
|
259
|
+
o()
|
|
260
260
|
], e.prototype, "name", 2);
|
|
261
|
-
|
|
262
|
-
|
|
261
|
+
t([
|
|
262
|
+
o()
|
|
263
263
|
], e.prototype, "value", 2);
|
|
264
|
-
|
|
265
|
-
|
|
264
|
+
t([
|
|
265
|
+
o({ type: Boolean })
|
|
266
266
|
], e.prototype, "checked", 2);
|
|
267
|
-
|
|
268
|
-
|
|
267
|
+
t([
|
|
268
|
+
o({ type: Boolean })
|
|
269
269
|
], e.prototype, "indeterminate", 2);
|
|
270
|
-
|
|
271
|
-
|
|
270
|
+
t([
|
|
271
|
+
o({ type: Boolean, reflect: !0 })
|
|
272
272
|
], e.prototype, "disabled", 2);
|
|
273
|
-
|
|
274
|
-
|
|
273
|
+
t([
|
|
274
|
+
o({ type: Boolean, reflect: !0 })
|
|
275
275
|
], e.prototype, "error", 2);
|
|
276
|
-
|
|
277
|
-
|
|
276
|
+
t([
|
|
277
|
+
o({ type: Boolean, reflect: !0 })
|
|
278
278
|
], e.prototype, "success", 2);
|
|
279
|
-
|
|
280
|
-
|
|
279
|
+
t([
|
|
280
|
+
o({ type: Boolean, reflect: !0 })
|
|
281
281
|
], e.prototype, "loading", 2);
|
|
282
|
-
|
|
283
|
-
|
|
282
|
+
t([
|
|
283
|
+
o({ type: Boolean })
|
|
284
284
|
], e.prototype, "required", 2);
|
|
285
|
-
|
|
286
|
-
|
|
285
|
+
t([
|
|
286
|
+
o({ reflect: !0 })
|
|
287
287
|
], e.prototype, "rounded", 2);
|
|
288
|
-
e =
|
|
288
|
+
e = t([
|
|
289
289
|
b("cg-checkbox")
|
|
290
290
|
], e);
|
|
291
291
|
export {
|