@syncular/ui 0.0.0
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/README.md +11 -0
- package/dist/charts/activity-chart.d.ts +11 -0
- package/dist/charts/activity-chart.d.ts.map +1 -0
- package/dist/charts/activity-chart.js +28 -0
- package/dist/charts/activity-chart.js.map +1 -0
- package/dist/charts/chart.d.ts +50 -0
- package/dist/charts/chart.d.ts.map +1 -0
- package/dist/charts/chart.js +108 -0
- package/dist/charts/chart.js.map +1 -0
- package/dist/charts/index.d.ts +5 -0
- package/dist/charts/index.d.ts.map +1 -0
- package/dist/charts/index.js +5 -0
- package/dist/charts/index.js.map +1 -0
- package/dist/charts/latency-chart.d.ts +15 -0
- package/dist/charts/latency-chart.d.ts.map +1 -0
- package/dist/charts/latency-chart.js +25 -0
- package/dist/charts/latency-chart.js.map +1 -0
- package/dist/charts/outcomes-chart.d.ts +11 -0
- package/dist/charts/outcomes-chart.d.ts.map +1 -0
- package/dist/charts/outcomes-chart.js +37 -0
- package/dist/charts/outcomes-chart.js.map +1 -0
- package/dist/console/activity-bars.d.ts +24 -0
- package/dist/console/activity-bars.d.ts.map +1 -0
- package/dist/console/activity-bars.js +25 -0
- package/dist/console/activity-bars.js.map +1 -0
- package/dist/console/alerts-config.d.ts +20 -0
- package/dist/console/alerts-config.d.ts.map +1 -0
- package/dist/console/alerts-config.js +31 -0
- package/dist/console/alerts-config.js.map +1 -0
- package/dist/console/api-keys-table.d.ts +16 -0
- package/dist/console/api-keys-table.d.ts.map +1 -0
- package/dist/console/api-keys-table.js +21 -0
- package/dist/console/api-keys-table.js.map +1 -0
- package/dist/console/bottom-bar.d.ts +17 -0
- package/dist/console/bottom-bar.d.ts.map +1 -0
- package/dist/console/bottom-bar.js +14 -0
- package/dist/console/bottom-bar.js.map +1 -0
- package/dist/console/commit-table.d.ts +12 -0
- package/dist/console/commit-table.d.ts.map +1 -0
- package/dist/console/commit-table.js +14 -0
- package/dist/console/commit-table.js.map +1 -0
- package/dist/console/connection-form.d.ts +29 -0
- package/dist/console/connection-form.d.ts.map +1 -0
- package/dist/console/connection-form.js +24 -0
- package/dist/console/connection-form.js.map +1 -0
- package/dist/console/connection-status-badge.d.ts +7 -0
- package/dist/console/connection-status-badge.d.ts.map +1 -0
- package/dist/console/connection-status-badge.js +19 -0
- package/dist/console/connection-status-badge.js.map +1 -0
- package/dist/console/danger-action-card.d.ts +10 -0
- package/dist/console/danger-action-card.d.ts.map +1 -0
- package/dist/console/danger-action-card.js +10 -0
- package/dist/console/danger-action-card.js.map +1 -0
- package/dist/console/empty-state.d.ts +9 -0
- package/dist/console/empty-state.d.ts.map +1 -0
- package/dist/console/empty-state.js +7 -0
- package/dist/console/empty-state.js.map +1 -0
- package/dist/console/filter-bar.d.ts +18 -0
- package/dist/console/filter-bar.d.ts.map +1 -0
- package/dist/console/filter-bar.js +14 -0
- package/dist/console/filter-bar.js.map +1 -0
- package/dist/console/fleet-card.d.ts +14 -0
- package/dist/console/fleet-card.d.ts.map +1 -0
- package/dist/console/fleet-card.js +58 -0
- package/dist/console/fleet-card.js.map +1 -0
- package/dist/console/handlers-table.d.ts +12 -0
- package/dist/console/handlers-table.d.ts.map +1 -0
- package/dist/console/handlers-table.js +21 -0
- package/dist/console/handlers-table.js.map +1 -0
- package/dist/console/index.d.ts +28 -0
- package/dist/console/index.d.ts.map +1 -0
- package/dist/console/index.js +28 -0
- package/dist/console/index.js.map +1 -0
- package/dist/console/kpi-card.d.ts +10 -0
- package/dist/console/kpi-card.d.ts.map +1 -0
- package/dist/console/kpi-card.js +17 -0
- package/dist/console/kpi-card.js.map +1 -0
- package/dist/console/kpi-strip.d.ts +10 -0
- package/dist/console/kpi-strip.d.ts.map +1 -0
- package/dist/console/kpi-strip.js +22 -0
- package/dist/console/kpi-strip.js.map +1 -0
- package/dist/console/latency-percentiles.d.ts +24 -0
- package/dist/console/latency-percentiles.d.ts.map +1 -0
- package/dist/console/latency-percentiles.js +23 -0
- package/dist/console/latency-percentiles.js.map +1 -0
- package/dist/console/live-activity-feed.d.ts +24 -0
- package/dist/console/live-activity-feed.d.ts.map +1 -0
- package/dist/console/live-activity-feed.js +29 -0
- package/dist/console/live-activity-feed.js.map +1 -0
- package/dist/console/maintenance-card.d.ts +28 -0
- package/dist/console/maintenance-card.d.ts.map +1 -0
- package/dist/console/maintenance-card.js +25 -0
- package/dist/console/maintenance-card.js.map +1 -0
- package/dist/console/page-header.d.ts +9 -0
- package/dist/console/page-header.d.ts.map +1 -0
- package/dist/console/page-header.js +9 -0
- package/dist/console/page-header.js.map +1 -0
- package/dist/console/panel-shell.d.ts +11 -0
- package/dist/console/panel-shell.d.ts.map +1 -0
- package/dist/console/panel-shell.js +10 -0
- package/dist/console/panel-shell.js.map +1 -0
- package/dist/console/preferences-panel.d.ts +30 -0
- package/dist/console/preferences-panel.d.ts.map +1 -0
- package/dist/console/preferences-panel.js +24 -0
- package/dist/console/preferences-panel.js.map +1 -0
- package/dist/console/section-card.d.ts +11 -0
- package/dist/console/section-card.d.ts.map +1 -0
- package/dist/console/section-card.js +9 -0
- package/dist/console/section-card.js.map +1 -0
- package/dist/console/stream-log.d.ts +26 -0
- package/dist/console/stream-log.d.ts.map +1 -0
- package/dist/console/stream-log.js +34 -0
- package/dist/console/stream-log.js.map +1 -0
- package/dist/console/sync-horizon.d.ts +18 -0
- package/dist/console/sync-horizon.d.ts.map +1 -0
- package/dist/console/sync-horizon.js +61 -0
- package/dist/console/sync-horizon.js.map +1 -0
- package/dist/console/sync-lag-bar.d.ts +23 -0
- package/dist/console/sync-lag-bar.d.ts.map +1 -0
- package/dist/console/sync-lag-bar.js +111 -0
- package/dist/console/sync-lag-bar.js.map +1 -0
- package/dist/console/sync-state-badge.d.ts +6 -0
- package/dist/console/sync-state-badge.d.ts.map +1 -0
- package/dist/console/sync-state-badge.js +21 -0
- package/dist/console/sync-state-badge.js.map +1 -0
- package/dist/console/topology-card.d.ts +9 -0
- package/dist/console/topology-card.d.ts.map +1 -0
- package/dist/console/topology-card.js +9 -0
- package/dist/console/topology-card.js.map +1 -0
- package/dist/console/topology-hero.d.ts +65 -0
- package/dist/console/topology-hero.d.ts.map +1 -0
- package/dist/console/topology-hero.js +90 -0
- package/dist/console/topology-hero.js.map +1 -0
- package/dist/demo/actor-panel.d.ts +11 -0
- package/dist/demo/actor-panel.d.ts.map +1 -0
- package/dist/demo/actor-panel.js +19 -0
- package/dist/demo/actor-panel.js.map +1 -0
- package/dist/demo/catalog-table.d.ts +17 -0
- package/dist/demo/catalog-table.d.ts.map +1 -0
- package/dist/demo/catalog-table.js +13 -0
- package/dist/demo/catalog-table.js.map +1 -0
- package/dist/demo/channel-selector.d.ts +12 -0
- package/dist/demo/channel-selector.d.ts.map +1 -0
- package/dist/demo/channel-selector.js +13 -0
- package/dist/demo/channel-selector.js.map +1 -0
- package/dist/demo/client-panel.d.ts +12 -0
- package/dist/demo/client-panel.d.ts.map +1 -0
- package/dist/demo/client-panel.js +18 -0
- package/dist/demo/client-panel.js.map +1 -0
- package/dist/demo/conflict-panel.d.ts +8 -0
- package/dist/demo/conflict-panel.d.ts.map +1 -0
- package/dist/demo/conflict-panel.js +9 -0
- package/dist/demo/conflict-panel.js.map +1 -0
- package/dist/demo/demo-header.d.ts +9 -0
- package/dist/demo/demo-header.d.ts.map +1 -0
- package/dist/demo/demo-header.js +12 -0
- package/dist/demo/demo-header.js.map +1 -0
- package/dist/demo/demo-section.d.ts +8 -0
- package/dist/demo/demo-section.d.ts.map +1 -0
- package/dist/demo/demo-section.js +10 -0
- package/dist/demo/demo-section.js.map +1 -0
- package/dist/demo/encrypted-badge.d.ts +7 -0
- package/dist/demo/encrypted-badge.d.ts.map +1 -0
- package/dist/demo/encrypted-badge.js +12 -0
- package/dist/demo/encrypted-badge.js.map +1 -0
- package/dist/demo/encryption-flow-diagram.d.ts +5 -0
- package/dist/demo/encryption-flow-diagram.d.ts.map +1 -0
- package/dist/demo/encryption-flow-diagram.js +24 -0
- package/dist/demo/encryption-flow-diagram.js.map +1 -0
- package/dist/demo/index.d.ts +27 -0
- package/dist/demo/index.d.ts.map +1 -0
- package/dist/demo/index.js +27 -0
- package/dist/demo/index.js.map +1 -0
- package/dist/demo/info-panel.d.ts +9 -0
- package/dist/demo/info-panel.d.ts.map +1 -0
- package/dist/demo/info-panel.js +11 -0
- package/dist/demo/info-panel.js.map +1 -0
- package/dist/demo/media-gallery.d.ts +7 -0
- package/dist/demo/media-gallery.d.ts.map +1 -0
- package/dist/demo/media-gallery.js +7 -0
- package/dist/demo/media-gallery.js.map +1 -0
- package/dist/demo/media-thumbnail.d.ts +11 -0
- package/dist/demo/media-thumbnail.d.ts.map +1 -0
- package/dist/demo/media-thumbnail.js +10 -0
- package/dist/demo/media-thumbnail.js.map +1 -0
- package/dist/demo/metric-card.d.ts +14 -0
- package/dist/demo/metric-card.d.ts.map +1 -0
- package/dist/demo/metric-card.js +20 -0
- package/dist/demo/metric-card.js.map +1 -0
- package/dist/demo/mnemonic-display.d.ts +8 -0
- package/dist/demo/mnemonic-display.d.ts.map +1 -0
- package/dist/demo/mnemonic-display.js +70 -0
- package/dist/demo/mnemonic-display.js.map +1 -0
- package/dist/demo/note-card.d.ts +10 -0
- package/dist/demo/note-card.d.ts.map +1 -0
- package/dist/demo/note-card.js +9 -0
- package/dist/demo/note-card.js.map +1 -0
- package/dist/demo/sync-controls.d.ts +8 -0
- package/dist/demo/sync-controls.d.ts.map +1 -0
- package/dist/demo/sync-controls.js +17 -0
- package/dist/demo/sync-controls.js.map +1 -0
- package/dist/demo/sync-status-badge.d.ts +7 -0
- package/dist/demo/sync-status-badge.d.ts.map +1 -0
- package/dist/demo/sync-status-badge.js +22 -0
- package/dist/demo/sync-status-badge.js.map +1 -0
- package/dist/demo/task-item.d.ts +12 -0
- package/dist/demo/task-item.d.ts.map +1 -0
- package/dist/demo/task-item.js +12 -0
- package/dist/demo/task-item.js.map +1 -0
- package/dist/demo/task-list.d.ts +8 -0
- package/dist/demo/task-list.d.ts.map +1 -0
- package/dist/demo/task-list.js +11 -0
- package/dist/demo/task-list.js.map +1 -0
- package/dist/demo/topology-panel.d.ts +10 -0
- package/dist/demo/topology-panel.d.ts.map +1 -0
- package/dist/demo/topology-panel.js +10 -0
- package/dist/demo/topology-panel.js.map +1 -0
- package/dist/demo/topology-svg-keyshare.d.ts +5 -0
- package/dist/demo/topology-svg-keyshare.d.ts.map +1 -0
- package/dist/demo/topology-svg-keyshare.js +31 -0
- package/dist/demo/topology-svg-keyshare.js.map +1 -0
- package/dist/demo/topology-svg-media.d.ts +5 -0
- package/dist/demo/topology-svg-media.d.ts.map +1 -0
- package/dist/demo/topology-svg-media.js +27 -0
- package/dist/demo/topology-svg-media.js.map +1 -0
- package/dist/demo/topology-svg-split.d.ts +5 -0
- package/dist/demo/topology-svg-split.d.ts.map +1 -0
- package/dist/demo/topology-svg-split.js +29 -0
- package/dist/demo/topology-svg-split.js.map +1 -0
- package/dist/demo/topology-svg-symmetric.d.ts +5 -0
- package/dist/demo/topology-svg-symmetric.d.ts.map +1 -0
- package/dist/demo/topology-svg-symmetric.js +35 -0
- package/dist/demo/topology-svg-symmetric.js.map +1 -0
- package/dist/demo/transfer-log.d.ts +14 -0
- package/dist/demo/transfer-log.d.ts.map +1 -0
- package/dist/demo/transfer-log.js +18 -0
- package/dist/demo/transfer-log.js.map +1 -0
- package/dist/demo/upload-area.d.ts +9 -0
- package/dist/demo/upload-area.d.ts.map +1 -0
- package/dist/demo/upload-area.js +58 -0
- package/dist/demo/upload-area.js.map +1 -0
- package/dist/forms/checkbox.d.ts +11 -0
- package/dist/forms/checkbox.d.ts.map +1 -0
- package/dist/forms/checkbox.js +16 -0
- package/dist/forms/checkbox.js.map +1 -0
- package/dist/forms/field.d.ts +7 -0
- package/dist/forms/field.d.ts.map +1 -0
- package/dist/forms/field.js +16 -0
- package/dist/forms/field.js.map +1 -0
- package/dist/forms/index.d.ts +7 -0
- package/dist/forms/index.d.ts.map +1 -0
- package/dist/forms/index.js +7 -0
- package/dist/forms/index.js.map +1 -0
- package/dist/forms/select.d.ts +11 -0
- package/dist/forms/select.d.ts.map +1 -0
- package/dist/forms/select.js +15 -0
- package/dist/forms/select.js.map +1 -0
- package/dist/forms/textarea.d.ts +6 -0
- package/dist/forms/textarea.d.ts.map +1 -0
- package/dist/forms/textarea.js +8 -0
- package/dist/forms/textarea.js.map +1 -0
- package/dist/forms/toggle-group.d.ts +8 -0
- package/dist/forms/toggle-group.d.ts.map +1 -0
- package/dist/forms/toggle-group.js +11 -0
- package/dist/forms/toggle-group.js.map +1 -0
- package/dist/forms/toggle.d.ts +7 -0
- package/dist/forms/toggle.d.ts.map +1 -0
- package/dist/forms/toggle.js +9 -0
- package/dist/forms/toggle.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/cn.d.ts +3 -0
- package/dist/lib/cn.d.ts.map +1 -0
- package/dist/lib/cn.js +6 -0
- package/dist/lib/cn.js.map +1 -0
- package/dist/lib/types.d.ts +64 -0
- package/dist/lib/types.d.ts.map +1 -0
- package/dist/lib/types.js +2 -0
- package/dist/lib/types.js.map +1 -0
- package/dist/navigation/index.d.ts +6 -0
- package/dist/navigation/index.d.ts.map +1 -0
- package/dist/navigation/index.js +6 -0
- package/dist/navigation/index.js.map +1 -0
- package/dist/navigation/nav-pill-group.d.ts +14 -0
- package/dist/navigation/nav-pill-group.d.ts.map +1 -0
- package/dist/navigation/nav-pill-group.js +15 -0
- package/dist/navigation/nav-pill-group.js.map +1 -0
- package/dist/navigation/nav-pill.d.ts +9 -0
- package/dist/navigation/nav-pill.d.ts.map +1 -0
- package/dist/navigation/nav-pill.js +7 -0
- package/dist/navigation/nav-pill.js.map +1 -0
- package/dist/navigation/status-dot.d.ts +13 -0
- package/dist/navigation/status-dot.d.ts.map +1 -0
- package/dist/navigation/status-dot.js +44 -0
- package/dist/navigation/status-dot.js.map +1 -0
- package/dist/navigation/syncular-brand.d.ts +6 -0
- package/dist/navigation/syncular-brand.d.ts.map +1 -0
- package/dist/navigation/syncular-brand.js +11 -0
- package/dist/navigation/syncular-brand.js.map +1 -0
- package/dist/navigation/top-navigation.d.ts +9 -0
- package/dist/navigation/top-navigation.d.ts.map +1 -0
- package/dist/navigation/top-navigation.js +9 -0
- package/dist/navigation/top-navigation.js.map +1 -0
- package/dist/observable-universe/architecture-section.d.ts +5 -0
- package/dist/observable-universe/architecture-section.d.ts.map +1 -0
- package/dist/observable-universe/architecture-section.js +44 -0
- package/dist/observable-universe/architecture-section.js.map +1 -0
- package/dist/observable-universe/code-section.d.ts +5 -0
- package/dist/observable-universe/code-section.d.ts.map +1 -0
- package/dist/observable-universe/code-section.js +86 -0
- package/dist/observable-universe/code-section.js.map +1 -0
- package/dist/observable-universe/commit-stream-panel.d.ts +8 -0
- package/dist/observable-universe/commit-stream-panel.d.ts.map +1 -0
- package/dist/observable-universe/commit-stream-panel.js +45 -0
- package/dist/observable-universe/commit-stream-panel.js.map +1 -0
- package/dist/observable-universe/connected-clients-panel.d.ts +7 -0
- package/dist/observable-universe/connected-clients-panel.d.ts.map +1 -0
- package/dist/observable-universe/connected-clients-panel.js +47 -0
- package/dist/observable-universe/connected-clients-panel.js.map +1 -0
- package/dist/observable-universe/constants.d.ts +10 -0
- package/dist/observable-universe/constants.d.ts.map +1 -0
- package/dist/observable-universe/constants.js +81 -0
- package/dist/observable-universe/constants.js.map +1 -0
- package/dist/observable-universe/explanation-section.d.ts +5 -0
- package/dist/observable-universe/explanation-section.d.ts.map +1 -0
- package/dist/observable-universe/explanation-section.js +76 -0
- package/dist/observable-universe/explanation-section.js.map +1 -0
- package/dist/observable-universe/footer-bar.d.ts +5 -0
- package/dist/observable-universe/footer-bar.d.ts.map +1 -0
- package/dist/observable-universe/footer-bar.js +12 -0
- package/dist/observable-universe/footer-bar.js.map +1 -0
- package/dist/observable-universe/hero-dashboard-section.d.ts +10 -0
- package/dist/observable-universe/hero-dashboard-section.d.ts.map +1 -0
- package/dist/observable-universe/hero-dashboard-section.js +20 -0
- package/dist/observable-universe/hero-dashboard-section.js.map +1 -0
- package/dist/observable-universe/index.d.ts +17 -0
- package/dist/observable-universe/index.d.ts.map +1 -0
- package/dist/observable-universe/index.js +17 -0
- package/dist/observable-universe/index.js.map +1 -0
- package/dist/observable-universe/install-section.d.ts +8 -0
- package/dist/observable-universe/install-section.d.ts.map +1 -0
- package/dist/observable-universe/install-section.js +24 -0
- package/dist/observable-universe/install-section.js.map +1 -0
- package/dist/observable-universe/live-metrics-bar.d.ts +7 -0
- package/dist/observable-universe/live-metrics-bar.d.ts.map +1 -0
- package/dist/observable-universe/live-metrics-bar.js +18 -0
- package/dist/observable-universe/live-metrics-bar.js.map +1 -0
- package/dist/observable-universe/observable-universe-header.d.ts +14 -0
- package/dist/observable-universe/observable-universe-header.d.ts.map +1 -0
- package/dist/observable-universe/observable-universe-header.js +45 -0
- package/dist/observable-universe/observable-universe-header.js.map +1 -0
- package/dist/observable-universe/observable-universe-landing.d.ts +12 -0
- package/dist/observable-universe/observable-universe-landing.d.ts.map +1 -0
- package/dist/observable-universe/observable-universe-landing.js +19 -0
- package/dist/observable-universe/observable-universe-landing.js.map +1 -0
- package/dist/observable-universe/section-heading.d.ts +8 -0
- package/dist/observable-universe/section-heading.d.ts.map +1 -0
- package/dist/observable-universe/section-heading.js +8 -0
- package/dist/observable-universe/section-heading.js.map +1 -0
- package/dist/observable-universe/sync-topology-panel.d.ts +7 -0
- package/dist/observable-universe/sync-topology-panel.d.ts.map +1 -0
- package/dist/observable-universe/sync-topology-panel.js +81 -0
- package/dist/observable-universe/sync-topology-panel.js.map +1 -0
- package/dist/observable-universe/types.d.ts +25 -0
- package/dist/observable-universe/types.d.ts.map +1 -0
- package/dist/observable-universe/types.js +2 -0
- package/dist/observable-universe/types.js.map +1 -0
- package/dist/observable-universe/use-observable-universe-simulation.d.ts +8 -0
- package/dist/observable-universe/use-observable-universe-simulation.d.ts.map +1 -0
- package/dist/observable-universe/use-observable-universe-simulation.js +92 -0
- package/dist/observable-universe/use-observable-universe-simulation.js.map +1 -0
- package/dist/primitives/alert.d.ts +14 -0
- package/dist/primitives/alert.d.ts.map +1 -0
- package/dist/primitives/alert.js +24 -0
- package/dist/primitives/alert.js.map +1 -0
- package/dist/primitives/badge.d.ts +12 -0
- package/dist/primitives/badge.d.ts.map +1 -0
- package/dist/primitives/badge.js +28 -0
- package/dist/primitives/badge.js.map +1 -0
- package/dist/primitives/button.d.ts +14 -0
- package/dist/primitives/button.d.ts.map +1 -0
- package/dist/primitives/button.js +30 -0
- package/dist/primitives/button.js.map +1 -0
- package/dist/primitives/card.d.ts +7 -0
- package/dist/primitives/card.d.ts.map +1 -0
- package/dist/primitives/card.js +16 -0
- package/dist/primitives/card.js.map +1 -0
- package/dist/primitives/dialog.d.ts +14 -0
- package/dist/primitives/dialog.d.ts.map +1 -0
- package/dist/primitives/dialog.js +25 -0
- package/dist/primitives/dialog.js.map +1 -0
- package/dist/primitives/index.d.ts +16 -0
- package/dist/primitives/index.d.ts.map +1 -0
- package/dist/primitives/index.js +16 -0
- package/dist/primitives/index.js.map +1 -0
- package/dist/primitives/input.d.ts +12 -0
- package/dist/primitives/input.d.ts.map +1 -0
- package/dist/primitives/input.js +20 -0
- package/dist/primitives/input.js.map +1 -0
- package/dist/primitives/pagination.d.ts +16 -0
- package/dist/primitives/pagination.d.ts.map +1 -0
- package/dist/primitives/pagination.js +13 -0
- package/dist/primitives/pagination.js.map +1 -0
- package/dist/primitives/separator.d.ts +10 -0
- package/dist/primitives/separator.d.ts.map +1 -0
- package/dist/primitives/separator.js +10 -0
- package/dist/primitives/separator.js.map +1 -0
- package/dist/primitives/sheet.d.ts +19 -0
- package/dist/primitives/sheet.d.ts.map +1 -0
- package/dist/primitives/sheet.js +35 -0
- package/dist/primitives/sheet.js.map +1 -0
- package/dist/primitives/skeleton.d.ts +3 -0
- package/dist/primitives/skeleton.d.ts.map +1 -0
- package/dist/primitives/skeleton.js +8 -0
- package/dist/primitives/skeleton.js.map +1 -0
- package/dist/primitives/spinner.d.ts +12 -0
- package/dist/primitives/spinner.d.ts.map +1 -0
- package/dist/primitives/spinner.js +23 -0
- package/dist/primitives/spinner.js.map +1 -0
- package/dist/primitives/switch.d.ts +7 -0
- package/dist/primitives/switch.d.ts.map +1 -0
- package/dist/primitives/switch.js +9 -0
- package/dist/primitives/switch.js.map +1 -0
- package/dist/primitives/table.d.ts +8 -0
- package/dist/primitives/table.d.ts.map +1 -0
- package/dist/primitives/table.js +18 -0
- package/dist/primitives/table.js.map +1 -0
- package/dist/primitives/tabs.d.ts +16 -0
- package/dist/primitives/tabs.d.ts.map +1 -0
- package/dist/primitives/tabs.js +26 -0
- package/dist/primitives/tabs.js.map +1 -0
- package/dist/primitives/tooltip.d.ts +13 -0
- package/dist/primitives/tooltip.d.ts.map +1 -0
- package/dist/primitives/tooltip.js +15 -0
- package/dist/primitives/tooltip.js.map +1 -0
- package/dist/version.d.ts +2 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +3 -0
- package/dist/version.js.map +1 -0
- package/package.json +114 -0
- package/src/charts/activity-chart.tsx +85 -0
- package/src/charts/chart.tsx +302 -0
- package/src/charts/index.ts +4 -0
- package/src/charts/latency-chart.tsx +77 -0
- package/src/charts/outcomes-chart.tsx +101 -0
- package/src/console/activity-bars.tsx +113 -0
- package/src/console/alerts-config.tsx +110 -0
- package/src/console/api-keys-table.tsx +102 -0
- package/src/console/bottom-bar.tsx +73 -0
- package/src/console/commit-table.tsx +66 -0
- package/src/console/connection-form.tsx +153 -0
- package/src/console/connection-status-badge.tsx +48 -0
- package/src/console/danger-action-card.tsx +40 -0
- package/src/console/empty-state.tsx +31 -0
- package/src/console/filter-bar.tsx +97 -0
- package/src/console/fleet-card.tsx +154 -0
- package/src/console/handlers-table.tsx +74 -0
- package/src/console/index.ts +27 -0
- package/src/console/kpi-card.tsx +46 -0
- package/src/console/kpi-strip.tsx +77 -0
- package/src/console/latency-percentiles.tsx +109 -0
- package/src/console/live-activity-feed.tsx +112 -0
- package/src/console/maintenance-card.tsx +112 -0
- package/src/console/page-header.tsx +32 -0
- package/src/console/panel-shell.tsx +42 -0
- package/src/console/preferences-panel.tsx +126 -0
- package/src/console/section-card.tsx +41 -0
- package/src/console/stream-log.tsx +138 -0
- package/src/console/sync-horizon.tsx +149 -0
- package/src/console/sync-lag-bar.tsx +226 -0
- package/src/console/sync-state-badge.tsx +32 -0
- package/src/console/topology-card.tsx +47 -0
- package/src/console/topology-hero.tsx +499 -0
- package/src/demo/actor-panel.tsx +50 -0
- package/src/demo/catalog-table.tsx +83 -0
- package/src/demo/channel-selector.tsx +51 -0
- package/src/demo/client-panel.tsx +61 -0
- package/src/demo/conflict-panel.tsx +25 -0
- package/src/demo/demo-header.tsx +44 -0
- package/src/demo/demo-section.tsx +24 -0
- package/src/demo/encrypted-badge.tsx +59 -0
- package/src/demo/encryption-flow-diagram.tsx +93 -0
- package/src/demo/index.ts +26 -0
- package/src/demo/info-panel.tsx +41 -0
- package/src/demo/media-gallery.tsx +15 -0
- package/src/demo/media-thumbnail.tsx +55 -0
- package/src/demo/metric-card.tsx +85 -0
- package/src/demo/mnemonic-display.tsx +114 -0
- package/src/demo/note-card.tsx +52 -0
- package/src/demo/sync-controls.tsx +75 -0
- package/src/demo/sync-status-badge.tsx +36 -0
- package/src/demo/task-item.tsx +83 -0
- package/src/demo/task-list.tsx +33 -0
- package/src/demo/topology-panel.tsx +44 -0
- package/src/demo/topology-svg-keyshare.tsx +474 -0
- package/src/demo/topology-svg-media.tsx +423 -0
- package/src/demo/topology-svg-split.tsx +402 -0
- package/src/demo/topology-svg-symmetric.tsx +527 -0
- package/src/demo/transfer-log.tsx +68 -0
- package/src/demo/upload-area.tsx +136 -0
- package/src/forms/checkbox.tsx +58 -0
- package/src/forms/field.tsx +60 -0
- package/src/forms/index.ts +6 -0
- package/src/forms/select.tsx +65 -0
- package/src/forms/textarea.tsx +23 -0
- package/src/forms/toggle-group.tsx +24 -0
- package/src/forms/toggle.tsx +24 -0
- package/src/index.ts +7 -0
- package/src/lib/cn.ts +6 -0
- package/src/lib/types.ts +69 -0
- package/src/navigation/index.ts +5 -0
- package/src/navigation/nav-pill-group.tsx +46 -0
- package/src/navigation/nav-pill.tsx +35 -0
- package/src/navigation/status-dot.tsx +66 -0
- package/src/navigation/syncular-brand.tsx +29 -0
- package/src/navigation/top-navigation.tsx +31 -0
- package/src/observable-universe/architecture-section.tsx +209 -0
- package/src/observable-universe/code-section.tsx +136 -0
- package/src/observable-universe/commit-stream-panel.tsx +115 -0
- package/src/observable-universe/connected-clients-panel.tsx +109 -0
- package/src/observable-universe/constants.ts +84 -0
- package/src/observable-universe/explanation-section.tsx +129 -0
- package/src/observable-universe/footer-bar.tsx +34 -0
- package/src/observable-universe/hero-dashboard-section.tsx +71 -0
- package/src/observable-universe/index.ts +16 -0
- package/src/observable-universe/install-section.tsx +119 -0
- package/src/observable-universe/live-metrics-bar.tsx +64 -0
- package/src/observable-universe/observable-universe-header.tsx +155 -0
- package/src/observable-universe/observable-universe-landing.tsx +74 -0
- package/src/observable-universe/section-heading.tsx +31 -0
- package/src/observable-universe/sync-topology-panel.tsx +409 -0
- package/src/observable-universe/types.ts +26 -0
- package/src/observable-universe/use-observable-universe-simulation.ts +111 -0
- package/src/primitives/alert.tsx +55 -0
- package/src/primitives/badge.tsx +45 -0
- package/src/primitives/button.tsx +51 -0
- package/src/primitives/card.tsx +67 -0
- package/src/primitives/dialog.tsx +114 -0
- package/src/primitives/index.ts +15 -0
- package/src/primitives/input.tsx +37 -0
- package/src/primitives/pagination.tsx +54 -0
- package/src/primitives/separator.tsx +29 -0
- package/src/primitives/sheet.tsx +114 -0
- package/src/primitives/skeleton.tsx +17 -0
- package/src/primitives/spinner.tsx +52 -0
- package/src/primitives/switch.tsx +26 -0
- package/src/primitives/table.tsx +71 -0
- package/src/primitives/tabs.tsx +66 -0
- package/src/primitives/tooltip.tsx +43 -0
- package/src/styles/styles.css +177 -0
- package/src/styles/tokens.css +47 -0
- package/src/version.ts +3 -0
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useMemo } from 'react';
|
|
4
|
+
import { cn } from '../lib/cn.js';
|
|
5
|
+
import { Tooltip, TooltipContent, TooltipTrigger } from '../primitives/tooltip.js';
|
|
6
|
+
export function getClientLagInfo(cursor, headSeq, lagOverride) {
|
|
7
|
+
const lag = lagOverride ?? Math.max(0, headSeq - cursor);
|
|
8
|
+
if (cursor <= 0) {
|
|
9
|
+
return {
|
|
10
|
+
lag,
|
|
11
|
+
status: 'bootstrapping',
|
|
12
|
+
colorClass: 'text-neutral-500',
|
|
13
|
+
bgClass: 'bg-neutral-700',
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
if (lag === 0) {
|
|
17
|
+
return {
|
|
18
|
+
lag,
|
|
19
|
+
status: 'ok',
|
|
20
|
+
colorClass: 'text-healthy',
|
|
21
|
+
bgClass: 'bg-healthy',
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
if (lag <= 10) {
|
|
25
|
+
return {
|
|
26
|
+
lag,
|
|
27
|
+
status: 'behind',
|
|
28
|
+
colorClass: 'text-syncing',
|
|
29
|
+
bgClass: 'bg-syncing',
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
return {
|
|
33
|
+
lag,
|
|
34
|
+
status: 'far-behind',
|
|
35
|
+
colorClass: 'text-offline',
|
|
36
|
+
bgClass: 'bg-offline',
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
export function SyncLagBar({ className, clients, stats }) {
|
|
40
|
+
const headSeq = stats.maxCommitSeq;
|
|
41
|
+
const analysis = useMemo(() => {
|
|
42
|
+
const infos = clients.map((c) => ({
|
|
43
|
+
...c,
|
|
44
|
+
info: getClientLagInfo(c.cursor, headSeq, c.lagCommitCount),
|
|
45
|
+
}));
|
|
46
|
+
const active = infos.filter((c) => c.info.status !== 'bootstrapping');
|
|
47
|
+
const bootstrapping = infos.filter((c) => c.info.status === 'bootstrapping');
|
|
48
|
+
const lags = active.map((c) => c.info.lag);
|
|
49
|
+
const maxLag = lags.length > 0 ? Math.max(...lags) : 0;
|
|
50
|
+
const avgLag = lags.length > 0
|
|
51
|
+
? Math.round(lags.reduce((sum, l) => sum + l, 0) / lags.length)
|
|
52
|
+
: 0;
|
|
53
|
+
const okCount = active.filter((c) => c.info.status === 'ok').length;
|
|
54
|
+
const behindCount = active.filter((c) => c.info.status === 'behind').length;
|
|
55
|
+
const farBehindCount = active.filter((c) => c.info.status === 'far-behind').length;
|
|
56
|
+
return {
|
|
57
|
+
infos,
|
|
58
|
+
active,
|
|
59
|
+
bootstrapping,
|
|
60
|
+
maxLag,
|
|
61
|
+
avgLag,
|
|
62
|
+
okCount,
|
|
63
|
+
behindCount,
|
|
64
|
+
farBehindCount,
|
|
65
|
+
};
|
|
66
|
+
}, [clients, headSeq]);
|
|
67
|
+
const total = analysis.active.length;
|
|
68
|
+
const barSegments = [
|
|
69
|
+
{ count: analysis.okCount, colorClass: 'bg-healthy', label: 'Up to date' },
|
|
70
|
+
{
|
|
71
|
+
count: analysis.behindCount,
|
|
72
|
+
colorClass: 'bg-syncing',
|
|
73
|
+
label: 'Behind (1-10)',
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
count: analysis.farBehindCount,
|
|
77
|
+
colorClass: 'bg-offline',
|
|
78
|
+
label: 'Far behind (>10)',
|
|
79
|
+
},
|
|
80
|
+
];
|
|
81
|
+
return (_jsxs("div", { className: cn('flex flex-col gap-3', className), children: [
|
|
82
|
+
_jsxs("div", { className: "flex items-center justify-between text-xs", children: [
|
|
83
|
+
_jsxs("div", { className: "flex items-center gap-4", children: [
|
|
84
|
+
_jsxs("span", { className: "text-neutral-500", children: ["Head: ",
|
|
85
|
+
_jsxs("span", { className: "text-foreground font-mono", children: ["#", headSeq] })
|
|
86
|
+
] }), _jsxs("span", { className: "text-neutral-500", children: ["Active:", ' ', _jsx("span", { className: "text-foreground", children: analysis.active.length })
|
|
87
|
+
] }), analysis.bootstrapping.length > 0 ? (_jsxs("span", { className: "text-neutral-500", children: ["Bootstrapping:", ' ', _jsx("span", { className: "text-foreground", children: analysis.bootstrapping.length })
|
|
88
|
+
] })) : null] }), _jsxs("div", { className: "flex items-center gap-4", children: [
|
|
89
|
+
_jsxs("span", { className: "text-neutral-500", children: ["Max lag:", ' ', _jsx("span", { className: cn('font-mono', analysis.maxLag === 0
|
|
90
|
+
? 'text-healthy'
|
|
91
|
+
: analysis.maxLag <= 10
|
|
92
|
+
? 'text-syncing'
|
|
93
|
+
: 'text-offline'), children: analysis.maxLag })
|
|
94
|
+
] }), _jsxs("span", { className: "text-neutral-500", children: ["Avg lag:", ' ', _jsx("span", { className: cn('font-mono', analysis.avgLag === 0
|
|
95
|
+
? 'text-healthy'
|
|
96
|
+
: analysis.avgLag <= 10
|
|
97
|
+
? 'text-syncing'
|
|
98
|
+
: 'text-offline'), children: analysis.avgLag })
|
|
99
|
+
] })
|
|
100
|
+
] })
|
|
101
|
+
] }), total > 0 ? (_jsx("div", { className: "h-3 rounded-full bg-neutral-900 overflow-hidden flex", children: barSegments.map((segment) => segment.count > 0 ? (_jsxs(Tooltip, { children: [
|
|
102
|
+
_jsx(TooltipTrigger, { render: _jsx("div", { className: cn('h-full transition-all', segment.colorClass), style: {
|
|
103
|
+
width: `${(segment.count / total) * 100}%`,
|
|
104
|
+
} }) }), _jsxs(TooltipContent, { children: [segment.label, ": ", segment.count, " client", segment.count !== 1 ? 's' : ''] })
|
|
105
|
+
] }, segment.label)) : null) })) : (_jsx("div", { className: "h-3 rounded-full bg-neutral-900" })), _jsx("div", { className: "flex items-center gap-4 text-xs", children: barSegments.map((segment) => (_jsxs("div", { className: "flex items-center gap-1.5", children: [
|
|
106
|
+
_jsx("div", { className: cn('h-2 w-2 rounded-full', segment.colorClass) }), _jsxs("span", { className: "text-neutral-500", children: [segment.label, ' ', _jsx("span", { className: "text-foreground", children: segment.count })
|
|
107
|
+
] })
|
|
108
|
+
] }, segment.label))) })
|
|
109
|
+
] }));
|
|
110
|
+
}
|
|
111
|
+
//# sourceMappingURL=sync-lag-bar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync-lag-bar.js","sourceRoot":"","sources":["../../src/console/sync-lag-bar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync-state-badge.d.ts","sourceRoot":"","sources":["../../src/console/sync-state-badge.tsx"],"names":[],"mappings":"AAKA,MAAM,WAAW,mBAAmB;IAClC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,wBAAgB,cAAc,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,mBAAmB,2CAQvE"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { cn } from '../lib/cn.js';
|
|
4
|
+
import { Badge } from '../primitives/badge.js';
|
|
5
|
+
export function SyncStateBadge({ className, state }) {
|
|
6
|
+
const variant = stateToVariant(state);
|
|
7
|
+
return (_jsx(Badge, { variant: variant, className: cn(className), children: state }));
|
|
8
|
+
}
|
|
9
|
+
function stateToVariant(state) {
|
|
10
|
+
switch (state) {
|
|
11
|
+
case 'idle':
|
|
12
|
+
return 'ghost';
|
|
13
|
+
case 'syncing':
|
|
14
|
+
return 'syncing';
|
|
15
|
+
case 'error':
|
|
16
|
+
return 'destructive';
|
|
17
|
+
default:
|
|
18
|
+
return 'ghost';
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=sync-state-badge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync-state-badge.js","sourceRoot":"","sources":["../../src/console/sync-state-badge.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AAC/B,OAAO,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AAO5C,MAAM,UAAU,cAAc,CAAC,EAAE,SAAS,EAAE,KAAK,EAAuB,EAAE;IACxE,MAAM,OAAO,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;IAEtC,OAAO,CACL,KAAC,KAAK,IAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,YAC9C,KAAK,GACA,CACT,CAAC;AAAA,CACH;AAED,SAAS,cAAc,CAAC,KAAa,EAAE;IACrC,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,MAAM;YACT,OAAO,OAAgB,CAAC;QAC1B,KAAK,SAAS;YACZ,OAAO,SAAkB,CAAC;QAC5B,KAAK,OAAO;YACV,OAAO,aAAsB,CAAC;QAChC;YACE,OAAO,OAAgB,CAAC;IAC5B,CAAC;AAAA,CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { SyncClient } from '../lib/types';
|
|
2
|
+
export interface TopologyCardProps {
|
|
3
|
+
clients: SyncClient[];
|
|
4
|
+
emptyMessage?: string;
|
|
5
|
+
isLoading?: boolean;
|
|
6
|
+
relayLabel?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function TopologyCard({ clients, emptyMessage, isLoading, relayLabel }: TopologyCardProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=topology-card.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"topology-card.d.ts","sourceRoot":"","sources":["../../src/console/topology-card.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAI/C,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,UAAU,EAAE,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,wBAAgB,YAAY,CAAC,EAC3B,OAAO,EACP,YAAqC,EACrC,SAAS,EACT,UAAU,EACX,EAAE,iBAAiB,2CA2BnB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { cn } from '../lib/cn.js';
|
|
4
|
+
import { Card, CardContent } from '../primitives/card.js';
|
|
5
|
+
import { Spinner } from '../primitives/spinner.js';
|
|
6
|
+
export function TopologyCard({ clients, emptyMessage = 'No clients connected', isLoading, relayLabel, }) {
|
|
7
|
+
return (_jsx(Card, { children: _jsxs(CardContent, { className: cn('min-h-[280px] flex flex-col'), children: [relayLabel ? (_jsx("span", { className: "text-xs text-neutral-500 mb-2", children: relayLabel })) : null, isLoading ? (_jsx("div", { className: "flex flex-1 items-center justify-center", children: _jsx(Spinner, { size: "lg" }) })) : clients.length === 0 ? (_jsx("div", { className: "flex flex-1 items-center justify-center", children: _jsx("p", { className: "text-sm text-neutral-500", children: emptyMessage }) })) : (_jsx("div", { className: "flex flex-1 items-center justify-center", children: _jsxs("div", { className: "text-xs text-neutral-500", children: [clients.length, " client", clients.length !== 1 ? 's' : '', " connected"] }) }))] }) }));
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=topology-card.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"topology-card.js","sourceRoot":"","sources":["../../src/console/topology-card.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AAE/B,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AAShD,MAAM,UAAU,YAAY,CAAC,EAC3B,OAAO,EACP,YAAY,GAAG,sBAAsB,EACrC,SAAS,EACT,UAAU,GACQ,EAAE;IACpB,OAAO,CACL,KAAC,IAAI,cACH,MAAC,WAAW,IAAC,SAAS,EAAE,EAAE,CAAC,6BAA6B,CAAC,aACtD,UAAU,CAAC,CAAC,CAAC,CACZ,eAAM,SAAS,EAAC,+BAA+B,YAAE,UAAU,GAAQ,CACpE,CAAC,CAAC,CAAC,IAAI,EAEP,SAAS,CAAC,CAAC,CAAC,CACX,cAAK,SAAS,EAAC,yCAAyC,YACtD,KAAC,OAAO,IAAC,IAAI,EAAC,IAAI,GAAG,GACjB,CACP,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CACzB,cAAK,SAAS,EAAC,yCAAyC,YACtD,YAAG,SAAS,EAAC,0BAA0B,YAAE,YAAY,GAAK,GACtD,CACP,CAAC,CAAC,CAAC,CACF,cAAK,SAAS,EAAC,yCAAyC,YAEtD,eAAK,SAAS,EAAC,0BAA0B,aACtC,OAAO,CAAC,MAAM,aAAS,OAAO,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,kBACnD,GACF,CACP,IACW,GACT,CACR,CAAC;AAAA,CACH"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { type ComponentPropsWithoutRef } from 'react';
|
|
2
|
+
import type { SyncClientNode } from '../lib/types';
|
|
3
|
+
export type TopologyNodePosition = {
|
|
4
|
+
clientId: string;
|
|
5
|
+
x: number;
|
|
6
|
+
y: number;
|
|
7
|
+
};
|
|
8
|
+
export type TopologyHeroProps = ComponentPropsWithoutRef<'div'> & {
|
|
9
|
+
clients: SyncClientNode[];
|
|
10
|
+
/** Positions for each client node keyed by client id */
|
|
11
|
+
positions?: TopologyNodePosition[];
|
|
12
|
+
/** IDs of clients connecting through the relay */
|
|
13
|
+
relayClientIds?: string[];
|
|
14
|
+
/** Override server position */
|
|
15
|
+
serverPosition?: {
|
|
16
|
+
x: number;
|
|
17
|
+
y: number;
|
|
18
|
+
};
|
|
19
|
+
/** Override relay position */
|
|
20
|
+
relayPosition?: {
|
|
21
|
+
x: number;
|
|
22
|
+
y: number;
|
|
23
|
+
};
|
|
24
|
+
/** SVG viewBox dimensions */
|
|
25
|
+
viewBox?: {
|
|
26
|
+
width: number;
|
|
27
|
+
height: number;
|
|
28
|
+
};
|
|
29
|
+
/** Stats overlay: total nodes */
|
|
30
|
+
totalNodes?: number;
|
|
31
|
+
/** Stats overlay: online count */
|
|
32
|
+
onlineCount?: number;
|
|
33
|
+
/** Stats overlay: offline count */
|
|
34
|
+
offlineCount?: number;
|
|
35
|
+
};
|
|
36
|
+
declare const TopologyHero: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
|
|
37
|
+
clients: SyncClientNode[];
|
|
38
|
+
/** Positions for each client node keyed by client id */
|
|
39
|
+
positions?: TopologyNodePosition[] | undefined;
|
|
40
|
+
/** IDs of clients connecting through the relay */
|
|
41
|
+
relayClientIds?: string[] | undefined;
|
|
42
|
+
/** Override server position */
|
|
43
|
+
serverPosition?: {
|
|
44
|
+
x: number;
|
|
45
|
+
y: number;
|
|
46
|
+
} | undefined;
|
|
47
|
+
/** Override relay position */
|
|
48
|
+
relayPosition?: {
|
|
49
|
+
x: number;
|
|
50
|
+
y: number;
|
|
51
|
+
} | undefined;
|
|
52
|
+
/** SVG viewBox dimensions */
|
|
53
|
+
viewBox?: {
|
|
54
|
+
width: number;
|
|
55
|
+
height: number;
|
|
56
|
+
} | undefined;
|
|
57
|
+
/** Stats overlay: total nodes */
|
|
58
|
+
totalNodes?: number | undefined;
|
|
59
|
+
/** Stats overlay: online count */
|
|
60
|
+
onlineCount?: number | undefined;
|
|
61
|
+
/** Stats overlay: offline count */
|
|
62
|
+
offlineCount?: number | undefined;
|
|
63
|
+
} & import("react").RefAttributes<HTMLDivElement>>;
|
|
64
|
+
export { TopologyHero };
|
|
65
|
+
//# sourceMappingURL=topology-hero.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"topology-hero.d.ts","sourceRoot":"","sources":["../../src/console/topology-hero.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,wBAAwB,EAAc,MAAM,OAAO,CAAC;AAElE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAEnD,MAAM,MAAM,oBAAoB,GAAG;IACjC,QAAQ,EAAE,MAAM,CAAC;IACjB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;CACX,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG,wBAAwB,CAAC,KAAK,CAAC,GAAG;IAChE,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,wDAAwD;IACxD,SAAS,CAAC,EAAE,oBAAoB,EAAE,CAAC;IACnC,kDAAkD;IAClD,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,+BAA+B;IAC/B,cAAc,CAAC,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAC1C,8BAA8B;IAC9B,aAAa,CAAC,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACzC,6BAA6B;IAC7B,OAAO,CAAC,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAC5C,iCAAiC;IACjC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,kCAAkC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,mCAAmC;IACnC,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAQF,QAAA,MAAM,YAAY;;IAxBhB,wDAAwD;;IAExD,kDAAkD;;IAElD,+BAA+B;;;;;IAE/B,8BAA8B;;;;;IAE9B,6BAA6B;;;;;IAE7B,iCAAiC;;IAEjC,kCAAkC;;IAElC,mCAAmC;;kDAmdpC,CAAC;AAGF,OAAO,EAAE,YAAY,EAAE,CAAC"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { cn } from '../lib/cn.js';
|
|
5
|
+
function getStatusColor(status) {
|
|
6
|
+
if (status === 'online')
|
|
7
|
+
return '#22c55e';
|
|
8
|
+
if (status === 'syncing')
|
|
9
|
+
return '#f59e0b';
|
|
10
|
+
return '#ef4444';
|
|
11
|
+
}
|
|
12
|
+
const TopologyHero = forwardRef(({ className, clients, positions, relayClientIds = [], serverPosition = { x: 420, y: 190 }, relayPosition = { x: 780, y: 190 }, viewBox = { width: 1200, height: 380 }, totalNodes, onlineCount, offlineCount, ...props }, ref) => {
|
|
13
|
+
const sX = serverPosition.x;
|
|
14
|
+
const sY = serverPosition.y;
|
|
15
|
+
const rX = relayPosition.x;
|
|
16
|
+
const rY = relayPosition.y;
|
|
17
|
+
const defaultPositions = {};
|
|
18
|
+
const angleStep = (2 * Math.PI) / Math.max(clients.length, 1);
|
|
19
|
+
clients.forEach((c, i) => {
|
|
20
|
+
const isRelay = relayClientIds.includes(c.id);
|
|
21
|
+
const cx = isRelay ? rX : sX;
|
|
22
|
+
const cy = isRelay ? rY : sY;
|
|
23
|
+
const rx = isRelay ? 240 : 260;
|
|
24
|
+
const ry = isRelay ? 130 : 150;
|
|
25
|
+
const angle = angleStep * i - Math.PI / 2;
|
|
26
|
+
defaultPositions[c.id] = {
|
|
27
|
+
x: cx + rx * Math.cos(angle),
|
|
28
|
+
y: cy + ry * Math.sin(angle),
|
|
29
|
+
};
|
|
30
|
+
});
|
|
31
|
+
const posMap = {};
|
|
32
|
+
if (positions) {
|
|
33
|
+
for (const p of positions) {
|
|
34
|
+
posMap[p.clientId] = { x: p.x, y: p.y };
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
function getPos(clientId) {
|
|
38
|
+
return (posMap[clientId] ?? defaultPositions[clientId] ?? { x: 600, y: 190 });
|
|
39
|
+
}
|
|
40
|
+
const computedTotalNodes = totalNodes ?? clients.length + 2;
|
|
41
|
+
const computedOnline = onlineCount ?? clients.filter((c) => c.status !== 'offline').length;
|
|
42
|
+
const computedOffline = offlineCount ?? clients.filter((c) => c.status === 'offline').length;
|
|
43
|
+
return (_jsxs("div", { ref: ref, className: cn('relative overflow-hidden', 'bg-[radial-gradient(ellipse_at_35%_50%,rgba(59,130,246,0.06)_0%,transparent_50%),radial-gradient(ellipse_at_68%_50%,rgba(139,92,246,0.04)_0%,transparent_40%),#0c0c0c]', 'bg-[image:radial-gradient(circle_at_1px_1px,#1a1a1a_1px,transparent_0)] bg-[size:24px_24px]', className), style: { height: 420 }, ...props, children: [
|
|
44
|
+
_jsx("div", { className: "absolute left-0 right-0 h-px bg-[linear-gradient(90deg,transparent,rgba(59,130,246,0.3),transparent)] animate-[scanSweep_6s_ease-in-out_infinite] pointer-events-none" }), _jsx("div", { className: "absolute top-4 left-5 z-10", children: _jsx("span", { className: "font-mono text-[10px] text-neutral-500 uppercase tracking-widest", children: "Sync Topology" }) }), _jsxs("div", { className: "absolute top-4 right-5 z-10 flex items-center gap-3", children: [
|
|
45
|
+
_jsxs("span", { className: "font-mono text-[10px] text-neutral-600", children: [computedTotalNodes, " nodes"] }), _jsx("span", { className: "font-mono text-[10px] text-neutral-600", children: "\u00B7" }), _jsxs("span", { className: "font-mono text-[10px] text-healthy", children: [computedOnline, " online"] }), _jsx("span", { className: "font-mono text-[10px] text-neutral-600", children: "\u00B7" }), _jsxs("span", { className: "font-mono text-[10px] text-offline", children: [computedOffline, " offline"] })
|
|
46
|
+
] }), _jsxs("svg", { viewBox: `0 0 ${viewBox.width} ${viewBox.height}`, className: "w-full h-full", preserveAspectRatio: "xMidYMid meet", children: [
|
|
47
|
+
_jsx("ellipse", { cx: sX, cy: sY, rx: 280, ry: 160, fill: "none", stroke: "#1a1a1a", strokeWidth: 0.5, strokeDasharray: "6 10" }), _jsx("ellipse", { cx: rX, cy: rY, rx: 260, ry: 140, fill: "none", stroke: "#1a1a1a", strokeWidth: 0.5, strokeDasharray: "6 10" }), _jsx("line", { x1: sX, y1: sY, x2: rX, y2: rY, stroke: "#8b5cf6", strokeWidth: 2, opacity: 0.3 }), _jsx("line", { x1: sX, y1: sY, x2: rX, y2: rY, stroke: "#8b5cf6", strokeWidth: 1, strokeDasharray: "4 2", opacity: 0.6, children: _jsx("animate", { attributeName: "stroke-dashoffset", from: "20", to: "0", dur: "1s", repeatCount: "indefinite" }) }), _jsxs("circle", { r: 3, fill: "#8b5cf6", opacity: 0.8, children: [
|
|
48
|
+
_jsx("animateMotion", { dur: "2.5s", repeatCount: "indefinite", path: `M${sX},${sY} L${rX},${rY}` }), _jsx("animate", { attributeName: "opacity", values: "0;0.8;0.8;0", dur: "2.5s", repeatCount: "indefinite" })
|
|
49
|
+
] }), _jsxs("circle", { r: 3, fill: "#8b5cf6", opacity: 0.8, children: [
|
|
50
|
+
_jsx("animateMotion", { dur: "2.5s", begin: "1.25s", repeatCount: "indefinite", path: `M${rX},${rY} L${sX},${sY}` }), _jsx("animate", { attributeName: "opacity", values: "0;0.8;0.8;0", dur: "2.5s", begin: "1.25s", repeatCount: "indefinite" })
|
|
51
|
+
] }), _jsx("text", { x: (sX + rX) / 2, y: sY - 20, textAnchor: "middle", fill: "#8b5cf6", fontFamily: "JetBrains Mono, monospace", fontSize: 8, opacity: 0.4, letterSpacing: 2, children: "BACKBONE" }), clients.map((c) => {
|
|
52
|
+
const p = getPos(c.id);
|
|
53
|
+
const isRelay = relayClientIds.includes(c.id);
|
|
54
|
+
const tX = isRelay ? rX : sX;
|
|
55
|
+
const tY = isRelay ? rY : sY;
|
|
56
|
+
const color = getStatusColor(c.status);
|
|
57
|
+
const w = c.status === 'syncing' ? 2.5 : 1.5;
|
|
58
|
+
if (c.status === 'offline') {
|
|
59
|
+
return (_jsx("line", { x1: tX, y1: tY, x2: p.x, y2: p.y, stroke: color, strokeWidth: 1, strokeDasharray: "3 6", opacity: 0.2 }, `line-${c.id}`));
|
|
60
|
+
}
|
|
61
|
+
const dur = c.status === 'syncing' ? '1.2s' : '2.8s';
|
|
62
|
+
const halfDur = `${Number.parseFloat(dur) / 2}s`;
|
|
63
|
+
return (_jsxs("g", { children: [
|
|
64
|
+
_jsx("line", { x1: tX, y1: tY, x2: p.x, y2: p.y, stroke: color, strokeWidth: w, strokeDasharray: "4 2", children: _jsx("animate", { attributeName: "stroke-dashoffset", from: "20", to: "0", dur: "1s", repeatCount: "indefinite" }) }), _jsxs("circle", { r: 2.5, fill: color, opacity: 0.7, children: [
|
|
65
|
+
_jsx("animateMotion", { dur: dur, repeatCount: "indefinite", path: `M${tX},${tY} L${p.x},${p.y}` }), _jsx("animate", { attributeName: "opacity", values: "0;0.7;0.7;0", dur: dur, repeatCount: "indefinite" })
|
|
66
|
+
] }), _jsxs("circle", { r: 2, fill: color, opacity: 0.5, children: [
|
|
67
|
+
_jsx("animateMotion", { dur: dur, begin: halfDur, repeatCount: "indefinite", path: `M${p.x},${p.y} L${tX},${tY}` }), _jsx("animate", { attributeName: "opacity", values: "0;0.5;0.5;0", dur: dur, begin: halfDur, repeatCount: "indefinite" })
|
|
68
|
+
] })
|
|
69
|
+
] }, `line-${c.id}`));
|
|
70
|
+
}), _jsxs("circle", { cx: sX, cy: sY, r: 50, fill: "none", stroke: "#3b82f6", strokeWidth: 0.5, opacity: 0.15, children: [
|
|
71
|
+
_jsx("animate", { attributeName: "r", from: "32", to: "60", dur: "3s", repeatCount: "indefinite" }), _jsx("animate", { attributeName: "opacity", from: "0.25", to: "0", dur: "3s", repeatCount: "indefinite" })
|
|
72
|
+
] }), _jsxs("circle", { cx: sX, cy: sY, r: 50, fill: "none", stroke: "#3b82f6", strokeWidth: 0.5, opacity: 0.15, children: [
|
|
73
|
+
_jsx("animate", { attributeName: "r", from: "32", to: "60", dur: "3s", begin: "1.5s", repeatCount: "indefinite" }), _jsx("animate", { attributeName: "opacity", from: "0.25", to: "0", dur: "3s", begin: "1.5s", repeatCount: "indefinite" })
|
|
74
|
+
] }), _jsx("circle", { cx: sX, cy: sY, r: 32, fill: "#0c0c0c", stroke: "#3b82f6", strokeWidth: 2, style: { filter: 'drop-shadow(0 0 12px rgba(59,130,246,0.4))' } }), _jsx("circle", { cx: sX, cy: sY, r: 16, fill: "rgba(59,130,246,0.12)", stroke: "#3b82f6", strokeWidth: 0.8 }), _jsx("circle", { cx: sX, cy: sY, r: 6, fill: "#3b82f6" }), _jsx("text", { x: sX, y: sY + 48, textAnchor: "middle", fill: "#444", fontFamily: "JetBrains Mono, monospace", fontSize: 9, letterSpacing: 2.5, children: "SERVER" }), _jsxs("circle", { cx: rX, cy: rY, r: 40, fill: "none", stroke: "#8b5cf6", strokeWidth: 0.5, opacity: 0.15, children: [
|
|
75
|
+
_jsx("animate", { attributeName: "r", from: "26", to: "48", dur: "3.5s", repeatCount: "indefinite" }), _jsx("animate", { attributeName: "opacity", from: "0.2", to: "0", dur: "3.5s", repeatCount: "indefinite" })
|
|
76
|
+
] }), _jsx("circle", { cx: rX, cy: rY, r: 26, fill: "#0c0c0c", stroke: "#8b5cf6", strokeWidth: 2, style: { filter: 'drop-shadow(0 0 10px rgba(139,92,246,0.35))' } }), _jsx("circle", { cx: rX, cy: rY, r: 13, fill: "rgba(139,92,246,0.12)", stroke: "#8b5cf6", strokeWidth: 0.8 }), _jsx("circle", { cx: rX, cy: rY, r: 5, fill: "#8b5cf6" }), _jsx("text", { x: rX, y: rY + 42, textAnchor: "middle", fill: "#444", fontFamily: "JetBrains Mono, monospace", fontSize: 9, letterSpacing: 2.5, children: "RELAY" }), clients.map((c) => {
|
|
77
|
+
const p = getPos(c.id);
|
|
78
|
+
const color = getStatusColor(c.status);
|
|
79
|
+
const op = c.status === 'offline' ? 0.25 : 1;
|
|
80
|
+
const label = c.actor.replace('user-', '').replace('svc-', '');
|
|
81
|
+
const isRelay = relayClientIds.includes(c.id);
|
|
82
|
+
return (_jsxs("g", { opacity: op, children: [
|
|
83
|
+
_jsx("circle", { cx: p.x, cy: p.y, r: 20, fill: "#0c0c0c", stroke: color, strokeWidth: 1.5 }), _jsx("circle", { cx: p.x, cy: p.y, r: 5, fill: color }), _jsx("text", { x: p.x, y: p.y + 32, textAnchor: "middle", fill: "#555", fontFamily: "JetBrains Mono, monospace", fontSize: 9, children: label }), _jsxs("text", { x: p.x, y: p.y + 42, textAnchor: "middle", fill: "#333", fontFamily: "JetBrains Mono, monospace", fontSize: 7, children: [c.type, isRelay ? ' \u00b7 relay' : ''] })
|
|
84
|
+
] }, `node-${c.id}`));
|
|
85
|
+
})] })
|
|
86
|
+
] }));
|
|
87
|
+
});
|
|
88
|
+
TopologyHero.displayName = 'TopologyHero';
|
|
89
|
+
export { TopologyHero };
|
|
90
|
+
//# sourceMappingURL=topology-hero.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"topology-hero.js","sourceRoot":"","sources":["../../src/console/topology-hero.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
export interface ActorPanelProps {
|
|
3
|
+
label: string;
|
|
4
|
+
color: 'flow' | 'healthy' | 'syncing' | 'relay' | 'encrypt';
|
|
5
|
+
icon: ReactNode;
|
|
6
|
+
badge?: ReactNode;
|
|
7
|
+
children: ReactNode;
|
|
8
|
+
className?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare function ActorPanel({ label, color, icon, badge, children, className }: ActorPanelProps): import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
//# sourceMappingURL=actor-panel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"actor-panel.d.ts","sourceRoot":"","sources":["../../src/demo/actor-panel.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,CAAC;IAC5D,IAAI,EAAE,SAAS,CAAC;IAChB,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAUD,wBAAgB,UAAU,CAAC,EACzB,KAAK,EACL,KAAK,EACL,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,SAAS,EACV,EAAE,eAAe,2CAoBjB"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { cn } from '../lib/cn.js';
|
|
4
|
+
const iconBgMap = {
|
|
5
|
+
flow: 'bg-flow/15',
|
|
6
|
+
healthy: 'bg-healthy/15',
|
|
7
|
+
syncing: 'bg-syncing/15',
|
|
8
|
+
relay: 'bg-relay/15',
|
|
9
|
+
encrypt: 'bg-encrypt/15',
|
|
10
|
+
};
|
|
11
|
+
export function ActorPanel({ label, color, icon, badge, children, className, }) {
|
|
12
|
+
return (_jsxs("div", { className: cn('panel', className), children: [
|
|
13
|
+
_jsxs("div", { className: "panel-header", children: [
|
|
14
|
+
_jsxs("div", { className: "flex items-center gap-2", children: [
|
|
15
|
+
_jsx("div", { className: cn('w-5 h-5 rounded-full flex items-center justify-center', iconBgMap[color]), children: _jsx("span", { className: "text-[12px] leading-none", children: icon }) }), _jsx("span", { className: "panel-label", children: label })
|
|
16
|
+
] }), badge] }), _jsx("div", { className: "p-3", children: children })
|
|
17
|
+
] }));
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=actor-panel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"actor-panel.js","sourceRoot":"","sources":["../../src/demo/actor-panel.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AAW/B,MAAM,SAAS,GAA6C;IAC1D,IAAI,EAAE,YAAY;IAClB,OAAO,EAAE,eAAe;IACxB,OAAO,EAAE,eAAe;IACxB,KAAK,EAAE,aAAa;IACpB,OAAO,EAAE,eAAe;CACzB,CAAC;AAEF,MAAM,UAAU,UAAU,CAAC,EACzB,KAAK,EACL,KAAK,EACL,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,SAAS,GACO,EAAE;IAClB,OAAO,CACL,eAAK,SAAS,EAAE,EAAE,CAAC,OAAO,EAAE,SAAS,CAAC;YACpC,eAAK,SAAS,EAAC,cAAc;oBAC3B,eAAK,SAAS,EAAC,yBAAyB;4BACtC,cACE,SAAS,EAAE,EAAE,CACX,uDAAuD,EACvD,SAAS,CAAC,KAAK,CAAC,CACjB,YAED,eAAM,SAAS,EAAC,0BAA0B,YAAE,IAAI,GAAQ,GACpD,EACN,eAAM,SAAS,EAAC,aAAa,YAAE,KAAK,GAAQ;4BACxC,EACL,KAAK,IACF,EACN,cAAK,SAAS,EAAC,KAAK,YAAE,QAAQ,GAAO;YACjC,CACP,CAAC;AAAA,CACH"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
export interface CatalogRow {
|
|
3
|
+
id: string;
|
|
4
|
+
name: string;
|
|
5
|
+
sku: string;
|
|
6
|
+
price: string;
|
|
7
|
+
}
|
|
8
|
+
export interface CatalogTableProps {
|
|
9
|
+
rows: CatalogRow[];
|
|
10
|
+
label?: string;
|
|
11
|
+
headerRight?: ReactNode;
|
|
12
|
+
footer?: ReactNode;
|
|
13
|
+
maxHeight?: number;
|
|
14
|
+
className?: string;
|
|
15
|
+
}
|
|
16
|
+
export declare function CatalogTable({ rows, label, headerRight, footer, maxHeight, className }: CatalogTableProps): import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
//# sourceMappingURL=catalog-table.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"catalog-table.d.ts","sourceRoot":"","sources":["../../src/demo/catalog-table.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,UAAU,EAAE,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,SAAS,CAAC;IACxB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,YAAY,CAAC,EAC3B,IAAI,EACJ,KAAuB,EACvB,WAAW,EACX,MAAM,EACN,SAAe,EACf,SAAS,EACV,EAAE,iBAAiB,2CAsDnB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { cn } from '../lib/cn.js';
|
|
4
|
+
export function CatalogTable({ rows, label = 'Catalog Items', headerRight, footer, maxHeight = 400, className, }) {
|
|
5
|
+
return (_jsxs("div", { className: cn('rounded-[10px] border border-border bg-panel', className), children: [
|
|
6
|
+
_jsxs("div", { className: "flex items-center justify-between px-3 py-2 border-b border-border", children: [
|
|
7
|
+
_jsx("span", { className: "font-mono text-[10px] uppercase tracking-wider text-neutral-500", children: label }), headerRight ? (_jsx("div", { className: "flex items-center gap-3", children: headerRight })) : null] }), _jsxs("div", { className: "grid grid-cols-[80px_1fr_100px_80px] px-3 py-2 border-b border-border bg-panel-alt", children: [
|
|
8
|
+
_jsx("span", { className: "font-mono text-[9px] text-neutral-500 uppercase", children: "ID" }), _jsx("span", { className: "font-mono text-[9px] text-neutral-500 uppercase", children: "Name" }), _jsx("span", { className: "font-mono text-[9px] text-neutral-500 uppercase", children: "SKU" }), _jsx("span", { className: "font-mono text-[9px] text-neutral-500 uppercase", children: "Price" })
|
|
9
|
+
] }), _jsx("div", { className: "overflow-auto", style: { maxHeight }, children: rows.map((row) => (_jsxs("div", { className: "grid grid-cols-[80px_1fr_100px_80px] px-3 py-2 border-b border-[#161616] font-mono text-[11px] text-neutral-400 hover:bg-white/[0.015] transition-colors", children: [
|
|
10
|
+
_jsx("span", { className: "text-neutral-600", children: row.id }), _jsx("span", { className: "text-neutral-300", children: row.name }), _jsx("span", { className: "text-neutral-600", children: row.sku }), _jsx("span", { className: "text-healthy", children: row.price })
|
|
11
|
+
] }, row.id))) }), footer ? (_jsx("div", { className: "border-t border-border px-4 py-2 flex items-center justify-between", children: footer })) : null] }));
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=catalog-table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"catalog-table.js","sourceRoot":"","sources":["../../src/demo/catalog-table.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AAkB/B,MAAM,UAAU,YAAY,CAAC,EAC3B,IAAI,EACJ,KAAK,GAAG,eAAe,EACvB,WAAW,EACX,MAAM,EACN,SAAS,GAAG,GAAG,EACf,SAAS,GACS,EAAE;IACpB,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CAAC,8CAA8C,EAAE,SAAS,CAAC;YAGxE,eAAK,SAAS,EAAC,oEAAoE;oBACjF,eAAM,SAAS,EAAC,iEAAiE,YAC9E,KAAK,GACD,EACN,WAAW,CAAC,CAAC,CAAC,CACb,cAAK,SAAS,EAAC,yBAAyB,YAAE,WAAW,GAAO,CAC7D,CAAC,CAAC,CAAC,IAAI,IACJ,EAGN,eAAK,SAAS,EAAC,oFAAoF;oBACjG,eAAM,SAAS,EAAC,iDAAiD,mBAE1D,EACP,eAAM,SAAS,EAAC,iDAAiD,qBAE1D,EACP,eAAM,SAAS,EAAC,iDAAiD,oBAE1D,EACP,eAAM,SAAS,EAAC,iDAAiD,sBAE1D;oBACH,EAGN,cAAK,SAAS,EAAC,eAAe,EAAC,KAAK,EAAE,EAAE,SAAS,EAAE,YAChD,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CACjB,eAEE,SAAS,EAAC,0JAA0J;wBAEpK,eAAM,SAAS,EAAC,kBAAkB,YAAE,GAAG,CAAC,EAAE,GAAQ,EAClD,eAAM,SAAS,EAAC,kBAAkB,YAAE,GAAG,CAAC,IAAI,GAAQ,EACpD,eAAM,SAAS,EAAC,kBAAkB,YAAE,GAAG,CAAC,GAAG,GAAQ,EACnD,eAAM,SAAS,EAAC,cAAc,YAAE,GAAG,CAAC,KAAK,GAAQ;yBAN5C,GAAG,CAAC,EAAE,CAOP,CACP,CAAC,GACE,EAGL,MAAM,CAAC,CAAC,CAAC,CACR,cAAK,SAAS,EAAC,oEAAoE,YAChF,MAAM,GACH,CACP,CAAC,CAAC,CAAC,IAAI,IACJ,CACP,CAAC;AAAA,CACH"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface Channel {
|
|
2
|
+
id: string;
|
|
3
|
+
label: string;
|
|
4
|
+
}
|
|
5
|
+
export interface ChannelSelectorProps {
|
|
6
|
+
channels: Channel[];
|
|
7
|
+
activeId: string;
|
|
8
|
+
onSelect: (id: string) => void;
|
|
9
|
+
className?: string;
|
|
10
|
+
}
|
|
11
|
+
export declare function ChannelSelector({ channels, activeId, onSelect, className }: ChannelSelectorProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
//# sourceMappingURL=channel-selector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"channel-selector.d.ts","sourceRoot":"","sources":["../../src/demo/channel-selector.tsx"],"names":[],"mappings":"AAIA,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,oBAAoB;IACnC,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAQ,EACR,QAAQ,EACR,QAAQ,EACR,SAAS,EACV,EAAE,oBAAoB,2CA6BtB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { cn } from '../lib/cn.js';
|
|
4
|
+
export function ChannelSelector({ channels, activeId, onSelect, className, }) {
|
|
5
|
+
return (_jsx("div", { className: cn('flex items-center gap-3', className), children: channels.map((ch) => {
|
|
6
|
+
const active = ch.id === activeId;
|
|
7
|
+
return (_jsxs("button", { type: "button", onClick: () => onSelect(ch.id), className: cn('inline-flex items-center gap-1.5 px-3 py-1 rounded-md font-mono text-[10px] border transition-all cursor-pointer', active
|
|
8
|
+
? 'border-flow/40 bg-flow/[0.08] text-white'
|
|
9
|
+
: 'border-border-bright bg-transparent text-neutral-500 hover:text-neutral-300'), children: [
|
|
10
|
+
_jsx("span", { className: cn('w-1.5 h-1.5 rounded-full', active ? 'bg-flow' : 'bg-neutral-600') }), ch.label] }, ch.id));
|
|
11
|
+
}) }));
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=channel-selector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"channel-selector.js","sourceRoot":"","sources":["../../src/demo/channel-selector.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AAc/B,MAAM,UAAU,eAAe,CAAC,EAC9B,QAAQ,EACR,QAAQ,EACR,QAAQ,EACR,SAAS,GACY,EAAE;IACvB,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,yBAAyB,EAAE,SAAS,CAAC,YACrD,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC;YACpB,MAAM,MAAM,GAAG,EAAE,CAAC,EAAE,KAAK,QAAQ,CAAC;YAClC,OAAO,CACL,kBAEE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,EAC9B,SAAS,EAAE,EAAE,CACX,kHAAkH,EAClH,MAAM;oBACJ,CAAC,CAAC,0CAA0C;oBAC5C,CAAC,CAAC,6EAA6E,CAClF;oBAED,eACE,SAAS,EAAE,EAAE,CACX,0BAA0B,EAC1B,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,gBAAgB,CACtC,GACD,EACD,EAAE,CAAC,KAAK,KAhBJ,EAAE,CAAC,EAAE,CAiBH,CACV,CAAC;QAAA,CACH,CAAC,GACE,CACP,CAAC;AAAA,CACH"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
export type ClientPanelColor = 'flow' | 'relay' | 'healthy' | 'syncing' | 'encrypt';
|
|
3
|
+
export interface ClientPanelProps {
|
|
4
|
+
label: string;
|
|
5
|
+
color: ClientPanelColor;
|
|
6
|
+
status?: ReactNode;
|
|
7
|
+
footer?: ReactNode;
|
|
8
|
+
children: ReactNode;
|
|
9
|
+
className?: string;
|
|
10
|
+
}
|
|
11
|
+
export declare function ClientPanel({ label, color, status, footer, children, className }: ClientPanelProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
//# sourceMappingURL=client-panel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-panel.d.ts","sourceRoot":"","sources":["../../src/demo/client-panel.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC,MAAM,MAAM,gBAAgB,GACxB,MAAM,GACN,OAAO,GACP,SAAS,GACT,SAAS,GACT,SAAS,CAAC;AAUd,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,gBAAgB,CAAC;IACxB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,WAAW,CAAC,EAC1B,KAAK,EACL,KAAK,EACL,MAAM,EACN,MAAM,EACN,QAAQ,EACR,SAAS,EACV,EAAE,gBAAgB,2CAwBlB"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { cn } from '../lib/cn.js';
|
|
4
|
+
const colorMap = {
|
|
5
|
+
flow: 'bg-flow',
|
|
6
|
+
relay: 'bg-relay',
|
|
7
|
+
healthy: 'bg-healthy',
|
|
8
|
+
syncing: 'bg-syncing',
|
|
9
|
+
encrypt: 'bg-encrypt',
|
|
10
|
+
};
|
|
11
|
+
export function ClientPanel({ label, color, status, footer, children, className, }) {
|
|
12
|
+
return (_jsxs("div", { className: cn('rounded-[10px] border border-border bg-panel', className), children: [
|
|
13
|
+
_jsxs("div", { className: "flex items-center justify-between px-4 py-2.5 border-b border-border", children: [
|
|
14
|
+
_jsxs("div", { className: "flex items-center gap-2", children: [
|
|
15
|
+
_jsx("div", { className: cn('w-2 h-2 rounded-full', colorMap[color]) }), _jsx("span", { className: "font-mono text-[10px] uppercase tracking-[1.5px] text-neutral-500", children: label })
|
|
16
|
+
] }), status ? (_jsx("div", { className: "flex items-center gap-2", children: status })) : null] }), _jsx("div", { className: "p-3", children: children }), footer ? (_jsx("div", { className: "border-t border-border px-3 py-2 flex items-center justify-between", children: footer })) : null] }));
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=client-panel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-panel.js","sourceRoot":"","sources":["../../src/demo/client-panel.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AAS/B,MAAM,QAAQ,GAAqC;IACjD,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,UAAU;IACjB,OAAO,EAAE,YAAY;IACrB,OAAO,EAAE,YAAY;IACrB,OAAO,EAAE,YAAY;CACtB,CAAC;AAWF,MAAM,UAAU,WAAW,CAAC,EAC1B,KAAK,EACL,KAAK,EACL,MAAM,EACN,MAAM,EACN,QAAQ,EACR,SAAS,GACQ,EAAE;IACnB,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CAAC,8CAA8C,EAAE,SAAS,CAAC;YAExE,eAAK,SAAS,EAAC,sEAAsE;oBACnF,eAAK,SAAS,EAAC,yBAAyB;4BACtC,cAAK,SAAS,EAAE,EAAE,CAAC,sBAAsB,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,GAAI,EAC/D,eAAM,SAAS,EAAC,mEAAmE,YAChF,KAAK,GACD;4BACH,EACL,MAAM,CAAC,CAAC,CAAC,CACR,cAAK,SAAS,EAAC,yBAAyB,YAAE,MAAM,GAAO,CACxD,CAAC,CAAC,CAAC,IAAI,IACJ,EACN,cAAK,SAAS,EAAC,KAAK,YAAE,QAAQ,GAAO,EACpC,MAAM,CAAC,CAAC,CAAC,CACR,cAAK,SAAS,EAAC,oEAAoE,YAChF,MAAM,GACH,CACP,CAAC,CAAC,CAAC,IAAI,IACJ,CACP,CAAC;AAAA,CACH"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
export interface ConflictPanelProps {
|
|
3
|
+
visible: boolean;
|
|
4
|
+
children: ReactNode;
|
|
5
|
+
className?: string;
|
|
6
|
+
}
|
|
7
|
+
export declare function ConflictPanel({ visible, children, className }: ConflictPanelProps): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
//# sourceMappingURL=conflict-panel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conflict-panel.d.ts","sourceRoot":"","sources":["../../src/demo/conflict-panel.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,aAAa,CAAC,EAC5B,OAAO,EACP,QAAQ,EACR,SAAS,EACV,EAAE,kBAAkB,2CASpB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { cn } from '../lib/cn.js';
|
|
4
|
+
export function ConflictPanel({ visible, children, className, }) {
|
|
5
|
+
return (_jsxs("div", { className: cn('mt-3', className), hidden: !visible, children: [
|
|
6
|
+
_jsx("div", { className: "font-mono text-[10px] text-syncing uppercase tracking-wider mb-2", children: "Pending Conflicts" }), _jsx("div", { className: "space-y-1", children: children })
|
|
7
|
+
] }));
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=conflict-panel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conflict-panel.js","sourceRoot":"","sources":["../../src/demo/conflict-panel.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AAQ/B,MAAM,UAAU,aAAa,CAAC,EAC5B,OAAO,EACP,QAAQ,EACR,SAAS,GACU,EAAE;IACrB,OAAO,CACL,eAAK,SAAS,EAAE,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC,OAAO;YACrD,cAAK,SAAS,EAAC,kEAAkE,kCAE3E,EACN,cAAK,SAAS,EAAC,WAAW,YAAE,QAAQ,GAAO;YACvC,CACP,CAAC;AAAA,CACH"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
export interface DemoHeaderProps {
|
|
3
|
+
title: string;
|
|
4
|
+
subtitle: string;
|
|
5
|
+
right?: ReactNode;
|
|
6
|
+
className?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function DemoHeader({ title, subtitle, right, className }: DemoHeaderProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=demo-header.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"demo-header.d.ts","sourceRoot":"","sources":["../../src/demo/demo-header.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAIvC,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,UAAU,CAAC,EACzB,KAAK,EACL,QAAQ,EACR,KAAK,EACL,SAAS,EACV,EAAE,eAAe,2CAyBjB"}
|