@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.
Files changed (359) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/LICENSE +21 -0
  3. package/README.md +589 -0
  4. package/dist/index.d.ts +8 -0
  5. package/dist/index.js +421 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/react/3d/EarthViewer.d.ts +46 -0
  8. package/dist/react/3d/EarthViewer.js +836 -0
  9. package/dist/react/3d/EarthViewer.js.map +1 -0
  10. package/dist/react/3d/SolarSystemViewer.d.ts +43 -0
  11. package/dist/react/3d/SolarSystemViewer.js +372 -0
  12. package/dist/react/3d/SolarSystemViewer.js.map +1 -0
  13. package/dist/react/3d/ZenSpace3D.d.ts +16 -0
  14. package/dist/react/3d/ZenSpace3D.js +1253 -0
  15. package/dist/react/3d/ZenSpace3D.js.map +1 -0
  16. package/dist/react/3d/ZenSpace3DCesium.d.ts +9 -0
  17. package/dist/react/3d/ZenSpace3DCesium.js +186 -0
  18. package/dist/react/3d/ZenSpace3DCesium.js.map +1 -0
  19. package/dist/react/3d/ZenSpace3DShaders.d.ts +78 -0
  20. package/dist/react/3d/ZenSpace3DShaders.js +94 -0
  21. package/dist/react/3d/ZenSpace3DShaders.js.map +1 -0
  22. package/dist/react/3d/ZenSpace3DTypes.d.ts +614 -0
  23. package/dist/react/3d/ZenSpace3DUtils.d.ts +183 -0
  24. package/dist/react/3d/ZenSpace3DUtils.js +213 -0
  25. package/dist/react/3d/ZenSpace3DUtils.js.map +1 -0
  26. package/dist/react/3d/index.d.ts +23 -0
  27. package/dist/react/3d/threeLoader.d.ts +22 -0
  28. package/dist/react/3d/threeLoader.js +18 -0
  29. package/dist/react/3d/threeLoader.js.map +1 -0
  30. package/dist/react/astro/ClassificationBanner.d.ts +25 -0
  31. package/dist/react/astro/ClassificationBanner.js +83 -0
  32. package/dist/react/astro/ClassificationBanner.js.map +1 -0
  33. package/dist/react/astro/GlobalStatusBar.d.ts +42 -0
  34. package/dist/react/astro/GlobalStatusBar.js +165 -0
  35. package/dist/react/astro/GlobalStatusBar.js.map +1 -0
  36. package/dist/react/astro/MissionClock.d.ts +169 -0
  37. package/dist/react/astro/MissionClock.js +411 -0
  38. package/dist/react/astro/MissionClock.js.map +1 -0
  39. package/dist/react/astro/MonitoringIcon.d.ts +60 -0
  40. package/dist/react/astro/MonitoringIcon.js +369 -0
  41. package/dist/react/astro/MonitoringIcon.js.map +1 -0
  42. package/dist/react/astro/Notification.d.ts +42 -0
  43. package/dist/react/astro/Notification.js +156 -0
  44. package/dist/react/astro/Notification.js.map +1 -0
  45. package/dist/react/astro/Progress.d.ts +39 -0
  46. package/dist/react/astro/Progress.js +149 -0
  47. package/dist/react/astro/Progress.js.map +1 -0
  48. package/dist/react/astro/SimulationControls.d.ts +136 -0
  49. package/dist/react/astro/SimulationControls.js +668 -0
  50. package/dist/react/astro/SimulationControls.js.map +1 -0
  51. package/dist/react/astro/StatusIndicator.d.ts +34 -0
  52. package/dist/react/astro/StatusIndicator.js +189 -0
  53. package/dist/react/astro/StatusIndicator.js.map +1 -0
  54. package/dist/react/astro/UnifiedTimeline.d.ts +106 -0
  55. package/dist/react/astro/UnifiedTimeline.js +1768 -0
  56. package/dist/react/astro/UnifiedTimeline.js.map +1 -0
  57. package/dist/react/astro/index.d.ts +63 -0
  58. package/dist/react/cards/AccessCard.d.ts +37 -0
  59. package/dist/react/cards/AccessCard.js +410 -0
  60. package/dist/react/cards/AccessCard.js.map +1 -0
  61. package/dist/react/cards/OrbitCard.d.ts +31 -0
  62. package/dist/react/cards/OrbitCard.js +372 -0
  63. package/dist/react/cards/OrbitCard.js.map +1 -0
  64. package/dist/react/cards/SpacecraftCard.d.ts +54 -0
  65. package/dist/react/cards/SpacecraftCard.js +941 -0
  66. package/dist/react/cards/SpacecraftCard.js.map +1 -0
  67. package/dist/react/cards/TelemetryCard.d.ts +40 -0
  68. package/dist/react/cards/TelemetryCard.js +742 -0
  69. package/dist/react/cards/TelemetryCard.js.map +1 -0
  70. package/dist/react/cards/TelemetryStreamCard.d.ts +59 -0
  71. package/dist/react/cards/TelemetryStreamCard.js +309 -0
  72. package/dist/react/cards/TelemetryStreamCard.js.map +1 -0
  73. package/dist/react/cards/index.d.ts +13 -0
  74. package/dist/react/charts/GroundTrackMap.d.ts +112 -0
  75. package/dist/react/charts/GroundTrackMap.js +1123 -0
  76. package/dist/react/charts/GroundTrackMap.js.map +1 -0
  77. package/dist/react/charts/GroundTrackMapLeaflet.d.ts +26 -0
  78. package/dist/react/charts/GroundTrackMapLeaflet.js +571 -0
  79. package/dist/react/charts/GroundTrackMapLeaflet.js.map +1 -0
  80. package/dist/react/charts/groundTrackMapLeafletTiles.d.ts +22 -0
  81. package/dist/react/charts/groundTrackMapLeafletTiles.js +11 -0
  82. package/dist/react/charts/groundTrackMapLeafletTiles.js.map +1 -0
  83. package/dist/react/charts/groundTrackMapLeafletUtils.d.ts +24 -0
  84. package/dist/react/charts/groundTrackMapLeafletUtils.js +109 -0
  85. package/dist/react/charts/groundTrackMapLeafletUtils.js.map +1 -0
  86. package/dist/react/charts/index.d.ts +10 -0
  87. package/dist/react/charts/unified/AstroChart.d.ts +24 -0
  88. package/dist/react/charts/unified/AstroChart.js +1405 -0
  89. package/dist/react/charts/unified/AstroChart.js.map +1 -0
  90. package/dist/react/charts/unified/PowerOverviewChart.d.ts +73 -0
  91. package/dist/react/charts/unified/PowerOverviewChart.js +488 -0
  92. package/dist/react/charts/unified/PowerOverviewChart.js.map +1 -0
  93. package/dist/react/charts/unified/domain.d.ts +845 -0
  94. package/dist/react/charts/unified/domain.js +3168 -0
  95. package/dist/react/charts/unified/domain.js.map +1 -0
  96. package/dist/react/charts/unified/generators.d.ts +276 -0
  97. package/dist/react/charts/unified/generators.js +518 -0
  98. package/dist/react/charts/unified/generators.js.map +1 -0
  99. package/dist/react/charts/unified/index.d.ts +55 -0
  100. package/dist/react/charts/unified/presets.d.ts +290 -0
  101. package/dist/react/charts/unified/presets.js +999 -0
  102. package/dist/react/charts/unified/presets.js.map +1 -0
  103. package/dist/react/charts/unified/sync.d.ts +69 -0
  104. package/dist/react/charts/unified/sync.js +219 -0
  105. package/dist/react/charts/unified/sync.js.map +1 -0
  106. package/dist/react/charts/unified/theme.d.ts +447 -0
  107. package/dist/react/charts/unified/theme.js +562 -0
  108. package/dist/react/charts/unified/theme.js.map +1 -0
  109. package/dist/react/charts/unified/types.d.ts +826 -0
  110. package/dist/react/charts/unified/useChartStream.d.ts +58 -0
  111. package/dist/react/charts/unified/useChartStream.js +226 -0
  112. package/dist/react/charts/unified/useChartStream.js.map +1 -0
  113. package/dist/react/chatgpt/AppCard.d.ts +59 -0
  114. package/dist/react/chatgpt/AppCard.js +306 -0
  115. package/dist/react/chatgpt/AppCard.js.map +1 -0
  116. package/dist/react/chatgpt/ChatGPTCard.d.ts +6 -0
  117. package/dist/react/chatgpt/index.d.ts +167 -0
  118. package/dist/react/chatgpt/index.js +166 -0
  119. package/dist/react/chatgpt/index.js.map +1 -0
  120. package/dist/react/context/DisplaySettingsContext.d.ts +107 -0
  121. package/dist/react/context/DisplaySettingsContext.js +169 -0
  122. package/dist/react/context/DisplaySettingsContext.js.map +1 -0
  123. package/dist/react/context/index.d.ts +5 -0
  124. package/dist/react/core/ActivityPlanner.d.ts +45 -0
  125. package/dist/react/core/ActivityPlanner.js +532 -0
  126. package/dist/react/core/ActivityPlanner.js.map +1 -0
  127. package/dist/react/core/AppBar.d.ts +71 -0
  128. package/dist/react/core/AppBar.js +817 -0
  129. package/dist/react/core/AppBar.js.map +1 -0
  130. package/dist/react/core/AstroIcon.d.ts +84 -0
  131. package/dist/react/core/AstroIcon.js +1243 -0
  132. package/dist/react/core/AstroIcon.js.map +1 -0
  133. package/dist/react/core/Badge.d.ts +27 -0
  134. package/dist/react/core/Badge.js +134 -0
  135. package/dist/react/core/Badge.js.map +1 -0
  136. package/dist/react/core/Button.d.ts +26 -0
  137. package/dist/react/core/Button.js +306 -0
  138. package/dist/react/core/Button.js.map +1 -0
  139. package/dist/react/core/CardHeader.d.ts +34 -0
  140. package/dist/react/core/CardHeader.js +316 -0
  141. package/dist/react/core/CardHeader.js.map +1 -0
  142. package/dist/react/core/ChatPanel.d.ts +627 -0
  143. package/dist/react/core/ChatPanel.js +1144 -0
  144. package/dist/react/core/ChatPanel.js.map +1 -0
  145. package/dist/react/core/Checkbox.d.ts +26 -0
  146. package/dist/react/core/Checkbox.js +130 -0
  147. package/dist/react/core/Checkbox.js.map +1 -0
  148. package/dist/react/core/ColorPickerPanel.d.ts +25 -0
  149. package/dist/react/core/ColorPickerPanel.js +293 -0
  150. package/dist/react/core/ColorPickerPanel.js.map +1 -0
  151. package/dist/react/core/CommandBuilder.d.ts +74 -0
  152. package/dist/react/core/CommandBuilder.js +518 -0
  153. package/dist/react/core/CommandBuilder.js.map +1 -0
  154. package/dist/react/core/ConfirmDialog.d.ts +45 -0
  155. package/dist/react/core/ConfirmDialog.js +315 -0
  156. package/dist/react/core/ConfirmDialog.js.map +1 -0
  157. package/dist/react/core/ConnectionForm.d.ts +57 -0
  158. package/dist/react/core/ConnectionForm.js +496 -0
  159. package/dist/react/core/ConnectionForm.js.map +1 -0
  160. package/dist/react/core/Container.d.ts +51 -0
  161. package/dist/react/core/Container.js +670 -0
  162. package/dist/react/core/Container.js.map +1 -0
  163. package/dist/react/core/CopyButton.d.ts +39 -0
  164. package/dist/react/core/CopyButton.js +105 -0
  165. package/dist/react/core/CopyButton.js.map +1 -0
  166. package/dist/react/core/DataTable.d.ts +113 -0
  167. package/dist/react/core/DataTable.js +446 -0
  168. package/dist/react/core/DataTable.js.map +1 -0
  169. package/dist/react/core/DataValue.d.ts +64 -0
  170. package/dist/react/core/DataValue.js +545 -0
  171. package/dist/react/core/DataValue.js.map +1 -0
  172. package/dist/react/core/Dialog.d.ts +32 -0
  173. package/dist/react/core/Dialog.js +201 -0
  174. package/dist/react/core/Dialog.js.map +1 -0
  175. package/dist/react/core/FileExplorer.d.ts +65 -0
  176. package/dist/react/core/FileExplorer.js +520 -0
  177. package/dist/react/core/FileExplorer.js.map +1 -0
  178. package/dist/react/core/GlassCard.d.ts +129 -0
  179. package/dist/react/core/GlassCard.js +375 -0
  180. package/dist/react/core/GlassCard.js.map +1 -0
  181. package/dist/react/core/HeaderIconWithStatus.d.ts +39 -0
  182. package/dist/react/core/HeaderIconWithStatus.js +157 -0
  183. package/dist/react/core/HeaderIconWithStatus.js.map +1 -0
  184. package/dist/react/core/HexViewer.d.ts +143 -0
  185. package/dist/react/core/HexViewer.js +1106 -0
  186. package/dist/react/core/HexViewer.js.map +1 -0
  187. package/dist/react/core/Icon.d.ts +32 -0
  188. package/dist/react/core/Icon.js +142 -0
  189. package/dist/react/core/Icon.js.map +1 -0
  190. package/dist/react/core/ImageGallery.d.ts +41 -0
  191. package/dist/react/core/ImageGallery.js +320 -0
  192. package/dist/react/core/ImageGallery.js.map +1 -0
  193. package/dist/react/core/Input.d.ts +38 -0
  194. package/dist/react/core/Input.js +288 -0
  195. package/dist/react/core/Input.js.map +1 -0
  196. package/dist/react/core/LimitsBar.d.ts +51 -0
  197. package/dist/react/core/LimitsBar.js +200 -0
  198. package/dist/react/core/LimitsBar.js.map +1 -0
  199. package/dist/react/core/LogViewer.d.ts +61 -0
  200. package/dist/react/core/LogViewer.js +599 -0
  201. package/dist/react/core/LogViewer.js.map +1 -0
  202. package/dist/react/core/MessageStream.d.ts +58 -0
  203. package/dist/react/core/MessageStream.js +455 -0
  204. package/dist/react/core/MessageStream.js.map +1 -0
  205. package/dist/react/core/MissionCalendar.d.ts +81 -0
  206. package/dist/react/core/MissionCalendar.js +1049 -0
  207. package/dist/react/core/MissionCalendar.js.map +1 -0
  208. package/dist/react/core/NumberInput.d.ts +85 -0
  209. package/dist/react/core/NumberInput.js +507 -0
  210. package/dist/react/core/NumberInput.js.map +1 -0
  211. package/dist/react/core/PacketViewer.d.ts +73 -0
  212. package/dist/react/core/PacketViewer.js +431 -0
  213. package/dist/react/core/PacketViewer.js.map +1 -0
  214. package/dist/react/core/Pagination.d.ts +30 -0
  215. package/dist/react/core/Pagination.js +190 -0
  216. package/dist/react/core/Pagination.js.map +1 -0
  217. package/dist/react/core/PinInput.d.ts +41 -0
  218. package/dist/react/core/PinInput.js +210 -0
  219. package/dist/react/core/PinInput.js.map +1 -0
  220. package/dist/react/core/Popover.d.ts +55 -0
  221. package/dist/react/core/Popover.js +288 -0
  222. package/dist/react/core/Popover.js.map +1 -0
  223. package/dist/react/core/Select.d.ts +42 -0
  224. package/dist/react/core/Select.js +303 -0
  225. package/dist/react/core/Select.js.map +1 -0
  226. package/dist/react/core/SideNav.d.ts +103 -0
  227. package/dist/react/core/SideNav.js +551 -0
  228. package/dist/react/core/SideNav.js.map +1 -0
  229. package/dist/react/core/SidePanel.d.ts +33 -0
  230. package/dist/react/core/SidePanel.js +199 -0
  231. package/dist/react/core/SidePanel.js.map +1 -0
  232. package/dist/react/core/Tabs.d.ts +47 -0
  233. package/dist/react/core/Tabs.js +129 -0
  234. package/dist/react/core/Tabs.js.map +1 -0
  235. package/dist/react/core/Toast.d.ts +56 -0
  236. package/dist/react/core/Toast.js +229 -0
  237. package/dist/react/core/Toast.js.map +1 -0
  238. package/dist/react/core/Toggle.d.ts +22 -0
  239. package/dist/react/core/Toggle.js +151 -0
  240. package/dist/react/core/Toggle.js.map +1 -0
  241. package/dist/react/core/Tooltip.d.ts +19 -0
  242. package/dist/react/core/Tooltip.js +179 -0
  243. package/dist/react/core/Tooltip.js.map +1 -0
  244. package/dist/react/core/Typography.d.ts +127 -0
  245. package/dist/react/core/Typography.js +187 -0
  246. package/dist/react/core/Typography.js.map +1 -0
  247. package/dist/react/core/index.d.ts +108 -0
  248. package/dist/react/core/layout/Box.d.ts +77 -0
  249. package/dist/react/core/layout/Box.js +126 -0
  250. package/dist/react/core/layout/Box.js.map +1 -0
  251. package/dist/react/core/layout/Center.d.ts +20 -0
  252. package/dist/react/core/layout/Center.js +34 -0
  253. package/dist/react/core/layout/Center.js.map +1 -0
  254. package/dist/react/core/layout/Divider.d.ts +16 -0
  255. package/dist/react/core/layout/Divider.js +108 -0
  256. package/dist/react/core/layout/Divider.js.map +1 -0
  257. package/dist/react/core/layout/Flex.d.ts +30 -0
  258. package/dist/react/core/layout/Flex.js +128 -0
  259. package/dist/react/core/layout/Flex.js.map +1 -0
  260. package/dist/react/core/layout/Grid.d.ts +36 -0
  261. package/dist/react/core/layout/Grid.js +142 -0
  262. package/dist/react/core/layout/Grid.js.map +1 -0
  263. package/dist/react/core/layout/Spacer.d.ts +8 -0
  264. package/dist/react/core/layout/Spacer.js +31 -0
  265. package/dist/react/core/layout/Spacer.js.map +1 -0
  266. package/dist/react/core/layout/Stack.d.ts +54 -0
  267. package/dist/react/core/layout/Stack.js +74 -0
  268. package/dist/react/core/layout/Stack.js.map +1 -0
  269. package/dist/react/core/layout/index.d.ts +38 -0
  270. package/dist/react/core/layout/responsive.d.ts +23 -0
  271. package/dist/react/core/layout/responsive.js +26 -0
  272. package/dist/react/core/layout/responsive.js.map +1 -0
  273. package/dist/react/core/layout/useBreakpoint.d.ts +77 -0
  274. package/dist/react/core/layout/useBreakpoint.js +73 -0
  275. package/dist/react/core/layout/useBreakpoint.js.map +1 -0
  276. package/dist/react/core/propertyConfig.d.ts +443 -0
  277. package/dist/react/core/propertyConfig.js +399 -0
  278. package/dist/react/core/propertyConfig.js.map +1 -0
  279. package/dist/react/hooks/index.d.ts +21 -0
  280. package/dist/react/hooks/useAccessWindows.d.ts +66 -0
  281. package/dist/react/hooks/useCompactMode.d.ts +82 -0
  282. package/dist/react/hooks/useCompactMode.js +62 -0
  283. package/dist/react/hooks/useCompactMode.js.map +1 -0
  284. package/dist/react/hooks/useLiveSelection.d.ts +57 -0
  285. package/dist/react/hooks/useSimulationPlayback.d.ts +97 -0
  286. package/dist/react/hooks/useSimulationTime.d.ts +61 -0
  287. package/dist/react/hooks/useSpacecraftPosition.d.ts +50 -0
  288. package/dist/react/hooks/useSpacecraftPosition.js +89 -0
  289. package/dist/react/hooks/useSpacecraftPosition.js.map +1 -0
  290. package/dist/react/hooks/useTelemetry.d.ts +55 -0
  291. package/dist/react/hooks/useTelemetry.js +73 -0
  292. package/dist/react/hooks/useTelemetry.js.map +1 -0
  293. package/dist/react/hooks/useZendirSession.d.ts +109 -0
  294. package/dist/react/hooks/useZendirSession.js +148 -0
  295. package/dist/react/hooks/useZendirSession.js.map +1 -0
  296. package/dist/react/index.d.ts +74 -0
  297. package/dist/react/shared/ErrorBoundary.d.ts +63 -0
  298. package/dist/react/shared/ErrorBoundary.js +142 -0
  299. package/dist/react/shared/ErrorBoundary.js.map +1 -0
  300. package/dist/react/shared/Skeleton.d.ts +110 -0
  301. package/dist/react/shared/Skeleton.js +324 -0
  302. package/dist/react/shared/Skeleton.js.map +1 -0
  303. package/dist/react/shared/index.d.ts +12 -0
  304. package/dist/react/theme/ThemeProvider.d.ts +385 -0
  305. package/dist/react/theme/ThemeProvider.js +1096 -0
  306. package/dist/react/theme/ThemeProvider.js.map +1 -0
  307. package/dist/react/theme/astro-tokens.d.ts +153 -0
  308. package/dist/react/theme/cardAccent.d.ts +75 -0
  309. package/dist/react/theme/cardAccent.js +137 -0
  310. package/dist/react/theme/cardAccent.js.map +1 -0
  311. package/dist/react/theme/config.d.ts +39 -0
  312. package/dist/react/theme/index.d.ts +9 -0
  313. package/dist/react/types.d.ts +360 -0
  314. package/dist/react/types.js +58 -0
  315. package/dist/react/types.js.map +1 -0
  316. package/dist/react/utils/index.d.ts +247 -0
  317. package/dist/react/utils/index.js +423 -0
  318. package/dist/react/utils/index.js.map +1 -0
  319. package/dist/react/visualizations/EclipseTimerCard.d.ts +17 -0
  320. package/dist/react/visualizations/EclipseTimerCard.js +250 -0
  321. package/dist/react/visualizations/EclipseTimerCard.js.map +1 -0
  322. package/dist/react/visualizations/LinkBudgetCard.d.ts +50 -0
  323. package/dist/react/visualizations/LinkBudgetCard.js +444 -0
  324. package/dist/react/visualizations/LinkBudgetCard.js.map +1 -0
  325. package/dist/react/visualizations/NavBallCard.d.ts +17 -0
  326. package/dist/react/visualizations/NavBallCard.js +243 -0
  327. package/dist/react/visualizations/NavBallCard.js.map +1 -0
  328. package/dist/react/visualizations/PropulsionCard.d.ts +37 -0
  329. package/dist/react/visualizations/PropulsionCard.js +298 -0
  330. package/dist/react/visualizations/PropulsionCard.js.map +1 -0
  331. package/dist/react/visualizations/SensorFootprintCard.d.ts +33 -0
  332. package/dist/react/visualizations/SensorFootprintCard.js +326 -0
  333. package/dist/react/visualizations/SensorFootprintCard.js.map +1 -0
  334. package/dist/react/visualizations/ThermalHeatmapCard.d.ts +38 -0
  335. package/dist/react/visualizations/ThermalHeatmapCard.js +372 -0
  336. package/dist/react/visualizations/ThermalHeatmapCard.js.map +1 -0
  337. package/dist/react/visualizations/index.d.ts +17 -0
  338. package/dist/react.d.ts +1 -0
  339. package/dist/react.js +421 -0
  340. package/dist/react.js.map +1 -0
  341. package/dist/shaders/atmosphere.frag.js +5 -0
  342. package/dist/shaders/atmosphere.frag.js.map +1 -0
  343. package/dist/shaders/atmosphere.vert.js +5 -0
  344. package/dist/shaders/atmosphere.vert.js.map +1 -0
  345. package/dist/shaders/stars.frag.js +5 -0
  346. package/dist/shaders/stars.frag.js.map +1 -0
  347. package/dist/shaders/stars.vert.js +5 -0
  348. package/dist/shaders/stars.vert.js.map +1 -0
  349. package/dist/style.css +143 -0
  350. package/dist/tokens/index.d.ts +296 -0
  351. package/dist/tokens/index.js +263 -0
  352. package/dist/tokens/index.js.map +1 -0
  353. package/dist/tokens/tokens.css +155 -0
  354. package/dist/types/index.d.ts +23 -0
  355. package/dist/types.d.ts +1 -0
  356. package/dist/types.js +2 -0
  357. package/dist/types.js.map +1 -0
  358. package/package.json +220 -0
  359. 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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"}