@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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-progress-bar.js","sources":["../../../src/components/cg-progress-bar/cg-progress-bar.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/**\n * <cg-progress-bar> — Linear progress bar with label, buffer, and custom formatting.\n *\n * @example\n * ```html\n * <cg-progress-bar value=\"68\" label=\"Upload\" showValue></cg-progress-bar>\n * <cg-progress-bar value=\"45\" label=\"Storage\" formatValue=\"45 MB / 100 MB\"></cg-progress-bar>\n * <cg-progress-bar value=\"80\" buffer=\"95\" label=\"Video\" showValue></cg-progress-bar>\n * <cg-progress-bar indeterminate label=\"Processing...\"></cg-progress-bar>\n * ```\n *\n * @cssprop --cg-component-progress-radius - Track border radius\n * @cssprop --cg-component-progress-height-sm - Track height sm (4px)\n * @cssprop --cg-component-progress-height-md - Track height md (8px)\n * @cssprop --cg-component-progress-height-lg - Track height lg (12px)\n */\n@customElement('cg-progress-bar')\nexport class CgProgressBar extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n width: 100%;\n }\n\n .header {\n display: flex;\n align-items: baseline;\n justify-content: space-between;\n margin-bottom: var(--cg-spacing-6);\n }\n\n .header-left {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-2);\n }\n\n .label {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-container-text);\n line-height: var(--cg-line-height-snug);\n }\n\n .description {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-outlined);\n line-height: var(--cg-line-height-snug);\n }\n\n .value-text {\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-container-text);\n font-variant-numeric: tabular-nums;\n white-space: nowrap;\n }\n\n /* ── Track ── */\n .track {\n width: 100%;\n background: var(--cg-color-loading-spinner-secondary);\n border-radius: var(--cg-component-progress-radius);\n overflow: hidden;\n position: relative;\n }\n\n /* Sizes */\n :host([size=\"sm\"]) .track { height: var(--cg-component-progress-height-sm); }\n :host([size=\"md\"]) .track { height: var(--cg-component-progress-height-md); }\n :host([size=\"lg\"]) .track { height: var(--cg-component-progress-height-lg); }\n\n /* ── Buffer bar (behind fill) ── */\n .buffer {\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n border-radius: var(--cg-component-progress-radius);\n background: var(--cg-color-loading-spinner-primary);\n opacity: 0.25;\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n\n /* ── Fill bar ── */\n .fill {\n height: 100%;\n border-radius: var(--cg-component-progress-radius);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n position: relative;\n overflow: hidden;\n }\n\n /* ── Variant colors ── */\n :host([variant=\"default\"]) .fill {\n background: var(--cg-color-loading-spinner-primary);\n }\n :host([variant=\"success\"]) .fill {\n background: var(--cg-color-status-success-text-default);\n }\n :host([variant=\"warning\"]) .fill {\n background: var(--cg-color-status-warning-text-default);\n }\n :host([variant=\"danger\"]) .fill {\n background: var(--cg-color-status-error-text-default);\n }\n\n /* ── Striped pattern ── */\n :host([striped]) .fill::after {\n content: '';\n position: absolute;\n inset: 0;\n background-image: linear-gradient(\n 45deg,\n var(--cg-overlay-white-strong) 25%,\n transparent 25%,\n transparent 50%,\n var(--cg-overlay-white-strong) 50%,\n var(--cg-overlay-white-strong) 75%,\n transparent 75%,\n transparent\n );\n background-size: 20px 20px;\n }\n\n /* ── Animated stripes ── */\n :host([animated]) .fill::after {\n animation: stripe-move 1s linear infinite;\n }\n\n @keyframes stripe-move {\n from { background-position: 0 0; }\n to { background-position: 20px 0; }\n }\n\n /* ── Indeterminate ── */\n :host([indeterminate]) .fill {\n width: 40% !important;\n animation: indeterminate-slide 1.5s var(--cg-transition-easing-ease-in-out) infinite;\n }\n\n @keyframes indeterminate-slide {\n 0% { transform: translateX(-100%); }\n 50% { transform: translateX(150%); }\n 100% { transform: translateX(-100%); }\n }\n\n @keyframes indeterminate-pulse {\n 0%, 100% { opacity: 0.4; }\n 50% { opacity: 1; }\n }\n\n /* ── Min/Max labels ── */\n .range-labels {\n display: flex;\n justify-content: space-between;\n margin-top: var(--cg-spacing-4);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-outlined);\n font-variant-numeric: tabular-nums;\n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .fill::before {\n animation: none !important;\n background: none !important;\n }\n :host([animated]) .fill::after {\n animation: none !important;\n }\n :host([indeterminate]) .fill {\n animation: indeterminate-pulse 2s ease-in-out infinite !important;\n animation-duration: 2s !important;\n transform: none !important;\n width: 100% !important;\n }\n }\n `];\n\n /** Progress value 0–100 */\n @property({ type: Number }) value = 0;\n\n /** Label text above the bar */\n @property({ type: String }) label = '';\n\n /** Description text below the label */\n @property({ type: String }) description = '';\n\n /** Show percentage value */\n @property({ type: Boolean }) showValue = false;\n\n /** Custom formatted value text (e.g. \"45 MB / 100 MB\") — overrides percentage */\n @property({ type: String }) formatValue = '';\n\n /** Buffer value 0–100 (secondary fill, e.g. video buffering) */\n @property({ type: Number }) buffer = 0;\n\n /** Min label shown under the track */\n @property({ type: String }) minLabel = '';\n\n /** Max label shown under the track */\n @property({ type: String }) maxLabel = '';\n\n @property({ type: String, reflect: true }) variant: 'default' | 'success' | 'warning' | 'danger' = 'default';\n @property({ type: Boolean, reflect: true }) indeterminate = false;\n @property({ type: String, reflect: true }) size: 'sm' | 'md' | 'lg' = 'md';\n @property({ type: Boolean, reflect: true }) striped = false;\n @property({ type: Boolean, reflect: true }) animated = false;\n\n private get _clampedValue(): number {\n return Math.max(0, Math.min(100, this.value));\n }\n\n private get _clampedBuffer(): number {\n return Math.max(0, Math.min(100, this.buffer));\n }\n\n private get _displayValue(): string {\n if (this.formatValue) return this.formatValue;\n return `${this._clampedValue}%`;\n }\n\n override render() {\n const showHeader = this.label || this.description || ((this.showValue || this.formatValue) && !this.indeterminate);\n const showRangeLabels = this.minLabel || this.maxLabel;\n const hasBuffer = this.buffer > 0 && !this.indeterminate;\n\n return html`\n ${showHeader ? html`\n <div class=\"header\">\n <div class=\"header-left\">\n ${this.label ? html`<span class=\"label\">${this.label}</span>` : nothing}\n ${this.description ? html`<span class=\"description\">${this.description}</span>` : nothing}\n </div>\n ${(this.showValue || this.formatValue) && !this.indeterminate ? html`\n <span class=\"value-text\">${this._displayValue}</span>\n ` : nothing}\n </div>\n ` : nothing}\n <div\n class=\"track\"\n role=\"progressbar\"\n aria-valuenow=\"${this.indeterminate ? nothing : this._clampedValue}\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n aria-label=\"${this.label || 'Progress'}\"\n aria-busy=\"${this.indeterminate}\"\n >\n ${hasBuffer ? html`\n <div class=\"buffer\" style=\"width: ${this._clampedBuffer}%\"></div>\n ` : nothing}\n <div\n class=\"fill\"\n style=\"${this.indeterminate ? '' : `width: ${this._clampedValue}%`}\"\n ></div>\n </div>\n ${showRangeLabels ? html`\n <div class=\"range-labels\">\n <span>${this.minLabel}</span>\n <span>${this.maxLabel}</span>\n </div>\n ` : nothing}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-progress-bar': CgProgressBar;\n }\n}\n"],"names":["CgProgressBar","LitElement","showHeader","showRangeLabels","hasBuffer","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cg-progress-bar.js","sources":["../../../src/components/cg-progress-bar/cg-progress-bar.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/**\n * <cg-progress-bar> — Linear progress bar with label, buffer, and custom formatting.\n *\n * @example\n * ```html\n * <cg-progress-bar value=\"68\" label=\"Upload\" showValue></cg-progress-bar>\n * <cg-progress-bar value=\"45\" label=\"Storage\" formatValue=\"45 MB / 100 MB\"></cg-progress-bar>\n * <cg-progress-bar value=\"80\" buffer=\"95\" label=\"Video\" showValue></cg-progress-bar>\n * <cg-progress-bar indeterminate label=\"Processing...\"></cg-progress-bar>\n * ```\n *\n * @cssprop --cg-component-progress-radius - Track border radius\n * @cssprop --cg-component-progress-height-sm - Track height sm (4px)\n * @cssprop --cg-component-progress-height-md - Track height md (8px)\n * @cssprop --cg-component-progress-height-lg - Track height lg (12px)\n */\n@customElement('cg-progress-bar')\nexport class CgProgressBar extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n width: 100%;\n }\n\n .header {\n display: flex;\n align-items: baseline;\n justify-content: space-between;\n margin-bottom: var(--cg-spacing-6);\n }\n\n .header-left {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-2);\n }\n\n .label {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-container-text);\n line-height: var(--cg-line-height-snug);\n }\n\n .description {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-outlined);\n line-height: var(--cg-line-height-snug);\n }\n\n .value-text {\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n color: var(--cg-color-surface-container-text);\n font-variant-numeric: tabular-nums;\n white-space: nowrap;\n }\n\n /* ── Track ── */\n .track {\n width: 100%;\n background: var(--cg-color-loading-spinner-secondary);\n border-radius: var(--cg-component-progress-radius);\n overflow: hidden;\n position: relative;\n }\n\n /* Sizes */\n :host([size=\"sm\"]) .track { height: var(--cg-component-progress-height-sm); }\n :host([size=\"md\"]) .track { height: var(--cg-component-progress-height-md); }\n :host([size=\"lg\"]) .track { height: var(--cg-component-progress-height-lg); }\n\n /* ── Buffer bar (behind fill) ── */\n .buffer {\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n border-radius: var(--cg-component-progress-radius);\n background: var(--cg-color-loading-spinner-primary);\n opacity: var(--cg-opacity-25);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n :host([variant=\"success\"]) .buffer { background: var(--cg-color-status-success-text-default); }\n :host([variant=\"warning\"]) .buffer { background: var(--cg-color-status-warning-text-default); }\n :host([variant=\"danger\"]) .buffer { background: var(--cg-color-status-error-text-default); }\n\n /* ── Fill bar ── */\n .fill {\n height: 100%;\n border-radius: var(--cg-component-progress-radius);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n position: relative;\n overflow: hidden;\n }\n\n /* ── Variant colors ── */\n :host([variant=\"default\"]) .fill {\n background: var(--cg-color-loading-spinner-primary);\n }\n :host([variant=\"success\"]) .fill {\n background: var(--cg-color-status-success-text-default);\n }\n :host([variant=\"warning\"]) .fill {\n background: var(--cg-color-status-warning-text-default);\n }\n :host([variant=\"danger\"]) .fill {\n background: var(--cg-color-status-error-text-default);\n }\n\n /* ── Striped pattern ── */\n :host([striped]) .fill::after {\n content: '';\n position: absolute;\n inset: 0;\n background-image: linear-gradient(\n 45deg,\n var(--cg-overlay-white-strong) 25%,\n transparent 25%,\n transparent 50%,\n var(--cg-overlay-white-strong) 50%,\n var(--cg-overlay-white-strong) 75%,\n transparent 75%,\n transparent\n );\n background-size: var(--cg-spacing-20) var(--cg-spacing-20);\n }\n\n /* ── Animated stripes ── */\n :host([animated]) .fill::after {\n animation: stripe-move 1s linear infinite;\n }\n\n @keyframes stripe-move {\n from { background-position: 0 0; }\n to { background-position: var(--cg-spacing-20) 0; }\n }\n\n /* ── Indeterminate ── */\n :host([indeterminate]) .fill {\n width: 40% !important;\n animation: indeterminate-slide 1.5s var(--cg-transition-easing-ease-in-out) infinite;\n }\n\n @keyframes indeterminate-slide {\n 0% { transform: translateX(-100%); }\n 50% { transform: translateX(150%); }\n 100% { transform: translateX(-100%); }\n }\n\n @keyframes indeterminate-pulse {\n 0%, 100% { opacity: 0.4; }\n 50% { opacity: 1; }\n }\n\n /* ── Min/Max labels ── */\n .range-labels {\n display: flex;\n justify-content: space-between;\n margin-top: var(--cg-spacing-4);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-outlined);\n font-variant-numeric: tabular-nums;\n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n :host([animated]) .fill::after {\n animation: none !important;\n }\n :host([indeterminate]) .fill {\n animation: indeterminate-pulse 2s ease-in-out infinite !important;\n animation-duration: 2s !important;\n transform: none !important;\n width: 100% !important;\n }\n }\n `];\n\n /** Progress value 0–100 */\n @property({ type: Number }) value = 0;\n\n /** Label text above the bar */\n @property({ type: String }) label = '';\n\n /** Description text below the label */\n @property({ type: String }) description = '';\n\n /** Show percentage value */\n @property({ type: Boolean }) showValue = false;\n\n /** Custom formatted value text (e.g. \"45 MB / 100 MB\") — overrides percentage */\n @property({ type: String }) formatValue = '';\n\n /** Buffer value 0–100 (secondary fill, e.g. video buffering) */\n @property({ type: Number }) buffer = 0;\n\n /** Min label shown under the track */\n @property({ type: String }) minLabel = '';\n\n /** Max label shown under the track */\n @property({ type: String }) maxLabel = '';\n\n @property({ type: String, reflect: true }) variant: 'default' | 'success' | 'warning' | 'danger' = 'default';\n @property({ type: Boolean, reflect: true }) indeterminate = false;\n @property({ type: String, reflect: true }) size: 'sm' | 'md' | 'lg' = 'md';\n @property({ type: Boolean, reflect: true }) striped = false;\n @property({ type: Boolean, reflect: true }) animated = false;\n\n private get _clampedValue(): number {\n return Math.max(0, Math.min(100, this.value));\n }\n\n private get _clampedBuffer(): number {\n return Math.max(0, Math.min(100, this.buffer));\n }\n\n private get _displayValue(): string {\n if (this.formatValue) return this.formatValue;\n return `${this._clampedValue}%`;\n }\n\n override render() {\n const showHeader = this.label || this.description || ((this.showValue || this.formatValue) && !this.indeterminate);\n const showRangeLabels = this.minLabel || this.maxLabel;\n const hasBuffer = this.buffer > 0 && !this.indeterminate;\n\n return html`\n ${showHeader ? html`\n <div class=\"header\">\n <div class=\"header-left\">\n ${this.label ? html`<span class=\"label\">${this.label}</span>` : nothing}\n ${this.description ? html`<span class=\"description\">${this.description}</span>` : nothing}\n </div>\n ${(this.showValue || this.formatValue) && !this.indeterminate ? html`\n <span class=\"value-text\">${this._displayValue}</span>\n ` : nothing}\n </div>\n ` : nothing}\n <div\n class=\"track\"\n role=\"progressbar\"\n aria-valuenow=\"${this.indeterminate ? nothing : this._clampedValue}\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n aria-label=\"${this.label || 'Progress'}\"\n aria-valuetext=${this.formatValue && !this.indeterminate ? this.formatValue : nothing}\n aria-busy=\"${this.indeterminate}\"\n >\n ${hasBuffer ? html`\n <div class=\"buffer\" style=\"width: ${this._clampedBuffer}%\"></div>\n ` : nothing}\n <div\n class=\"fill\"\n style=\"${this.indeterminate ? '' : `width: ${this._clampedValue}%`}\"\n ></div>\n </div>\n ${showRangeLabels ? html`\n <div class=\"range-labels\">\n <span>${this.minLabel}</span>\n <span>${this.maxLabel}</span>\n </div>\n ` : nothing}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'cg-progress-bar': CgProgressBar;\n }\n}\n"],"names":["CgProgressBar","LitElement","showHeader","showRangeLabels","hasBuffer","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
@@ -14,6 +14,14 @@ import { LitElement, PropertyValues } from 'lit';
|
|
|
14
14
|
*/
|
|
15
15
|
export declare class CgRadio extends LitElement {
|
|
16
16
|
static formAssociated: boolean;
|
|
17
|
+
static shadowRootOptions: {
|
|
18
|
+
delegatesFocus: boolean;
|
|
19
|
+
clonable?: boolean;
|
|
20
|
+
customElementRegistry?: CustomElementRegistry;
|
|
21
|
+
mode: ShadowRootMode;
|
|
22
|
+
serializable?: boolean;
|
|
23
|
+
slotAssignment?: SlotAssignmentMode;
|
|
24
|
+
};
|
|
17
25
|
private _internals;
|
|
18
26
|
constructor();
|
|
19
27
|
static styles: import('lit').CSSResult[];
|
|
@@ -28,6 +36,8 @@ export declare class CgRadio extends LitElement {
|
|
|
28
36
|
loading: boolean;
|
|
29
37
|
required: boolean;
|
|
30
38
|
variant: 'dot' | 'tick';
|
|
39
|
+
/** Roving tabindex slot managed by cg-radio-group; standalone radios stay tabbable. */
|
|
40
|
+
groupTabIndex: number;
|
|
31
41
|
updated(changed: PropertyValues): void;
|
|
32
42
|
formResetCallback(): void;
|
|
33
43
|
formStateRestoreCallback(state: string): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-radio.d.ts","sourceRoot":"","sources":["../../../src/components/cg-radio/cg-radio.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E;;;;;;;;;;;;GAYG;AACH,qBACa,OAAQ,SAAQ,UAAU;IACrC,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,
|
|
1
|
+
{"version":3,"file":"cg-radio.d.ts","sourceRoot":"","sources":["../../../src/components/cg-radio/cg-radio.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E;;;;;;;;;;;;GAYG;AACH,qBACa,OAAQ,SAAQ,UAAU;IACrC,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAgB,iBAAiB;;;;;;;MAA6D;IAC9F,OAAO,CAAC,UAAU,CAA+B;;IASjD,OAAgB,MAAM,4BAoKnB;IAES,KAAK,SAAM;IACX,WAAW,SAAM;IACA,IAAI,SAAM;IAC3B,KAAK,SAAM;IACM,OAAO,UAAS;IACD,QAAQ,UAAS;IACjB,KAAK,UAAS;IACd,OAAO,UAAS;IAChB,OAAO,UAAS;IAC/B,QAAQ,UAAS;IACjB,OAAO,EAAE,KAAK,GAAG,MAAM,CAAS;IAE7D,uFAAuF;IAC3D,aAAa,SAAK;IAErC,OAAO,CAAC,OAAO,EAAE,cAAc;IAcxC,iBAAiB;IAIjB,wBAAwB,CAAC,KAAK,EAAE,MAAM;IAItC,OAAO,CAAC,OAAO;IASf,OAAO,CAAC,gBAAgB;IAYf,MAAM;CA+BhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,UAAU,EAAE,OAAO,CAAC;KAAE;CACzD"}
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { property as
|
|
3
|
-
import { h as f, r as v } from "../../chunks/premium.css-
|
|
4
|
-
var b = Object.defineProperty, k = Object.getOwnPropertyDescriptor, t = (
|
|
5
|
-
for (var
|
|
6
|
-
(d =
|
|
7
|
-
return c &&
|
|
1
|
+
import { LitElement as h, css as g, nothing as u, html as s } from "lit";
|
|
2
|
+
import { property as o, customElement as p } from "lit/decorators.js";
|
|
3
|
+
import { h as f, r as v } from "../../chunks/premium.css-DHekUEUt.js";
|
|
4
|
+
var b = Object.defineProperty, k = Object.getOwnPropertyDescriptor, t = (r, i, l, c) => {
|
|
5
|
+
for (var a = c > 1 ? void 0 : c ? k(i, l) : i, n = r.length - 1, d; n >= 0; n--)
|
|
6
|
+
(d = r[n]) && (a = (c ? d(i, l, a) : d(a)) || a);
|
|
7
|
+
return c && a && b(i, l, a), a;
|
|
8
8
|
};
|
|
9
|
-
let
|
|
9
|
+
let e = class extends h {
|
|
10
10
|
constructor() {
|
|
11
|
-
super(), this.label = "", this.description = "", this.name = "", this.value = "", this.checked = !1, this.disabled = !1, this.error = !1, this.success = !1, this.loading = !1, this.required = !1, this.variant = "dot", typeof this.attachInternals == "function" && (this._internals = this.attachInternals());
|
|
11
|
+
super(), this.label = "", this.description = "", this.name = "", this.value = "", this.checked = !1, this.disabled = !1, this.error = !1, this.success = !1, this.loading = !1, this.required = !1, this.variant = "dot", this.groupTabIndex = 0, typeof this.attachInternals == "function" && (this._internals = this.attachInternals());
|
|
12
12
|
}
|
|
13
|
-
updated(
|
|
14
|
-
super.updated(
|
|
13
|
+
updated(r) {
|
|
14
|
+
super.updated(r), (r.has("checked") || r.has("value")) && this._internals?.setFormValue(this.checked ? this.value : null), (r.has("required") || r.has("checked")) && (this.required && !this.checked ? this._internals?.setValidity({ valueMissing: !0 }, "This field is required") : this._internals?.setValidity({}));
|
|
15
15
|
}
|
|
16
16
|
formResetCallback() {
|
|
17
17
|
this.checked = this.hasAttribute("checked");
|
|
18
18
|
}
|
|
19
|
-
formStateRestoreCallback(
|
|
20
|
-
this.checked =
|
|
19
|
+
formStateRestoreCallback(r) {
|
|
20
|
+
this.checked = r === this.value;
|
|
21
21
|
}
|
|
22
22
|
_select() {
|
|
23
23
|
this.disabled || this.loading || this.checked || (this.checked = !0, this.dispatchEvent(new CustomEvent("cg-change", {
|
|
@@ -36,20 +36,21 @@ let r = class extends g {
|
|
|
36
36
|
render() {
|
|
37
37
|
return s`
|
|
38
38
|
<label
|
|
39
|
-
tabindex=${this.disabled ? "-1" :
|
|
39
|
+
tabindex=${this.disabled ? "-1" : String(this.groupTabIndex)}
|
|
40
40
|
role="radio"
|
|
41
41
|
aria-checked=${String(this.checked)}
|
|
42
42
|
aria-disabled=${String(this.disabled)}
|
|
43
43
|
aria-required=${this.required ? "true" : "false"}
|
|
44
|
+
aria-busy=${this.loading ? "true" : "false"}
|
|
44
45
|
@click=${this._select}
|
|
45
|
-
@keydown=${(
|
|
46
|
-
(
|
|
46
|
+
@keydown=${(r) => {
|
|
47
|
+
(r.key === " " || r.key === "Enter") && (r.preventDefault(), this._select());
|
|
47
48
|
}}
|
|
48
49
|
>
|
|
49
50
|
<input type="radio" .checked=${this.checked}
|
|
50
51
|
?disabled=${this.disabled} name=${this.name} value=${this.value}
|
|
51
52
|
tabindex="-1" aria-hidden="true"
|
|
52
|
-
@click=${(
|
|
53
|
+
@click=${(r) => r.stopPropagation()} />
|
|
53
54
|
|
|
54
55
|
${this.loading ? s`<span class="loading-spinner" aria-hidden="true"></span>` : s`
|
|
55
56
|
<span class="circle ${this.checked ? "checked" : ""}">
|
|
@@ -66,8 +67,9 @@ let r = class extends g {
|
|
|
66
67
|
`;
|
|
67
68
|
}
|
|
68
69
|
};
|
|
69
|
-
|
|
70
|
-
|
|
70
|
+
e.formAssociated = !0;
|
|
71
|
+
e.shadowRootOptions = { ...h.shadowRootOptions, delegatesFocus: !0 };
|
|
72
|
+
e.styles = [f, v, g`
|
|
71
73
|
label {
|
|
72
74
|
display: inline-flex;
|
|
73
75
|
align-items: center;
|
|
@@ -122,9 +124,15 @@ r.styles = [f, v, h`
|
|
|
122
124
|
/* Focus ring */
|
|
123
125
|
label:focus-visible .circle {
|
|
124
126
|
border-color: var(--cg-color-radio-border-focus);
|
|
125
|
-
box-shadow: 0 0 0
|
|
127
|
+
box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
|
|
126
128
|
outline: none;
|
|
127
129
|
}
|
|
130
|
+
:host([error]) label:focus-visible .circle {
|
|
131
|
+
box-shadow: 0 0 0 3px var(--cg-shadow-focus-error);
|
|
132
|
+
}
|
|
133
|
+
:host([success]) label:focus-visible .circle {
|
|
134
|
+
box-shadow: 0 0 0 3px var(--cg-shadow-focus-success);
|
|
135
|
+
}
|
|
128
136
|
|
|
129
137
|
/* Checked */
|
|
130
138
|
.circle.checked {
|
|
@@ -143,8 +151,8 @@ r.styles = [f, v, h`
|
|
|
143
151
|
|
|
144
152
|
/* ── Dot indicator ── */
|
|
145
153
|
.dot {
|
|
146
|
-
width:
|
|
147
|
-
height:
|
|
154
|
+
width: var(--cg-spacing-8);
|
|
155
|
+
height: var(--cg-spacing-8);
|
|
148
156
|
border-radius: var(--cg-border-radius-full);
|
|
149
157
|
background: var(--cg-color-radio-dot-default);
|
|
150
158
|
animation: dotIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) forwards;
|
|
@@ -198,7 +206,7 @@ r.styles = [f, v, h`
|
|
|
198
206
|
:host([success]) .label-text { color: var(--cg-color-status-success-text-default); }
|
|
199
207
|
|
|
200
208
|
/* ── Loading state ── */
|
|
201
|
-
:host([loading]) label { pointer-events: none; opacity:
|
|
209
|
+
:host([loading]) label { pointer-events: none; opacity: var(--cg-opacity-50); }
|
|
202
210
|
.loading-spinner {
|
|
203
211
|
width: var(--cg-spacing-20);
|
|
204
212
|
height: var(--cg-spacing-20);
|
|
@@ -227,42 +235,45 @@ r.styles = [f, v, h`
|
|
|
227
235
|
}
|
|
228
236
|
`];
|
|
229
237
|
t([
|
|
230
|
-
|
|
231
|
-
],
|
|
238
|
+
o()
|
|
239
|
+
], e.prototype, "label", 2);
|
|
240
|
+
t([
|
|
241
|
+
o()
|
|
242
|
+
], e.prototype, "description", 2);
|
|
232
243
|
t([
|
|
233
|
-
|
|
234
|
-
],
|
|
244
|
+
o({ reflect: !0 })
|
|
245
|
+
], e.prototype, "name", 2);
|
|
235
246
|
t([
|
|
236
|
-
|
|
237
|
-
],
|
|
247
|
+
o()
|
|
248
|
+
], e.prototype, "value", 2);
|
|
238
249
|
t([
|
|
239
|
-
|
|
240
|
-
],
|
|
250
|
+
o({ type: Boolean })
|
|
251
|
+
], e.prototype, "checked", 2);
|
|
241
252
|
t([
|
|
242
|
-
|
|
243
|
-
],
|
|
253
|
+
o({ type: Boolean, reflect: !0 })
|
|
254
|
+
], e.prototype, "disabled", 2);
|
|
244
255
|
t([
|
|
245
|
-
|
|
246
|
-
],
|
|
256
|
+
o({ type: Boolean, reflect: !0 })
|
|
257
|
+
], e.prototype, "error", 2);
|
|
247
258
|
t([
|
|
248
|
-
|
|
249
|
-
],
|
|
259
|
+
o({ type: Boolean, reflect: !0 })
|
|
260
|
+
], e.prototype, "success", 2);
|
|
250
261
|
t([
|
|
251
|
-
|
|
252
|
-
],
|
|
262
|
+
o({ type: Boolean, reflect: !0 })
|
|
263
|
+
], e.prototype, "loading", 2);
|
|
253
264
|
t([
|
|
254
|
-
|
|
255
|
-
],
|
|
265
|
+
o({ type: Boolean })
|
|
266
|
+
], e.prototype, "required", 2);
|
|
256
267
|
t([
|
|
257
|
-
|
|
258
|
-
],
|
|
268
|
+
o({ reflect: !0 })
|
|
269
|
+
], e.prototype, "variant", 2);
|
|
259
270
|
t([
|
|
260
|
-
|
|
261
|
-
],
|
|
262
|
-
|
|
271
|
+
o({ type: Number })
|
|
272
|
+
], e.prototype, "groupTabIndex", 2);
|
|
273
|
+
e = t([
|
|
263
274
|
p("cg-radio")
|
|
264
|
-
],
|
|
275
|
+
], e);
|
|
265
276
|
export {
|
|
266
|
-
|
|
277
|
+
e as CgRadio
|
|
267
278
|
};
|
|
268
279
|
//# sourceMappingURL=cg-radio.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-radio.js","sources":["../../../src/components/cg-radio/cg-radio.ts"],"sourcesContent":["import { LitElement, html, css, nothing, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/**\n * @element cg-radio\n * Radio button with dot or tick indicator and spring animation.\n *\n * @example\n * ```html\n * <cg-radio label=\"Option A\" value=\"a\"></cg-radio>\n * <cg-radio label=\"Option B\" value=\"b\" checked></cg-radio>\n * <cg-radio label=\"With tick\" value=\"c\" variant=\"tick\" checked></cg-radio>\n * ```\n *\n * @fires {CustomEvent<{value: string, checked: true}>} cg-change - When selected\n */\n@customElement('cg-radio')\nexport class CgRadio extends LitElement {\n static formAssociated = true;\n private _internals: ElementInternals | undefined;\n\n constructor() {\n super();\n if (typeof this.attachInternals === 'function') {\n this._internals = this.attachInternals();\n }\n }\n\n static override styles = [hostBlock, reducedMotion, css`\n label {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n cursor: pointer;\n padding: var(--cg-spacing-6) 0;\n min-height: 44px;\n -webkit-tap-highlight-color: transparent;\n user-select: none;\n }\n :host([disabled]) label { cursor: not-allowed; }\n :host([disabled]) .circle {\n background: var(--cg-color-radio-background-disabled);\n border-color: var(--cg-color-radio-border-disabled);\n }\n :host([disabled]) .dot {\n background: var(--cg-color-radio-dot-disabled);\n }\n :host([disabled]) .tick-icon {\n color: var(--cg-color-radio-dot-disabled);\n }\n\n /* ── Circle ── */\n .circle {\n width: var(--cg-spacing-20);\n height: var(--cg-spacing-20);\n flex-shrink: 0;\n border: var(--cg-border-width-100) solid var(--cg-color-radio-border-default);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-radio-background-default);\n display: flex;\n align-items: center;\n justify-content: center;\n transition:\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n background 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-default) var(--cg-transition-easing-ease-out);\n }\n\n /* Hover */\n :host(:not([disabled])) label:hover .circle {\n border-color: var(--cg-color-radio-border-checked);\n background: var(--cg-color-radio-background-hover);\n }\n\n /* Press */\n :host(:not([disabled])) label:active .circle {\n transform: scale(var(--cg-interaction-press-scale));\n }\n\n /* Focus ring */\n label:focus-visible .circle {\n border-color: var(--cg-color-radio-border-focus);\n box-shadow: 0 0 0 var(--cg-spacing-2) var(--cg-overlay-accent-strong);\n outline: none;\n }\n\n /* Checked */\n .circle.checked {\n border-color: var(--cg-color-radio-border-checked);\n background: var(--cg-color-radio-background-checked);\n animation: circlePop var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n\n @keyframes circlePop {\n 0% { transform: scale(1); }\n 30% { transform: scale(0.85); }\n 60% { transform: scale(1.08); }\n 80% { transform: scale(0.97); }\n 100% { transform: scale(1); }\n }\n\n /* ── Dot indicator ── */\n .dot {\n width: 10px;\n height: 10px;\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-radio-dot-default);\n animation: dotIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) forwards;\n }\n\n @keyframes dotIn {\n 0% { transform: scale(0); }\n 60% { transform: scale(1.2); }\n 100% { transform: scale(1); }\n }\n\n /* ── Tick indicator — stroke reveal ── */\n .tick-icon {\n width: var(--cg-spacing-12);\n height: var(--cg-spacing-12);\n color: var(--cg-color-radio-dot-default);\n overflow: visible;\n }\n\n .tick-icon .tick-path {\n stroke-dasharray: 24;\n stroke-dashoffset: 24;\n animation: drawRadioTick var(--cg-transition-duration-default) 60ms var(--cg-transition-easing-ease-out) forwards;\n }\n\n @keyframes drawRadioTick {\n to { stroke-dashoffset: 0; }\n }\n\n /* Hidden native input */\n input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n /* ── Error state ── */\n :host([error]) .circle { border-color: var(--cg-color-status-error-text-default); }\n :host([error]) .circle.checked { border-color: var(--cg-color-status-error-text-default); }\n :host([error]) .dot { background: var(--cg-color-status-error-text-default); }\n :host([error]) .tick-icon { color: var(--cg-color-status-error-text-default); }\n :host([error]) .label-text { color: var(--cg-color-status-error-text-default); }\n\n /* ── Success state ── */\n :host([success]) .circle { border-color: var(--cg-color-status-success-text-default); }\n :host([success]) .circle.checked { border-color: var(--cg-color-status-success-text-default); }\n :host([success]) .dot { background: var(--cg-color-status-success-text-default); }\n :host([success]) .tick-icon { color: var(--cg-color-status-success-text-default); }\n :host([success]) .label-text { color: var(--cg-color-status-success-text-default); }\n\n /* ── Loading state ── */\n :host([loading]) label { pointer-events: none; opacity: 0.5; }\n .loading-spinner {\n width: var(--cg-spacing-20);\n height: var(--cg-spacing-20);\n flex-shrink: 0;\n border: var(--cg-border-width-100) solid var(--cg-color-loading-spinner-secondary);\n border-top-color: var(--cg-color-loading-spinner-primary);\n border-radius: var(--cg-border-radius-full);\n animation: cg-radio-spin var(--cg-transition-duration-slow) linear infinite;\n }\n @keyframes cg-radio-spin {\n to { transform: rotate(360deg); }\n }\n\n /* Text */\n .text-group { display: flex; flex-direction: column; gap: var(--cg-spacing-2); }\n .label-text {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-base-text);\n line-height: var(--cg-line-height-snug);\n }\n .description {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-outlined);\n line-height: var(--cg-line-height-snug);\n }\n `];\n\n @property() label = '';\n @property() description = '';\n @property() name = '';\n @property() value = '';\n @property({ type: Boolean }) checked = false;\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: Boolean, reflect: true }) error = false;\n @property({ type: Boolean, reflect: true }) success = false;\n @property({ type: Boolean, reflect: true }) loading = false;\n @property({ type: Boolean }) required = false;\n @property({ reflect: true }) variant: 'dot' | 'tick' = 'dot';\n\n override updated(changed: PropertyValues) {\n super.updated(changed);\n if (changed.has('checked') || changed.has('value')) {\n this._internals?.setFormValue(this.checked ? this.value : null);\n }\n if (changed.has('required') || changed.has('checked')) {\n if (this.required && !this.checked) {\n this._internals?.setValidity({ valueMissing: true }, 'This field is required');\n } else {\n this._internals?.setValidity({});\n }\n }\n }\n\n formResetCallback() {\n this.checked = this.hasAttribute('checked');\n }\n\n formStateRestoreCallback(state: string) {\n this.checked = state === this.value;\n }\n\n private _select() {\n if (this.disabled || this.loading || this.checked) return;\n this.checked = true;\n this.dispatchEvent(new CustomEvent('cg-change', {\n detail: { value: this.value, checked: true },\n bubbles: true, composed: true,\n }));\n }\n\n private _renderIndicator() {\n if (!this.checked) return nothing;\n if (this.variant === 'tick') {\n return html`\n <svg class=\"tick-icon\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path class=\"tick-path\" d=\"M20 6L9 17l-5-5\"></path>\n </svg>\n `;\n }\n return html`<span class=\"dot\"></span>`;\n }\n\n override render() {\n return html`\n <label\n tabindex=${this.disabled ? '-1' : '0'}\n role=\"radio\"\n aria-checked=${String(this.checked)}\n aria-disabled=${String(this.disabled)}\n aria-required=${this.required ? 'true' : 'false'}\n @click=${this._select}\n @keydown=${(e: KeyboardEvent) => { if (e.key === ' ' || e.key === 'Enter') { e.preventDefault(); this._select(); } }}\n >\n <input type=\"radio\" .checked=${this.checked}\n ?disabled=${this.disabled} name=${this.name} value=${this.value}\n tabindex=\"-1\" aria-hidden=\"true\"\n @click=${(e: Event) => e.stopPropagation()} />\n\n ${this.loading ? html`<span class=\"loading-spinner\" aria-hidden=\"true\"></span>` : html`\n <span class=\"circle ${this.checked ? 'checked' : ''}\">\n ${this._renderIndicator()}\n </span>`}\n\n ${this.label ? html`\n <span class=\"text-group\">\n <span class=\"label-text\">${this.label}</span>\n ${this.description ? html`<span class=\"description\">${this.description}</span>` : nothing}\n </span>\n ` : nothing}\n </label>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-radio': CgRadio; }\n}\n"],"names":["CgRadio","LitElement","changed","state","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":";;;;;;;;AAkBO,IAAMA,IAAN,cAAsBC,EAAW;AAAA,EAItC,cAAc;AACZ,UAAA,GAsKU,KAAA,QAAQ,IACR,KAAA,cAAc,IACd,KAAA,OAAO,IACP,KAAA,QAAQ,IACS,KAAA,UAAU,IACK,KAAA,WAAW,IACX,KAAA,QAAQ,IACR,KAAA,UAAU,IACV,KAAA,UAAU,IACzB,KAAA,WAAW,IACX,KAAA,UAA0B,OA/KjD,OAAO,KAAK,mBAAoB,eAClC,KAAK,aAAa,KAAK,gBAAA;AAAA,EAE3B;AAAA,EA8KS,QAAQC,GAAyB;AACxC,UAAM,QAAQA,CAAO,IACjBA,EAAQ,IAAI,SAAS,KAAKA,EAAQ,IAAI,OAAO,MAC/C,KAAK,YAAY,aAAa,KAAK,UAAU,KAAK,QAAQ,IAAI,IAE5DA,EAAQ,IAAI,UAAU,KAAKA,EAAQ,IAAI,SAAS,OAC9C,KAAK,YAAY,CAAC,KAAK,UACzB,KAAK,YAAY,YAAY,EAAE,cAAc,GAAA,GAAQ,wBAAwB,IAE7E,KAAK,YAAY,YAAY,EAAE;AAAA,EAGrC;AAAA,EAEA,oBAAoB;AAClB,SAAK,UAAU,KAAK,aAAa,SAAS;AAAA,EAC5C;AAAA,EAEA,yBAAyBC,GAAe;AACtC,SAAK,UAAUA,MAAU,KAAK;AAAA,EAChC;AAAA,EAEQ,UAAU;AAChB,IAAI,KAAK,YAAY,KAAK,WAAW,KAAK,YAC1C,KAAK,UAAU,IACf,KAAK,cAAc,IAAI,YAAY,aAAa;AAAA,MAC9C,QAAQ,EAAE,OAAO,KAAK,OAAO,SAAS,GAAA;AAAA,MACtC,SAAS;AAAA,MAAM,UAAU;AAAA,IAAA,CAC1B,CAAC;AAAA,EACJ;AAAA,EAEQ,mBAAmB;AACzB,WAAK,KAAK,UACN,KAAK,YAAY,SACZC;AAAA;AAAA;AAAA;AAAA,UAMFA,+BARmBC;AAAA,EAS5B;AAAA,EAES,SAAS;AAChB,WAAOD;AAAA;AAAA,mBAEQ,KAAK,WAAW,OAAO,GAAG;AAAA;AAAA,uBAEtB,OAAO,KAAK,OAAO,CAAC;AAAA,wBACnB,OAAO,KAAK,QAAQ,CAAC;AAAA,wBACrB,KAAK,WAAW,SAAS,OAAO;AAAA,iBACvC,KAAK,OAAO;AAAA,mBACV,CAAC,MAAqB;AAAE,OAAI,EAAE,QAAQ,OAAO,EAAE,QAAQ,aAAW,EAAE,eAAA,GAAkB,KAAK,QAAA;AAAA,IAAa,CAAC;AAAA;AAAA,uCAErF,KAAK,OAAO;AAAA,sBAC7B,KAAK,QAAQ,SAAS,KAAK,IAAI,UAAU,KAAK,KAAK;AAAA;AAAA,mBAEtD,CAAC,MAAa,EAAE,iBAAiB;AAAA;AAAA,UAE1C,KAAK,UAAUA,8DAAiEA;AAAA,8BAC5D,KAAK,UAAU,YAAY,EAAE;AAAA,YAC/C,KAAK,kBAAkB;AAAA,gBACnB;AAAA;AAAA,UAEN,KAAK,QAAQA;AAAA;AAAA,uCAEgB,KAAK,KAAK;AAAA,cACnC,KAAK,cAAcA,8BAAiC,KAAK,WAAW,YAAYC,CAAO;AAAA;AAAA,YAEzFA,CAAO;AAAA;AAAA;AAAA,EAGjB;AACF;AAhQaL,EACJ,iBAAiB;AADbA,EAWK,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;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;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,GA8JnD;AAEWC,EAAA;AAAA,EAAXC,EAAA;AAAS,GA3KCV,EA2KC,WAAA,SAAA,CAAA;AACAS,EAAA;AAAA,EAAXC,EAAA;AAAS,GA5KCV,EA4KC,WAAA,eAAA,CAAA;AACAS,EAAA;AAAA,EAAXC,EAAA;AAAS,GA7KCV,EA6KC,WAAA,QAAA,CAAA;AACAS,EAAA;AAAA,EAAXC,EAAA;AAAS,GA9KCV,EA8KC,WAAA,SAAA,CAAA;AACiBS,EAAA;AAAA,EAA5BC,EAAS,EAAE,MAAM,QAAA,CAAS;AAAA,GA/KhBV,EA+KkB,WAAA,WAAA,CAAA;AACeS,EAAA;AAAA,EAA3CC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAhL/BV,EAgLiC,WAAA,YAAA,CAAA;AACAS,EAAA;AAAA,EAA3CC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAjL/BV,EAiLiC,WAAA,SAAA,CAAA;AACAS,EAAA;AAAA,EAA3CC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAlL/BV,EAkLiC,WAAA,WAAA,CAAA;AACAS,EAAA;AAAA,EAA3CC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAnL/BV,EAmLiC,WAAA,WAAA,CAAA;AACfS,EAAA;AAAA,EAA5BC,EAAS,EAAE,MAAM,QAAA,CAAS;AAAA,GApLhBV,EAoLkB,WAAA,YAAA,CAAA;AACAS,EAAA;AAAA,EAA5BC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GArLhBV,EAqLkB,WAAA,WAAA,CAAA;AArLlBA,IAANS,EAAA;AAAA,EADNE,EAAc,UAAU;AAAA,GACZX,CAAA;"}
|
|
1
|
+
{"version":3,"file":"cg-radio.js","sources":["../../../src/components/cg-radio/cg-radio.ts"],"sourcesContent":["import { LitElement, html, css, nothing, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\n\n/**\n * @element cg-radio\n * Radio button with dot or tick indicator and spring animation.\n *\n * @example\n * ```html\n * <cg-radio label=\"Option A\" value=\"a\"></cg-radio>\n * <cg-radio label=\"Option B\" value=\"b\" checked></cg-radio>\n * <cg-radio label=\"With tick\" value=\"c\" variant=\"tick\" checked></cg-radio>\n * ```\n *\n * @fires {CustomEvent<{value: string, checked: true}>} cg-change - When selected\n */\n@customElement('cg-radio')\nexport class CgRadio extends LitElement {\n static formAssociated = true;\n static override shadowRootOptions = { ...LitElement.shadowRootOptions, delegatesFocus: true };\n private _internals: ElementInternals | undefined;\n\n constructor() {\n super();\n if (typeof this.attachInternals === 'function') {\n this._internals = this.attachInternals();\n }\n }\n\n static override styles = [hostBlock, reducedMotion, css`\n label {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n cursor: pointer;\n padding: var(--cg-spacing-6) 0;\n min-height: 44px;\n -webkit-tap-highlight-color: transparent;\n user-select: none;\n }\n :host([disabled]) label { cursor: not-allowed; }\n :host([disabled]) .circle {\n background: var(--cg-color-radio-background-disabled);\n border-color: var(--cg-color-radio-border-disabled);\n }\n :host([disabled]) .dot {\n background: var(--cg-color-radio-dot-disabled);\n }\n :host([disabled]) .tick-icon {\n color: var(--cg-color-radio-dot-disabled);\n }\n\n /* ── Circle ── */\n .circle {\n width: var(--cg-spacing-20);\n height: var(--cg-spacing-20);\n flex-shrink: 0;\n border: var(--cg-border-width-100) solid var(--cg-color-radio-border-default);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-radio-background-default);\n display: flex;\n align-items: center;\n justify-content: center;\n transition:\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n background 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-default) var(--cg-transition-easing-ease-out);\n }\n\n /* Hover */\n :host(:not([disabled])) label:hover .circle {\n border-color: var(--cg-color-radio-border-checked);\n background: var(--cg-color-radio-background-hover);\n }\n\n /* Press */\n :host(:not([disabled])) label:active .circle {\n transform: scale(var(--cg-interaction-press-scale));\n }\n\n /* Focus ring */\n label:focus-visible .circle {\n border-color: var(--cg-color-radio-border-focus);\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n outline: none;\n }\n :host([error]) label:focus-visible .circle {\n box-shadow: 0 0 0 3px var(--cg-shadow-focus-error);\n }\n :host([success]) label:focus-visible .circle {\n box-shadow: 0 0 0 3px var(--cg-shadow-focus-success);\n }\n\n /* Checked */\n .circle.checked {\n border-color: var(--cg-color-radio-border-checked);\n background: var(--cg-color-radio-background-checked);\n animation: circlePop var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out);\n }\n\n @keyframes circlePop {\n 0% { transform: scale(1); }\n 30% { transform: scale(0.85); }\n 60% { transform: scale(1.08); }\n 80% { transform: scale(0.97); }\n 100% { transform: scale(1); }\n }\n\n /* ── Dot indicator ── */\n .dot {\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n background: var(--cg-color-radio-dot-default);\n animation: dotIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) forwards;\n }\n\n @keyframes dotIn {\n 0% { transform: scale(0); }\n 60% { transform: scale(1.2); }\n 100% { transform: scale(1); }\n }\n\n /* ── Tick indicator — stroke reveal ── */\n .tick-icon {\n width: var(--cg-spacing-12);\n height: var(--cg-spacing-12);\n color: var(--cg-color-radio-dot-default);\n overflow: visible;\n }\n\n .tick-icon .tick-path {\n stroke-dasharray: 24;\n stroke-dashoffset: 24;\n animation: drawRadioTick var(--cg-transition-duration-default) 60ms var(--cg-transition-easing-ease-out) forwards;\n }\n\n @keyframes drawRadioTick {\n to { stroke-dashoffset: 0; }\n }\n\n /* Hidden native input */\n input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n /* ── Error state ── */\n :host([error]) .circle { border-color: var(--cg-color-status-error-text-default); }\n :host([error]) .circle.checked { border-color: var(--cg-color-status-error-text-default); }\n :host([error]) .dot { background: var(--cg-color-status-error-text-default); }\n :host([error]) .tick-icon { color: var(--cg-color-status-error-text-default); }\n :host([error]) .label-text { color: var(--cg-color-status-error-text-default); }\n\n /* ── Success state ── */\n :host([success]) .circle { border-color: var(--cg-color-status-success-text-default); }\n :host([success]) .circle.checked { border-color: var(--cg-color-status-success-text-default); }\n :host([success]) .dot { background: var(--cg-color-status-success-text-default); }\n :host([success]) .tick-icon { color: var(--cg-color-status-success-text-default); }\n :host([success]) .label-text { color: var(--cg-color-status-success-text-default); }\n\n /* ── Loading state ── */\n :host([loading]) label { pointer-events: none; opacity: var(--cg-opacity-50); }\n .loading-spinner {\n width: var(--cg-spacing-20);\n height: var(--cg-spacing-20);\n flex-shrink: 0;\n border: var(--cg-border-width-100) solid var(--cg-color-loading-spinner-secondary);\n border-top-color: var(--cg-color-loading-spinner-primary);\n border-radius: var(--cg-border-radius-full);\n animation: cg-radio-spin var(--cg-transition-duration-slow) linear infinite;\n }\n @keyframes cg-radio-spin {\n to { transform: rotate(360deg); }\n }\n\n /* Text */\n .text-group { display: flex; flex-direction: column; gap: var(--cg-spacing-2); }\n .label-text {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-base-text);\n line-height: var(--cg-line-height-snug);\n }\n .description {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-surface-container-outlined);\n line-height: var(--cg-line-height-snug);\n }\n `];\n\n @property() label = '';\n @property() description = '';\n @property({ reflect: true }) name = '';\n @property() value = '';\n @property({ type: Boolean }) checked = false;\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: Boolean, reflect: true }) error = false;\n @property({ type: Boolean, reflect: true }) success = false;\n @property({ type: Boolean, reflect: true }) loading = false;\n @property({ type: Boolean }) required = false;\n @property({ reflect: true }) variant: 'dot' | 'tick' = 'dot';\n\n /** Roving tabindex slot managed by cg-radio-group; standalone radios stay tabbable. */\n @property({ type: Number }) groupTabIndex = 0;\n\n override updated(changed: PropertyValues) {\n super.updated(changed);\n if (changed.has('checked') || changed.has('value')) {\n this._internals?.setFormValue(this.checked ? this.value : null);\n }\n if (changed.has('required') || changed.has('checked')) {\n if (this.required && !this.checked) {\n this._internals?.setValidity({ valueMissing: true }, 'This field is required');\n } else {\n this._internals?.setValidity({});\n }\n }\n }\n\n formResetCallback() {\n this.checked = this.hasAttribute('checked');\n }\n\n formStateRestoreCallback(state: string) {\n this.checked = state === this.value;\n }\n\n private _select() {\n if (this.disabled || this.loading || this.checked) return;\n this.checked = true;\n this.dispatchEvent(new CustomEvent('cg-change', {\n detail: { value: this.value, checked: true },\n bubbles: true, composed: true,\n }));\n }\n\n private _renderIndicator() {\n if (!this.checked) return nothing;\n if (this.variant === 'tick') {\n return html`\n <svg class=\"tick-icon\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path class=\"tick-path\" d=\"M20 6L9 17l-5-5\"></path>\n </svg>\n `;\n }\n return html`<span class=\"dot\"></span>`;\n }\n\n override render() {\n return html`\n <label\n tabindex=${this.disabled ? '-1' : String(this.groupTabIndex)}\n role=\"radio\"\n aria-checked=${String(this.checked)}\n aria-disabled=${String(this.disabled)}\n aria-required=${this.required ? 'true' : 'false'}\n aria-busy=${this.loading ? 'true' : 'false'}\n @click=${this._select}\n @keydown=${(e: KeyboardEvent) => { if (e.key === ' ' || e.key === 'Enter') { e.preventDefault(); this._select(); } }}\n >\n <input type=\"radio\" .checked=${this.checked}\n ?disabled=${this.disabled} name=${this.name} value=${this.value}\n tabindex=\"-1\" aria-hidden=\"true\"\n @click=${(e: Event) => e.stopPropagation()} />\n\n ${this.loading ? html`<span class=\"loading-spinner\" aria-hidden=\"true\"></span>` : html`\n <span class=\"circle ${this.checked ? 'checked' : ''}\">\n ${this._renderIndicator()}\n </span>`}\n\n ${this.label ? html`\n <span class=\"text-group\">\n <span class=\"label-text\">${this.label}</span>\n ${this.description ? html`<span class=\"description\">${this.description}</span>` : nothing}\n </span>\n ` : nothing}\n </label>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-radio': CgRadio; }\n}\n"],"names":["CgRadio","LitElement","changed","state","html","nothing","e","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
@@ -30,7 +30,13 @@ export declare class CgRadioGroup extends LitElement {
|
|
|
30
30
|
disabled: boolean;
|
|
31
31
|
/** Layout direction */
|
|
32
32
|
orientation: 'vertical' | 'horizontal';
|
|
33
|
+
/** Group-level error state, propagated to every child radio */
|
|
34
|
+
error: boolean;
|
|
33
35
|
private _radios;
|
|
36
|
+
/** Radios WE disabled via group disabled — so re-enabling is reversible
|
|
37
|
+
* without clobbering individually-disabled radios. */
|
|
38
|
+
private _groupDisabled;
|
|
39
|
+
private _appliedName;
|
|
34
40
|
private _getRadios;
|
|
35
41
|
private _syncRadios;
|
|
36
42
|
private _updateTabindex;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-radio-group.d.ts","sourceRoot":"","sources":["../../../src/components/cg-radio-group/cg-radio-group.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAKrD;;;;;;;;;;;;;;;;;;GAkBG;AACH,qBACa,YAAa,SAAQ,UAAU;IAC1C,OAAgB,MAAM,
|
|
1
|
+
{"version":3,"file":"cg-radio-group.d.ts","sourceRoot":"","sources":["../../../src/components/cg-radio-group/cg-radio-group.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAKrD;;;;;;;;;;;;;;;;;;GAkBG;AACH,qBACa,YAAa,SAAQ,UAAU;IAC1C,OAAgB,MAAM,4BAuBnB;IAEH,uCAAuC;IAC3B,IAAI,SAAM;IAEtB,+BAA+B;IACnB,KAAK,SAAM;IAEvB,6BAA6B;IACjB,KAAK,SAAM;IAEvB,gCAAgC;IACY,QAAQ,UAAS;IAE7D,uBAAuB;IACM,WAAW,EAAE,UAAU,GAAG,YAAY,CAAc;IAEjF,+DAA+D;IACnB,KAAK,UAAS;IAE1D,OAAO,CAAC,OAAO,CAAiB;IAChC;2DACuD;IACvD,OAAO,CAAC,cAAc,CAA0B;IAChD,OAAO,CAAC,YAAY,CAAS;IAE7B,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,WAAW;IA0BnB,OAAO,CAAC,eAAe;IAYvB,OAAO,CAAC,iBAAiB;IAIzB,OAAO,CAAC,aAAa;IAuBrB,OAAO,CAAC,cAAc;IAwCtB,OAAO,CAAC,YAAY;IAiBX,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC;IAMrC,MAAM;CAehB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAAG,gBAAgB,EAAE,YAAY,CAAC;KAAE;CACpE"}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import { css as
|
|
2
|
-
import { property as d, customElement as
|
|
3
|
-
import { h as
|
|
4
|
-
var
|
|
5
|
-
for (var a = s > 1 ? void 0 : s ?
|
|
6
|
-
(
|
|
7
|
-
return s && a &&
|
|
1
|
+
import { css as p, LitElement as f, nothing as c, html as u } from "lit";
|
|
2
|
+
import { property as d, customElement as g } from "lit/decorators.js";
|
|
3
|
+
import { h as b, r as v } from "../../chunks/premium.css-DHekUEUt.js";
|
|
4
|
+
var _ = Object.defineProperty, m = Object.getOwnPropertyDescriptor, n = (e, t, o, s) => {
|
|
5
|
+
for (var a = s > 1 ? void 0 : s ? m(t, o) : t, r = e.length - 1, l; r >= 0; r--)
|
|
6
|
+
(l = e[r]) && (a = (s ? l(t, o, a) : l(a)) || a);
|
|
7
|
+
return s && a && _(t, o, a), a;
|
|
8
8
|
};
|
|
9
|
-
let
|
|
9
|
+
let i = class extends f {
|
|
10
10
|
constructor() {
|
|
11
|
-
super(...arguments), this.name = "", this.value = "", this.label = "", this.disabled = !1, this.orientation = "vertical", this._radios = [];
|
|
11
|
+
super(...arguments), this.name = "", this.value = "", this.label = "", this.disabled = !1, this.orientation = "vertical", this.error = !1, this._radios = [], this._groupDisabled = /* @__PURE__ */ new WeakSet(), this._appliedName = !1;
|
|
12
12
|
}
|
|
13
13
|
_getRadios() {
|
|
14
14
|
const e = this.shadowRoot?.querySelector("slot");
|
|
@@ -17,7 +17,7 @@ let r = class extends c {
|
|
|
17
17
|
_syncRadios() {
|
|
18
18
|
this._radios = this._getRadios();
|
|
19
19
|
for (const e of this._radios)
|
|
20
|
-
this.name
|
|
20
|
+
this.name ? (e.name = this.name, this._appliedName = !0) : this._appliedName && (e.name = ""), this.disabled ? e.disabled || (this._groupDisabled.add(e), e.disabled = !0) : this._groupDisabled.has(e) && (this._groupDisabled.delete(e), e.disabled = !1), e.error = this.error, e.checked = e.value === this.value;
|
|
21
21
|
this._updateTabindex();
|
|
22
22
|
}
|
|
23
23
|
_updateTabindex() {
|
|
@@ -25,12 +25,13 @@ let r = class extends c {
|
|
|
25
25
|
if (e.length === 0) return;
|
|
26
26
|
const o = e.find((s) => s.checked) ?? e[0];
|
|
27
27
|
for (const s of this._radios)
|
|
28
|
-
s.
|
|
28
|
+
s.groupTabIndex = s === o ? 0 : -1;
|
|
29
29
|
}
|
|
30
30
|
_handleSlotChange() {
|
|
31
31
|
this._syncRadios();
|
|
32
32
|
}
|
|
33
33
|
_handleChange(e) {
|
|
34
|
+
e.stopPropagation();
|
|
34
35
|
const t = e.detail;
|
|
35
36
|
if (!t) return;
|
|
36
37
|
const o = t.value;
|
|
@@ -46,31 +47,31 @@ let r = class extends c {
|
|
|
46
47
|
}
|
|
47
48
|
}
|
|
48
49
|
_handleKeydown(e) {
|
|
49
|
-
const t = this._radios.filter((
|
|
50
|
+
const t = this._radios.filter((h) => !h.disabled);
|
|
50
51
|
if (t.length === 0 || !["ArrowDown", "ArrowRight", "ArrowUp", "ArrowLeft", "Home", "End"].includes(e.key)) return;
|
|
51
52
|
e.preventDefault();
|
|
52
|
-
const s = t.findIndex((
|
|
53
|
-
let
|
|
53
|
+
const s = t.findIndex((h) => h.matches(":focus-within")), a = s !== -1 ? s : t.findIndex((h) => h.checked);
|
|
54
|
+
let r;
|
|
54
55
|
switch (e.key) {
|
|
55
56
|
case "ArrowDown":
|
|
56
57
|
case "ArrowRight":
|
|
57
|
-
|
|
58
|
+
r = a === -1 ? 0 : (a + 1) % t.length;
|
|
58
59
|
break;
|
|
59
60
|
case "ArrowUp":
|
|
60
61
|
case "ArrowLeft":
|
|
61
|
-
|
|
62
|
+
r = a === -1 ? t.length - 1 : (a - 1 + t.length) % t.length;
|
|
62
63
|
break;
|
|
63
64
|
case "Home":
|
|
64
|
-
|
|
65
|
+
r = 0;
|
|
65
66
|
break;
|
|
66
67
|
case "End":
|
|
67
|
-
|
|
68
|
+
r = t.length - 1;
|
|
68
69
|
break;
|
|
69
70
|
default:
|
|
70
71
|
return;
|
|
71
72
|
}
|
|
72
|
-
const
|
|
73
|
-
|
|
73
|
+
const l = t[r];
|
|
74
|
+
l && (this._selectRadio(l), l.focus());
|
|
74
75
|
}
|
|
75
76
|
_selectRadio(e) {
|
|
76
77
|
if (e.value !== this.value) {
|
|
@@ -88,11 +89,13 @@ let r = class extends c {
|
|
|
88
89
|
(e.has("value") || e.has("name") || e.has("disabled")) && this._syncRadios();
|
|
89
90
|
}
|
|
90
91
|
render() {
|
|
91
|
-
return
|
|
92
|
+
return u`
|
|
93
|
+
${this.label ? u`<div class="label" id="group-label">${this.label}</div>` : c}
|
|
92
94
|
<div
|
|
93
95
|
class="group"
|
|
94
96
|
role="radiogroup"
|
|
95
|
-
aria-
|
|
97
|
+
aria-labelledby=${this.label ? "group-label" : c}
|
|
98
|
+
aria-orientation=${this.orientation}
|
|
96
99
|
@cg-change=${this._handleChange}
|
|
97
100
|
@keydown=${this._handleKeydown}
|
|
98
101
|
>
|
|
@@ -101,7 +104,7 @@ let r = class extends c {
|
|
|
101
104
|
`;
|
|
102
105
|
}
|
|
103
106
|
};
|
|
104
|
-
|
|
107
|
+
i.styles = [b, v, p`
|
|
105
108
|
:host {
|
|
106
109
|
display: block;
|
|
107
110
|
}
|
|
@@ -117,26 +120,36 @@ r.styles = [g, v, h`
|
|
|
117
120
|
gap: var(--cg-spacing-16);
|
|
118
121
|
flex-wrap: wrap;
|
|
119
122
|
}
|
|
123
|
+
|
|
124
|
+
.label {
|
|
125
|
+
font-size: var(--cg-font-size-sm);
|
|
126
|
+
font-weight: var(--cg-font-weight-medium);
|
|
127
|
+
color: var(--cg-color-surface-base-text);
|
|
128
|
+
margin-bottom: var(--cg-spacing-8);
|
|
129
|
+
}
|
|
120
130
|
`];
|
|
121
|
-
|
|
131
|
+
n([
|
|
122
132
|
d()
|
|
123
|
-
],
|
|
124
|
-
|
|
133
|
+
], i.prototype, "name", 2);
|
|
134
|
+
n([
|
|
125
135
|
d()
|
|
126
|
-
],
|
|
127
|
-
|
|
136
|
+
], i.prototype, "value", 2);
|
|
137
|
+
n([
|
|
128
138
|
d()
|
|
129
|
-
],
|
|
130
|
-
|
|
139
|
+
], i.prototype, "label", 2);
|
|
140
|
+
n([
|
|
131
141
|
d({ type: Boolean, reflect: !0 })
|
|
132
|
-
],
|
|
133
|
-
|
|
142
|
+
], i.prototype, "disabled", 2);
|
|
143
|
+
n([
|
|
134
144
|
d({ reflect: !0 })
|
|
135
|
-
],
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
],
|
|
145
|
+
], i.prototype, "orientation", 2);
|
|
146
|
+
n([
|
|
147
|
+
d({ type: Boolean, reflect: !0 })
|
|
148
|
+
], i.prototype, "error", 2);
|
|
149
|
+
i = n([
|
|
150
|
+
g("cg-radio-group")
|
|
151
|
+
], i);
|
|
139
152
|
export {
|
|
140
|
-
|
|
153
|
+
i as CgRadioGroup
|
|
141
154
|
};
|
|
142
155
|
//# sourceMappingURL=cg-radio-group.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-radio-group.js","sources":["../../../src/components/cg-radio-group/cg-radio-group.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\nimport type { CgRadio } from '../cg-radio/cg-radio.js';\n\n/**\n * @element cg-radio-group\n * Manages a group of `<cg-radio>` elements with WAI-ARIA keyboard navigation.\n *\n * @example\n * ```html\n * <cg-radio-group name=\"color\" value=\"red\" label=\"Pick a color\">\n * <cg-radio label=\"Red\" value=\"red\"></cg-radio>\n * <cg-radio label=\"Blue\" value=\"blue\"></cg-radio>\n * </cg-radio-group>\n * ```\n *\n * @slot - Default slot for `<cg-radio>` children\n *\n * @fires {CustomEvent<{value: string}>} cg-change - When the selected value changes\n *\n * @cssprop [--cg-spacing-8=8px] - Gap between radio items (vertical)\n * @cssprop [--cg-spacing-16=16px] - Gap between radio items (horizontal)\n */\n@customElement('cg-radio-group')\nexport class CgRadioGroup extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: block;\n }\n\n .group {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-8);\n }\n\n :host([orientation=\"horizontal\"]) .group {\n flex-direction: row;\n gap: var(--cg-spacing-16);\n flex-wrap: wrap;\n }\n `];\n\n /** Shared name for all child radios */\n @property() name = '';\n\n /** Currently selected value */\n @property() value = '';\n\n /** Accessible group label */\n @property() label = '';\n\n /** Disables all child radios */\n @property({ type: Boolean, reflect: true }) disabled = false;\n\n /** Layout direction */\n @property({ reflect: true }) orientation: 'vertical' | 'horizontal' = 'vertical';\n\n private _radios: CgRadio[] = [];\n\n private _getRadios(): CgRadio[] {\n const slot = this.shadowRoot?.querySelector('slot');\n if (!slot) return [];\n return slot.assignedElements({ flatten: true })\n .filter((el): el is CgRadio => el.tagName === 'CG-RADIO') as CgRadio[];\n }\n\n private _syncRadios() {\n this._radios = this._getRadios();\n\n for (const radio of this._radios) {\n if (this.name) radio.name = this.name;\n if (this.disabled) radio.disabled = true;\n radio.checked = radio.value === this.value;\n }\n\n this._updateTabindex();\n }\n\n private _updateTabindex() {\n const enabledRadios = this._radios.filter(r => !r.disabled);\n if (enabledRadios.length === 0) return;\n\n const selected = enabledRadios.find(r => r.checked);\n const focusTarget = selected ?? enabledRadios[0];\n\n for (const radio of this._radios) {\n radio.tabIndex = radio === focusTarget ? 0 : -1;\n }\n }\n\n private _handleSlotChange() {\n this._syncRadios();\n }\n\n private _handleChange(e: Event) {\n const detail = (e as CustomEvent).detail;\n if (!detail) return;\n\n const newValue = detail.value as string;\n if (newValue === this.value) return;\n\n this.value = newValue;\n\n // Deselect all others and update tabindex\n for (const radio of this._radios) {\n radio.checked = radio.value === newValue;\n }\n this._updateTabindex();\n\n this.dispatchEvent(new CustomEvent('cg-change', {\n detail: { value: newValue },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _handleKeydown(e: KeyboardEvent) {\n const enabledRadios = this._radios.filter(r => !r.disabled);\n if (enabledRadios.length === 0) return;\n\n const keys = ['ArrowDown', 'ArrowRight', 'ArrowUp', 'ArrowLeft', 'Home', 'End'];\n if (!keys.includes(e.key)) return;\n\n e.preventDefault();\n\n const currentIndex = enabledRadios.findIndex(r => r.checked);\n let nextIndex: number;\n\n switch (e.key) {\n case 'ArrowDown':\n case 'ArrowRight':\n nextIndex = currentIndex === -1 ? 0 : (currentIndex + 1) % enabledRadios.length;\n break;\n case 'ArrowUp':\n case 'ArrowLeft':\n nextIndex = currentIndex === -1\n ? enabledRadios.length - 1\n : (currentIndex - 1 + enabledRadios.length) % enabledRadios.length;\n break;\n case 'Home':\n nextIndex = 0;\n break;\n case 'End':\n nextIndex = enabledRadios.length - 1;\n break;\n default:\n return;\n }\n\n const target = enabledRadios[nextIndex];\n if (!target) return;\n this._selectRadio(target);\n target.focus();\n }\n\n private _selectRadio(radio: CgRadio) {\n if (radio.value === this.value) return;\n\n this.value = radio.value;\n\n for (const r of this._radios) {\n r.checked = r === radio;\n }\n this._updateTabindex();\n\n this.dispatchEvent(new CustomEvent('cg-change', {\n detail: { value: radio.value },\n bubbles: true,\n composed: true,\n }));\n }\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('value') || changed.has('name') || changed.has('disabled')) {\n this._syncRadios();\n }\n }\n\n override render() {\n return html`\n <div\n class=\"group\"\n role=\"radiogroup\"\n aria-label=${this.label || nothing}\n @cg-change=${this._handleChange}\n @keydown=${this._handleKeydown}\n >\n <slot @slotchange=${this._handleSlotChange}></slot>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-radio-group': CgRadioGroup; }\n}\n"],"names":["CgRadioGroup","LitElement","slot","el","radio","enabledRadios","r","focusTarget","detail","newValue","currentIndex","nextIndex","target","changed","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cg-radio-group.js","sources":["../../../src/components/cg-radio-group/cg-radio-group.ts"],"sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion } from '../../styles/index.js';\nimport type { CgRadio } from '../cg-radio/cg-radio.js';\n\n/**\n * @element cg-radio-group\n * Manages a group of `<cg-radio>` elements with WAI-ARIA keyboard navigation.\n *\n * @example\n * ```html\n * <cg-radio-group name=\"color\" value=\"red\" label=\"Pick a color\">\n * <cg-radio label=\"Red\" value=\"red\"></cg-radio>\n * <cg-radio label=\"Blue\" value=\"blue\"></cg-radio>\n * </cg-radio-group>\n * ```\n *\n * @slot - Default slot for `<cg-radio>` children\n *\n * @fires {CustomEvent<{value: string}>} cg-change - When the selected value changes\n *\n * @cssprop [--cg-spacing-8=8px] - Gap between radio items (vertical)\n * @cssprop [--cg-spacing-16=16px] - Gap between radio items (horizontal)\n */\n@customElement('cg-radio-group')\nexport class CgRadioGroup extends LitElement {\n static override styles = [hostBlock, reducedMotion, css`\n :host {\n display: block;\n }\n\n .group {\n display: flex;\n flex-direction: column;\n gap: var(--cg-spacing-8);\n }\n\n :host([orientation=\"horizontal\"]) .group {\n flex-direction: row;\n gap: var(--cg-spacing-16);\n flex-wrap: wrap;\n }\n\n .label {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-medium);\n color: var(--cg-color-surface-base-text);\n margin-bottom: var(--cg-spacing-8);\n }\n `];\n\n /** Shared name for all child radios */\n @property() name = '';\n\n /** Currently selected value */\n @property() value = '';\n\n /** Accessible group label */\n @property() label = '';\n\n /** Disables all child radios */\n @property({ type: Boolean, reflect: true }) disabled = false;\n\n /** Layout direction */\n @property({ reflect: true }) orientation: 'vertical' | 'horizontal' = 'vertical';\n\n /** Group-level error state, propagated to every child radio */\n @property({ type: Boolean, reflect: true }) error = false;\n\n private _radios: CgRadio[] = [];\n /** Radios WE disabled via group disabled — so re-enabling is reversible\n * without clobbering individually-disabled radios. */\n private _groupDisabled = new WeakSet<CgRadio>();\n private _appliedName = false;\n\n private _getRadios(): CgRadio[] {\n const slot = this.shadowRoot?.querySelector('slot');\n if (!slot) return [];\n return slot.assignedElements({ flatten: true })\n .filter((el): el is CgRadio => el.tagName === 'CG-RADIO') as CgRadio[];\n }\n\n private _syncRadios() {\n this._radios = this._getRadios();\n\n for (const radio of this._radios) {\n if (this.name) {\n radio.name = this.name;\n this._appliedName = true;\n } else if (this._appliedName) {\n radio.name = '';\n }\n if (this.disabled) {\n if (!radio.disabled) {\n this._groupDisabled.add(radio);\n radio.disabled = true;\n }\n } else if (this._groupDisabled.has(radio)) {\n this._groupDisabled.delete(radio);\n radio.disabled = false;\n }\n radio.error = this.error;\n radio.checked = radio.value === this.value;\n }\n\n this._updateTabindex();\n }\n\n private _updateTabindex() {\n const enabledRadios = this._radios.filter(r => !r.disabled);\n if (enabledRadios.length === 0) return;\n\n const selected = enabledRadios.find(r => r.checked);\n const focusTarget = selected ?? enabledRadios[0];\n\n for (const radio of this._radios) {\n radio.groupTabIndex = radio === focusTarget ? 0 : -1;\n }\n }\n\n private _handleSlotChange() {\n this._syncRadios();\n }\n\n private _handleChange(e: Event) {\n e.stopPropagation();\n const detail = (e as CustomEvent).detail;\n if (!detail) return;\n\n const newValue = detail.value as string;\n if (newValue === this.value) return;\n\n this.value = newValue;\n\n // Deselect all others and update tabindex\n for (const radio of this._radios) {\n radio.checked = radio.value === newValue;\n }\n this._updateTabindex();\n\n this.dispatchEvent(new CustomEvent('cg-change', {\n detail: { value: newValue },\n bubbles: true,\n composed: true,\n }));\n }\n\n private _handleKeydown(e: KeyboardEvent) {\n const enabledRadios = this._radios.filter(r => !r.disabled);\n if (enabledRadios.length === 0) return;\n\n const keys = ['ArrowDown', 'ArrowRight', 'ArrowUp', 'ArrowLeft', 'Home', 'End'];\n if (!keys.includes(e.key)) return;\n\n e.preventDefault();\n\n const focusedIndex = enabledRadios.findIndex(r => r.matches(':focus-within'));\n const currentIndex = focusedIndex !== -1 ? focusedIndex : enabledRadios.findIndex(r => r.checked);\n let nextIndex: number;\n\n switch (e.key) {\n case 'ArrowDown':\n case 'ArrowRight':\n nextIndex = currentIndex === -1 ? 0 : (currentIndex + 1) % enabledRadios.length;\n break;\n case 'ArrowUp':\n case 'ArrowLeft':\n nextIndex = currentIndex === -1\n ? enabledRadios.length - 1\n : (currentIndex - 1 + enabledRadios.length) % enabledRadios.length;\n break;\n case 'Home':\n nextIndex = 0;\n break;\n case 'End':\n nextIndex = enabledRadios.length - 1;\n break;\n default:\n return;\n }\n\n const target = enabledRadios[nextIndex];\n if (!target) return;\n this._selectRadio(target);\n target.focus();\n }\n\n private _selectRadio(radio: CgRadio) {\n if (radio.value === this.value) return;\n\n this.value = radio.value;\n\n for (const r of this._radios) {\n r.checked = r === radio;\n }\n this._updateTabindex();\n\n this.dispatchEvent(new CustomEvent('cg-change', {\n detail: { value: radio.value },\n bubbles: true,\n composed: true,\n }));\n }\n\n override updated(changed: Map<string, unknown>) {\n if (changed.has('value') || changed.has('name') || changed.has('disabled')) {\n this._syncRadios();\n }\n }\n\n override render() {\n return html`\n ${this.label ? html`<div class=\"label\" id=\"group-label\">${this.label}</div>` : nothing}\n <div\n class=\"group\"\n role=\"radiogroup\"\n aria-labelledby=${this.label ? 'group-label' : nothing}\n aria-orientation=${this.orientation}\n @cg-change=${this._handleChange}\n @keydown=${this._handleKeydown}\n >\n <slot @slotchange=${this._handleSlotChange}></slot>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap { 'cg-radio-group': CgRadioGroup; }\n}\n"],"names":["CgRadioGroup","LitElement","slot","el","radio","enabledRadios","r","focusTarget","detail","newValue","focusedIndex","currentIndex","nextIndex","target","changed","html","nothing","hostBlock","reducedMotion","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cg-rating.d.ts","sourceRoot":"","sources":["../../../src/components/cg-rating/cg-rating.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD;;;;;;;;;;;GAWG;AACH,qBACa,QAAS,SAAQ,UAAU;IACtC,OAAgB,MAAM,4BA4DnB;IAEH,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAAC,CAAmB;;IASV,KAAK,SAAK;IACV,GAAG,SAAK;IACR,SAAS,EAAE,GAAG,GAAG,CAAC,CAAK;IACP,QAAQ,UAAS;IACjB,QAAQ,UAAS;IAChC,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IACjD,IAAI,SAAM;IAEb,OAAO,CAAC,WAAW,CAAK;IAExB,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAMrD,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,YAAY;IAQpB,OAAO,CAAC,YAAY;IAmBpB,OAAO,CAAC,gBAAgB;IAYxB,OAAO,CAAC,iBAAiB;IAIzB,OAAO,CAAC,cAAc;IA6Bb,MAAM;
|
|
1
|
+
{"version":3,"file":"cg-rating.d.ts","sourceRoot":"","sources":["../../../src/components/cg-rating/cg-rating.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAsB,MAAM,KAAK,CAAC;AAIrD;;;;;;;;;;;GAWG;AACH,qBACa,QAAS,SAAQ,UAAU;IACtC,OAAgB,MAAM,4BA4DnB;IAEH,MAAM,CAAC,cAAc,UAAQ;IAC7B,OAAO,CAAC,UAAU,CAAC,CAAmB;;IASV,KAAK,SAAK;IACV,GAAG,SAAK;IACR,SAAS,EAAE,GAAG,GAAG,CAAC,CAAK;IACP,QAAQ,UAAS;IACjB,QAAQ,UAAS;IAChC,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAQ;IACjD,IAAI,SAAM;IAEb,OAAO,CAAC,WAAW,CAAK;IAExB,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAMrD,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,YAAY;IAQpB,OAAO,CAAC,YAAY;IAmBpB,OAAO,CAAC,gBAAgB;IAYxB,OAAO,CAAC,iBAAiB;IAIzB,OAAO,CAAC,cAAc;IA6Bb,MAAM;CA2ChB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,WAAW,EAAE,QAAQ,CAAC;KACvB;CACF"}
|