@zendir/ui 0.1.8 → 0.1.10

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 (92) hide show
  1. package/dist/index.js +0 -169
  2. package/dist/index.js.map +1 -1
  3. package/dist/react/context/DisplaySettingsContext.js +0 -12
  4. package/dist/react/context/DisplaySettingsContext.js.map +1 -1
  5. package/dist/react/core/AstroIcon.js +1 -816
  6. package/dist/react/core/AstroIcon.js.map +1 -1
  7. package/dist/react/core/index.d.ts +0 -1
  8. package/dist/react/index.d.ts +2 -42
  9. package/dist/react/utils/index.js +0 -8
  10. package/dist/react/utils/index.js.map +1 -1
  11. package/dist/react.js +0 -169
  12. package/dist/react.js.map +1 -1
  13. package/package.json +1 -1
  14. package/dist/react/3d/EarthViewer.js +0 -836
  15. package/dist/react/3d/EarthViewer.js.map +0 -1
  16. package/dist/react/3d/SolarSystemViewer.js +0 -372
  17. package/dist/react/3d/SolarSystemViewer.js.map +0 -1
  18. package/dist/react/3d/ZenSpace3D.js +0 -1253
  19. package/dist/react/3d/ZenSpace3D.js.map +0 -1
  20. package/dist/react/3d/ZenSpace3DCesium.js +0 -186
  21. package/dist/react/3d/ZenSpace3DCesium.js.map +0 -1
  22. package/dist/react/3d/ZenSpace3DShaders.js +0 -94
  23. package/dist/react/3d/ZenSpace3DShaders.js.map +0 -1
  24. package/dist/react/3d/ZenSpace3DUtils.js +0 -213
  25. package/dist/react/3d/ZenSpace3DUtils.js.map +0 -1
  26. package/dist/react/3d/threeLoader.js +0 -18
  27. package/dist/react/3d/threeLoader.js.map +0 -1
  28. package/dist/react/cards/AccessCard.js +0 -410
  29. package/dist/react/cards/AccessCard.js.map +0 -1
  30. package/dist/react/cards/OrbitCard.js +0 -372
  31. package/dist/react/cards/OrbitCard.js.map +0 -1
  32. package/dist/react/cards/SpacecraftCard.js +0 -941
  33. package/dist/react/cards/SpacecraftCard.js.map +0 -1
  34. package/dist/react/cards/TelemetryCard.js +0 -742
  35. package/dist/react/cards/TelemetryCard.js.map +0 -1
  36. package/dist/react/cards/TelemetryStreamCard.js +0 -309
  37. package/dist/react/cards/TelemetryStreamCard.js.map +0 -1
  38. package/dist/react/charts/GroundTrackMap.js +0 -1123
  39. package/dist/react/charts/GroundTrackMap.js.map +0 -1
  40. package/dist/react/charts/GroundTrackMapLeaflet.js +0 -571
  41. package/dist/react/charts/GroundTrackMapLeaflet.js.map +0 -1
  42. package/dist/react/charts/groundTrackMapLeafletTiles.js +0 -11
  43. package/dist/react/charts/groundTrackMapLeafletTiles.js.map +0 -1
  44. package/dist/react/charts/groundTrackMapLeafletUtils.js +0 -109
  45. package/dist/react/charts/groundTrackMapLeafletUtils.js.map +0 -1
  46. package/dist/react/charts/unified/AstroChart.js +0 -1405
  47. package/dist/react/charts/unified/AstroChart.js.map +0 -1
  48. package/dist/react/charts/unified/PowerOverviewChart.js +0 -488
  49. package/dist/react/charts/unified/PowerOverviewChart.js.map +0 -1
  50. package/dist/react/charts/unified/domain.js +0 -3168
  51. package/dist/react/charts/unified/domain.js.map +0 -1
  52. package/dist/react/charts/unified/generators.js +0 -518
  53. package/dist/react/charts/unified/generators.js.map +0 -1
  54. package/dist/react/charts/unified/presets.js +0 -999
  55. package/dist/react/charts/unified/presets.js.map +0 -1
  56. package/dist/react/charts/unified/sync.js +0 -219
  57. package/dist/react/charts/unified/sync.js.map +0 -1
  58. package/dist/react/charts/unified/theme.js +0 -562
  59. package/dist/react/charts/unified/theme.js.map +0 -1
  60. package/dist/react/charts/unified/useChartStream.js +0 -226
  61. package/dist/react/charts/unified/useChartStream.js.map +0 -1
  62. package/dist/react/chatgpt/AppCard.js +0 -306
  63. package/dist/react/chatgpt/AppCard.js.map +0 -1
  64. package/dist/react/chatgpt/index.js +0 -166
  65. package/dist/react/chatgpt/index.js.map +0 -1
  66. package/dist/react/hooks/useSpacecraftPosition.js +0 -89
  67. package/dist/react/hooks/useSpacecraftPosition.js.map +0 -1
  68. package/dist/react/hooks/useTelemetry.js +0 -73
  69. package/dist/react/hooks/useTelemetry.js.map +0 -1
  70. package/dist/react/hooks/useZendirSession.js +0 -148
  71. package/dist/react/hooks/useZendirSession.js.map +0 -1
  72. package/dist/react/visualizations/EclipseTimerCard.js +0 -250
  73. package/dist/react/visualizations/EclipseTimerCard.js.map +0 -1
  74. package/dist/react/visualizations/LinkBudgetCard.js +0 -444
  75. package/dist/react/visualizations/LinkBudgetCard.js.map +0 -1
  76. package/dist/react/visualizations/NavBallCard.js +0 -243
  77. package/dist/react/visualizations/NavBallCard.js.map +0 -1
  78. package/dist/react/visualizations/PropulsionCard.js +0 -298
  79. package/dist/react/visualizations/PropulsionCard.js.map +0 -1
  80. package/dist/react/visualizations/SensorFootprintCard.js +0 -326
  81. package/dist/react/visualizations/SensorFootprintCard.js.map +0 -1
  82. package/dist/react/visualizations/ThermalHeatmapCard.js +0 -372
  83. package/dist/react/visualizations/ThermalHeatmapCard.js.map +0 -1
  84. package/dist/shaders/atmosphere.frag.js +0 -5
  85. package/dist/shaders/atmosphere.frag.js.map +0 -1
  86. package/dist/shaders/atmosphere.vert.js +0 -5
  87. package/dist/shaders/atmosphere.vert.js.map +0 -1
  88. package/dist/shaders/stars.frag.js +0 -5
  89. package/dist/shaders/stars.frag.js.map +0 -1
  90. package/dist/shaders/stars.vert.js +0 -5
  91. package/dist/shaders/stars.vert.js.map +0 -1
  92. package/dist/style.css +0 -143
@@ -1,372 +0,0 @@
1
- import { jsxs, jsx } from "react/jsx-runtime";
2
- import { memo, useMemo } from "react";
3
- import { estimateOrbitalPeriod, estimateOrbitalVelocity } from "../types.js";
4
- import { Icon } from "../core/Icon.js";
5
- import { AstroIcon } from "../core/AstroIcon.js";
6
- import { CardHeader } from "../core/CardHeader.js";
7
- import { classNames, formatAltitude, safeAccentText, formatVelocity, formatDegrees, formatDuration, formatCoordinate, formatTime } from "../utils/index.js";
8
- import { useTheme } from "../theme/ThemeProvider.js";
9
- import { useCompactMode } from "../hooks/useCompactMode.js";
10
- function getOrbitTypeInfo(orbitType) {
11
- const types = {
12
- LEO: { color: "#3E3CFF", description: "Low Earth Orbit (200-2,000 km)" },
13
- // Zendir Electric
14
- MEO: { color: "#3548C0", description: "Medium Earth Orbit (2,000-35,786 km)" },
15
- // Zendir Prussian Blue Light
16
- GEO: { color: "#9D70FF", description: "Geostationary Orbit (~35,786 km)" },
17
- // Zendir Purple
18
- HEO: { color: "#1B2DA0", description: "Highly Elliptical Orbit" },
19
- // Zendir Prussian Blue
20
- SSO: { color: "#B48DFF", description: "Sun-Synchronous Orbit" },
21
- // Zendir Purple Light
22
- POLAR: { color: "#6B69FF", description: "Polar Orbit" },
23
- // Zendir Electric Light
24
- MOLNIYA: { color: "#C9A8FF", description: "Molniya Orbit (12h period)" }
25
- // Zendir Purple Lighter
26
- };
27
- return types[(orbitType == null ? void 0 : orbitType.toUpperCase()) ?? ""] ?? { color: "#a4abb6", description: "Unknown orbit type" };
28
- }
29
- const OrbitCard = memo(function OrbitCard2({
30
- spacecraft,
31
- showComputed = true,
32
- loading = false,
33
- className = "",
34
- compact = false,
35
- defaultExpanded = false,
36
- onPinChange
37
- }) {
38
- const { tokens, theme, prefersReducedMotion } = useTheme();
39
- const isTransparentTheme = theme === "transparent" || theme === "transparent-bold" || theme === "transparent-minimal";
40
- const isBoldVariant = theme === "transparent-bold";
41
- const isMinimalVariant = theme === "transparent-minimal";
42
- const useGlassMode = isBoldVariant || isMinimalVariant;
43
- const glassAccentColor = tokens.colors.accent.primary;
44
- const glassAccentMuted = `${glassAccentColor}66`;
45
- const cardBg = isTransparentTheme ? "transparent" : tokens.colors.background.surface;
46
- const cardGlass = isTransparentTheme ? {
47
- backdropFilter: "blur(12px)",
48
- WebkitBackdropFilter: "blur(12px)"
49
- } : {};
50
- const glassContainerStyle = useGlassMode ? {
51
- backgroundColor: "rgba(10, 15, 25, 0.35)",
52
- backdropFilter: "blur(12px)",
53
- WebkitBackdropFilter: "blur(12px)",
54
- border: `1px solid ${glassAccentMuted}`,
55
- borderTop: isBoldVariant ? `2px solid ${glassAccentColor}` : `1px solid ${glassAccentColor}`
56
- } : {};
57
- const { expanded, isPinned, handlers, transitionDuration } = useCompactMode({
58
- compact,
59
- defaultExpanded,
60
- onPinChange
61
- });
62
- const orbitInfo = useMemo(() => getOrbitTypeInfo(spacecraft == null ? void 0 : spacecraft.orbitType), [spacecraft == null ? void 0 : spacecraft.orbitType]);
63
- const computedPeriod = useMemo(() => {
64
- if (!(spacecraft == null ? void 0 : spacecraft.altitude)) return null;
65
- try {
66
- return estimateOrbitalPeriod(spacecraft.altitude);
67
- } catch {
68
- return null;
69
- }
70
- }, [spacecraft == null ? void 0 : spacecraft.altitude]);
71
- const computedVelocity = useMemo(() => {
72
- if (!(spacecraft == null ? void 0 : spacecraft.altitude)) return null;
73
- try {
74
- return estimateOrbitalVelocity(spacecraft.altitude);
75
- } catch {
76
- return null;
77
- }
78
- }, [spacecraft == null ? void 0 : spacecraft.altitude]);
79
- if (loading) {
80
- return /* @__PURE__ */ jsxs(
81
- "div",
82
- {
83
- className: classNames("zendir-orbit-card", "loading", className),
84
- role: "article",
85
- "aria-busy": "true",
86
- "aria-label": "Loading orbit data",
87
- style: {
88
- backgroundColor: cardBg,
89
- ...cardGlass,
90
- ...tokens.colors.border.cardStyle ?? {},
91
- borderRadius: tokens.borderRadius.lg,
92
- padding: tokens.spacing.md,
93
- minHeight: 200
94
- },
95
- children: [
96
- /* @__PURE__ */ jsxs("div", { style: { display: "flex", alignItems: "center", gap: 12, marginBottom: 20 }, children: [
97
- /* @__PURE__ */ jsx("div", { style: { width: 40, height: 40, borderRadius: 8, backgroundColor: "rgba(255,255,255,0.1)" } }),
98
- /* @__PURE__ */ jsxs("div", { style: { flex: 1 }, children: [
99
- /* @__PURE__ */ jsx("div", { style: { height: 18, width: "50%", backgroundColor: "rgba(255,255,255,0.1)", borderRadius: 4 } }),
100
- /* @__PURE__ */ jsx("div", { style: { height: 12, width: "70%", backgroundColor: "rgba(255,255,255,0.06)", borderRadius: 4, marginTop: 6 } })
101
- ] })
102
- ] }),
103
- /* @__PURE__ */ jsx("div", { style: { display: "grid", gridTemplateColumns: "repeat(2, 1fr)", gap: 16 }, children: [1, 2, 3, 4].map((i) => /* @__PURE__ */ jsxs("div", { children: [
104
- /* @__PURE__ */ jsx("div", { style: { height: 10, width: "40%", backgroundColor: "rgba(255,255,255,0.06)", borderRadius: 2 } }),
105
- /* @__PURE__ */ jsx("div", { style: { height: 20, width: "60%", backgroundColor: "rgba(255,255,255,0.1)", borderRadius: 4, marginTop: 4 } })
106
- ] }, i)) })
107
- ]
108
- }
109
- );
110
- }
111
- if (!spacecraft) {
112
- return /* @__PURE__ */ jsxs(
113
- "div",
114
- {
115
- className: classNames("zendir-orbit-card", "empty", className),
116
- role: "article",
117
- "aria-label": "No orbit data",
118
- style: {
119
- backgroundColor: cardBg,
120
- ...cardGlass,
121
- ...tokens.colors.border.cardStyleDashed ?? {},
122
- borderRadius: tokens.borderRadius.lg,
123
- padding: tokens.spacing.lg,
124
- textAlign: "center",
125
- color: tokens.colors.text.tertiary
126
- },
127
- children: [
128
- /* @__PURE__ */ jsxs("svg", { width: "32", height: "32", viewBox: "0 0 24 24", fill: "currentColor", style: { opacity: 0.5, marginBottom: 8 }, children: [
129
- /* @__PURE__ */ jsx("path", { d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" }),
130
- /* @__PURE__ */ jsx("ellipse", { cx: "12", cy: "12", rx: "10", ry: "4", fill: "none", stroke: "currentColor", strokeWidth: "1", strokeDasharray: "3,3" })
131
- ] }),
132
- /* @__PURE__ */ jsx("p", { style: { margin: 0, fontSize: tokens.typography.body[2].fontSize }, children: "No orbit data available" })
133
- ]
134
- }
135
- );
136
- }
137
- if (compact && !expanded) {
138
- return /* @__PURE__ */ jsxs(
139
- "article",
140
- {
141
- className: classNames("zendir-orbit-card", "compact", className),
142
- ...handlers,
143
- "aria-label": `Orbit: ${spacecraft.orbitType ?? "Unknown"} (compact)`,
144
- style: {
145
- position: "relative",
146
- overflow: "hidden",
147
- ...useGlassMode ? glassContainerStyle : {
148
- backgroundColor: cardBg,
149
- ...cardGlass,
150
- ...tokens.colors.border.cardStyle ?? {}
151
- },
152
- borderRadius: tokens.borderRadius.lg,
153
- padding: `${tokens.spacing.sm} ${tokens.spacing.md}`,
154
- fontFamily: tokens.typography.fontFamily.primary,
155
- color: tokens.colors.text.primary,
156
- fontSize: tokens.typography.fontSize.sm,
157
- cursor: "pointer",
158
- transition: `all ${transitionDuration} ease-out`,
159
- transform: "scale(1)"
160
- },
161
- onMouseEnter: (e) => {
162
- handlers.onMouseEnter();
163
- if (!prefersReducedMotion) {
164
- e.currentTarget.style.transform = "scale(1.01)";
165
- e.currentTarget.style.boxShadow = `0 4px 12px ${orbitInfo.color}20`;
166
- }
167
- },
168
- onMouseLeave: (e) => {
169
- handlers.onMouseLeave();
170
- e.currentTarget.style.transform = "scale(1)";
171
- e.currentTarget.style.boxShadow = "";
172
- },
173
- children: [
174
- useGlassMode && /* @__PURE__ */ jsx(
175
- "div",
176
- {
177
- style: {
178
- position: "absolute",
179
- inset: 0,
180
- background: "linear-gradient(135deg, rgba(255,255,255,0.03) 0%, transparent 50%, rgba(0,0,0,0.1) 100%)",
181
- pointerEvents: "none",
182
- zIndex: 0
183
- }
184
- }
185
- ),
186
- /* @__PURE__ */ jsxs("div", { style: { display: "flex", alignItems: "center", justifyContent: "space-between", gap: tokens.spacing.md, position: "relative", zIndex: 1 }, children: [
187
- /* @__PURE__ */ jsxs("div", { style: { display: "flex", alignItems: "center", gap: tokens.spacing.sm, flex: 1, minWidth: 0 }, children: [
188
- /* @__PURE__ */ jsx(AstroIcon, { name: "360", size: 16, color: orbitInfo.color }),
189
- /* @__PURE__ */ jsx("span", { style: {
190
- fontWeight: tokens.typography.fontWeight.medium,
191
- color: useGlassMode ? glassAccentColor : void 0,
192
- textShadow: useGlassMode ? `0 0 16px ${glassAccentMuted}` : void 0
193
- }, children: "Orbit" }),
194
- useGlassMode && /* @__PURE__ */ jsx("div", { style: {
195
- flex: 1,
196
- height: isBoldVariant ? "2px" : "1px",
197
- minWidth: 20,
198
- background: `linear-gradient(90deg, ${glassAccentColor} 0%, ${glassAccentMuted} 60%, transparent 100%)`,
199
- boxShadow: isBoldVariant ? `0 0 8px ${glassAccentMuted}` : void 0
200
- } })
201
- ] }),
202
- /* @__PURE__ */ jsxs("div", { style: { display: "flex", alignItems: "center", gap: tokens.spacing.sm, flexShrink: 0 }, children: [
203
- /* @__PURE__ */ jsx(
204
- "span",
205
- {
206
- style: {
207
- backgroundColor: `${orbitInfo.color}20`,
208
- color: orbitInfo.color,
209
- padding: `2px 6px`,
210
- borderRadius: tokens.borderRadius.sm,
211
- fontSize: tokens.typography.fontSize.xs,
212
- fontWeight: tokens.typography.fontWeight.medium
213
- },
214
- children: spacecraft.orbitType ?? "—"
215
- }
216
- ),
217
- /* @__PURE__ */ jsx("span", { style: {
218
- fontVariantNumeric: "tabular-nums",
219
- fontFamily: tokens.typography.fontFamily.mono,
220
- fontSize: tokens.typography.fontSize.xs
221
- }, children: formatAltitude(spacecraft.altitude) }),
222
- isPinned && /* @__PURE__ */ jsx(Icon, { name: "lock", size: 12, color: tokens.colors.accent.primary })
223
- ] })
224
- ] })
225
- ]
226
- }
227
- );
228
- }
229
- const labelStyle = {
230
- color: tokens.colors.text.secondary,
231
- // WCAG AA compliant - 4.5:1 contrast
232
- fontSize: tokens.typography.fontSize.xs,
233
- fontWeight: tokens.typography.fontWeight.medium
234
- };
235
- const valueStyle = {
236
- color: tokens.colors.text.primary,
237
- fontWeight: tokens.typography.fontWeight.medium,
238
- fontFamily: tokens.typography.fontFamily.mono,
239
- fontVariantNumeric: "tabular-nums",
240
- fontSize: tokens.typography.fontSize.md,
241
- marginTop: 2
242
- };
243
- return /* @__PURE__ */ jsxs(
244
- "article",
245
- {
246
- className: classNames("zendir-orbit-card", compact ? "expanded" : "", className),
247
- ...compact ? handlers : {},
248
- role: compact ? handlers.role : "article",
249
- tabIndex: compact ? handlers.tabIndex : void 0,
250
- "aria-expanded": compact ? handlers["aria-expanded"] : void 0,
251
- "aria-label": `Orbit data for ${spacecraft.name ?? spacecraft.id}`,
252
- style: {
253
- position: "relative",
254
- overflow: "hidden",
255
- ...useGlassMode ? glassContainerStyle : {
256
- backgroundColor: cardBg,
257
- ...cardGlass,
258
- ...tokens.colors.border.cardStyle ?? {}
259
- },
260
- borderRadius: tokens.borderRadius.lg,
261
- padding: tokens.spacing.md,
262
- fontFamily: tokens.typography.fontFamily.primary,
263
- cursor: compact ? "pointer" : void 0,
264
- transition: compact ? `all ${transitionDuration} ease-out` : void 0,
265
- color: tokens.colors.text.primary,
266
- fontSize: tokens.typography.fontSize.sm
267
- },
268
- children: [
269
- useGlassMode && /* @__PURE__ */ jsx(
270
- "div",
271
- {
272
- style: {
273
- position: "absolute",
274
- inset: 0,
275
- background: "linear-gradient(135deg, rgba(255,255,255,0.03) 0%, transparent 50%, rgba(0,0,0,0.1) 100%)",
276
- pointerEvents: "none",
277
- zIndex: 0
278
- }
279
- }
280
- ),
281
- /* @__PURE__ */ jsx(
282
- CardHeader,
283
- {
284
- icon: "360",
285
- title: spacecraft.name ?? spacecraft.id ?? "Unknown",
286
- subtitle: orbitInfo.description,
287
- badge: spacecraft.orbitType ?? "ORBIT",
288
- badgeColor: orbitInfo.color,
289
- iconColor: orbitInfo.color,
290
- hideStatusIndicator: true
291
- }
292
- ),
293
- /* @__PURE__ */ jsx("section", { "aria-label": "Orbital parameters", children: /* @__PURE__ */ jsxs("div", { style: { display: "grid", gridTemplateColumns: "repeat(2, 1fr)", gap: tokens.spacing.md }, children: [
294
- /* @__PURE__ */ jsxs("div", { children: [
295
- /* @__PURE__ */ jsx("span", { style: labelStyle, children: "Altitude" }),
296
- /* @__PURE__ */ jsx("div", { style: { ...valueStyle, color: safeAccentText(tokens.colors.accent.primary) }, children: formatAltitude(spacecraft.altitude) })
297
- ] }),
298
- /* @__PURE__ */ jsxs("div", { children: [
299
- /* @__PURE__ */ jsx("span", { style: labelStyle, children: "Velocity" }),
300
- /* @__PURE__ */ jsx("div", { style: valueStyle, children: spacecraft.velocity ? formatVelocity(spacecraft.velocity) : computedVelocity ? formatVelocity(computedVelocity) : "-- km/s" })
301
- ] }),
302
- spacecraft.inclination !== void 0 && /* @__PURE__ */ jsxs("div", { children: [
303
- /* @__PURE__ */ jsx("span", { style: labelStyle, children: "Inclination" }),
304
- /* @__PURE__ */ jsx("div", { style: valueStyle, children: formatDegrees(spacecraft.inclination) })
305
- ] }),
306
- showComputed && computedPeriod !== null && /* @__PURE__ */ jsxs("div", { children: [
307
- /* @__PURE__ */ jsx("span", { style: labelStyle, children: "Period" }),
308
- /* @__PURE__ */ jsx("div", { style: valueStyle, children: formatDuration(computedPeriod) })
309
- ] })
310
- ] }) }),
311
- /* @__PURE__ */ jsxs(
312
- "section",
313
- {
314
- style: {
315
- marginTop: tokens.spacing.lg,
316
- paddingTop: tokens.spacing.lg,
317
- borderTop: `1px solid ${tokens.colors.border.muted}`
318
- },
319
- "aria-label": "Current position",
320
- children: [
321
- /* @__PURE__ */ jsxs(
322
- "h4",
323
- {
324
- style: {
325
- margin: `0 0 ${tokens.spacing.sm} 0`,
326
- ...labelStyle,
327
- display: "flex",
328
- alignItems: "center",
329
- gap: 4
330
- },
331
- children: [
332
- /* @__PURE__ */ jsx("svg", { width: "12", height: "12", viewBox: "0 0 24 24", fill: "currentColor", children: /* @__PURE__ */ jsx("path", { d: "M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z" }) }),
333
- "Current Position"
334
- ]
335
- }
336
- ),
337
- /* @__PURE__ */ jsxs("div", { style: { display: "grid", gridTemplateColumns: "repeat(2, 1fr)", gap: tokens.spacing.md }, children: [
338
- /* @__PURE__ */ jsxs("div", { children: [
339
- /* @__PURE__ */ jsx("span", { style: labelStyle, children: "Latitude" }),
340
- /* @__PURE__ */ jsx("div", { style: valueStyle, children: formatCoordinate(spacecraft.latitude, "lat") })
341
- ] }),
342
- /* @__PURE__ */ jsxs("div", { children: [
343
- /* @__PURE__ */ jsx("span", { style: labelStyle, children: "Longitude" }),
344
- /* @__PURE__ */ jsx("div", { style: valueStyle, children: formatCoordinate(spacecraft.longitude, "lon") })
345
- ] })
346
- ] })
347
- ]
348
- }
349
- ),
350
- spacecraft.timestamp && /* @__PURE__ */ jsx(
351
- "footer",
352
- {
353
- style: {
354
- marginTop: tokens.spacing.md,
355
- fontSize: tokens.typography.fontSize.xs,
356
- color: tokens.colors.text.tertiary,
357
- textAlign: "right"
358
- },
359
- children: /* @__PURE__ */ jsxs("time", { dateTime: spacecraft.timestamp, children: [
360
- formatTime(spacecraft.timestamp),
361
- " UTC"
362
- ] })
363
- }
364
- )
365
- ]
366
- }
367
- );
368
- });
369
- export {
370
- OrbitCard
371
- };
372
- //# sourceMappingURL=OrbitCard.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"OrbitCard.js","sources":["../../../src/react/cards/OrbitCard.tsx"],"sourcesContent":["/**\n * @zendir/ui - OrbitCard Component\n * \n * Enterprise-grade orbital parameters display card.\n * \n * AstroUXDS Compliance:\n * - Orbit type colors use Zendir-Astro data viz palette (categorical, not status)\n * - Tabular numbers for orbital data display\n * - Sentence-case labels per Tier 3 compliance\n * \n * Features:\n * - Full null-safety with graceful fallbacks\n * - WCAG 2.1 AA accessibility\n * - Computed orbital parameters (period, velocity)\n * - Orbit type classification with Zendir-branded color coding\n * - Loading and empty states\n */\n\nimport React, { memo, useMemo } from 'react';\nimport type { SpacecraftPosition } from '../types';\nimport { estimateOrbitalPeriod, estimateOrbitalVelocity } from '../types';\nimport { useTheme } from '../theme';\nimport { Icon } from '../core/Icon';\nimport { AstroIcon } from '../core/AstroIcon';\nimport { CardHeader } from '../core/CardHeader';\nimport { useCompactMode } from '../hooks';\nimport {\n formatAltitude,\n formatVelocity,\n formatDuration,\n formatCoordinate,\n formatDegrees,\n formatTime,\n classNames,\n safeAccentText,\n} from '../utils';\n\nexport interface OrbitCardProps {\n /** Spacecraft position data */\n spacecraft?: SpacecraftPosition;\n /** Show computed orbital parameters (period, velocity) */\n showComputed?: boolean;\n /** Loading state */\n loading?: boolean;\n /** Custom className */\n className?: string;\n /** Enable compact mode - shows condensed view that expands on hover/click */\n compact?: boolean;\n /** Start expanded when in compact mode (pinned state) */\n defaultExpanded?: boolean;\n /** Callback when pin state changes in compact mode */\n onPinChange?: (isPinned: boolean) => void;\n}\n\n/**\n * Orbit type information with color and description\n */\ninterface OrbitTypeInfo {\n color: string;\n description: string;\n}\n\n/**\n * Get orbit type info with Zendir-branded colors\n * Uses AstroUXDS data visualization palette for orbit classification\n */\nfunction getOrbitTypeInfo(orbitType: string | undefined): OrbitTypeInfo {\n // Orbit type colors using Zendir-Astro palette\n // Non-status colors since orbit type is categorical, not status\n const types: Record<string, OrbitTypeInfo> = {\n LEO: { color: '#3E3CFF', description: 'Low Earth Orbit (200-2,000 km)' }, // Zendir Electric\n MEO: { color: '#3548C0', description: 'Medium Earth Orbit (2,000-35,786 km)' }, // Zendir Prussian Blue Light\n GEO: { color: '#9D70FF', description: 'Geostationary Orbit (~35,786 km)' }, // Zendir Purple\n HEO: { color: '#1B2DA0', description: 'Highly Elliptical Orbit' }, // Zendir Prussian Blue\n SSO: { color: '#B48DFF', description: 'Sun-Synchronous Orbit' }, // Zendir Purple Light\n POLAR: { color: '#6B69FF', description: 'Polar Orbit' }, // Zendir Electric Light\n MOLNIYA: { color: '#C9A8FF', description: 'Molniya Orbit (12h period)' }, // Zendir Purple Lighter\n };\n\n return types[orbitType?.toUpperCase() ?? ''] ?? { color: '#a4abb6', description: 'Unknown orbit type' };\n}\n\n/**\n * OrbitCard - Displays spacecraft orbital parameters\n * \n * @example\n * ```tsx\n * <OrbitCard\n * spacecraft={spacecraftData}\n * showComputed\n * />\n * ```\n */\nexport const OrbitCard = memo(function OrbitCard({\n spacecraft,\n showComputed = true,\n loading = false,\n className = '',\n compact = false,\n defaultExpanded = false,\n onPinChange,\n}: OrbitCardProps): React.ReactElement {\n const { tokens, theme, prefersReducedMotion } = useTheme();\n const isTransparentTheme = theme === 'transparent' || theme === 'transparent-bold' || theme === 'transparent-minimal';\n const isBoldVariant = theme === 'transparent-bold';\n const isMinimalVariant = theme === 'transparent-minimal';\n const useGlassMode = isBoldVariant || isMinimalVariant;\n \n // Glass accent colors for bold/minimal themes (matching Container/AstroChart)\n const glassAccentColor = tokens.colors.accent.primary;\n const glassAccentMuted = `${glassAccentColor}66`;\n \n // Use transparent background with blur for transparent themes (matching Timeline)\n const cardBg = isTransparentTheme ? 'transparent' : tokens.colors.background.surface;\n const cardGlass = isTransparentTheme ? { \n backdropFilter: 'blur(12px)' as const, \n WebkitBackdropFilter: 'blur(12px)' as const,\n } : {};\n \n // Glass mode container style (matching Container/AstroChart for bold/minimal)\n const glassContainerStyle: React.CSSProperties = useGlassMode ? {\n backgroundColor: 'rgba(10, 15, 25, 0.35)',\n backdropFilter: 'blur(12px)',\n WebkitBackdropFilter: 'blur(12px)',\n border: `1px solid ${glassAccentMuted}`,\n borderTop: isBoldVariant ? `2px solid ${glassAccentColor}` : `1px solid ${glassAccentColor}`,\n } : {};\n\n // Compact mode state management\n const { expanded, isPinned, handlers, transitionDuration } = useCompactMode({\n compact,\n defaultExpanded,\n onPinChange,\n });\n\n // Computed orbital parameters\n const orbitInfo = useMemo(() => getOrbitTypeInfo(spacecraft?.orbitType), [spacecraft?.orbitType]);\n\n const computedPeriod = useMemo(() => {\n if (!spacecraft?.altitude) return null;\n try {\n return estimateOrbitalPeriod(spacecraft.altitude);\n } catch {\n return null;\n }\n }, [spacecraft?.altitude]);\n\n const computedVelocity = useMemo(() => {\n if (!spacecraft?.altitude) return null;\n try {\n return estimateOrbitalVelocity(spacecraft.altitude);\n } catch {\n return null;\n }\n }, [spacecraft?.altitude]);\n\n // Loading state\n if (loading) {\n return (\n <div\n className={classNames('zendir-orbit-card', 'loading', className)}\n role=\"article\"\n aria-busy=\"true\"\n aria-label=\"Loading orbit data\"\n style={{\n backgroundColor: cardBg,\n ...cardGlass,\n ...(tokens.colors.border.cardStyle ?? {}),\n borderRadius: tokens.borderRadius.lg,\n padding: tokens.spacing.md,\n minHeight: 200,\n }}\n >\n <div style={{ display: 'flex', alignItems: 'center', gap: 12, marginBottom: 20 }}>\n <div style={{ width: 40, height: 40, borderRadius: 8, backgroundColor: 'rgba(255,255,255,0.1)' }} />\n <div style={{ flex: 1 }}>\n <div style={{ height: 18, width: '50%', backgroundColor: 'rgba(255,255,255,0.1)', borderRadius: 4 }} />\n <div style={{ height: 12, width: '70%', backgroundColor: 'rgba(255,255,255,0.06)', borderRadius: 4, marginTop: 6 }} />\n </div>\n </div>\n <div style={{ display: 'grid', gridTemplateColumns: 'repeat(2, 1fr)', gap: 16 }}>\n {[1, 2, 3, 4].map((i) => (\n <div key={i}>\n <div style={{ height: 10, width: '40%', backgroundColor: 'rgba(255,255,255,0.06)', borderRadius: 2 }} />\n <div style={{ height: 20, width: '60%', backgroundColor: 'rgba(255,255,255,0.1)', borderRadius: 4, marginTop: 4 }} />\n </div>\n ))}\n </div>\n </div>\n );\n }\n\n // Empty state\n if (!spacecraft) {\n return (\n <div\n className={classNames('zendir-orbit-card', 'empty', className)}\n role=\"article\"\n aria-label=\"No orbit data\"\n style={{\n backgroundColor: cardBg,\n ...cardGlass,\n ...(tokens.colors.border.cardStyleDashed ?? {}),\n borderRadius: tokens.borderRadius.lg,\n padding: tokens.spacing.lg,\n textAlign: 'center',\n color: tokens.colors.text.tertiary,\n }}\n >\n <svg width=\"32\" height=\"32\" viewBox=\"0 0 24 24\" fill=\"currentColor\" style={{ opacity: 0.5, marginBottom: 8 }}>\n <path d=\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z\" />\n <ellipse cx=\"12\" cy=\"12\" rx=\"10\" ry=\"4\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1\" strokeDasharray=\"3,3\" />\n </svg>\n <p style={{ margin: 0, fontSize: tokens.typography.body[2].fontSize }}>No orbit data available</p>\n </div>\n );\n }\n\n // Compact view - shows key orbit info in a single row\n if (compact && !expanded) {\n return (\n <article\n className={classNames('zendir-orbit-card', 'compact', className)}\n {...handlers}\n aria-label={`Orbit: ${spacecraft.orbitType ?? 'Unknown'} (compact)`}\n style={{\n position: 'relative',\n overflow: 'hidden',\n ...(useGlassMode ? glassContainerStyle : {\n backgroundColor: cardBg,\n ...cardGlass,\n ...(tokens.colors.border.cardStyle ?? {}),\n }),\n borderRadius: tokens.borderRadius.lg,\n padding: `${tokens.spacing.sm} ${tokens.spacing.md}`,\n fontFamily: tokens.typography.fontFamily.primary,\n color: tokens.colors.text.primary,\n fontSize: tokens.typography.fontSize.sm,\n cursor: 'pointer',\n transition: `all ${transitionDuration} ease-out`,\n transform: 'scale(1)',\n }}\n onMouseEnter={(e) => {\n handlers.onMouseEnter();\n if (!prefersReducedMotion) {\n (e.currentTarget as HTMLElement).style.transform = 'scale(1.01)';\n (e.currentTarget as HTMLElement).style.boxShadow = `0 4px 12px ${orbitInfo.color}20`;\n }\n }}\n onMouseLeave={(e) => {\n handlers.onMouseLeave();\n (e.currentTarget as HTMLElement).style.transform = 'scale(1)';\n (e.currentTarget as HTMLElement).style.boxShadow = '';\n }}\n >\n {/* Glass gradient overlay for bold/minimal themes */}\n {useGlassMode && (\n <div\n style={{\n position: 'absolute',\n inset: 0,\n background: 'linear-gradient(135deg, rgba(255,255,255,0.03) 0%, transparent 50%, rgba(0,0,0,0.1) 100%)',\n pointerEvents: 'none',\n zIndex: 0,\n }}\n />\n )}\n <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between', gap: tokens.spacing.md, position: 'relative', zIndex: 1 }}>\n {/* Left side: Icon + Title + Accent line */}\n <div style={{ display: 'flex', alignItems: 'center', gap: tokens.spacing.sm, flex: 1, minWidth: 0 }}>\n <AstroIcon name=\"360\" size={16} color={orbitInfo.color} />\n <span style={{ \n fontWeight: tokens.typography.fontWeight.medium,\n color: useGlassMode ? glassAccentColor : undefined,\n textShadow: useGlassMode ? `0 0 16px ${glassAccentMuted}` : undefined,\n }}>\n Orbit\n </span>\n {useGlassMode && (\n <div style={{\n flex: 1,\n height: isBoldVariant ? '2px' : '1px',\n minWidth: 20,\n background: `linear-gradient(90deg, ${glassAccentColor} 0%, ${glassAccentMuted} 60%, transparent 100%)`,\n boxShadow: isBoldVariant ? `0 0 8px ${glassAccentMuted}` : undefined,\n }} />\n )}\n </div>\n \n {/* Right side: Orbit badge + Altitude + Pin */}\n <div style={{ display: 'flex', alignItems: 'center', gap: tokens.spacing.sm, flexShrink: 0 }}>\n <span\n style={{\n backgroundColor: `${orbitInfo.color}20`,\n color: orbitInfo.color,\n padding: `2px 6px`,\n borderRadius: tokens.borderRadius.sm,\n fontSize: tokens.typography.fontSize.xs,\n fontWeight: tokens.typography.fontWeight.medium,\n }}\n >\n {spacecraft.orbitType ?? '—'}\n </span>\n <span style={{ \n fontVariantNumeric: 'tabular-nums', \n fontFamily: tokens.typography.fontFamily.mono,\n fontSize: tokens.typography.fontSize.xs,\n }}>\n {formatAltitude(spacecraft.altitude)}\n </span>\n {isPinned && (\n <Icon name=\"lock\" size={12} color={tokens.colors.accent.primary} />\n )}\n </div>\n </div>\n </article>\n );\n }\n\n const labelStyle: React.CSSProperties = {\n color: tokens.colors.text.secondary, // WCAG AA compliant - 4.5:1 contrast\n fontSize: tokens.typography.fontSize.xs,\n fontWeight: tokens.typography.fontWeight.medium,\n };\n\n const valueStyle: React.CSSProperties = {\n color: tokens.colors.text.primary,\n fontWeight: tokens.typography.fontWeight.medium,\n fontFamily: tokens.typography.fontFamily.mono,\n fontVariantNumeric: 'tabular-nums',\n fontSize: tokens.typography.fontSize.md,\n marginTop: 2,\n };\n\n return (\n <article\n className={classNames('zendir-orbit-card', compact ? 'expanded' : '', className)}\n {...(compact ? handlers : {})}\n role={compact ? handlers.role : 'article'}\n tabIndex={compact ? handlers.tabIndex : undefined}\n aria-expanded={compact ? handlers['aria-expanded'] : undefined}\n aria-label={`Orbit data for ${spacecraft.name ?? spacecraft.id}`}\n style={{\n position: 'relative',\n overflow: 'hidden',\n ...(useGlassMode ? glassContainerStyle : {\n backgroundColor: cardBg,\n ...cardGlass,\n ...(tokens.colors.border.cardStyle ?? {}),\n }),\n borderRadius: tokens.borderRadius.lg,\n padding: tokens.spacing.md,\n fontFamily: tokens.typography.fontFamily.primary,\n cursor: compact ? 'pointer' : undefined,\n transition: compact ? `all ${transitionDuration} ease-out` : undefined,\n color: tokens.colors.text.primary,\n fontSize: tokens.typography.fontSize.sm,\n }}\n >\n {/* Glass gradient overlay for bold/minimal themes */}\n {useGlassMode && (\n <div\n style={{\n position: 'absolute',\n inset: 0,\n background: 'linear-gradient(135deg, rgba(255,255,255,0.03) 0%, transparent 50%, rgba(0,0,0,0.1) 100%)',\n pointerEvents: 'none',\n zIndex: 0,\n }}\n />\n )}\n \n {/* Unified Card Header - handles all theme variants */}\n {/* OrbitCard uses categorical colors (orbit type), not status colors */}\n <CardHeader\n icon=\"360\"\n title={spacecraft.name ?? spacecraft.id ?? 'Unknown'}\n subtitle={orbitInfo.description}\n badge={spacecraft.orbitType ?? 'ORBIT'}\n badgeColor={orbitInfo.color}\n iconColor={orbitInfo.color}\n hideStatusIndicator\n />\n\n {/* Orbital Parameters */}\n <section aria-label=\"Orbital parameters\">\n <div style={{ display: 'grid', gridTemplateColumns: 'repeat(2, 1fr)', gap: tokens.spacing.md }}>\n <div>\n <span style={labelStyle}>Altitude</span>\n <div style={{ ...valueStyle, color: safeAccentText(tokens.colors.accent.primary) }}>\n {formatAltitude(spacecraft.altitude)}\n </div>\n </div>\n <div>\n <span style={labelStyle}>Velocity</span>\n <div style={valueStyle}>\n {spacecraft.velocity\n ? formatVelocity(spacecraft.velocity)\n : computedVelocity\n ? formatVelocity(computedVelocity)\n : '-- km/s'}\n </div>\n </div>\n {spacecraft.inclination !== undefined && (\n <div>\n <span style={labelStyle}>Inclination</span>\n <div style={valueStyle}>{formatDegrees(spacecraft.inclination)}</div>\n </div>\n )}\n {showComputed && computedPeriod !== null && (\n <div>\n <span style={labelStyle}>Period</span>\n <div style={valueStyle}>{formatDuration(computedPeriod)}</div>\n </div>\n )}\n </div>\n </section>\n\n {/* Current Position */}\n <section\n style={{\n marginTop: tokens.spacing.lg,\n paddingTop: tokens.spacing.lg,\n borderTop: `1px solid ${tokens.colors.border.muted}`,\n }}\n aria-label=\"Current position\"\n >\n <h4\n style={{\n margin: `0 0 ${tokens.spacing.sm} 0`,\n ...labelStyle,\n display: 'flex',\n alignItems: 'center',\n gap: 4,\n }}\n >\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"currentColor\">\n <path d=\"M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z\" />\n </svg>\n Current Position\n </h4>\n <div style={{ display: 'grid', gridTemplateColumns: 'repeat(2, 1fr)', gap: tokens.spacing.md }}>\n <div>\n <span style={labelStyle}>Latitude</span>\n <div style={valueStyle}>{formatCoordinate(spacecraft.latitude, 'lat')}</div>\n </div>\n <div>\n <span style={labelStyle}>Longitude</span>\n <div style={valueStyle}>{formatCoordinate(spacecraft.longitude, 'lon')}</div>\n </div>\n </div>\n </section>\n\n {/* Timestamp */}\n {spacecraft.timestamp && (\n <footer\n style={{\n marginTop: tokens.spacing.md,\n fontSize: tokens.typography.fontSize.xs,\n color: tokens.colors.text.tertiary,\n textAlign: 'right',\n }}\n >\n <time dateTime={spacecraft.timestamp}>{formatTime(spacecraft.timestamp)} UTC</time>\n </footer>\n )}\n </article>\n );\n});\n"],"names":["OrbitCard"],"mappings":"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"}