@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,21 +1,14 @@
|
|
|
1
|
-
import { css as
|
|
2
|
-
import { property as
|
|
3
|
-
import { h as
|
|
4
|
-
|
|
5
|
-
var
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
return l && s && m(o, n, s), s;
|
|
1
|
+
import { css as v, LitElement as u, nothing as c, html as e } from "lit";
|
|
2
|
+
import { property as s, customElement as h } from "lit/decorators.js";
|
|
3
|
+
import { h as p, r as b, f } from "../../chunks/premium.css-DHekUEUt.js";
|
|
4
|
+
var m = Object.defineProperty, w = Object.getOwnPropertyDescriptor, r = (g, i, l, o) => {
|
|
5
|
+
for (var t = o > 1 ? void 0 : o ? w(i, l) : i, n = g.length - 1, d; n >= 0; n--)
|
|
6
|
+
(d = g[n]) && (t = (o ? d(i, l, t) : d(t)) || t);
|
|
7
|
+
return o && t && m(i, l, t), t;
|
|
9
8
|
};
|
|
10
|
-
let
|
|
9
|
+
let a = class extends u {
|
|
11
10
|
constructor() {
|
|
12
|
-
super(...arguments), this.status = "disabled", this.hitRate = 0, this.latencySaved = "", this.cacheAge = "", this.
|
|
13
|
-
}
|
|
14
|
-
get _hitRateTier() {
|
|
15
|
-
return this.hitRate < 50 ? "tier-low" : this.hitRate < 80 ? "tier-mid" : "tier-high";
|
|
16
|
-
}
|
|
17
|
-
_formatTokens(a) {
|
|
18
|
-
return a >= 1e6 ? `${(a / 1e6).toFixed(1)}M` : a >= 1e3 ? `${(a / 1e3).toFixed(1)}K` : `${a}`;
|
|
11
|
+
super(...arguments), this.status = "disabled", this.hitRate = 0, this.latencySaved = "", this.cacheAge = "", this.showDetails = !1;
|
|
19
12
|
}
|
|
20
13
|
_toggleDetails() {
|
|
21
14
|
this.showDetails = !this.showDetails, this.dispatchEvent(new CustomEvent("ai-cache-detail", {
|
|
@@ -24,203 +17,112 @@ let t = class extends h {
|
|
|
24
17
|
composed: !0
|
|
25
18
|
}));
|
|
26
19
|
}
|
|
27
|
-
_onClear(
|
|
28
|
-
const o = a.currentTarget;
|
|
20
|
+
_onClear() {
|
|
29
21
|
this.dispatchEvent(new CustomEvent("ai-cache-clear", {
|
|
30
22
|
bubbles: !0,
|
|
31
23
|
composed: !0
|
|
32
|
-
}))
|
|
33
|
-
});
|
|
24
|
+
}));
|
|
34
25
|
}
|
|
35
26
|
render() {
|
|
36
|
-
|
|
37
|
-
return i`
|
|
27
|
+
return e`
|
|
38
28
|
<div class="wrapper">
|
|
39
29
|
<button
|
|
40
30
|
class="pill"
|
|
41
|
-
type="button"
|
|
42
31
|
@click=${this._toggleDetails}
|
|
43
|
-
aria-expanded=${this.showDetails
|
|
44
|
-
aria-label="Cache status: ${this.status}
|
|
32
|
+
aria-expanded=${this.showDetails}
|
|
33
|
+
aria-label="Cache status: ${this.status}"
|
|
45
34
|
>
|
|
46
|
-
<span class="dot ${this.status}"
|
|
35
|
+
<span class="dot ${this.status}"></span>
|
|
47
36
|
<span class="status-text">${this.status}</span>
|
|
48
|
-
${this.latencySaved && this.status === "hit" ?
|
|
49
|
-
<svg class="chevron" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
|
|
50
|
-
<path d="m6 9 6 6 6-6"/>
|
|
51
|
-
</svg>
|
|
37
|
+
${this.latencySaved && this.status === "hit" ? e`<span>${this.latencySaved}</span>` : c}
|
|
52
38
|
</button>
|
|
53
39
|
|
|
54
|
-
${this.showDetails ?
|
|
40
|
+
${this.showDetails ? e`
|
|
55
41
|
<div class="detail-card" role="region" aria-label="Cache details">
|
|
56
42
|
<div class="detail-row">
|
|
57
|
-
<span class="detail-label">Hit
|
|
43
|
+
<span class="detail-label">Hit Rate</span>
|
|
58
44
|
<span class="detail-value">${this.hitRate}%</span>
|
|
59
45
|
</div>
|
|
60
|
-
<div
|
|
61
|
-
class="rate-bar-
|
|
62
|
-
role="progressbar"
|
|
63
|
-
aria-valuenow=${this.hitRate}
|
|
64
|
-
aria-valuemin="0"
|
|
65
|
-
aria-valuemax="100"
|
|
66
|
-
aria-label="Cache hit rate"
|
|
67
|
-
>
|
|
68
|
-
<div class="rate-bar-fill ${this._hitRateTier}" style="width: ${a}%"></div>
|
|
46
|
+
<div class="rate-bar-track" role="progressbar" aria-valuenow=${this.hitRate} aria-valuemin="0" aria-valuemax="100">
|
|
47
|
+
<div class="rate-bar-fill" style="width:${Math.min(100, Math.max(0, this.hitRate))}%"></div>
|
|
69
48
|
</div>
|
|
70
49
|
|
|
71
|
-
${this.latencySaved ?
|
|
72
|
-
<div class="detail-row">
|
|
73
|
-
<span class="detail-label">Latency
|
|
74
|
-
<span class="detail-value success">${this.latencySaved}</span>
|
|
75
|
-
</div>
|
|
76
|
-
` : c}
|
|
77
|
-
|
|
78
|
-
${this.costSaved ? i`
|
|
79
|
-
<div class="detail-row">
|
|
80
|
-
<span class="detail-label">Cost saved</span>
|
|
81
|
-
<span class="detail-value success">${this.costSaved}</span>
|
|
82
|
-
</div>
|
|
83
|
-
` : c}
|
|
84
|
-
|
|
85
|
-
${this.tokensCached > 0 ? i`
|
|
86
|
-
<div class="detail-row">
|
|
87
|
-
<span class="detail-label">Tokens cached</span>
|
|
88
|
-
<span class="detail-value">${this._formatTokens(this.tokensCached)}</span>
|
|
50
|
+
${this.latencySaved ? e`
|
|
51
|
+
<div class="detail-row" style="margin-top:var(--cg-spacing-8);">
|
|
52
|
+
<span class="detail-label">Latency Saved</span>
|
|
53
|
+
<span class="detail-value" style="color:var(--cg-color-status-success-text-default)">${this.latencySaved}</span>
|
|
89
54
|
</div>
|
|
90
55
|
` : c}
|
|
91
56
|
|
|
92
|
-
${this.cacheAge ?
|
|
57
|
+
${this.cacheAge ? e`
|
|
93
58
|
<div class="detail-row">
|
|
94
|
-
<span class="detail-label">Cache
|
|
59
|
+
<span class="detail-label">Cache Age</span>
|
|
95
60
|
<span class="detail-value">${this.cacheAge}</span>
|
|
96
61
|
</div>
|
|
97
62
|
` : c}
|
|
98
63
|
|
|
99
|
-
<
|
|
100
|
-
|
|
101
|
-
<span class="clear-slot">
|
|
102
|
-
<cg-button
|
|
103
|
-
variant="secondary"
|
|
104
|
-
size="sm"
|
|
105
|
-
type="danger"
|
|
106
|
-
full
|
|
107
|
-
success-message="Cache cleared"
|
|
108
|
-
error-message="Clear failed"
|
|
109
|
-
@click=${this._onClear}
|
|
110
|
-
>Clear cache</cg-button>
|
|
111
|
-
</span>
|
|
64
|
+
<div class="divider"></div>
|
|
65
|
+
<button class="clear-btn" @click=${this._onClear} aria-label="Clear cache">Clear Cache</button>
|
|
112
66
|
</div>
|
|
113
67
|
` : c}
|
|
114
68
|
</div>
|
|
115
69
|
`;
|
|
116
70
|
}
|
|
117
71
|
};
|
|
118
|
-
|
|
72
|
+
a.styles = [p, b, f, v`
|
|
119
73
|
:host {
|
|
120
74
|
display: inline-flex;
|
|
121
75
|
}
|
|
122
76
|
:host([hidden]) { display: none; }
|
|
123
77
|
|
|
124
|
-
/* ── Pill ── */
|
|
125
78
|
.pill {
|
|
126
|
-
position: relative;
|
|
127
79
|
display: inline-flex;
|
|
128
80
|
align-items: center;
|
|
129
|
-
gap: var(--cg-spacing-
|
|
130
|
-
|
|
131
|
-
padding: var(--cg-spacing-6) var(--cg-spacing-12);
|
|
81
|
+
gap: var(--cg-spacing-6);
|
|
82
|
+
padding: var(--cg-spacing-4) var(--cg-spacing-12);
|
|
132
83
|
background: var(--cg-color-surface-cards-background);
|
|
133
84
|
border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
|
|
134
85
|
border-radius: var(--cg-border-radius-full);
|
|
135
86
|
cursor: pointer;
|
|
136
|
-
|
|
87
|
+
transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
|
|
137
88
|
font-size: var(--cg-font-size-xs);
|
|
138
89
|
color: var(--cg-color-input-text-placeholder);
|
|
139
|
-
transition:
|
|
140
|
-
border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
|
|
141
|
-
transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
|
|
142
90
|
}
|
|
143
91
|
.pill:hover {
|
|
144
|
-
border-color: var(--cg-color-surface-cards-border
|
|
145
|
-
}
|
|
146
|
-
.pill:active {
|
|
147
|
-
transform: scale(var(--cg-interaction-press-scale));
|
|
92
|
+
border-color: var(--cg-color-surface-cards-border);
|
|
148
93
|
}
|
|
149
94
|
.pill:focus-visible {
|
|
150
95
|
outline: none;
|
|
151
96
|
box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
|
|
152
97
|
}
|
|
153
|
-
/* Extends pointer hit area so the small pill still meets 44px target. */
|
|
154
|
-
.pill::before {
|
|
155
|
-
content: '';
|
|
156
|
-
position: absolute;
|
|
157
|
-
inset: calc(-1 * var(--cg-spacing-6));
|
|
158
|
-
}
|
|
159
98
|
|
|
160
|
-
/* ── Status dot ── */
|
|
161
99
|
.dot {
|
|
162
100
|
width: var(--cg-spacing-8);
|
|
163
101
|
height: var(--cg-spacing-8);
|
|
164
102
|
border-radius: var(--cg-border-radius-full);
|
|
165
103
|
flex-shrink: 0;
|
|
166
104
|
}
|
|
167
|
-
.dot.hit
|
|
168
|
-
.dot.miss
|
|
169
|
-
.dot.stale
|
|
170
|
-
.dot.disabled
|
|
171
|
-
.dot.loading
|
|
172
|
-
|
|
173
|
-
/* Pulse on loading + hit so the indicator feels alive. ease-in-out
|
|
174
|
-
gives a symmetric breath; ease-default (=ease) had a fast-out
|
|
175
|
-
slow-in cadence that felt off-beat. */
|
|
176
|
-
.dot.loading,
|
|
177
|
-
.dot.hit {
|
|
178
|
-
animation: cg-cache-pulse 2s var(--cg-transition-easing-ease-in-out) infinite;
|
|
179
|
-
}
|
|
180
|
-
@keyframes cg-cache-pulse {
|
|
181
|
-
0%, 100% { opacity: 1; transform: scale(1); }
|
|
182
|
-
50% { opacity: 0.55; transform: scale(0.82); }
|
|
183
|
-
}
|
|
105
|
+
.dot.hit { background: var(--cg-color-ai-cached-text); }
|
|
106
|
+
.dot.miss { background: var(--cg-color-status-error-text-default); }
|
|
107
|
+
.dot.stale { background: var(--cg-color-status-warning-text-default); }
|
|
108
|
+
.dot.disabled { background: var(--cg-color-input-text-placeholder); }
|
|
109
|
+
.dot.loading { background: var(--cg-color-status-info-text-default); }
|
|
184
110
|
|
|
185
111
|
.status-text {
|
|
186
112
|
font-weight: var(--cg-font-weight-semibold);
|
|
187
113
|
text-transform: capitalize;
|
|
188
|
-
color: var(--cg-color-surface-base-text);
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
.latency {
|
|
192
|
-
color: var(--cg-color-status-success-text-default);
|
|
193
|
-
font-variant-numeric: tabular-nums;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
.chevron {
|
|
197
|
-
width: var(--cg-icon-size-100);
|
|
198
|
-
height: var(--cg-icon-size-100);
|
|
199
|
-
color: var(--cg-color-input-text-placeholder);
|
|
200
|
-
transition: transform var(--cg-transition-duration-default) var(--cg-transition-easing-spring);
|
|
201
|
-
margin-left: auto;
|
|
202
|
-
flex-shrink: 0;
|
|
203
114
|
}
|
|
204
|
-
:host([show-details]) .chevron { transform: rotate(180deg); }
|
|
205
115
|
|
|
206
116
|
/* ── Detail card ── */
|
|
207
117
|
.detail-card {
|
|
208
118
|
margin-top: var(--cg-spacing-8);
|
|
209
119
|
background: var(--cg-color-surface-cards-background);
|
|
210
120
|
border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
|
|
211
|
-
border-radius: var(--cg-border-radius-
|
|
212
|
-
box-shadow: var(--cg-elevation-1);
|
|
121
|
+
border-radius: var(--cg-border-radius-200);
|
|
213
122
|
padding: var(--cg-spacing-16);
|
|
214
123
|
color: var(--cg-color-surface-base-text);
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
animation: cg-cache-detail-pop var(--cg-transition-duration-default) var(--cg-transition-easing-spring) both;
|
|
218
|
-
min-width: 260px;
|
|
219
|
-
transform-origin: top left;
|
|
220
|
-
}
|
|
221
|
-
@keyframes cg-cache-detail-pop {
|
|
222
|
-
from { opacity: 0; transform: translateY(-4px) scale(0.98); }
|
|
223
|
-
to { opacity: 1; transform: translateY(0) scale(1); }
|
|
124
|
+
animation: fadeSlideIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;
|
|
125
|
+
min-width: var(--cg-spacing-256);
|
|
224
126
|
}
|
|
225
127
|
|
|
226
128
|
.detail-row {
|
|
@@ -228,9 +130,7 @@ t.styles = [v, f, b, u`
|
|
|
228
130
|
justify-content: space-between;
|
|
229
131
|
align-items: center;
|
|
230
132
|
padding: var(--cg-spacing-6) 0;
|
|
231
|
-
gap: var(--cg-spacing-12);
|
|
232
133
|
}
|
|
233
|
-
.detail-row + .detail-row { margin-top: var(--cg-spacing-2); }
|
|
234
134
|
|
|
235
135
|
.detail-label {
|
|
236
136
|
font-size: var(--cg-font-size-xs);
|
|
@@ -240,75 +140,80 @@ t.styles = [v, f, b, u`
|
|
|
240
140
|
.detail-value {
|
|
241
141
|
font-size: var(--cg-font-size-sm);
|
|
242
142
|
font-weight: var(--cg-font-weight-semibold);
|
|
243
|
-
font-variant-numeric: tabular-nums;
|
|
244
143
|
}
|
|
245
|
-
.detail-value.success { color: var(--cg-color-status-success-text-default); }
|
|
246
144
|
|
|
247
|
-
/* ── Hit
|
|
145
|
+
/* ── Hit rate bar ── */
|
|
248
146
|
.rate-bar-track {
|
|
249
147
|
height: var(--cg-spacing-6);
|
|
250
148
|
background: var(--cg-color-surface-cards-divider);
|
|
251
149
|
border-radius: var(--cg-border-radius-50);
|
|
252
150
|
overflow: hidden;
|
|
253
|
-
margin-top: var(--cg-spacing-
|
|
151
|
+
margin-top: var(--cg-spacing-6);
|
|
254
152
|
}
|
|
153
|
+
|
|
255
154
|
.rate-bar-fill {
|
|
256
155
|
height: 100%;
|
|
156
|
+
background: var(--cg-color-ai-cached-text);
|
|
257
157
|
border-radius: var(--cg-border-radius-50);
|
|
258
|
-
transition:
|
|
259
|
-
width var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out),
|
|
260
|
-
background-color var(--cg-transition-duration-default) var(--cg-transition-easing-default);
|
|
158
|
+
transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);
|
|
261
159
|
}
|
|
262
|
-
.rate-bar-fill.tier-low { background: var(--cg-color-status-error-text-default); }
|
|
263
|
-
.rate-bar-fill.tier-mid { background: var(--cg-color-status-warning-text-default); }
|
|
264
|
-
.rate-bar-fill.tier-high { background: var(--cg-color-status-success-text-default); }
|
|
265
160
|
|
|
266
161
|
.divider {
|
|
267
162
|
height: var(--cg-border-width-50);
|
|
268
163
|
background: var(--cg-color-surface-cards-divider);
|
|
269
164
|
margin: var(--cg-spacing-12) 0;
|
|
270
|
-
border: none;
|
|
271
165
|
}
|
|
272
166
|
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
167
|
+
.clear-btn {
|
|
168
|
+
width: 100%;
|
|
169
|
+
background: transparent;
|
|
170
|
+
border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
|
|
171
|
+
color: var(--cg-color-input-text-placeholder);
|
|
172
|
+
font-size: var(--cg-font-size-xs);
|
|
173
|
+
font-weight: var(--cg-font-weight-semibold);
|
|
174
|
+
padding: var(--cg-spacing-8);
|
|
175
|
+
border-radius: var(--cg-border-radius-100);
|
|
176
|
+
cursor: pointer;
|
|
177
|
+
transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),
|
|
178
|
+
color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
|
|
179
|
+
}
|
|
180
|
+
.clear-btn:hover {
|
|
181
|
+
border-color: var(--cg-color-status-error-text-default);
|
|
182
|
+
color: var(--cg-color-status-error-text-default);
|
|
183
|
+
}
|
|
184
|
+
.clear-btn:focus-visible {
|
|
185
|
+
outline: none;
|
|
186
|
+
box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
@media (prefers-reduced-motion: reduce) {
|
|
190
|
+
.detail-card { animation: none; }
|
|
191
|
+
}
|
|
278
192
|
|
|
279
193
|
.wrapper {
|
|
280
194
|
display: inline-flex;
|
|
281
195
|
flex-direction: column;
|
|
282
196
|
}
|
|
283
197
|
`];
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
],
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
],
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
],
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
],
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
],
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
],
|
|
302
|
-
e([
|
|
303
|
-
r({ type: Boolean, attribute: "show-details", reflect: !0 })
|
|
304
|
-
], t.prototype, "showDetails", 2);
|
|
305
|
-
e([
|
|
306
|
-
r({ attribute: !1 })
|
|
307
|
-
], t.prototype, "clearAction", 2);
|
|
308
|
-
t = e([
|
|
309
|
-
p("ai-cache-indicator")
|
|
310
|
-
], t);
|
|
198
|
+
r([
|
|
199
|
+
s({ type: String })
|
|
200
|
+
], a.prototype, "status", 2);
|
|
201
|
+
r([
|
|
202
|
+
s({ type: Number })
|
|
203
|
+
], a.prototype, "hitRate", 2);
|
|
204
|
+
r([
|
|
205
|
+
s({ type: String })
|
|
206
|
+
], a.prototype, "latencySaved", 2);
|
|
207
|
+
r([
|
|
208
|
+
s({ type: String })
|
|
209
|
+
], a.prototype, "cacheAge", 2);
|
|
210
|
+
r([
|
|
211
|
+
s({ type: Boolean })
|
|
212
|
+
], a.prototype, "showDetails", 2);
|
|
213
|
+
a = r([
|
|
214
|
+
h("ai-cache-indicator")
|
|
215
|
+
], a);
|
|
311
216
|
export {
|
|
312
|
-
|
|
217
|
+
a as AiCacheIndicator
|
|
313
218
|
};
|
|
314
219
|
//# sourceMappingURL=ai-cache-indicator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ai-cache-indicator.js","sources":["../../../src/components/ai-cache-indicator/ai-cache-indicator.ts"],"sourcesContent":["/**\n * @element ai-cache-indicator\n * Compact inline cache-status pill with an expandable detail card.\n *\n * Shows the current cache state (hit/miss/stale/disabled/loading) as a\n * colored dot, optional latency-saved on hits, and on click reveals a\n * detail card with hit-rate bar (color-tiered), cost saved, tokens cached,\n * and a \"Clear Cache\" button. Mirrors the metrics surfaced by OpenAI's\n * `cached_tokens` / Anthropic's `cache_read_input_tokens` so consumers can\n * map provider responses 1:1.\n *\n * @example\n * ```html\n * <ai-cache-indicator\n * status=\"hit\"\n * hit-rate=\"87\"\n * latency-saved=\"240 ms\"\n * cache-age=\"2 min ago\"\n * tokens-cached=\"2400\"\n * cost-saved=\"$0.04\"\n * ></ai-cache-indicator>\n * ```\n *\n * @fires {CustomEvent} ai-cache-clear - Clear Cache clicked\n * @fires {CustomEvent<{status, hitRate}>} ai-cache-detail - Detail panel toggled\n *\n * @cssprop [--cg-color-surface-cards-background] - Pill background\n * @cssprop [--cg-color-status-success-text-default] - Hit dot + bar high-tier color\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n// Dogfood: clear-cache action uses our own <cg-button> instead of a native\n// <button>. Free press-scale, focus ring, type=\"danger\" styling, and\n// runAction() async lifecycle if the consumer wires one up via clearAction.\nimport '../cg-button/cg-button.js';\nimport type { CgButton } from '../cg-button/cg-button.js';\n\n@customElement('ai-cache-indicator')\nexport class AiCacheIndicator extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n display: inline-flex;\n }\n :host([hidden]) { display: none; }\n\n /* ── Pill ── */\n .pill {\n position: relative;\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-8);\n min-height: var(--cg-spacing-32);\n padding: var(--cg-spacing-6) var(--cg-spacing-12);\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-full);\n cursor: pointer;\n font-family: inherit;\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n transition:\n border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n transform var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .pill:hover {\n border-color: var(--cg-color-surface-cards-border-strong);\n }\n .pill:active {\n transform: scale(var(--cg-interaction-press-scale));\n }\n .pill:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n /* Extends pointer hit area so the small pill still meets 44px target. */\n .pill::before {\n content: '';\n position: absolute;\n inset: calc(-1 * var(--cg-spacing-6));\n }\n\n /* ── Status dot ── */\n .dot {\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n flex-shrink: 0;\n }\n .dot.hit { background: var(--cg-color-status-success-text-default); }\n .dot.miss { background: var(--cg-color-status-error-text-default); }\n .dot.stale { background: var(--cg-color-status-warning-text-default); }\n .dot.disabled { background: var(--cg-color-input-text-placeholder); }\n .dot.loading { background: var(--cg-color-status-info-text-default); }\n\n /* Pulse on loading + hit so the indicator feels alive. ease-in-out\n gives a symmetric breath; ease-default (=ease) had a fast-out\n slow-in cadence that felt off-beat. */\n .dot.loading,\n .dot.hit {\n animation: cg-cache-pulse 2s var(--cg-transition-easing-ease-in-out) infinite;\n }\n @keyframes cg-cache-pulse {\n 0%, 100% { opacity: 1; transform: scale(1); }\n 50% { opacity: 0.55; transform: scale(0.82); }\n }\n\n .status-text {\n font-weight: var(--cg-font-weight-semibold);\n text-transform: capitalize;\n color: var(--cg-color-surface-base-text);\n }\n\n .latency {\n color: var(--cg-color-status-success-text-default);\n font-variant-numeric: tabular-nums;\n }\n\n .chevron {\n width: var(--cg-icon-size-100);\n height: var(--cg-icon-size-100);\n color: var(--cg-color-input-text-placeholder);\n transition: transform var(--cg-transition-duration-default) var(--cg-transition-easing-spring);\n margin-left: auto;\n flex-shrink: 0;\n }\n :host([show-details]) .chevron { transform: rotate(180deg); }\n\n /* ── Detail card ── */\n .detail-card {\n margin-top: var(--cg-spacing-8);\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-150);\n box-shadow: var(--cg-elevation-1);\n padding: var(--cg-spacing-16);\n color: var(--cg-color-surface-base-text);\n /* Spring easing gives a slight overshoot — feels responsive instead\n of just sliding in. */\n animation: cg-cache-detail-pop var(--cg-transition-duration-default) var(--cg-transition-easing-spring) both;\n min-width: 260px;\n transform-origin: top left;\n }\n @keyframes cg-cache-detail-pop {\n from { opacity: 0; transform: translateY(-4px) scale(0.98); }\n to { opacity: 1; transform: translateY(0) scale(1); }\n }\n\n .detail-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: var(--cg-spacing-6) 0;\n gap: var(--cg-spacing-12);\n }\n .detail-row + .detail-row { margin-top: var(--cg-spacing-2); }\n\n .detail-label {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n }\n\n .detail-value {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n font-variant-numeric: tabular-nums;\n }\n .detail-value.success { color: var(--cg-color-status-success-text-default); }\n\n /* ── Hit-rate bar — color-tiered by value ── */\n .rate-bar-track {\n height: var(--cg-spacing-6);\n background: var(--cg-color-surface-cards-divider);\n border-radius: var(--cg-border-radius-50);\n overflow: hidden;\n margin-top: var(--cg-spacing-8);\n }\n .rate-bar-fill {\n height: 100%;\n border-radius: var(--cg-border-radius-50);\n transition:\n width var(--cg-transition-duration-slow) var(--cg-transition-easing-ease-out),\n background-color var(--cg-transition-duration-default) var(--cg-transition-easing-default);\n }\n .rate-bar-fill.tier-low { background: var(--cg-color-status-error-text-default); }\n .rate-bar-fill.tier-mid { background: var(--cg-color-status-warning-text-default); }\n .rate-bar-fill.tier-high { background: var(--cg-color-status-success-text-default); }\n\n .divider {\n height: var(--cg-border-width-50);\n background: var(--cg-color-surface-cards-divider);\n margin: var(--cg-spacing-12) 0;\n border: none;\n }\n\n /* The Clear button is composed from <cg-button>, so we don't\n maintain pill/border/focus styles here. The wrapper just gives\n it full width inside the detail card. */\n .clear-slot { width: 100%; display: block; }\n .clear-slot cg-button { width: 100%; }\n\n .wrapper {\n display: inline-flex;\n flex-direction: column;\n }\n `];\n\n @property({ type: String }) status: 'hit' | 'miss' | 'stale' | 'disabled' | 'loading' = 'disabled';\n @property({ type: Number, attribute: 'hit-rate' }) hitRate = 0;\n @property({ type: String, attribute: 'latency-saved' }) latencySaved = '';\n @property({ type: String, attribute: 'cache-age' }) cacheAge = '';\n /** Optional: tokens served from cache. Surfaces OpenAI's cached_tokens / Anthropic's cache_read_input_tokens. */\n @property({ type: Number, attribute: 'tokens-cached' }) tokensCached = 0;\n /** Optional: dollar cost saved, formatted by the consumer (e.g. \"$0.04\"). */\n @property({ type: String, attribute: 'cost-saved' }) costSaved = '';\n @property({ type: Boolean, attribute: 'show-details', reflect: true }) showDetails = false;\n /**\n * Optional async clear handler. When provided, the Clear button uses\n * cg-button.runAction() so the user gets a spinner → ✓ / × pop on the\n * same button instead of a plain click. Without this prop we just fire\n * `ai-cache-clear` and let the consumer manage state.\n */\n @property({ attribute: false }) clearAction?: () => Promise<void>;\n\n private get _hitRateTier(): 'tier-low' | 'tier-mid' | 'tier-high' {\n if (this.hitRate < 50) return 'tier-low';\n if (this.hitRate < 80) return 'tier-mid';\n return 'tier-high';\n }\n\n private _formatTokens(n: number): string {\n if (n >= 1_000_000) return `${(n / 1_000_000).toFixed(1)}M`;\n if (n >= 1000) return `${(n / 1000).toFixed(1)}K`;\n return `${n}`;\n }\n\n private _toggleDetails(): void {\n this.showDetails = !this.showDetails;\n this.dispatchEvent(new CustomEvent('ai-cache-detail', {\n detail: { status: this.status, hitRate: this.hitRate },\n bubbles: true, composed: true,\n }));\n }\n\n private _onClear(e: Event): void {\n const btn = e.currentTarget as CgButton;\n this.dispatchEvent(new CustomEvent('ai-cache-clear', {\n bubbles: true, composed: true,\n }));\n if (this.clearAction) {\n btn.runAction(() => this.clearAction!()).catch(() => {\n /* runAction re-throws so callers can chain; we already showed\n the error pop on the button — swallow here. */\n });\n }\n }\n\n override render() {\n const clamped = Math.min(100, Math.max(0, this.hitRate));\n\n return html`\n <div class=\"wrapper\">\n <button\n class=\"pill\"\n type=\"button\"\n @click=${this._toggleDetails}\n aria-expanded=${this.showDetails ? 'true' : 'false'}\n aria-label=\"Cache status: ${this.status}. ${this.showDetails ? 'Hide' : 'Show'} details.\"\n >\n <span class=\"dot ${this.status}\" aria-hidden=\"true\"></span>\n <span class=\"status-text\">${this.status}</span>\n ${this.latencySaved && this.status === 'hit' ? html`<span class=\"latency\">−${this.latencySaved}</span>` : nothing}\n <svg class=\"chevron\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">\n <path d=\"m6 9 6 6 6-6\"/>\n </svg>\n </button>\n\n ${this.showDetails ? html`\n <div class=\"detail-card\" role=\"region\" aria-label=\"Cache details\">\n <div class=\"detail-row\">\n <span class=\"detail-label\">Hit rate</span>\n <span class=\"detail-value\">${this.hitRate}%</span>\n </div>\n <div\n class=\"rate-bar-track\"\n role=\"progressbar\"\n aria-valuenow=${this.hitRate}\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n aria-label=\"Cache hit rate\"\n >\n <div class=\"rate-bar-fill ${this._hitRateTier}\" style=\"width: ${clamped}%\"></div>\n </div>\n\n ${this.latencySaved ? html`\n <div class=\"detail-row\">\n <span class=\"detail-label\">Latency saved</span>\n <span class=\"detail-value success\">${this.latencySaved}</span>\n </div>\n ` : nothing}\n\n ${this.costSaved ? html`\n <div class=\"detail-row\">\n <span class=\"detail-label\">Cost saved</span>\n <span class=\"detail-value success\">${this.costSaved}</span>\n </div>\n ` : nothing}\n\n ${this.tokensCached > 0 ? html`\n <div class=\"detail-row\">\n <span class=\"detail-label\">Tokens cached</span>\n <span class=\"detail-value\">${this._formatTokens(this.tokensCached)}</span>\n </div>\n ` : nothing}\n\n ${this.cacheAge ? html`\n <div class=\"detail-row\">\n <span class=\"detail-label\">Cache age</span>\n <span class=\"detail-value\">${this.cacheAge}</span>\n </div>\n ` : nothing}\n\n <hr class=\"divider\" aria-hidden=\"true\" />\n\n <span class=\"clear-slot\">\n <cg-button\n variant=\"secondary\"\n size=\"sm\"\n type=\"danger\"\n full\n success-message=\"Cache cleared\"\n error-message=\"Clear failed\"\n @click=${this._onClear}\n >Clear cache</cg-button>\n </span>\n </div>\n ` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-cache-indicator': AiCacheIndicator;\n }\n}\n"],"names":["AiCacheIndicator","LitElement","n","e","btn","clamped","html","nothing","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ai-cache-indicator.js","sources":["../../../src/components/ai-cache-indicator/ai-cache-indicator.ts"],"sourcesContent":["/**\n * @element ai-cache-indicator\n * Compact inline cache status indicator with optional expanded detail card.\n *\n * @example\n * ```html\n * <ai-cache-indicator status=\"hit\" hitRate=\"87\" latencySaved=\"240ms\" cacheAge=\"2m ago\"></ai-cache-indicator>\n * ```\n *\n * @fires {CustomEvent} ai-cache-clear - Clear cache clicked\n * @fires {CustomEvent<{status, hitRate}>} ai-cache-detail - Detail panel toggled\n *\n * @cssprop [--cg-brand-ai-accent=#dfff61] - Accent for hit rate bar\n */\nimport { LitElement, html, css, nothing } from 'lit';\nimport { property, customElement } from 'lit/decorators.js';\nimport { hostBlock, reducedMotion, fadeSlideInKeyframes } from '../../styles/index.js';\n\n@customElement('ai-cache-indicator')\nexport class AiCacheIndicator extends LitElement {\n static override styles = [hostBlock, reducedMotion, fadeSlideInKeyframes, css`\n :host {\n display: inline-flex;\n }\n :host([hidden]) { display: none; }\n\n .pill {\n display: inline-flex;\n align-items: center;\n gap: var(--cg-spacing-6);\n padding: var(--cg-spacing-4) var(--cg-spacing-12);\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-full);\n cursor: pointer;\n transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n }\n .pill:hover {\n border-color: var(--cg-color-surface-cards-border);\n }\n .pill:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n .dot {\n width: var(--cg-spacing-8);\n height: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-full);\n flex-shrink: 0;\n }\n .dot.hit { background: var(--cg-color-ai-cached-text); }\n .dot.miss { background: var(--cg-color-status-error-text-default); }\n .dot.stale { background: var(--cg-color-status-warning-text-default); }\n .dot.disabled { background: var(--cg-color-input-text-placeholder); }\n .dot.loading { background: var(--cg-color-status-info-text-default); }\n\n .status-text {\n font-weight: var(--cg-font-weight-semibold);\n text-transform: capitalize;\n }\n\n /* ── Detail card ── */\n .detail-card {\n margin-top: var(--cg-spacing-8);\n background: var(--cg-color-surface-cards-background);\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n border-radius: var(--cg-border-radius-200);\n padding: var(--cg-spacing-16);\n color: var(--cg-color-surface-base-text);\n animation: fadeSlideIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;\n min-width: var(--cg-spacing-256);\n }\n\n .detail-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: var(--cg-spacing-6) 0;\n }\n\n .detail-label {\n font-size: var(--cg-font-size-xs);\n color: var(--cg-color-input-text-placeholder);\n }\n\n .detail-value {\n font-size: var(--cg-font-size-sm);\n font-weight: var(--cg-font-weight-semibold);\n }\n\n /* ── Hit rate bar ── */\n .rate-bar-track {\n height: var(--cg-spacing-6);\n background: var(--cg-color-surface-cards-divider);\n border-radius: var(--cg-border-radius-50);\n overflow: hidden;\n margin-top: var(--cg-spacing-6);\n }\n\n .rate-bar-fill {\n height: 100%;\n background: var(--cg-color-ai-cached-text);\n border-radius: var(--cg-border-radius-50);\n transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);\n }\n\n .divider {\n height: var(--cg-border-width-50);\n background: var(--cg-color-surface-cards-divider);\n margin: var(--cg-spacing-12) 0;\n }\n\n .clear-btn {\n width: 100%;\n background: transparent;\n border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);\n color: var(--cg-color-input-text-placeholder);\n font-size: var(--cg-font-size-xs);\n font-weight: var(--cg-font-weight-semibold);\n padding: var(--cg-spacing-8);\n border-radius: var(--cg-border-radius-100);\n cursor: pointer;\n transition: border-color var(--cg-transition-duration-fast) var(--cg-transition-easing-default),\n color var(--cg-transition-duration-fast) var(--cg-transition-easing-default);\n }\n .clear-btn:hover {\n border-color: var(--cg-color-status-error-text-default);\n color: var(--cg-color-status-error-text-default);\n }\n .clear-btn:focus-visible {\n outline: none;\n box-shadow: 0 0 0 3px var(--cg-overlay-accent-strong);\n }\n\n @media (prefers-reduced-motion: reduce) {\n .detail-card { animation: none; }\n }\n\n .wrapper {\n display: inline-flex;\n flex-direction: column;\n }\n `];\n\n @property({ type: String }) status: 'hit' | 'miss' | 'stale' | 'disabled' | 'loading' = 'disabled';\n @property({ type: Number }) hitRate = 0;\n @property({ type: String }) latencySaved = '';\n @property({ type: String }) cacheAge = '';\n @property({ type: Boolean }) showDetails = false;\n\n private _toggleDetails() {\n this.showDetails = !this.showDetails;\n this.dispatchEvent(new CustomEvent('ai-cache-detail', {\n detail: { status: this.status, hitRate: this.hitRate },\n bubbles: true, composed: true,\n }));\n }\n\n private _onClear() {\n this.dispatchEvent(new CustomEvent('ai-cache-clear', {\n bubbles: true, composed: true,\n }));\n }\n\n override render() {\n return html`\n <div class=\"wrapper\">\n <button\n class=\"pill\"\n @click=${this._toggleDetails}\n aria-expanded=${this.showDetails}\n aria-label=\"Cache status: ${this.status}\"\n >\n <span class=\"dot ${this.status}\"></span>\n <span class=\"status-text\">${this.status}</span>\n ${this.latencySaved && this.status === 'hit' ? html`<span>${this.latencySaved}</span>` : nothing}\n </button>\n\n ${this.showDetails ? html`\n <div class=\"detail-card\" role=\"region\" aria-label=\"Cache details\">\n <div class=\"detail-row\">\n <span class=\"detail-label\">Hit Rate</span>\n <span class=\"detail-value\">${this.hitRate}%</span>\n </div>\n <div class=\"rate-bar-track\" role=\"progressbar\" aria-valuenow=${this.hitRate} aria-valuemin=\"0\" aria-valuemax=\"100\">\n <div class=\"rate-bar-fill\" style=\"width:${Math.min(100, Math.max(0, this.hitRate))}%\"></div>\n </div>\n\n ${this.latencySaved ? html`\n <div class=\"detail-row\" style=\"margin-top:var(--cg-spacing-8);\">\n <span class=\"detail-label\">Latency Saved</span>\n <span class=\"detail-value\" style=\"color:var(--cg-color-status-success-text-default)\">${this.latencySaved}</span>\n </div>\n ` : nothing}\n\n ${this.cacheAge ? html`\n <div class=\"detail-row\">\n <span class=\"detail-label\">Cache Age</span>\n <span class=\"detail-value\">${this.cacheAge}</span>\n </div>\n ` : nothing}\n\n <div class=\"divider\"></div>\n <button class=\"clear-btn\" @click=${this._onClear} aria-label=\"Clear cache\">Clear Cache</button>\n </div>\n ` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'ai-cache-indicator': AiCacheIndicator;\n }\n}\n"],"names":["AiCacheIndicator","LitElement","html","nothing","hostBlock","reducedMotion","fadeSlideInKeyframes","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { css as p, LitElement as
|
|
2
|
-
import { property as n, state as
|
|
3
|
-
import { h
|
|
1
|
+
import { css as p, LitElement as v, nothing as g, html as t } from "lit";
|
|
2
|
+
import { property as n, state as u, customElement as f } from "lit/decorators.js";
|
|
3
|
+
import { h, r as b, f as m } from "../../chunks/premium.css-DHekUEUt.js";
|
|
4
4
|
var w = Object.defineProperty, y = Object.getOwnPropertyDescriptor, c = (r, e, s, a) => {
|
|
5
5
|
for (var o = a > 1 ? void 0 : a ? y(e, s) : e, d = r.length - 1, l; d >= 0; d--)
|
|
6
6
|
(l = r[d]) && (o = (a ? l(e, s, o) : l(o)) || o);
|
|
7
7
|
return a && o && w(e, s, o), o;
|
|
8
8
|
};
|
|
9
|
-
const
|
|
10
|
-
let i = class extends
|
|
9
|
+
const _ = ["upload", "preview", "processing", "complete"];
|
|
10
|
+
let i = class extends v {
|
|
11
11
|
constructor() {
|
|
12
12
|
super(...arguments), this.step = "upload", this.accept = ".pdf,.jpg,.png", this.previewUrl = "", this.result = "", this.progress = 0, this.heading = "Capture", this._dragOver = !1;
|
|
13
13
|
}
|
|
@@ -33,7 +33,7 @@ let i = class extends u {
|
|
|
33
33
|
this.shadowRoot?.querySelector("#file-input")?.click();
|
|
34
34
|
}
|
|
35
35
|
_stepIndex() {
|
|
36
|
-
return this.step === "error" ? -1 :
|
|
36
|
+
return this.step === "error" ? -1 : _.indexOf(this.step);
|
|
37
37
|
}
|
|
38
38
|
_renderSteps() {
|
|
39
39
|
const r = this._stepIndex();
|
|
@@ -127,9 +127,9 @@ let i = class extends u {
|
|
|
127
127
|
`;
|
|
128
128
|
}
|
|
129
129
|
};
|
|
130
|
-
i.styles = [
|
|
130
|
+
i.styles = [h, b, m, p`
|
|
131
131
|
:host {
|
|
132
|
-
animation: fadeSlideIn
|
|
132
|
+
animation: fadeSlideIn var(--cg-transition-duration-default) var(--cg-transition-easing-ease-out) both;
|
|
133
133
|
}
|
|
134
134
|
|
|
135
135
|
.card {
|
|
@@ -180,7 +180,7 @@ i.styles = [b, h, m, p`
|
|
|
180
180
|
}
|
|
181
181
|
.step-line {
|
|
182
182
|
flex: 1;
|
|
183
|
-
height:
|
|
183
|
+
height: var(--cg-spacing-2);
|
|
184
184
|
background: var(--cg-color-surface-container-background);
|
|
185
185
|
transition: background var(--cg-transition-duration-default) var(--cg-transition-easing-default);
|
|
186
186
|
}
|
|
@@ -188,7 +188,7 @@ i.styles = [b, h, m, p`
|
|
|
188
188
|
|
|
189
189
|
/* ── Upload zone ── */
|
|
190
190
|
.upload-zone {
|
|
191
|
-
border:
|
|
191
|
+
border: var(--cg-border-width-100) dashed var(--cg-color-surface-cards-border);
|
|
192
192
|
border-radius: var(--cg-border-radius-100);
|
|
193
193
|
padding: var(--cg-spacing-24) var(--cg-spacing-16);
|
|
194
194
|
text-align: center;
|
|
@@ -200,14 +200,14 @@ i.styles = [b, h, m, p`
|
|
|
200
200
|
background: var(--cg-overlay-accent-subtle);
|
|
201
201
|
}
|
|
202
202
|
.upload-zone:focus-visible {
|
|
203
|
-
outline:
|
|
203
|
+
outline: var(--cg-border-width-100) solid var(--cg-color-focus-ring);
|
|
204
204
|
outline-offset: var(--cg-outline-offset-default);
|
|
205
205
|
}
|
|
206
206
|
.upload-icon { font-size: var(--cg-font-size-3xl); margin-bottom: var(--cg-spacing-8); }
|
|
207
207
|
.upload-text {
|
|
208
208
|
font-size: var(--cg-font-size-sm);
|
|
209
209
|
color: var(--cg-color-input-text-placeholder);
|
|
210
|
-
line-height:
|
|
210
|
+
line-height: var(--cg-line-height-normal);
|
|
211
211
|
}
|
|
212
212
|
.upload-hint {
|
|
213
213
|
font-size: var(--cg-font-size-xs);
|
|
@@ -220,7 +220,7 @@ i.styles = [b, h, m, p`
|
|
|
220
220
|
.preview { text-align: center; }
|
|
221
221
|
.preview-img {
|
|
222
222
|
max-width: 100%;
|
|
223
|
-
max-height: var(
|
|
223
|
+
max-height: var(--cg-spacing-256);
|
|
224
224
|
border-radius: var(--cg-border-radius-100);
|
|
225
225
|
border: var(--cg-border-width-50) solid var(--cg-color-surface-cards-border);
|
|
226
226
|
margin-bottom: var(--cg-spacing-16);
|
|
@@ -238,14 +238,14 @@ i.styles = [b, h, m, p`
|
|
|
238
238
|
width: 100%;
|
|
239
239
|
height: var(--cg-spacing-6);
|
|
240
240
|
background: var(--cg-color-surface-container-background);
|
|
241
|
-
border-radius: var(--cg-border-radius-
|
|
241
|
+
border-radius: var(--cg-border-radius-50);
|
|
242
242
|
overflow: hidden;
|
|
243
243
|
margin-bottom: var(--cg-spacing-8);
|
|
244
244
|
}
|
|
245
245
|
.progress-fill {
|
|
246
246
|
height: 100%;
|
|
247
247
|
background: var(--cg-color-action-primary-background-default);
|
|
248
|
-
border-radius: var(--cg-border-radius-
|
|
248
|
+
border-radius: var(--cg-border-radius-50);
|
|
249
249
|
transition: width var(--cg-transition-duration-slow) var(--cg-transition-easing-default);
|
|
250
250
|
}
|
|
251
251
|
.progress-pct {
|
|
@@ -259,19 +259,19 @@ i.styles = [b, h, m, p`
|
|
|
259
259
|
.result-icon {
|
|
260
260
|
font-size: var(--cg-font-size-2xl);
|
|
261
261
|
margin-bottom: var(--cg-spacing-8);
|
|
262
|
-
color: var(--cg-color-
|
|
262
|
+
color: var(--cg-color-ai-complete-text);
|
|
263
263
|
}
|
|
264
264
|
.result-text {
|
|
265
265
|
font-size: var(--cg-font-size-sm);
|
|
266
266
|
color: var(--cg-color-surface-base-text);
|
|
267
|
-
line-height:
|
|
267
|
+
line-height: var(--cg-line-height-normal);
|
|
268
268
|
margin-bottom: var(--cg-spacing-16);
|
|
269
269
|
white-space: pre-wrap;
|
|
270
270
|
}
|
|
271
271
|
|
|
272
272
|
/* ── Error ── */
|
|
273
|
-
.error-icon { color: var(--cg-color-
|
|
274
|
-
.error-text { color: var(--cg-color-
|
|
273
|
+
.error-icon { color: var(--cg-color-ai-error-text); }
|
|
274
|
+
.error-text { color: var(--cg-color-ai-error-text); }
|
|
275
275
|
|
|
276
276
|
/* ── Buttons ── */
|
|
277
277
|
.btn-row {
|
|
@@ -291,7 +291,7 @@ i.styles = [b, h, m, p`
|
|
|
291
291
|
transition: filter var(--cg-transition-duration-fast) var(--cg-transition-easing-default), background var(--cg-transition-duration-fast) var(--cg-transition-easing-default);
|
|
292
292
|
}
|
|
293
293
|
.btn-row button:focus-visible {
|
|
294
|
-
outline:
|
|
294
|
+
outline: var(--cg-border-width-100) solid var(--cg-color-focus-ring);
|
|
295
295
|
outline-offset: var(--cg-outline-offset-default);
|
|
296
296
|
}
|
|
297
297
|
.btn-primary {
|
|
@@ -325,7 +325,7 @@ c([
|
|
|
325
325
|
n({ type: String })
|
|
326
326
|
], i.prototype, "heading", 2);
|
|
327
327
|
c([
|
|
328
|
-
|
|
328
|
+
u()
|
|
329
329
|
], i.prototype, "_dragOver", 2);
|
|
330
330
|
i = c([
|
|
331
331
|
f("ai-capture-flow")
|