@zendir/ui 0.1.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/CHANGELOG.md +19 -0
- package/LICENSE +21 -0
- package/README.md +589 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.js +421 -0
- package/dist/index.js.map +1 -0
- package/dist/react/3d/EarthViewer.d.ts +46 -0
- package/dist/react/3d/EarthViewer.js +836 -0
- package/dist/react/3d/EarthViewer.js.map +1 -0
- package/dist/react/3d/SolarSystemViewer.d.ts +43 -0
- package/dist/react/3d/SolarSystemViewer.js +372 -0
- package/dist/react/3d/SolarSystemViewer.js.map +1 -0
- package/dist/react/3d/ZenSpace3D.d.ts +16 -0
- package/dist/react/3d/ZenSpace3D.js +1253 -0
- package/dist/react/3d/ZenSpace3D.js.map +1 -0
- package/dist/react/3d/ZenSpace3DCesium.d.ts +9 -0
- package/dist/react/3d/ZenSpace3DCesium.js +186 -0
- package/dist/react/3d/ZenSpace3DCesium.js.map +1 -0
- package/dist/react/3d/ZenSpace3DShaders.d.ts +78 -0
- package/dist/react/3d/ZenSpace3DShaders.js +94 -0
- package/dist/react/3d/ZenSpace3DShaders.js.map +1 -0
- package/dist/react/3d/ZenSpace3DTypes.d.ts +614 -0
- package/dist/react/3d/ZenSpace3DUtils.d.ts +183 -0
- package/dist/react/3d/ZenSpace3DUtils.js +213 -0
- package/dist/react/3d/ZenSpace3DUtils.js.map +1 -0
- package/dist/react/3d/index.d.ts +23 -0
- package/dist/react/3d/threeLoader.d.ts +22 -0
- package/dist/react/3d/threeLoader.js +18 -0
- package/dist/react/3d/threeLoader.js.map +1 -0
- package/dist/react/astro/ClassificationBanner.d.ts +25 -0
- package/dist/react/astro/ClassificationBanner.js +83 -0
- package/dist/react/astro/ClassificationBanner.js.map +1 -0
- package/dist/react/astro/GlobalStatusBar.d.ts +42 -0
- package/dist/react/astro/GlobalStatusBar.js +165 -0
- package/dist/react/astro/GlobalStatusBar.js.map +1 -0
- package/dist/react/astro/MissionClock.d.ts +169 -0
- package/dist/react/astro/MissionClock.js +411 -0
- package/dist/react/astro/MissionClock.js.map +1 -0
- package/dist/react/astro/MonitoringIcon.d.ts +60 -0
- package/dist/react/astro/MonitoringIcon.js +369 -0
- package/dist/react/astro/MonitoringIcon.js.map +1 -0
- package/dist/react/astro/Notification.d.ts +42 -0
- package/dist/react/astro/Notification.js +156 -0
- package/dist/react/astro/Notification.js.map +1 -0
- package/dist/react/astro/Progress.d.ts +39 -0
- package/dist/react/astro/Progress.js +149 -0
- package/dist/react/astro/Progress.js.map +1 -0
- package/dist/react/astro/SimulationControls.d.ts +136 -0
- package/dist/react/astro/SimulationControls.js +668 -0
- package/dist/react/astro/SimulationControls.js.map +1 -0
- package/dist/react/astro/StatusIndicator.d.ts +34 -0
- package/dist/react/astro/StatusIndicator.js +189 -0
- package/dist/react/astro/StatusIndicator.js.map +1 -0
- package/dist/react/astro/UnifiedTimeline.d.ts +106 -0
- package/dist/react/astro/UnifiedTimeline.js +1768 -0
- package/dist/react/astro/UnifiedTimeline.js.map +1 -0
- package/dist/react/astro/index.d.ts +63 -0
- package/dist/react/cards/AccessCard.d.ts +37 -0
- package/dist/react/cards/AccessCard.js +410 -0
- package/dist/react/cards/AccessCard.js.map +1 -0
- package/dist/react/cards/OrbitCard.d.ts +31 -0
- package/dist/react/cards/OrbitCard.js +372 -0
- package/dist/react/cards/OrbitCard.js.map +1 -0
- package/dist/react/cards/SpacecraftCard.d.ts +54 -0
- package/dist/react/cards/SpacecraftCard.js +941 -0
- package/dist/react/cards/SpacecraftCard.js.map +1 -0
- package/dist/react/cards/TelemetryCard.d.ts +40 -0
- package/dist/react/cards/TelemetryCard.js +742 -0
- package/dist/react/cards/TelemetryCard.js.map +1 -0
- package/dist/react/cards/TelemetryStreamCard.d.ts +59 -0
- package/dist/react/cards/TelemetryStreamCard.js +309 -0
- package/dist/react/cards/TelemetryStreamCard.js.map +1 -0
- package/dist/react/cards/index.d.ts +13 -0
- package/dist/react/charts/GroundTrackMap.d.ts +112 -0
- package/dist/react/charts/GroundTrackMap.js +1123 -0
- package/dist/react/charts/GroundTrackMap.js.map +1 -0
- package/dist/react/charts/GroundTrackMapLeaflet.d.ts +26 -0
- package/dist/react/charts/GroundTrackMapLeaflet.js +571 -0
- package/dist/react/charts/GroundTrackMapLeaflet.js.map +1 -0
- package/dist/react/charts/groundTrackMapLeafletTiles.d.ts +22 -0
- package/dist/react/charts/groundTrackMapLeafletTiles.js +11 -0
- package/dist/react/charts/groundTrackMapLeafletTiles.js.map +1 -0
- package/dist/react/charts/groundTrackMapLeafletUtils.d.ts +24 -0
- package/dist/react/charts/groundTrackMapLeafletUtils.js +109 -0
- package/dist/react/charts/groundTrackMapLeafletUtils.js.map +1 -0
- package/dist/react/charts/index.d.ts +10 -0
- package/dist/react/charts/unified/AstroChart.d.ts +24 -0
- package/dist/react/charts/unified/AstroChart.js +1405 -0
- package/dist/react/charts/unified/AstroChart.js.map +1 -0
- package/dist/react/charts/unified/PowerOverviewChart.d.ts +73 -0
- package/dist/react/charts/unified/PowerOverviewChart.js +488 -0
- package/dist/react/charts/unified/PowerOverviewChart.js.map +1 -0
- package/dist/react/charts/unified/domain.d.ts +845 -0
- package/dist/react/charts/unified/domain.js +3168 -0
- package/dist/react/charts/unified/domain.js.map +1 -0
- package/dist/react/charts/unified/generators.d.ts +276 -0
- package/dist/react/charts/unified/generators.js +518 -0
- package/dist/react/charts/unified/generators.js.map +1 -0
- package/dist/react/charts/unified/index.d.ts +55 -0
- package/dist/react/charts/unified/presets.d.ts +290 -0
- package/dist/react/charts/unified/presets.js +999 -0
- package/dist/react/charts/unified/presets.js.map +1 -0
- package/dist/react/charts/unified/sync.d.ts +69 -0
- package/dist/react/charts/unified/sync.js +219 -0
- package/dist/react/charts/unified/sync.js.map +1 -0
- package/dist/react/charts/unified/theme.d.ts +447 -0
- package/dist/react/charts/unified/theme.js +562 -0
- package/dist/react/charts/unified/theme.js.map +1 -0
- package/dist/react/charts/unified/types.d.ts +826 -0
- package/dist/react/charts/unified/useChartStream.d.ts +58 -0
- package/dist/react/charts/unified/useChartStream.js +226 -0
- package/dist/react/charts/unified/useChartStream.js.map +1 -0
- package/dist/react/chatgpt/AppCard.d.ts +59 -0
- package/dist/react/chatgpt/AppCard.js +306 -0
- package/dist/react/chatgpt/AppCard.js.map +1 -0
- package/dist/react/chatgpt/ChatGPTCard.d.ts +6 -0
- package/dist/react/chatgpt/index.d.ts +167 -0
- package/dist/react/chatgpt/index.js +166 -0
- package/dist/react/chatgpt/index.js.map +1 -0
- package/dist/react/context/DisplaySettingsContext.d.ts +107 -0
- package/dist/react/context/DisplaySettingsContext.js +169 -0
- package/dist/react/context/DisplaySettingsContext.js.map +1 -0
- package/dist/react/context/index.d.ts +5 -0
- package/dist/react/core/ActivityPlanner.d.ts +45 -0
- package/dist/react/core/ActivityPlanner.js +532 -0
- package/dist/react/core/ActivityPlanner.js.map +1 -0
- package/dist/react/core/AppBar.d.ts +71 -0
- package/dist/react/core/AppBar.js +817 -0
- package/dist/react/core/AppBar.js.map +1 -0
- package/dist/react/core/AstroIcon.d.ts +84 -0
- package/dist/react/core/AstroIcon.js +1243 -0
- package/dist/react/core/AstroIcon.js.map +1 -0
- package/dist/react/core/Badge.d.ts +27 -0
- package/dist/react/core/Badge.js +134 -0
- package/dist/react/core/Badge.js.map +1 -0
- package/dist/react/core/Button.d.ts +26 -0
- package/dist/react/core/Button.js +306 -0
- package/dist/react/core/Button.js.map +1 -0
- package/dist/react/core/CardHeader.d.ts +34 -0
- package/dist/react/core/CardHeader.js +316 -0
- package/dist/react/core/CardHeader.js.map +1 -0
- package/dist/react/core/ChatPanel.d.ts +627 -0
- package/dist/react/core/ChatPanel.js +1144 -0
- package/dist/react/core/ChatPanel.js.map +1 -0
- package/dist/react/core/Checkbox.d.ts +26 -0
- package/dist/react/core/Checkbox.js +130 -0
- package/dist/react/core/Checkbox.js.map +1 -0
- package/dist/react/core/ColorPickerPanel.d.ts +25 -0
- package/dist/react/core/ColorPickerPanel.js +293 -0
- package/dist/react/core/ColorPickerPanel.js.map +1 -0
- package/dist/react/core/CommandBuilder.d.ts +74 -0
- package/dist/react/core/CommandBuilder.js +518 -0
- package/dist/react/core/CommandBuilder.js.map +1 -0
- package/dist/react/core/ConfirmDialog.d.ts +45 -0
- package/dist/react/core/ConfirmDialog.js +315 -0
- package/dist/react/core/ConfirmDialog.js.map +1 -0
- package/dist/react/core/ConnectionForm.d.ts +57 -0
- package/dist/react/core/ConnectionForm.js +496 -0
- package/dist/react/core/ConnectionForm.js.map +1 -0
- package/dist/react/core/Container.d.ts +51 -0
- package/dist/react/core/Container.js +670 -0
- package/dist/react/core/Container.js.map +1 -0
- package/dist/react/core/CopyButton.d.ts +39 -0
- package/dist/react/core/CopyButton.js +105 -0
- package/dist/react/core/CopyButton.js.map +1 -0
- package/dist/react/core/DataTable.d.ts +113 -0
- package/dist/react/core/DataTable.js +446 -0
- package/dist/react/core/DataTable.js.map +1 -0
- package/dist/react/core/DataValue.d.ts +64 -0
- package/dist/react/core/DataValue.js +545 -0
- package/dist/react/core/DataValue.js.map +1 -0
- package/dist/react/core/Dialog.d.ts +32 -0
- package/dist/react/core/Dialog.js +201 -0
- package/dist/react/core/Dialog.js.map +1 -0
- package/dist/react/core/FileExplorer.d.ts +65 -0
- package/dist/react/core/FileExplorer.js +520 -0
- package/dist/react/core/FileExplorer.js.map +1 -0
- package/dist/react/core/GlassCard.d.ts +129 -0
- package/dist/react/core/GlassCard.js +375 -0
- package/dist/react/core/GlassCard.js.map +1 -0
- package/dist/react/core/HeaderIconWithStatus.d.ts +39 -0
- package/dist/react/core/HeaderIconWithStatus.js +157 -0
- package/dist/react/core/HeaderIconWithStatus.js.map +1 -0
- package/dist/react/core/HexViewer.d.ts +143 -0
- package/dist/react/core/HexViewer.js +1106 -0
- package/dist/react/core/HexViewer.js.map +1 -0
- package/dist/react/core/Icon.d.ts +32 -0
- package/dist/react/core/Icon.js +142 -0
- package/dist/react/core/Icon.js.map +1 -0
- package/dist/react/core/ImageGallery.d.ts +41 -0
- package/dist/react/core/ImageGallery.js +320 -0
- package/dist/react/core/ImageGallery.js.map +1 -0
- package/dist/react/core/Input.d.ts +38 -0
- package/dist/react/core/Input.js +288 -0
- package/dist/react/core/Input.js.map +1 -0
- package/dist/react/core/LimitsBar.d.ts +51 -0
- package/dist/react/core/LimitsBar.js +200 -0
- package/dist/react/core/LimitsBar.js.map +1 -0
- package/dist/react/core/LogViewer.d.ts +61 -0
- package/dist/react/core/LogViewer.js +599 -0
- package/dist/react/core/LogViewer.js.map +1 -0
- package/dist/react/core/MessageStream.d.ts +58 -0
- package/dist/react/core/MessageStream.js +455 -0
- package/dist/react/core/MessageStream.js.map +1 -0
- package/dist/react/core/MissionCalendar.d.ts +81 -0
- package/dist/react/core/MissionCalendar.js +1049 -0
- package/dist/react/core/MissionCalendar.js.map +1 -0
- package/dist/react/core/NumberInput.d.ts +85 -0
- package/dist/react/core/NumberInput.js +507 -0
- package/dist/react/core/NumberInput.js.map +1 -0
- package/dist/react/core/PacketViewer.d.ts +73 -0
- package/dist/react/core/PacketViewer.js +431 -0
- package/dist/react/core/PacketViewer.js.map +1 -0
- package/dist/react/core/Pagination.d.ts +30 -0
- package/dist/react/core/Pagination.js +190 -0
- package/dist/react/core/Pagination.js.map +1 -0
- package/dist/react/core/PinInput.d.ts +41 -0
- package/dist/react/core/PinInput.js +210 -0
- package/dist/react/core/PinInput.js.map +1 -0
- package/dist/react/core/Popover.d.ts +55 -0
- package/dist/react/core/Popover.js +288 -0
- package/dist/react/core/Popover.js.map +1 -0
- package/dist/react/core/Select.d.ts +42 -0
- package/dist/react/core/Select.js +303 -0
- package/dist/react/core/Select.js.map +1 -0
- package/dist/react/core/SideNav.d.ts +103 -0
- package/dist/react/core/SideNav.js +551 -0
- package/dist/react/core/SideNav.js.map +1 -0
- package/dist/react/core/SidePanel.d.ts +33 -0
- package/dist/react/core/SidePanel.js +199 -0
- package/dist/react/core/SidePanel.js.map +1 -0
- package/dist/react/core/Tabs.d.ts +47 -0
- package/dist/react/core/Tabs.js +129 -0
- package/dist/react/core/Tabs.js.map +1 -0
- package/dist/react/core/Toast.d.ts +56 -0
- package/dist/react/core/Toast.js +229 -0
- package/dist/react/core/Toast.js.map +1 -0
- package/dist/react/core/Toggle.d.ts +22 -0
- package/dist/react/core/Toggle.js +151 -0
- package/dist/react/core/Toggle.js.map +1 -0
- package/dist/react/core/Tooltip.d.ts +19 -0
- package/dist/react/core/Tooltip.js +179 -0
- package/dist/react/core/Tooltip.js.map +1 -0
- package/dist/react/core/Typography.d.ts +127 -0
- package/dist/react/core/Typography.js +187 -0
- package/dist/react/core/Typography.js.map +1 -0
- package/dist/react/core/index.d.ts +108 -0
- package/dist/react/core/layout/Box.d.ts +77 -0
- package/dist/react/core/layout/Box.js +126 -0
- package/dist/react/core/layout/Box.js.map +1 -0
- package/dist/react/core/layout/Center.d.ts +20 -0
- package/dist/react/core/layout/Center.js +34 -0
- package/dist/react/core/layout/Center.js.map +1 -0
- package/dist/react/core/layout/Divider.d.ts +16 -0
- package/dist/react/core/layout/Divider.js +108 -0
- package/dist/react/core/layout/Divider.js.map +1 -0
- package/dist/react/core/layout/Flex.d.ts +30 -0
- package/dist/react/core/layout/Flex.js +128 -0
- package/dist/react/core/layout/Flex.js.map +1 -0
- package/dist/react/core/layout/Grid.d.ts +36 -0
- package/dist/react/core/layout/Grid.js +142 -0
- package/dist/react/core/layout/Grid.js.map +1 -0
- package/dist/react/core/layout/Spacer.d.ts +8 -0
- package/dist/react/core/layout/Spacer.js +31 -0
- package/dist/react/core/layout/Spacer.js.map +1 -0
- package/dist/react/core/layout/Stack.d.ts +54 -0
- package/dist/react/core/layout/Stack.js +74 -0
- package/dist/react/core/layout/Stack.js.map +1 -0
- package/dist/react/core/layout/index.d.ts +38 -0
- package/dist/react/core/layout/responsive.d.ts +23 -0
- package/dist/react/core/layout/responsive.js +26 -0
- package/dist/react/core/layout/responsive.js.map +1 -0
- package/dist/react/core/layout/useBreakpoint.d.ts +77 -0
- package/dist/react/core/layout/useBreakpoint.js +73 -0
- package/dist/react/core/layout/useBreakpoint.js.map +1 -0
- package/dist/react/core/propertyConfig.d.ts +443 -0
- package/dist/react/core/propertyConfig.js +399 -0
- package/dist/react/core/propertyConfig.js.map +1 -0
- package/dist/react/hooks/index.d.ts +21 -0
- package/dist/react/hooks/useAccessWindows.d.ts +66 -0
- package/dist/react/hooks/useCompactMode.d.ts +82 -0
- package/dist/react/hooks/useCompactMode.js +62 -0
- package/dist/react/hooks/useCompactMode.js.map +1 -0
- package/dist/react/hooks/useLiveSelection.d.ts +57 -0
- package/dist/react/hooks/useSimulationPlayback.d.ts +97 -0
- package/dist/react/hooks/useSimulationTime.d.ts +61 -0
- package/dist/react/hooks/useSpacecraftPosition.d.ts +50 -0
- package/dist/react/hooks/useSpacecraftPosition.js +89 -0
- package/dist/react/hooks/useSpacecraftPosition.js.map +1 -0
- package/dist/react/hooks/useTelemetry.d.ts +55 -0
- package/dist/react/hooks/useTelemetry.js +73 -0
- package/dist/react/hooks/useTelemetry.js.map +1 -0
- package/dist/react/hooks/useZendirSession.d.ts +109 -0
- package/dist/react/hooks/useZendirSession.js +148 -0
- package/dist/react/hooks/useZendirSession.js.map +1 -0
- package/dist/react/index.d.ts +74 -0
- package/dist/react/shared/ErrorBoundary.d.ts +63 -0
- package/dist/react/shared/ErrorBoundary.js +142 -0
- package/dist/react/shared/ErrorBoundary.js.map +1 -0
- package/dist/react/shared/Skeleton.d.ts +110 -0
- package/dist/react/shared/Skeleton.js +324 -0
- package/dist/react/shared/Skeleton.js.map +1 -0
- package/dist/react/shared/index.d.ts +12 -0
- package/dist/react/theme/ThemeProvider.d.ts +385 -0
- package/dist/react/theme/ThemeProvider.js +1096 -0
- package/dist/react/theme/ThemeProvider.js.map +1 -0
- package/dist/react/theme/astro-tokens.d.ts +153 -0
- package/dist/react/theme/cardAccent.d.ts +75 -0
- package/dist/react/theme/cardAccent.js +137 -0
- package/dist/react/theme/cardAccent.js.map +1 -0
- package/dist/react/theme/config.d.ts +39 -0
- package/dist/react/theme/index.d.ts +9 -0
- package/dist/react/types.d.ts +360 -0
- package/dist/react/types.js +58 -0
- package/dist/react/types.js.map +1 -0
- package/dist/react/utils/index.d.ts +247 -0
- package/dist/react/utils/index.js +423 -0
- package/dist/react/utils/index.js.map +1 -0
- package/dist/react/visualizations/EclipseTimerCard.d.ts +17 -0
- package/dist/react/visualizations/EclipseTimerCard.js +250 -0
- package/dist/react/visualizations/EclipseTimerCard.js.map +1 -0
- package/dist/react/visualizations/LinkBudgetCard.d.ts +50 -0
- package/dist/react/visualizations/LinkBudgetCard.js +444 -0
- package/dist/react/visualizations/LinkBudgetCard.js.map +1 -0
- package/dist/react/visualizations/NavBallCard.d.ts +17 -0
- package/dist/react/visualizations/NavBallCard.js +243 -0
- package/dist/react/visualizations/NavBallCard.js.map +1 -0
- package/dist/react/visualizations/PropulsionCard.d.ts +37 -0
- package/dist/react/visualizations/PropulsionCard.js +298 -0
- package/dist/react/visualizations/PropulsionCard.js.map +1 -0
- package/dist/react/visualizations/SensorFootprintCard.d.ts +33 -0
- package/dist/react/visualizations/SensorFootprintCard.js +326 -0
- package/dist/react/visualizations/SensorFootprintCard.js.map +1 -0
- package/dist/react/visualizations/ThermalHeatmapCard.d.ts +38 -0
- package/dist/react/visualizations/ThermalHeatmapCard.js +372 -0
- package/dist/react/visualizations/ThermalHeatmapCard.js.map +1 -0
- package/dist/react/visualizations/index.d.ts +17 -0
- package/dist/react.d.ts +1 -0
- package/dist/react.js +421 -0
- package/dist/react.js.map +1 -0
- package/dist/shaders/atmosphere.frag.js +5 -0
- package/dist/shaders/atmosphere.frag.js.map +1 -0
- package/dist/shaders/atmosphere.vert.js +5 -0
- package/dist/shaders/atmosphere.vert.js.map +1 -0
- package/dist/shaders/stars.frag.js +5 -0
- package/dist/shaders/stars.frag.js.map +1 -0
- package/dist/shaders/stars.vert.js +5 -0
- package/dist/shaders/stars.vert.js.map +1 -0
- package/dist/style.css +143 -0
- package/dist/tokens/index.d.ts +296 -0
- package/dist/tokens/index.js +263 -0
- package/dist/tokens/index.js.map +1 -0
- package/dist/tokens/tokens.css +155 -0
- package/dist/types/index.d.ts +23 -0
- package/dist/types.d.ts +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/package.json +220 -0
- package/sdk-stub.js +22 -0
|
@@ -0,0 +1,562 @@
|
|
|
1
|
+
const ZENDIR_BRAND_COLORS = {
|
|
2
|
+
// === Core Brand Colors ===
|
|
3
|
+
/** Electric - Primary accent (#3E3CFF) */
|
|
4
|
+
electric: "#3E3CFF",
|
|
5
|
+
/** Purple - Secondary accent (#9D70FF) */
|
|
6
|
+
purple: "#9D70FF",
|
|
7
|
+
/** Prussian Blue - Subsections (#1B2DA0) */
|
|
8
|
+
prussianBlue: "#1B2DA0",
|
|
9
|
+
// === Electric Shades (10%, 20%, 35% overlays) ===
|
|
10
|
+
electricLighter: "#9997FF",
|
|
11
|
+
// 35% white overlay
|
|
12
|
+
electricLight: "#6B69FF",
|
|
13
|
+
// 20% white overlay
|
|
14
|
+
electricSoft: "#5250FF",
|
|
15
|
+
// 10% white overlay
|
|
16
|
+
electricDark: "#3836E6",
|
|
17
|
+
// 10% black overlay
|
|
18
|
+
electricDarker: "#3230CC",
|
|
19
|
+
// 35% black overlay
|
|
20
|
+
// === Purple Shades ===
|
|
21
|
+
purpleLighter: "#C9A8FF",
|
|
22
|
+
// 35% white overlay
|
|
23
|
+
purpleLight: "#B48DFF",
|
|
24
|
+
// 10% black overlay
|
|
25
|
+
purpleDarker: "#7E5ACC",
|
|
26
|
+
// 35% black overlay
|
|
27
|
+
// === Prussian Blue Shades ===
|
|
28
|
+
prussianBlueLighter: "#4A5FD6",
|
|
29
|
+
// 35% white overlay
|
|
30
|
+
prussianBlueLight: "#3548C0",
|
|
31
|
+
// 10% black overlay
|
|
32
|
+
prussianBlueDarker: "#142380"
|
|
33
|
+
};
|
|
34
|
+
const OFFICIAL_ASTRO_DATA_VIZ_COLORS = {
|
|
35
|
+
/** Extended palette - primary + additional derived colors for 11 max */
|
|
36
|
+
extended: [
|
|
37
|
+
"#00c7cb",
|
|
38
|
+
// Teal 500 - Primary
|
|
39
|
+
"#938bdb",
|
|
40
|
+
// Purple 400 - Secondary
|
|
41
|
+
"#4dacff",
|
|
42
|
+
// Brightblue 500
|
|
43
|
+
"#70dde0",
|
|
44
|
+
// Teal 300
|
|
45
|
+
"#c9c5ed",
|
|
46
|
+
// Purple 200
|
|
47
|
+
"#92cbff",
|
|
48
|
+
// Brightblue 400
|
|
49
|
+
"#a1e9eb",
|
|
50
|
+
// Teal 200
|
|
51
|
+
"#b7dcff",
|
|
52
|
+
// Brightblue 300
|
|
53
|
+
"#009a9d",
|
|
54
|
+
// Teal 600 (darker)
|
|
55
|
+
"#756bb8",
|
|
56
|
+
// Purple 500 (darker)
|
|
57
|
+
"#2b659b"
|
|
58
|
+
// Brightblue 700 (darker)
|
|
59
|
+
],
|
|
60
|
+
/** Sequential palettes for heatmaps using AstroUXDS colors */
|
|
61
|
+
sequential: {
|
|
62
|
+
/** Teal sequential */
|
|
63
|
+
teal: ["#e5f9f9", "#a1e9eb", "#70dde0", "#00c7cb", "#009a9d", "#006e70"]
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
const ASTRO_DATA_VIZ_COLORS = {
|
|
67
|
+
/**
|
|
68
|
+
* Primary data visualization palette - Pure Zendir Brand
|
|
69
|
+
* Uses only Zendir brand colors and their derived shades
|
|
70
|
+
* Max 11 colors per AstroUXDS compliance requirement 3.2.1
|
|
71
|
+
*
|
|
72
|
+
* NOTE: Status colors (green, yellow, red) reserved for status indication only
|
|
73
|
+
*/
|
|
74
|
+
mixed: [
|
|
75
|
+
ZENDIR_BRAND_COLORS.electric,
|
|
76
|
+
// #3E3CFF - Primary
|
|
77
|
+
ZENDIR_BRAND_COLORS.purple,
|
|
78
|
+
// #9D70FF - Secondary
|
|
79
|
+
ZENDIR_BRAND_COLORS.electricLight,
|
|
80
|
+
// #6B69FF - Electric 20% lighter
|
|
81
|
+
ZENDIR_BRAND_COLORS.purpleLight,
|
|
82
|
+
// #B48DFF - Purple 20% lighter
|
|
83
|
+
ZENDIR_BRAND_COLORS.prussianBlueLight,
|
|
84
|
+
// #3548C0 - Prussian Blue lighter
|
|
85
|
+
ZENDIR_BRAND_COLORS.electricLighter,
|
|
86
|
+
// #9997FF - Electric 35% lighter
|
|
87
|
+
ZENDIR_BRAND_COLORS.purpleLighter,
|
|
88
|
+
// #C9A8FF - Purple 35% lighter
|
|
89
|
+
ZENDIR_BRAND_COLORS.prussianBlue,
|
|
90
|
+
// #1B2DA0 - Prussian Blue
|
|
91
|
+
ZENDIR_BRAND_COLORS.electricDarker,
|
|
92
|
+
// #3230CC - Electric 20% darker
|
|
93
|
+
ZENDIR_BRAND_COLORS.purpleDarker,
|
|
94
|
+
// #7E5ACC - Purple 20% darker
|
|
95
|
+
ZENDIR_BRAND_COLORS.prussianBlueLighter
|
|
96
|
+
// #4A5FD6 - Prussian Blue lightest
|
|
97
|
+
],
|
|
98
|
+
/**
|
|
99
|
+
* Zendir Brand palette - Full brand spectrum
|
|
100
|
+
* Complete set of Zendir brand colors for maximum brand expression
|
|
101
|
+
*/
|
|
102
|
+
zendir: [
|
|
103
|
+
ZENDIR_BRAND_COLORS.electric,
|
|
104
|
+
// #3E3CFF - Primary
|
|
105
|
+
ZENDIR_BRAND_COLORS.purple,
|
|
106
|
+
// #9D70FF - Secondary
|
|
107
|
+
ZENDIR_BRAND_COLORS.electricLight,
|
|
108
|
+
// #6B69FF
|
|
109
|
+
ZENDIR_BRAND_COLORS.purpleLight,
|
|
110
|
+
// #B48DFF
|
|
111
|
+
ZENDIR_BRAND_COLORS.prussianBlue,
|
|
112
|
+
// #1B2DA0
|
|
113
|
+
ZENDIR_BRAND_COLORS.electricLighter,
|
|
114
|
+
// #9997FF
|
|
115
|
+
ZENDIR_BRAND_COLORS.purpleLighter,
|
|
116
|
+
// #C9A8FF
|
|
117
|
+
ZENDIR_BRAND_COLORS.prussianBlueLight
|
|
118
|
+
// #3548C0
|
|
119
|
+
],
|
|
120
|
+
/**
|
|
121
|
+
* Extended Zendir palette - All shades for complex visualizations
|
|
122
|
+
* Includes dark and light variants for maximum differentiation
|
|
123
|
+
*/
|
|
124
|
+
zendirExtended: [
|
|
125
|
+
ZENDIR_BRAND_COLORS.electric,
|
|
126
|
+
// #3E3CFF
|
|
127
|
+
ZENDIR_BRAND_COLORS.purple,
|
|
128
|
+
// #9D70FF
|
|
129
|
+
ZENDIR_BRAND_COLORS.prussianBlue,
|
|
130
|
+
// #1B2DA0
|
|
131
|
+
ZENDIR_BRAND_COLORS.electricLight,
|
|
132
|
+
// #6B69FF
|
|
133
|
+
ZENDIR_BRAND_COLORS.purpleLight,
|
|
134
|
+
// #B48DFF
|
|
135
|
+
ZENDIR_BRAND_COLORS.prussianBlueLight,
|
|
136
|
+
// #3548C0
|
|
137
|
+
ZENDIR_BRAND_COLORS.electricLighter,
|
|
138
|
+
// #9997FF
|
|
139
|
+
ZENDIR_BRAND_COLORS.purpleLighter,
|
|
140
|
+
// #C9A8FF
|
|
141
|
+
ZENDIR_BRAND_COLORS.electricDarker,
|
|
142
|
+
// #3230CC
|
|
143
|
+
ZENDIR_BRAND_COLORS.purpleDarker,
|
|
144
|
+
// #7E5ACC
|
|
145
|
+
ZENDIR_BRAND_COLORS.prussianBlueDarker
|
|
146
|
+
// #142380
|
|
147
|
+
],
|
|
148
|
+
/**
|
|
149
|
+
* Cool palette - Blues and purples
|
|
150
|
+
* Professional Zendir-branded cool tones
|
|
151
|
+
*/
|
|
152
|
+
cool: [
|
|
153
|
+
ZENDIR_BRAND_COLORS.electric,
|
|
154
|
+
// #3E3CFF
|
|
155
|
+
ZENDIR_BRAND_COLORS.prussianBlue,
|
|
156
|
+
// #1B2DA0
|
|
157
|
+
ZENDIR_BRAND_COLORS.purple,
|
|
158
|
+
// #9D70FF
|
|
159
|
+
ZENDIR_BRAND_COLORS.electricLight,
|
|
160
|
+
// #6B69FF
|
|
161
|
+
ZENDIR_BRAND_COLORS.prussianBlueLight,
|
|
162
|
+
// #3548C0
|
|
163
|
+
ZENDIR_BRAND_COLORS.purpleLight,
|
|
164
|
+
// #B48DFF
|
|
165
|
+
ZENDIR_BRAND_COLORS.electricLighter,
|
|
166
|
+
// #9997FF
|
|
167
|
+
ZENDIR_BRAND_COLORS.prussianBlueLighter
|
|
168
|
+
// #4A5FD6
|
|
169
|
+
],
|
|
170
|
+
/**
|
|
171
|
+
* Warm accent palette - For charts needing warm tones
|
|
172
|
+
* Use sparingly - not part of Zendir brand
|
|
173
|
+
*/
|
|
174
|
+
warm: [
|
|
175
|
+
"#ffb302",
|
|
176
|
+
// Amber
|
|
177
|
+
"#ff9966",
|
|
178
|
+
// Coral
|
|
179
|
+
"#fce83a",
|
|
180
|
+
// Yellow
|
|
181
|
+
"#ff6b6b",
|
|
182
|
+
// Salmon
|
|
183
|
+
"#f0a000",
|
|
184
|
+
// Orange
|
|
185
|
+
"#ffcc80",
|
|
186
|
+
// Peach
|
|
187
|
+
"#e0a86c",
|
|
188
|
+
// Tan
|
|
189
|
+
"#d4b896"
|
|
190
|
+
// Sand
|
|
191
|
+
],
|
|
192
|
+
/**
|
|
193
|
+
* Electric-Purple gradient palette (Zendir brand gradient)
|
|
194
|
+
* Matches the official brand gradient from Electric to Purple
|
|
195
|
+
*/
|
|
196
|
+
electricPurple: [
|
|
197
|
+
ZENDIR_BRAND_COLORS.electric,
|
|
198
|
+
// #3E3CFF
|
|
199
|
+
ZENDIR_BRAND_COLORS.electricSoft,
|
|
200
|
+
// #5250FF
|
|
201
|
+
ZENDIR_BRAND_COLORS.electricLight,
|
|
202
|
+
// #6B69FF
|
|
203
|
+
"#8070FF",
|
|
204
|
+
// Blend E→P
|
|
205
|
+
ZENDIR_BRAND_COLORS.purple,
|
|
206
|
+
// #9D70FF
|
|
207
|
+
ZENDIR_BRAND_COLORS.purpleLight,
|
|
208
|
+
// #B48DFF
|
|
209
|
+
ZENDIR_BRAND_COLORS.purpleLighter,
|
|
210
|
+
// #C9A8FF
|
|
211
|
+
"#DCC4FF"
|
|
212
|
+
// Lightest
|
|
213
|
+
],
|
|
214
|
+
/**
|
|
215
|
+
* Prussian-Electric gradient palette
|
|
216
|
+
* Deep to vibrant brand progression
|
|
217
|
+
*/
|
|
218
|
+
prussianElectric: [
|
|
219
|
+
ZENDIR_BRAND_COLORS.prussianBlueDarker,
|
|
220
|
+
// #142380
|
|
221
|
+
ZENDIR_BRAND_COLORS.prussianBlue,
|
|
222
|
+
// #1B2DA0
|
|
223
|
+
ZENDIR_BRAND_COLORS.prussianBlueLight,
|
|
224
|
+
// #3548C0
|
|
225
|
+
ZENDIR_BRAND_COLORS.electricDarker,
|
|
226
|
+
// #3230CC
|
|
227
|
+
ZENDIR_BRAND_COLORS.electric,
|
|
228
|
+
// #3E3CFF
|
|
229
|
+
ZENDIR_BRAND_COLORS.electricLight
|
|
230
|
+
// #6B69FF
|
|
231
|
+
],
|
|
232
|
+
/**
|
|
233
|
+
* Full Zendir spectrum gradient
|
|
234
|
+
* Prussian Blue → Electric → Purple
|
|
235
|
+
*/
|
|
236
|
+
zendirSpectrum: [
|
|
237
|
+
ZENDIR_BRAND_COLORS.prussianBlue,
|
|
238
|
+
// #1B2DA0
|
|
239
|
+
ZENDIR_BRAND_COLORS.prussianBlueLight,
|
|
240
|
+
// #3548C0
|
|
241
|
+
ZENDIR_BRAND_COLORS.electric,
|
|
242
|
+
// #3E3CFF
|
|
243
|
+
ZENDIR_BRAND_COLORS.electricLight,
|
|
244
|
+
// #6B69FF
|
|
245
|
+
ZENDIR_BRAND_COLORS.purple,
|
|
246
|
+
// #9D70FF
|
|
247
|
+
ZENDIR_BRAND_COLORS.purpleLight
|
|
248
|
+
// #B48DFF
|
|
249
|
+
],
|
|
250
|
+
/**
|
|
251
|
+
* Sequential palettes for heatmaps and gradual data
|
|
252
|
+
* Zendir brand-forward gradients
|
|
253
|
+
*/
|
|
254
|
+
sequential: {
|
|
255
|
+
/** Zendir Electric sequential - Primary brand gradient */
|
|
256
|
+
electric: ["#E8E8FF", "#C9C8FF", "#9997FF", "#6B69FF", "#3E3CFF", "#3230CC", "#262499"],
|
|
257
|
+
/** Zendir Purple sequential - Secondary brand gradient */
|
|
258
|
+
purple: ["#F0E8FF", "#DCC4FF", "#C9A8FF", "#B48DFF", "#9D70FF", "#7E5ACC", "#5F4499"],
|
|
259
|
+
/** Zendir Prussian Blue sequential - Deep brand gradient */
|
|
260
|
+
prussianBlue: ["#E8ECFF", "#C5CFF0", "#8A9DD6", "#4A5FD6", "#3548C0", "#1B2DA0", "#0F1A60"],
|
|
261
|
+
/** Zendir gradient - Electric → Purple blend */
|
|
262
|
+
brand: ["#3E3CFF", "#5250FF", "#6B69FF", "#7E70FF", "#9D70FF", "#B48DFF", "#C9A8FF"],
|
|
263
|
+
/** Thermal - Status colors for temperature (AstroUXDS compliant) */
|
|
264
|
+
thermal: ["#00C7CB", "#56F000", "#FCE83A", "#FFB302", "#FF6B35", "#FF3838"]
|
|
265
|
+
}
|
|
266
|
+
};
|
|
267
|
+
const STATUS_COLORS = {
|
|
268
|
+
normal: "#56f000",
|
|
269
|
+
// Green - System operating normally
|
|
270
|
+
standby: "#2dccff",
|
|
271
|
+
// Cyan - Awaiting/standby state
|
|
272
|
+
caution: "#fce83a",
|
|
273
|
+
// Yellow - Requires attention
|
|
274
|
+
serious: "#ffb302",
|
|
275
|
+
// Orange - Significant issue
|
|
276
|
+
critical: "#ff3838",
|
|
277
|
+
// Red - Immediate action required
|
|
278
|
+
off: "#a4abb6"
|
|
279
|
+
// Grey - Inactive/off state
|
|
280
|
+
};
|
|
281
|
+
function createAstroEChartsTheme(tokens, mode, themeVariant) {
|
|
282
|
+
const isDark = mode === "dark";
|
|
283
|
+
const isAstroTheme = themeVariant === "astro";
|
|
284
|
+
const dataVizColors = isAstroTheme ? [...OFFICIAL_ASTRO_DATA_VIZ_COLORS.extended] : ASTRO_DATA_VIZ_COLORS.mixed;
|
|
285
|
+
return {
|
|
286
|
+
// Data visualization color palette
|
|
287
|
+
// - 'astro' theme: Official AstroUXDS colors (teal, purple, brightblue)
|
|
288
|
+
// - Other themes: Zendir brand colors (electric, purple, prussian blue)
|
|
289
|
+
color: dataVizColors,
|
|
290
|
+
// Background
|
|
291
|
+
backgroundColor: "transparent",
|
|
292
|
+
// Global text style - 14pt minimum per AstroUXDS; no white border on labels
|
|
293
|
+
textStyle: {
|
|
294
|
+
color: tokens.colors.text.primary,
|
|
295
|
+
fontFamily: tokens.typography.fontFamily.primary,
|
|
296
|
+
fontSize: 14,
|
|
297
|
+
// AstroUXD minimum requirement
|
|
298
|
+
textBorderWidth: 0,
|
|
299
|
+
textBorderColor: "transparent"
|
|
300
|
+
},
|
|
301
|
+
// Title - Grey for readability, AstroUXDS compliant
|
|
302
|
+
title: {
|
|
303
|
+
textStyle: {
|
|
304
|
+
color: tokens.colors.text.secondary,
|
|
305
|
+
// Grey for headings
|
|
306
|
+
fontSize: 14,
|
|
307
|
+
fontWeight: "bold",
|
|
308
|
+
textBorderWidth: 0,
|
|
309
|
+
textBorderColor: "transparent"
|
|
310
|
+
},
|
|
311
|
+
subtextStyle: {
|
|
312
|
+
color: tokens.colors.text.tertiary,
|
|
313
|
+
fontSize: 12,
|
|
314
|
+
textBorderWidth: 0,
|
|
315
|
+
textBorderColor: "transparent"
|
|
316
|
+
}
|
|
317
|
+
},
|
|
318
|
+
// Legend
|
|
319
|
+
legend: {
|
|
320
|
+
textStyle: {
|
|
321
|
+
color: tokens.colors.text.secondary,
|
|
322
|
+
fontSize: 12,
|
|
323
|
+
textBorderWidth: 0,
|
|
324
|
+
textBorderColor: "transparent"
|
|
325
|
+
},
|
|
326
|
+
inactiveColor: tokens.colors.text.tertiary
|
|
327
|
+
},
|
|
328
|
+
// Tooltip
|
|
329
|
+
tooltip: {
|
|
330
|
+
backgroundColor: isDark ? "rgba(27, 45, 62, 0.95)" : "rgba(255, 255, 255, 0.95)",
|
|
331
|
+
borderColor: tokens.colors.border.default,
|
|
332
|
+
borderWidth: 1,
|
|
333
|
+
textStyle: {
|
|
334
|
+
color: tokens.colors.text.primary,
|
|
335
|
+
fontSize: 12,
|
|
336
|
+
textBorderWidth: 0,
|
|
337
|
+
textBorderColor: "transparent"
|
|
338
|
+
},
|
|
339
|
+
extraCssText: `
|
|
340
|
+
border-radius: ${tokens.borderRadius.md};
|
|
341
|
+
box-shadow: ${tokens.shadows.lg};
|
|
342
|
+
backdrop-filter: blur(8px);
|
|
343
|
+
`
|
|
344
|
+
},
|
|
345
|
+
// Axis pointer / crosshair - Subtle grey for clarity
|
|
346
|
+
axisPointer: {
|
|
347
|
+
lineStyle: {
|
|
348
|
+
color: tokens.colors.text.tertiary,
|
|
349
|
+
// Subtle grey
|
|
350
|
+
width: 1
|
|
351
|
+
},
|
|
352
|
+
crossStyle: {
|
|
353
|
+
color: tokens.colors.text.tertiary,
|
|
354
|
+
// Subtle grey
|
|
355
|
+
width: 1
|
|
356
|
+
}
|
|
357
|
+
},
|
|
358
|
+
// X Axis
|
|
359
|
+
xAxis: {
|
|
360
|
+
axisLine: {
|
|
361
|
+
lineStyle: {
|
|
362
|
+
color: tokens.colors.border.default
|
|
363
|
+
}
|
|
364
|
+
},
|
|
365
|
+
axisTick: {
|
|
366
|
+
lineStyle: {
|
|
367
|
+
color: tokens.colors.border.muted
|
|
368
|
+
}
|
|
369
|
+
},
|
|
370
|
+
axisLabel: {
|
|
371
|
+
color: tokens.colors.text.secondary,
|
|
372
|
+
fontSize: 12,
|
|
373
|
+
fontFamily: tokens.typography.fontFamily.mono,
|
|
374
|
+
// Tabular numbers
|
|
375
|
+
textBorderWidth: 0,
|
|
376
|
+
textBorderColor: "transparent"
|
|
377
|
+
},
|
|
378
|
+
splitLine: {
|
|
379
|
+
lineStyle: {
|
|
380
|
+
color: tokens.colors.border.muted,
|
|
381
|
+
type: "dashed"
|
|
382
|
+
}
|
|
383
|
+
},
|
|
384
|
+
nameTextStyle: {
|
|
385
|
+
color: tokens.colors.text.secondary,
|
|
386
|
+
fontSize: 12,
|
|
387
|
+
textBorderWidth: 0,
|
|
388
|
+
textBorderColor: "transparent"
|
|
389
|
+
}
|
|
390
|
+
},
|
|
391
|
+
// Y Axis
|
|
392
|
+
yAxis: {
|
|
393
|
+
axisLine: {
|
|
394
|
+
lineStyle: {
|
|
395
|
+
color: tokens.colors.border.default
|
|
396
|
+
}
|
|
397
|
+
},
|
|
398
|
+
axisTick: {
|
|
399
|
+
lineStyle: {
|
|
400
|
+
color: tokens.colors.border.muted
|
|
401
|
+
}
|
|
402
|
+
},
|
|
403
|
+
axisLabel: {
|
|
404
|
+
color: tokens.colors.text.secondary,
|
|
405
|
+
fontSize: 12,
|
|
406
|
+
fontFamily: tokens.typography.fontFamily.mono,
|
|
407
|
+
// Tabular numbers
|
|
408
|
+
textBorderWidth: 0,
|
|
409
|
+
textBorderColor: "transparent"
|
|
410
|
+
},
|
|
411
|
+
splitLine: {
|
|
412
|
+
lineStyle: {
|
|
413
|
+
color: tokens.colors.border.muted,
|
|
414
|
+
type: "dashed"
|
|
415
|
+
}
|
|
416
|
+
},
|
|
417
|
+
nameTextStyle: {
|
|
418
|
+
color: tokens.colors.text.secondary,
|
|
419
|
+
fontSize: 12,
|
|
420
|
+
textBorderWidth: 0,
|
|
421
|
+
textBorderColor: "transparent"
|
|
422
|
+
}
|
|
423
|
+
},
|
|
424
|
+
// Series defaults
|
|
425
|
+
series: {
|
|
426
|
+
line: {
|
|
427
|
+
lineStyle: {
|
|
428
|
+
width: 2
|
|
429
|
+
},
|
|
430
|
+
symbolSize: 6
|
|
431
|
+
},
|
|
432
|
+
bar: {
|
|
433
|
+
barMaxWidth: 40,
|
|
434
|
+
itemStyle: {
|
|
435
|
+
borderRadius: [4, 4, 0, 0]
|
|
436
|
+
}
|
|
437
|
+
},
|
|
438
|
+
pie: {
|
|
439
|
+
itemStyle: {
|
|
440
|
+
borderColor: tokens.colors.background.surface,
|
|
441
|
+
borderWidth: 2
|
|
442
|
+
},
|
|
443
|
+
label: {
|
|
444
|
+
color: tokens.colors.text.primary,
|
|
445
|
+
textBorderWidth: 0,
|
|
446
|
+
textBorderColor: "transparent",
|
|
447
|
+
fontSize: 12
|
|
448
|
+
}
|
|
449
|
+
},
|
|
450
|
+
scatter: {
|
|
451
|
+
symbolSize: 10
|
|
452
|
+
},
|
|
453
|
+
gauge: {
|
|
454
|
+
axisLine: {
|
|
455
|
+
lineStyle: {
|
|
456
|
+
width: 10
|
|
457
|
+
}
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
},
|
|
461
|
+
// Data zoom - Theme-aware interactive controls
|
|
462
|
+
dataZoom: {
|
|
463
|
+
backgroundColor: isDark ? "rgba(27, 45, 62, 0.5)" : "rgba(234, 238, 244, 0.5)",
|
|
464
|
+
borderColor: tokens.colors.border.muted,
|
|
465
|
+
// Astro theme uses brightblue, others use Zendir Electric
|
|
466
|
+
fillerColor: isAstroTheme ? "rgba(77, 172, 255, 0.15)" : "rgba(62, 60, 255, 0.15)",
|
|
467
|
+
// Zendir Electric
|
|
468
|
+
handleColor: isAstroTheme ? "#4dacff" : ZENDIR_BRAND_COLORS.electric,
|
|
469
|
+
// Zendir Electric
|
|
470
|
+
textStyle: {
|
|
471
|
+
color: tokens.colors.text.secondary,
|
|
472
|
+
textBorderWidth: 0,
|
|
473
|
+
textBorderColor: "transparent"
|
|
474
|
+
}
|
|
475
|
+
},
|
|
476
|
+
// Visual map (for heatmaps) - Theme-aware sequential palette
|
|
477
|
+
visualMap: {
|
|
478
|
+
textStyle: {
|
|
479
|
+
color: tokens.colors.text.secondary,
|
|
480
|
+
textBorderWidth: 0,
|
|
481
|
+
textBorderColor: "transparent"
|
|
482
|
+
},
|
|
483
|
+
inRange: {
|
|
484
|
+
// Astro theme uses official teal gradient, others use Zendir Electric
|
|
485
|
+
color: isAstroTheme ? [...OFFICIAL_ASTRO_DATA_VIZ_COLORS.sequential.teal] : ASTRO_DATA_VIZ_COLORS.sequential.electric
|
|
486
|
+
}
|
|
487
|
+
},
|
|
488
|
+
// Grid
|
|
489
|
+
grid: {
|
|
490
|
+
borderColor: tokens.colors.border.muted
|
|
491
|
+
}
|
|
492
|
+
};
|
|
493
|
+
}
|
|
494
|
+
function getSeriesColor(index, palette = ASTRO_DATA_VIZ_COLORS.mixed) {
|
|
495
|
+
return palette[index % palette.length];
|
|
496
|
+
}
|
|
497
|
+
function createAreaGradient(color, direction = "vertical") {
|
|
498
|
+
return {
|
|
499
|
+
type: "linear",
|
|
500
|
+
x: 0,
|
|
501
|
+
y: direction === "vertical" ? 0 : 0,
|
|
502
|
+
x2: direction === "horizontal" ? 1 : 0,
|
|
503
|
+
y2: direction === "vertical" ? 1 : 0,
|
|
504
|
+
colorStops: [
|
|
505
|
+
{ offset: 0, color: `${color}40` },
|
|
506
|
+
{ offset: 1, color: `${color}05` }
|
|
507
|
+
]
|
|
508
|
+
};
|
|
509
|
+
}
|
|
510
|
+
function formatTimeLabel(timestamp, format = "short") {
|
|
511
|
+
const date = new Date(timestamp);
|
|
512
|
+
switch (format) {
|
|
513
|
+
case "short":
|
|
514
|
+
return date.toLocaleTimeString([], {
|
|
515
|
+
hour: "2-digit",
|
|
516
|
+
minute: "2-digit",
|
|
517
|
+
hour12: false
|
|
518
|
+
});
|
|
519
|
+
case "medium":
|
|
520
|
+
return date.toLocaleTimeString([], {
|
|
521
|
+
hour: "2-digit",
|
|
522
|
+
minute: "2-digit",
|
|
523
|
+
second: "2-digit",
|
|
524
|
+
hour12: false
|
|
525
|
+
});
|
|
526
|
+
case "long":
|
|
527
|
+
return date.toLocaleString([], {
|
|
528
|
+
month: "short",
|
|
529
|
+
day: "numeric",
|
|
530
|
+
hour: "2-digit",
|
|
531
|
+
minute: "2-digit",
|
|
532
|
+
hour12: false
|
|
533
|
+
});
|
|
534
|
+
}
|
|
535
|
+
}
|
|
536
|
+
function formatValueWithUnit(value, unit, precision = 2) {
|
|
537
|
+
const formatted = Number.isInteger(value) ? value.toString() : value.toFixed(precision);
|
|
538
|
+
return unit ? `${formatted}${unit}` : formatted;
|
|
539
|
+
}
|
|
540
|
+
function calculateAxisBounds(values, padding = 0.1) {
|
|
541
|
+
if (values.length === 0) return { min: 0, max: 100 };
|
|
542
|
+
const min = Math.min(...values);
|
|
543
|
+
const max = Math.max(...values);
|
|
544
|
+
const range = max - min || 1;
|
|
545
|
+
return {
|
|
546
|
+
min: min - range * padding,
|
|
547
|
+
max: max + range * padding
|
|
548
|
+
};
|
|
549
|
+
}
|
|
550
|
+
export {
|
|
551
|
+
ASTRO_DATA_VIZ_COLORS,
|
|
552
|
+
OFFICIAL_ASTRO_DATA_VIZ_COLORS,
|
|
553
|
+
STATUS_COLORS,
|
|
554
|
+
ZENDIR_BRAND_COLORS,
|
|
555
|
+
calculateAxisBounds,
|
|
556
|
+
createAreaGradient,
|
|
557
|
+
createAstroEChartsTheme,
|
|
558
|
+
formatTimeLabel,
|
|
559
|
+
formatValueWithUnit,
|
|
560
|
+
getSeriesColor
|
|
561
|
+
};
|
|
562
|
+
//# sourceMappingURL=theme.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"theme.js","sources":["../../../../src/react/charts/unified/theme.ts"],"sourcesContent":["/**\n * @zendir/ui - ECharts Theme Adapter\n * \n * Converts Astro UX Design System tokens to ECharts theme configuration.\n * Supports dark/light modes and colorblind-accessible palettes.\n * \n * AstroUXD Compliance:\n * - Max 11 colors per dataset\n * - Colorblind-accessible palette\n * - Sentence-case labels\n * - 14pt minimum axis text\n * - WCAG contrast compliance\n * \n * @version 2.0.0 - Full Zendir Brand Color Migration\n */\n\nimport type { ThemeTokens, ThemeMode, ThemeVariant } from '../../theme';\n\n// =============================================================================\n// AstroUXD Data Visualization Color Palettes\n// =============================================================================\n\n/**\n * Zendir Brand Colors (from Brand Guide v2026)\n * Core: Electric (#3E3CFF), Purple (#9D70FF), Prussian Blue (#1B2DA0)\n * Shades derived using 10%, 20%, 35% white/black overlays per brand guide\n */\nexport const ZENDIR_BRAND_COLORS = {\n // === Core Brand Colors ===\n /** Electric - Primary accent (#3E3CFF) */\n electric: '#3E3CFF',\n /** Purple - Secondary accent (#9D70FF) */\n purple: '#9D70FF',\n /** Prussian Blue - Subsections (#1B2DA0) */\n prussianBlue: '#1B2DA0',\n /** Black */\n black: '#000000',\n /** White */\n white: '#FFFFFF',\n \n // === Electric Shades (10%, 20%, 35% overlays) ===\n electricLighter: '#9997FF', // 35% white overlay\n electricLight: '#6B69FF', // 20% white overlay \n electricSoft: '#5250FF', // 10% white overlay\n electricDark: '#3836E6', // 10% black overlay\n electricDarker: '#3230CC', // 20% black overlay\n electricDeep: '#2926A3', // 35% black overlay\n \n // === Purple Shades ===\n purpleLighter: '#C9A8FF', // 35% white overlay\n purpleLight: '#B48DFF', // 20% white overlay\n purpleSoft: '#A97FFF', // 10% white overlay\n purpleDark: '#8E64E6', // 10% black overlay\n purpleDarker: '#7E5ACC', // 20% black overlay\n purpleDeep: '#5F4499', // 35% black overlay\n \n // === Prussian Blue Shades ===\n prussianBlueLighter: '#4A5FD6', // 35% white overlay\n prussianBlueLight: '#3548C0', // 20% white overlay\n prussianBlueSoft: '#2838B0', // 10% white overlay\n prussianBlueDark: '#182890', // 10% black overlay\n prussianBlueDarker: '#142380', // 20% black overlay\n prussianBlueDeep: '#0F1A60', // 35% black overlay\n} as const;\n\n/**\n * Official AstroUXDS Data Visualization Color Palette\n * Per https://astrouxds.com/design-tokens/system/#data-viz\n * \n * These are the OFFICIAL AstroUXDS data visualization colors from the design system.\n * Use these for pure AstroUXDS compliance (e.g., 'astro' theme).\n * \n * @see https://astrouxds.com/design-tokens/system/\n */\nexport const OFFICIAL_ASTRO_DATA_VIZ_COLORS = {\n /** Official AstroUXDS data visualization palette (8 colors) */\n primary: [\n '#00c7cb', // color-data-visualization-1 - Teal 500\n '#938bdb', // color-data-visualization-2 - Purple 400\n '#4dacff', // color-data-visualization-3 - Brightblue 500\n '#70dde0', // color-data-visualization-4 - Teal 300\n '#c9c5ed', // color-data-visualization-5 - Purple 200\n '#92cbff', // color-data-visualization-6 - Brightblue 400\n '#a1e9eb', // color-data-visualization-7 - Teal 200\n '#b7dcff', // color-data-visualization-8 - Brightblue 300\n ],\n \n /** Extended palette - primary + additional derived colors for 11 max */\n extended: [\n '#00c7cb', // Teal 500 - Primary\n '#938bdb', // Purple 400 - Secondary\n '#4dacff', // Brightblue 500\n '#70dde0', // Teal 300\n '#c9c5ed', // Purple 200\n '#92cbff', // Brightblue 400\n '#a1e9eb', // Teal 200\n '#b7dcff', // Brightblue 300\n '#009a9d', // Teal 600 (darker)\n '#756bb8', // Purple 500 (darker)\n '#2b659b', // Brightblue 700 (darker)\n ],\n \n /** Sequential palettes for heatmaps using AstroUXDS colors */\n sequential: {\n /** Teal sequential */\n teal: ['#e5f9f9', '#a1e9eb', '#70dde0', '#00c7cb', '#009a9d', '#006e70'],\n /** Purple sequential */\n purple: ['#eceaf7', '#c9c5ed', '#a9a3dc', '#938bdb', '#756bb8', '#5b5299'],\n /** Brightblue sequential */\n brightblue: ['#e8f4ff', '#b7dcff', '#92cbff', '#4dacff', '#2b659b', '#1c3f5e'],\n /** Thermal - Status colors for temperature */\n thermal: ['#00c7cb', '#56f000', '#fce83a', '#ffb302', '#ff6b35', '#ff3838'],\n },\n} as const;\n\n/**\n * Zendir-branded Data Visualization Color Palette \n * Uses Zendir brand colors (Electric, Purple, Prussian Blue)\n * while maintaining AstroUXDS compliance (max 11 colors, colorblind-accessible)\n * \n * @see https://www.astrouxds.com/patterns/data-visualization/\n */\nexport const ASTRO_DATA_VIZ_COLORS = {\n /** \n * Primary data visualization palette - Pure Zendir Brand\n * Uses only Zendir brand colors and their derived shades\n * Max 11 colors per AstroUXDS compliance requirement 3.2.1\n * \n * NOTE: Status colors (green, yellow, red) reserved for status indication only\n */\n mixed: [\n ZENDIR_BRAND_COLORS.electric, // #3E3CFF - Primary\n ZENDIR_BRAND_COLORS.purple, // #9D70FF - Secondary\n ZENDIR_BRAND_COLORS.electricLight, // #6B69FF - Electric 20% lighter\n ZENDIR_BRAND_COLORS.purpleLight, // #B48DFF - Purple 20% lighter\n ZENDIR_BRAND_COLORS.prussianBlueLight, // #3548C0 - Prussian Blue lighter\n ZENDIR_BRAND_COLORS.electricLighter, // #9997FF - Electric 35% lighter\n ZENDIR_BRAND_COLORS.purpleLighter, // #C9A8FF - Purple 35% lighter\n ZENDIR_BRAND_COLORS.prussianBlue, // #1B2DA0 - Prussian Blue\n ZENDIR_BRAND_COLORS.electricDarker, // #3230CC - Electric 20% darker\n ZENDIR_BRAND_COLORS.purpleDarker, // #7E5ACC - Purple 20% darker\n ZENDIR_BRAND_COLORS.prussianBlueLighter, // #4A5FD6 - Prussian Blue lightest\n ],\n \n /** \n * Zendir Brand palette - Full brand spectrum\n * Complete set of Zendir brand colors for maximum brand expression\n */\n zendir: [\n ZENDIR_BRAND_COLORS.electric, // #3E3CFF - Primary\n ZENDIR_BRAND_COLORS.purple, // #9D70FF - Secondary\n ZENDIR_BRAND_COLORS.electricLight, // #6B69FF\n ZENDIR_BRAND_COLORS.purpleLight, // #B48DFF\n ZENDIR_BRAND_COLORS.prussianBlue, // #1B2DA0\n ZENDIR_BRAND_COLORS.electricLighter, // #9997FF\n ZENDIR_BRAND_COLORS.purpleLighter, // #C9A8FF\n ZENDIR_BRAND_COLORS.prussianBlueLight, // #3548C0\n ],\n \n /** \n * Extended Zendir palette - All shades for complex visualizations\n * Includes dark and light variants for maximum differentiation\n */\n zendirExtended: [\n ZENDIR_BRAND_COLORS.electric, // #3E3CFF\n ZENDIR_BRAND_COLORS.purple, // #9D70FF\n ZENDIR_BRAND_COLORS.prussianBlue, // #1B2DA0\n ZENDIR_BRAND_COLORS.electricLight, // #6B69FF\n ZENDIR_BRAND_COLORS.purpleLight, // #B48DFF\n ZENDIR_BRAND_COLORS.prussianBlueLight, // #3548C0\n ZENDIR_BRAND_COLORS.electricLighter, // #9997FF\n ZENDIR_BRAND_COLORS.purpleLighter, // #C9A8FF\n ZENDIR_BRAND_COLORS.electricDarker, // #3230CC\n ZENDIR_BRAND_COLORS.purpleDarker, // #7E5ACC\n ZENDIR_BRAND_COLORS.prussianBlueDarker, // #142380\n ],\n \n /** \n * Cool palette - Blues and purples\n * Professional Zendir-branded cool tones\n */\n cool: [\n ZENDIR_BRAND_COLORS.electric, // #3E3CFF\n ZENDIR_BRAND_COLORS.prussianBlue, // #1B2DA0\n ZENDIR_BRAND_COLORS.purple, // #9D70FF\n ZENDIR_BRAND_COLORS.electricLight, // #6B69FF\n ZENDIR_BRAND_COLORS.prussianBlueLight, // #3548C0\n ZENDIR_BRAND_COLORS.purpleLight, // #B48DFF\n ZENDIR_BRAND_COLORS.electricLighter, // #9997FF\n ZENDIR_BRAND_COLORS.prussianBlueLighter, // #4A5FD6\n ],\n \n /** \n * Warm accent palette - For charts needing warm tones\n * Use sparingly - not part of Zendir brand\n */\n warm: [\n '#ffb302', // Amber\n '#ff9966', // Coral\n '#fce83a', // Yellow\n '#ff6b6b', // Salmon\n '#f0a000', // Orange\n '#ffcc80', // Peach\n '#e0a86c', // Tan\n '#d4b896', // Sand\n ],\n \n /** \n * Electric-Purple gradient palette (Zendir brand gradient)\n * Matches the official brand gradient from Electric to Purple\n */\n electricPurple: [\n ZENDIR_BRAND_COLORS.electric, // #3E3CFF\n ZENDIR_BRAND_COLORS.electricSoft, // #5250FF\n ZENDIR_BRAND_COLORS.electricLight, // #6B69FF\n '#8070FF', // Blend E→P\n ZENDIR_BRAND_COLORS.purple, // #9D70FF\n ZENDIR_BRAND_COLORS.purpleLight, // #B48DFF\n ZENDIR_BRAND_COLORS.purpleLighter, // #C9A8FF\n '#DCC4FF', // Lightest\n ],\n \n /** \n * Prussian-Electric gradient palette\n * Deep to vibrant brand progression\n */\n prussianElectric: [\n ZENDIR_BRAND_COLORS.prussianBlueDarker, // #142380\n ZENDIR_BRAND_COLORS.prussianBlue, // #1B2DA0\n ZENDIR_BRAND_COLORS.prussianBlueLight, // #3548C0\n ZENDIR_BRAND_COLORS.electricDarker, // #3230CC\n ZENDIR_BRAND_COLORS.electric, // #3E3CFF\n ZENDIR_BRAND_COLORS.electricLight, // #6B69FF\n ],\n \n /** \n * Full Zendir spectrum gradient\n * Prussian Blue → Electric → Purple\n */\n zendirSpectrum: [\n ZENDIR_BRAND_COLORS.prussianBlue, // #1B2DA0\n ZENDIR_BRAND_COLORS.prussianBlueLight, // #3548C0\n ZENDIR_BRAND_COLORS.electric, // #3E3CFF\n ZENDIR_BRAND_COLORS.electricLight, // #6B69FF\n ZENDIR_BRAND_COLORS.purple, // #9D70FF\n ZENDIR_BRAND_COLORS.purpleLight, // #B48DFF\n ],\n \n /**\n * Sequential palettes for heatmaps and gradual data\n * Zendir brand-forward gradients\n */\n sequential: {\n /** Zendir Electric sequential - Primary brand gradient */\n electric: ['#E8E8FF', '#C9C8FF', '#9997FF', '#6B69FF', '#3E3CFF', '#3230CC', '#262499'],\n /** Zendir Purple sequential - Secondary brand gradient */\n purple: ['#F0E8FF', '#DCC4FF', '#C9A8FF', '#B48DFF', '#9D70FF', '#7E5ACC', '#5F4499'],\n /** Zendir Prussian Blue sequential - Deep brand gradient */\n prussianBlue: ['#E8ECFF', '#C5CFF0', '#8A9DD6', '#4A5FD6', '#3548C0', '#1B2DA0', '#0F1A60'],\n /** Zendir gradient - Electric → Purple blend */\n brand: ['#3E3CFF', '#5250FF', '#6B69FF', '#7E70FF', '#9D70FF', '#B48DFF', '#C9A8FF'],\n /** Thermal - Status colors for temperature (AstroUXDS compliant) */\n thermal: ['#00C7CB', '#56F000', '#FCE83A', '#FFB302', '#FF6B35', '#FF3838'],\n },\n};\n\n/**\n * AstroUXDS Status Colors (DO NOT MODIFY)\n * Per https://www.astrouxds.com/patterns/status-system/\n * \n * These colors are RESERVED for status indication only.\n * Per compliance requirement, do not use status colors for\n * non-status data visualization.\n * \n * @see https://www.astrouxds.com/compliance/astro-design-compliance/\n * Rule 3.1.2: Elements indicating state shall use only specified Status Colors\n */\nexport const STATUS_COLORS = {\n normal: '#56f000', // Green - System operating normally\n standby: '#2dccff', // Cyan - Awaiting/standby state\n caution: '#fce83a', // Yellow - Requires attention\n serious: '#ffb302', // Orange - Significant issue\n critical: '#ff3838', // Red - Immediate action required\n off: '#a4abb6', // Grey - Inactive/off state\n} as const;\n\n/**\n * Zendir Accent Colors for UI elements (non-status)\n * Use these for interactive elements, highlights, and branding\n */\nexport const ZENDIR_ACCENT_COLORS = {\n /** Primary accent - Zendir Electric */\n primary: ZENDIR_BRAND_COLORS.electric,\n /** Secondary accent - Zendir Purple */\n secondary: ZENDIR_BRAND_COLORS.purple,\n /** Tertiary accent - Zendir Prussian Blue */\n tertiary: ZENDIR_BRAND_COLORS.prussianBlue,\n /** Info accent - Prussian Blue Light */\n info: ZENDIR_BRAND_COLORS.prussianBlueLight,\n /** Highlight - Electric Light */\n highlight: ZENDIR_BRAND_COLORS.electricLight,\n} as const;\n\n// =============================================================================\n// Theme Generator\n// =============================================================================\n\nexport interface EChartsTheme {\n color: string[];\n backgroundColor: string;\n textStyle: {\n color: string;\n fontFamily: string;\n fontSize: number;\n textBorderWidth?: number;\n textBorderColor?: string;\n };\n title: {\n textStyle: { color: string; fontSize: number; fontWeight: string; textBorderWidth?: number; textBorderColor?: string };\n subtextStyle: { color: string; fontSize: number; textBorderWidth?: number; textBorderColor?: string };\n };\n legend: {\n textStyle: { color: string; fontSize: number; textBorderWidth?: number; textBorderColor?: string };\n inactiveColor: string;\n };\n tooltip: {\n backgroundColor: string;\n borderColor: string;\n borderWidth: number;\n textStyle: { color: string; fontSize: number; textBorderWidth?: number; textBorderColor?: string };\n extraCssText: string;\n };\n axisPointer: {\n lineStyle: { color: string; width: number };\n crossStyle: { color: string; width: number };\n };\n xAxis: {\n axisLine: { lineStyle: { color: string } };\n axisTick: { lineStyle: { color: string } };\n axisLabel: { color: string; fontSize: number; fontFamily: string; textBorderWidth?: number; textBorderColor?: string };\n splitLine: { lineStyle: { color: string; type: string } };\n nameTextStyle: { color: string; fontSize: number; textBorderWidth?: number; textBorderColor?: string };\n };\n yAxis: {\n axisLine: { lineStyle: { color: string } };\n axisTick: { lineStyle: { color: string } };\n axisLabel: { color: string; fontSize: number; fontFamily: string; textBorderWidth?: number; textBorderColor?: string };\n splitLine: { lineStyle: { color: string; type: string } };\n nameTextStyle: { color: string; fontSize: number; textBorderWidth?: number; textBorderColor?: string };\n };\n series: {\n line: { lineStyle: { width: number }; symbolSize: number };\n bar: { barMaxWidth: number; itemStyle: { borderRadius: number[] } };\n pie: {\n itemStyle: { borderColor: string; borderWidth: number };\n label?: { color: string; textBorderWidth: number; textBorderColor: string; fontSize: number };\n };\n scatter: { symbolSize: number };\n gauge: { axisLine: { lineStyle: { width: number } } };\n };\n dataZoom: {\n backgroundColor: string;\n borderColor: string;\n fillerColor: string;\n handleColor: string;\n textStyle: { color: string; textBorderWidth?: number; textBorderColor?: string };\n };\n visualMap: {\n textStyle: { color: string; textBorderWidth?: number; textBorderColor?: string };\n inRange: { color: string[] };\n };\n grid: {\n borderColor: string;\n };\n}\n\n/**\n * Generate ECharts theme from Astro tokens\n * \n * Creates a theme that:\n * - Uses official AstroUXDS colors for 'astro' theme variant\n * - Uses Zendir brand colors for all other theme variants\n * - Maintains AstroUXDS compliance (max 11 colors, 14pt min font)\n * - Preserves status colors for their reserved purposes\n * - Supports both dark and light modes\n * \n * @param tokens - Theme tokens from ThemeProvider\n * @param mode - Current theme mode ('dark' | 'light')\n * @param themeVariant - Optional theme variant to determine color palette\n * @returns ECharts theme configuration\n */\nexport function createAstroEChartsTheme(\n tokens: ThemeTokens,\n mode: ThemeMode,\n themeVariant?: ThemeVariant\n): EChartsTheme {\n const isDark = mode === 'dark';\n \n // Use official AstroUXDS colors for 'astro' theme, Zendir colors for others\n const isAstroTheme = themeVariant === 'astro';\n const dataVizColors = isAstroTheme \n ? [...OFFICIAL_ASTRO_DATA_VIZ_COLORS.extended] \n : ASTRO_DATA_VIZ_COLORS.mixed;\n \n return {\n // Data visualization color palette\n // - 'astro' theme: Official AstroUXDS colors (teal, purple, brightblue)\n // - Other themes: Zendir brand colors (electric, purple, prussian blue)\n color: dataVizColors,\n \n // Background\n backgroundColor: 'transparent',\n \n // Global text style - 14pt minimum per AstroUXDS; no white border on labels\n textStyle: {\n color: tokens.colors.text.primary,\n fontFamily: tokens.typography.fontFamily.primary,\n fontSize: 14, // AstroUXD minimum requirement\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n \n // Title - Grey for readability, AstroUXDS compliant\n title: {\n textStyle: {\n color: tokens.colors.text.secondary, // Grey for headings\n fontSize: 14,\n fontWeight: 'bold',\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n subtextStyle: {\n color: tokens.colors.text.tertiary,\n fontSize: 12,\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n },\n \n // Legend\n legend: {\n textStyle: {\n color: tokens.colors.text.secondary,\n fontSize: 12,\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n inactiveColor: tokens.colors.text.tertiary,\n },\n \n // Tooltip\n tooltip: {\n backgroundColor: isDark \n ? 'rgba(27, 45, 62, 0.95)' \n : 'rgba(255, 255, 255, 0.95)',\n borderColor: tokens.colors.border.default,\n borderWidth: 1,\n textStyle: {\n color: tokens.colors.text.primary,\n fontSize: 12,\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n extraCssText: `\n border-radius: ${tokens.borderRadius.md};\n box-shadow: ${tokens.shadows.lg};\n backdrop-filter: blur(8px);\n `,\n },\n \n // Axis pointer / crosshair - Subtle grey for clarity\n axisPointer: {\n lineStyle: {\n color: tokens.colors.text.tertiary, // Subtle grey\n width: 1,\n },\n crossStyle: {\n color: tokens.colors.text.tertiary, // Subtle grey\n width: 1,\n },\n },\n \n // X Axis\n xAxis: {\n axisLine: {\n lineStyle: {\n color: tokens.colors.border.default,\n },\n },\n axisTick: {\n lineStyle: {\n color: tokens.colors.border.muted,\n },\n },\n axisLabel: {\n color: tokens.colors.text.secondary,\n fontSize: 12,\n fontFamily: tokens.typography.fontFamily.mono, // Tabular numbers\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n splitLine: {\n lineStyle: {\n color: tokens.colors.border.muted,\n type: 'dashed',\n },\n },\n nameTextStyle: {\n color: tokens.colors.text.secondary,\n fontSize: 12,\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n },\n \n // Y Axis\n yAxis: {\n axisLine: {\n lineStyle: {\n color: tokens.colors.border.default,\n },\n },\n axisTick: {\n lineStyle: {\n color: tokens.colors.border.muted,\n },\n },\n axisLabel: {\n color: tokens.colors.text.secondary,\n fontSize: 12,\n fontFamily: tokens.typography.fontFamily.mono, // Tabular numbers\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n splitLine: {\n lineStyle: {\n color: tokens.colors.border.muted,\n type: 'dashed',\n },\n },\n nameTextStyle: {\n color: tokens.colors.text.secondary,\n fontSize: 12,\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n },\n \n // Series defaults\n series: {\n line: {\n lineStyle: {\n width: 2,\n },\n symbolSize: 6,\n },\n bar: {\n barMaxWidth: 40,\n itemStyle: {\n borderRadius: [4, 4, 0, 0],\n },\n },\n pie: {\n itemStyle: {\n borderColor: tokens.colors.background.surface,\n borderWidth: 2,\n },\n label: {\n color: tokens.colors.text.primary,\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n fontSize: 12,\n },\n },\n scatter: {\n symbolSize: 10,\n },\n gauge: {\n axisLine: {\n lineStyle: {\n width: 10,\n },\n },\n },\n },\n \n // Data zoom - Theme-aware interactive controls\n dataZoom: {\n backgroundColor: isDark \n ? 'rgba(27, 45, 62, 0.5)' \n : 'rgba(234, 238, 244, 0.5)',\n borderColor: tokens.colors.border.muted,\n // Astro theme uses brightblue, others use Zendir Electric\n fillerColor: isAstroTheme \n ? 'rgba(77, 172, 255, 0.15)' // AstroUXDS Brightblue\n : 'rgba(62, 60, 255, 0.15)', // Zendir Electric\n handleColor: isAstroTheme \n ? '#4dacff' // AstroUXDS Brightblue 500\n : ZENDIR_BRAND_COLORS.electric, // Zendir Electric\n textStyle: {\n color: tokens.colors.text.secondary,\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n },\n \n // Visual map (for heatmaps) - Theme-aware sequential palette\n visualMap: {\n textStyle: {\n color: tokens.colors.text.secondary,\n textBorderWidth: 0,\n textBorderColor: 'transparent',\n },\n inRange: {\n // Astro theme uses official teal gradient, others use Zendir Electric\n color: isAstroTheme \n ? [...OFFICIAL_ASTRO_DATA_VIZ_COLORS.sequential.teal]\n : ASTRO_DATA_VIZ_COLORS.sequential.electric,\n },\n },\n \n // Grid\n grid: {\n borderColor: tokens.colors.border.muted,\n },\n };\n}\n\n// =============================================================================\n// Utility Functions\n// =============================================================================\n\n/**\n * Get status color from value and thresholds\n */\nexport function getStatusColor(\n value: number,\n thresholds: {\n critical?: number;\n serious?: number;\n caution?: number;\n normal?: number;\n }\n): string {\n if (thresholds.critical !== undefined && value >= thresholds.critical) {\n return STATUS_COLORS.critical;\n }\n if (thresholds.serious !== undefined && value >= thresholds.serious) {\n return STATUS_COLORS.serious;\n }\n if (thresholds.caution !== undefined && value >= thresholds.caution) {\n return STATUS_COLORS.caution;\n }\n return STATUS_COLORS.normal;\n}\n\n/**\n * Get color for series by index (wraps around palette)\n * \n * @param index - Series index\n * @param palette - Color palette to use (defaults to Zendir-Astro mixed)\n * @returns Hex color string\n * \n * @example\n * ```tsx\n * // Uses Zendir-Astro fusion palette\n * const color = getSeriesColor(0); // #3E3CFF (Zendir Electric)\n * \n * // Use Zendir-only palette\n * const brandColor = getSeriesColor(0, ASTRO_DATA_VIZ_COLORS.zendir);\n * ```\n */\nexport function getSeriesColor(index: number, palette = ASTRO_DATA_VIZ_COLORS.mixed): string {\n return palette[index % palette.length];\n}\n\n/**\n * Get Zendir brand color by role\n * Use for consistent branding across the application\n */\nexport function getZendirAccentColor(role: keyof typeof ZENDIR_ACCENT_COLORS): string {\n return ZENDIR_ACCENT_COLORS[role];\n}\n\n/**\n * Get appropriate palette based on data type and optional theme\n * \n * @param dataType - Type of data being visualized\n * @param useAstroTheme - If true, uses official AstroUXDS colors; otherwise Zendir colors\n * @returns Appropriate color palette\n * \n * @example\n * ```tsx\n * // For general multi-series data (Zendir brand - default)\n * const colors = getPaletteForDataType('categorical');\n * \n * // For official AstroUXDS colors\n * const astroColors = getPaletteForDataType('categorical', true);\n * \n * // For Zendir brand-forward charts\n * const brandColors = getPaletteForDataType('zendir');\n * \n * // For official AstroUXDS palette explicitly\n * const officialColors = getPaletteForDataType('astro-official');\n * \n * // For status-based data (uses reserved AstroUXDS status colors)\n * const statusColors = getPaletteForDataType('status');\n * ```\n */\nexport function getPaletteForDataType(\n dataType: 'categorical' | 'sequential' | 'diverging' | 'status' | 'zendir' | 'zendirExtended' | 'cool' | 'warm' | 'astro-official',\n useAstroTheme = false\n): string[] {\n // If useAstroTheme is true, default to official AstroUXDS colors\n if (useAstroTheme && (dataType === 'categorical' || dataType === 'sequential')) {\n return dataType === 'sequential' \n ? [...OFFICIAL_ASTRO_DATA_VIZ_COLORS.sequential.teal]\n : [...OFFICIAL_ASTRO_DATA_VIZ_COLORS.extended];\n }\n \n switch (dataType) {\n case 'astro-official':\n return [...OFFICIAL_ASTRO_DATA_VIZ_COLORS.extended]; // Official AstroUXDS colors\n case 'categorical':\n return ASTRO_DATA_VIZ_COLORS.mixed; // Pure Zendir brand palette\n case 'zendir':\n return ASTRO_DATA_VIZ_COLORS.zendir; // Core Zendir brand colors\n case 'zendirExtended':\n return ASTRO_DATA_VIZ_COLORS.zendirExtended; // All Zendir shades\n case 'sequential':\n return ASTRO_DATA_VIZ_COLORS.sequential.electric; // Zendir Electric gradient\n case 'diverging':\n return [...ASTRO_DATA_VIZ_COLORS.sequential.electric].reverse()\n .concat(ASTRO_DATA_VIZ_COLORS.sequential.purple);\n case 'status':\n // AstroUXDS status colors - RESERVED for status indication only\n return [\n STATUS_COLORS.normal,\n STATUS_COLORS.standby,\n STATUS_COLORS.caution,\n STATUS_COLORS.serious,\n STATUS_COLORS.critical,\n ];\n case 'cool':\n return ASTRO_DATA_VIZ_COLORS.cool;\n case 'warm':\n return ASTRO_DATA_VIZ_COLORS.warm;\n default:\n return ASTRO_DATA_VIZ_COLORS.mixed;\n }\n}\n\n/**\n * Create gradient for area charts\n */\nexport function createAreaGradient(\n color: string,\n direction: 'vertical' | 'horizontal' = 'vertical'\n): {\n type: 'linear';\n x: number;\n y: number;\n x2: number;\n y2: number;\n colorStops: Array<{ offset: number; color: string }>;\n} {\n return {\n type: 'linear',\n x: 0,\n y: direction === 'vertical' ? 0 : 0,\n x2: direction === 'horizontal' ? 1 : 0,\n y2: direction === 'vertical' ? 1 : 0,\n colorStops: [\n { offset: 0, color: `${color}40` },\n { offset: 1, color: `${color}05` },\n ],\n };\n}\n\n/**\n * Format time for axis labels\n */\nexport function formatTimeLabel(timestamp: number, format: 'short' | 'medium' | 'long' = 'short'): string {\n const date = new Date(timestamp);\n \n switch (format) {\n case 'short':\n return date.toLocaleTimeString([], { \n hour: '2-digit', \n minute: '2-digit',\n hour12: false,\n });\n case 'medium':\n return date.toLocaleTimeString([], { \n hour: '2-digit', \n minute: '2-digit',\n second: '2-digit',\n hour12: false,\n });\n case 'long':\n return date.toLocaleString([], {\n month: 'short',\n day: 'numeric',\n hour: '2-digit',\n minute: '2-digit',\n hour12: false,\n });\n }\n}\n\n/**\n * Format number with unit suffix\n */\nexport function formatValueWithUnit(value: number, unit?: string, precision = 2): string {\n const formatted = Number.isInteger(value) ? value.toString() : value.toFixed(precision);\n return unit ? `${formatted}${unit}` : formatted;\n}\n\n/**\n * Calculate nice axis bounds\n */\nexport function calculateAxisBounds(\n values: number[],\n padding = 0.1\n): { min: number; max: number } {\n if (values.length === 0) return { min: 0, max: 100 };\n \n const min = Math.min(...values);\n const max = Math.max(...values);\n const range = max - min || 1;\n \n return {\n min: min - range * padding,\n max: max + range * padding,\n };\n}\n"],"names":[],"mappings":"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"}
|