@zendir/ui 0.2.21 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +183 -1
- package/README.md +70 -28
- package/dist/index.d.ts +1 -1
- package/dist/index.js +51 -42
- package/dist/index.js.map +1 -1
- package/dist/react/3d/CesiumCaptureSource.d.ts +1 -1
- package/dist/react/3d/CesiumCaptureSource.js +1 -1
- package/dist/react/3d/CesiumCaptureSource.js.map +1 -1
- package/dist/react/3d/ZenSpace3D.js +1253 -0
- package/dist/react/3d/ZenSpace3D.js.map +1 -0
- package/dist/react/3d/ZenSpace3DCesium.js +579 -0
- package/dist/react/3d/ZenSpace3DCesium.js.map +1 -0
- package/dist/react/3d/ZenSpace3DTypes.d.ts +28 -1
- package/dist/react/3d/ZenSpace3DUtils.d.ts +17 -173
- package/dist/react/3d/ZenSpace3DUtils.js +20 -1
- package/dist/react/3d/ZenSpace3DUtils.js.map +1 -1
- package/dist/react/3d/index.d.ts +6 -12
- package/dist/react/3d/threeLoader.js +18 -0
- package/dist/react/3d/threeLoader.js.map +1 -0
- package/dist/react/astro/MonitoringIcon.js +1 -1
- package/dist/react/astro/MonitoringIcon.js.map +1 -1
- package/dist/react/astro/SimulationControls.js +2 -2
- package/dist/react/astro/SimulationControls.js.map +1 -1
- package/dist/react/astro/UnifiedTimeline.js +4 -4
- package/dist/react/astro/UnifiedTimeline.js.map +1 -1
- package/dist/react/charts/GroundTrackMap.d.ts +2 -15
- package/dist/react/charts/GroundTrackMap.js +1 -1
- package/dist/react/charts/GroundTrackMap.js.map +1 -1
- package/dist/react/charts/unified/AstroChart.js +34 -13
- package/dist/react/charts/unified/AstroChart.js.map +1 -1
- package/dist/react/chatgpt/AppCard.d.ts +0 -4
- package/dist/react/chatgpt/index.d.ts +0 -19
- package/dist/react/context/SpatialSelectionContext.d.ts +40 -0
- package/dist/react/context/SpatialSelectionContext.js +10 -0
- package/dist/react/context/SpatialSelectionContext.js.map +1 -0
- package/dist/react/context/index.d.ts +2 -0
- package/dist/react/core/{DataTable.d.ts → data/DataTable.d.ts} +1 -1
- package/dist/react/core/{DataTable.js → data/DataTable.js} +4 -4
- package/dist/react/core/data/DataTable.js.map +1 -0
- package/dist/react/core/{DataValue.d.ts → data/DataValue.d.ts} +2 -2
- package/dist/react/core/{DataValue.js → data/DataValue.js} +2 -2
- package/dist/react/core/data/DataValue.js.map +1 -0
- package/dist/react/core/{propertyConfig.d.ts → data/propertyConfig.d.ts} +2 -2
- package/dist/react/core/data/propertyConfig.js.map +1 -0
- package/dist/react/core/{AstroIcon.js → display/AstroIcon.js} +1 -1
- package/dist/react/core/display/AstroIcon.js.map +1 -0
- package/dist/react/core/{Badge.d.ts → display/Badge.d.ts} +1 -1
- package/dist/react/core/{Badge.js → display/Badge.js} +2 -2
- package/dist/react/core/display/Badge.js.map +1 -0
- package/dist/react/core/{CardHeader.d.ts → display/CardHeader.d.ts} +1 -1
- package/dist/react/core/{CardHeader.js → display/CardHeader.js} +2 -2
- package/dist/react/core/display/CardHeader.js.map +1 -0
- package/dist/react/core/{Container.d.ts → display/Container.d.ts} +1 -1
- package/dist/react/core/{Container.js → display/Container.js} +3 -3
- package/dist/react/core/display/Container.js.map +1 -0
- package/dist/react/core/{CopyButton.js → display/CopyButton.js} +1 -1
- package/dist/react/core/display/CopyButton.js.map +1 -0
- package/dist/react/core/{GlassCard.d.ts → display/GlassCard.d.ts} +1 -1
- package/dist/react/core/{GlassCard.js → display/GlassCard.js} +2 -2
- package/dist/react/core/display/GlassCard.js.map +1 -0
- package/dist/react/core/{HeaderIconWithStatus.d.ts → display/HeaderIconWithStatus.d.ts} +1 -1
- package/dist/react/core/{HeaderIconWithStatus.js → display/HeaderIconWithStatus.js} +1 -1
- package/dist/react/core/display/HeaderIconWithStatus.js.map +1 -0
- package/dist/react/core/{Icon.d.ts → display/Icon.d.ts} +1 -1
- package/dist/react/core/{Icon.js → display/Icon.js} +1 -1
- package/dist/react/core/display/Icon.js.map +1 -0
- package/dist/react/core/{Typography.d.ts → display/Typography.d.ts} +13 -4
- package/dist/react/core/{Typography.js → display/Typography.js} +1 -1
- package/dist/react/core/display/Typography.js.map +1 -0
- package/dist/react/core/{ConfirmDialog.js → feedback/ConfirmDialog.js} +1 -1
- package/dist/react/core/feedback/ConfirmDialog.js.map +1 -0
- package/dist/react/core/{Dialog.js → feedback/Dialog.js} +2 -2
- package/dist/react/core/feedback/Dialog.js.map +1 -0
- package/dist/react/core/{Toast.js → feedback/Toast.js} +3 -3
- package/dist/react/core/feedback/Toast.js.map +1 -0
- package/dist/react/core/index.d.ts +85 -85
- package/dist/react/core/{Button.js → inputs/Button.js} +2 -2
- package/dist/react/core/inputs/Button.js.map +1 -0
- package/dist/react/core/{Checkbox.js → inputs/Checkbox.js} +2 -2
- package/dist/react/core/inputs/Checkbox.js.map +1 -0
- package/dist/react/core/{Input.d.ts → inputs/Input.d.ts} +1 -1
- package/dist/react/core/{Input.js → inputs/Input.js} +3 -3
- package/dist/react/core/inputs/Input.js.map +1 -0
- package/dist/react/core/{LimitsBar.js → inputs/LimitsBar.js} +1 -1
- package/dist/react/core/inputs/LimitsBar.js.map +1 -0
- package/dist/react/core/{NumberInput.d.ts → inputs/NumberInput.d.ts} +2 -2
- package/dist/react/core/{NumberInput.js → inputs/NumberInput.js} +3 -3
- package/dist/react/core/inputs/NumberInput.js.map +1 -0
- package/dist/react/core/{PinInput.js → inputs/PinInput.js} +2 -2
- package/dist/react/core/inputs/PinInput.js.map +1 -0
- package/dist/react/core/{Select.js → inputs/Select.js} +3 -3
- package/dist/react/core/inputs/Select.js.map +1 -0
- package/dist/react/core/{Toggle.js → inputs/Toggle.js} +2 -2
- package/dist/react/core/inputs/Toggle.js.map +1 -0
- package/dist/react/core/{AppBar.d.ts → navigation/AppBar.d.ts} +1 -1
- package/dist/react/core/{AppBar.js → navigation/AppBar.js} +7 -7
- package/dist/react/core/navigation/AppBar.js.map +1 -0
- package/dist/react/core/{Pagination.js → navigation/Pagination.js} +2 -2
- package/dist/react/core/navigation/Pagination.js.map +1 -0
- package/dist/react/core/{SideNav.d.ts → navigation/SideNav.d.ts} +1 -1
- package/dist/react/core/{SideNav.js → navigation/SideNav.js} +3 -3
- package/dist/react/core/navigation/SideNav.js.map +1 -0
- package/dist/react/core/{Tabs.js → navigation/Tabs.js} +2 -2
- package/dist/react/core/navigation/Tabs.js.map +1 -0
- package/dist/react/core/{Popover.js → overlays/Popover.js} +1 -1
- package/dist/react/core/overlays/Popover.js.map +1 -0
- package/dist/react/core/{SidePanel.js → overlays/SidePanel.js} +3 -3
- package/dist/react/core/overlays/SidePanel.js.map +1 -0
- package/dist/react/core/{Tooltip.js → overlays/Tooltip.js} +2 -2
- package/dist/react/core/overlays/Tooltip.js.map +1 -0
- package/dist/react/core/{ActivityPlanner.js → widgets/ActivityPlanner.js} +1 -1
- package/dist/react/core/widgets/ActivityPlanner.js.map +1 -0
- package/dist/react/core/{Capture.js → widgets/Capture.js} +3 -3
- package/dist/react/core/widgets/Capture.js.map +1 -0
- package/dist/react/core/{ChatPanel.d.ts → widgets/ChatPanel.d.ts} +1 -1
- package/dist/react/core/{ChatPanel.js → widgets/ChatPanel.js} +2 -2
- package/dist/react/core/widgets/ChatPanel.js.map +1 -0
- package/dist/react/core/{ColorPickerPanel.d.ts → widgets/ColorPickerPanel.d.ts} +1 -1
- package/dist/react/core/{ColorPickerPanel.js → widgets/ColorPickerPanel.js} +3 -3
- package/dist/react/core/widgets/ColorPickerPanel.js.map +1 -0
- package/dist/react/core/{CommandBuilder.js → widgets/CommandBuilder.js} +1 -1
- package/dist/react/core/widgets/CommandBuilder.js.map +1 -0
- package/dist/react/core/{ConnectionForm.d.ts → widgets/ConnectionForm.d.ts} +1 -1
- package/dist/react/core/{ConnectionForm.js → widgets/ConnectionForm.js} +2 -2
- package/dist/react/core/widgets/ConnectionForm.js.map +1 -0
- package/dist/react/core/{FileExplorer.js → widgets/FileExplorer.js} +2 -2
- package/dist/react/core/widgets/FileExplorer.js.map +1 -0
- package/dist/react/core/{HexViewer.js → widgets/HexViewer.js} +1 -1
- package/dist/react/core/widgets/HexViewer.js.map +1 -0
- package/dist/react/core/{ImageGallery.d.ts → widgets/ImageGallery.d.ts} +1 -1
- package/dist/react/core/{ImageGallery.js → widgets/ImageGallery.js} +3 -3
- package/dist/react/core/widgets/ImageGallery.js.map +1 -0
- package/dist/react/core/{LogViewer.d.ts → widgets/LogViewer.d.ts} +13 -3
- package/dist/react/core/{LogViewer.js → widgets/LogViewer.js} +28 -8
- package/dist/react/core/widgets/LogViewer.js.map +1 -0
- package/dist/react/core/{MessageStream.d.ts → widgets/MessageStream.d.ts} +2 -2
- package/dist/react/core/{MessageStream.js → widgets/MessageStream.js} +4 -4
- package/dist/react/core/widgets/MessageStream.js.map +1 -0
- package/dist/react/core/{MissionCalendar.js → widgets/MissionCalendar.js} +2 -2
- package/dist/react/core/widgets/MissionCalendar.js.map +1 -0
- package/dist/react/core/{PacketViewer.js → widgets/PacketViewer.js} +1 -1
- package/dist/react/core/widgets/PacketViewer.js.map +1 -0
- package/dist/react/core/widgets/capture-placeholder.png.js.map +1 -0
- package/dist/react/hooks/index.d.ts +9 -11
- package/dist/react/hooks/useAccessWindows.d.ts +15 -19
- package/dist/react/hooks/useGroundTrackHistory.d.ts +34 -0
- package/dist/react/hooks/useSimulationScene.d.ts +141 -0
- package/dist/react/hooks/useSimulationScene.js +401 -0
- package/dist/react/hooks/useSimulationScene.js.map +1 -0
- package/dist/react/hooks/useZendirSession.d.ts +44 -69
- package/dist/react/index.d.ts +7 -3
- package/dist/react/panels/LayerControlPanel.d.ts +54 -0
- package/dist/react/panels/LayerControlPanel.js +184 -0
- package/dist/react/panels/LayerControlPanel.js.map +1 -0
- package/dist/react/panels/ObjectInventoryPanel.d.ts +57 -0
- package/dist/react/panels/ObjectInventoryPanel.js +261 -0
- package/dist/react/panels/ObjectInventoryPanel.js.map +1 -0
- package/dist/react/panels/index.d.ts +15 -0
- package/dist/react/theme/ThemeProvider.d.ts +2 -0
- package/dist/react/theme/ThemeProvider.js +50 -72
- package/dist/react/theme/ThemeProvider.js.map +1 -1
- package/dist/react/types.d.ts +32 -3
- package/dist/react/types.js.map +1 -1
- package/dist/react.js +51 -42
- package/dist/react.js.map +1 -1
- package/dist/shaders/atmosphere.frag.js +5 -0
- package/dist/shaders/atmosphere.frag.js.map +1 -0
- package/dist/shaders/atmosphere.vert.js +5 -0
- package/dist/shaders/atmosphere.vert.js.map +1 -0
- package/dist/shaders/stars.frag.js +5 -0
- package/dist/shaders/stars.frag.js.map +1 -0
- package/dist/shaders/stars.vert.js +5 -0
- package/dist/shaders/stars.vert.js.map +1 -0
- package/dist/style.css +6 -4
- package/dist/tokens/css-vars.d.ts +91 -0
- package/dist/tokens/css-vars.js +228 -0
- package/dist/tokens/css-vars.js.map +1 -0
- package/dist/tokens/index.d.ts +71 -18
- package/dist/tokens/index.js +206 -97
- package/dist/tokens/index.js.map +1 -1
- package/dist/tokens/tokens.css +50 -50
- package/package.json +26 -22
- package/sdk-stub.js +10 -5
- package/dist/react/3d/EarthViewer.d.ts +0 -46
- package/dist/react/3d/SolarSystemViewer.d.ts +0 -43
- package/dist/react/chatgpt/ChatGPTCard.d.ts +0 -6
- package/dist/react/core/ActivityPlanner.js.map +0 -1
- package/dist/react/core/AppBar.js.map +0 -1
- package/dist/react/core/AstroIcon.js.map +0 -1
- package/dist/react/core/Badge.js.map +0 -1
- package/dist/react/core/Button.js.map +0 -1
- package/dist/react/core/Capture.js.map +0 -1
- package/dist/react/core/CardHeader.js.map +0 -1
- package/dist/react/core/ChatPanel.js.map +0 -1
- package/dist/react/core/Checkbox.js.map +0 -1
- package/dist/react/core/ColorPickerPanel.js.map +0 -1
- package/dist/react/core/CommandBuilder.js.map +0 -1
- package/dist/react/core/ConfirmDialog.js.map +0 -1
- package/dist/react/core/ConnectionForm.js.map +0 -1
- package/dist/react/core/Container.js.map +0 -1
- package/dist/react/core/CopyButton.js.map +0 -1
- package/dist/react/core/DataTable.js.map +0 -1
- package/dist/react/core/DataValue.js.map +0 -1
- package/dist/react/core/Dialog.js.map +0 -1
- package/dist/react/core/FileExplorer.js.map +0 -1
- package/dist/react/core/GlassCard.js.map +0 -1
- package/dist/react/core/HeaderIconWithStatus.js.map +0 -1
- package/dist/react/core/HexViewer.js.map +0 -1
- package/dist/react/core/Icon.js.map +0 -1
- package/dist/react/core/ImageGallery.js.map +0 -1
- package/dist/react/core/Input.js.map +0 -1
- package/dist/react/core/LimitsBar.js.map +0 -1
- package/dist/react/core/LogViewer.js.map +0 -1
- package/dist/react/core/MessageStream.js.map +0 -1
- package/dist/react/core/MissionCalendar.js.map +0 -1
- package/dist/react/core/NumberInput.js.map +0 -1
- package/dist/react/core/PacketViewer.js.map +0 -1
- package/dist/react/core/Pagination.js.map +0 -1
- package/dist/react/core/PinInput.js.map +0 -1
- package/dist/react/core/Popover.js.map +0 -1
- package/dist/react/core/Select.js.map +0 -1
- package/dist/react/core/SideNav.js.map +0 -1
- package/dist/react/core/SidePanel.js.map +0 -1
- package/dist/react/core/Tabs.js.map +0 -1
- package/dist/react/core/Toast.js.map +0 -1
- package/dist/react/core/Toggle.js.map +0 -1
- package/dist/react/core/Tooltip.js.map +0 -1
- package/dist/react/core/Typography.js.map +0 -1
- package/dist/react/core/capture-placeholder.png.js.map +0 -1
- package/dist/react/core/propertyConfig.js.map +0 -1
- package/dist/react/hooks/useSimulationTime.d.ts +0 -61
- package/dist/react/hooks/useSpacecraftPosition.d.ts +0 -50
- package/dist/react/hooks/useTelemetry.d.ts +0 -55
- package/dist/types.d.ts +0 -1
- package/dist/types.js +0 -2
- package/dist/types.js.map +0 -1
- /package/dist/react/core/{propertyConfig.js → data/propertyConfig.js} +0 -0
- /package/dist/react/core/{AstroIcon.d.ts → display/AstroIcon.d.ts} +0 -0
- /package/dist/react/core/{CopyButton.d.ts → display/CopyButton.d.ts} +0 -0
- /package/dist/react/core/{ConfirmDialog.d.ts → feedback/ConfirmDialog.d.ts} +0 -0
- /package/dist/react/core/{Dialog.d.ts → feedback/Dialog.d.ts} +0 -0
- /package/dist/react/core/{Toast.d.ts → feedback/Toast.d.ts} +0 -0
- /package/dist/react/core/{Button.d.ts → inputs/Button.d.ts} +0 -0
- /package/dist/react/core/{Checkbox.d.ts → inputs/Checkbox.d.ts} +0 -0
- /package/dist/react/core/{LimitsBar.d.ts → inputs/LimitsBar.d.ts} +0 -0
- /package/dist/react/core/{PinInput.d.ts → inputs/PinInput.d.ts} +0 -0
- /package/dist/react/core/{Select.d.ts → inputs/Select.d.ts} +0 -0
- /package/dist/react/core/{Toggle.d.ts → inputs/Toggle.d.ts} +0 -0
- /package/dist/react/core/{Pagination.d.ts → navigation/Pagination.d.ts} +0 -0
- /package/dist/react/core/{Tabs.d.ts → navigation/Tabs.d.ts} +0 -0
- /package/dist/react/core/{Popover.d.ts → overlays/Popover.d.ts} +0 -0
- /package/dist/react/core/{SidePanel.d.ts → overlays/SidePanel.d.ts} +0 -0
- /package/dist/react/core/{Tooltip.d.ts → overlays/Tooltip.d.ts} +0 -0
- /package/dist/react/core/{ActivityPlanner.d.ts → widgets/ActivityPlanner.d.ts} +0 -0
- /package/dist/react/core/{Capture.d.ts → widgets/Capture.d.ts} +0 -0
- /package/dist/react/core/{CommandBuilder.d.ts → widgets/CommandBuilder.d.ts} +0 -0
- /package/dist/react/core/{FileExplorer.d.ts → widgets/FileExplorer.d.ts} +0 -0
- /package/dist/react/core/{HexViewer.d.ts → widgets/HexViewer.d.ts} +0 -0
- /package/dist/react/core/{MissionCalendar.d.ts → widgets/MissionCalendar.d.ts} +0 -0
- /package/dist/react/core/{PacketViewer.d.ts → widgets/PacketViewer.d.ts} +0 -0
- /package/dist/react/core/{capture-placeholder.png.js → widgets/capture-placeholder.png.js} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MissionCalendar.js","sources":["../../../../src/react/core/widgets/MissionCalendar.tsx"],"sourcesContent":["/**\n * @zendir/ui - MissionCalendar Component\n * \n * Full-featured calendar for mission planning and scheduling with 5 views:\n * Month, Week (time-grid), Day (time-grid), Gantt, and List.\n * \n * Includes a mini calendar sidebar for quick date navigation, timeline\n * and event type filtering, right-click to create at time slots, week\n * number display, and DOY (Day of Year) in the header.\n * \n * Features (matching/exceeding OpenC3 Calendar):\n * - Day / Week / Month / Gantt / List views\n * - Time-grid with 30-min rows for Week and Day views\n * - Mini calendar sidebar with event type + timeline filters\n * - Activity scheduling with command/script/reserve execution types\n * - Metadata recording (key-value pairs, start time only)\n * - Notes with start + end time\n * - Status-colored events per Astro UX (circle, square, triangle down)\n * - Activity lifecycle (created, started, completed, paused, stopped, error, etc.)\n * - Multi-timeline support (overlapping prevention per timeline)\n * - Right-click context menu to create events at specific time slots\n * - Week number + DOY display\n * - Contact window / eclipse / pass event types (beyond OpenC3)\n * - weekStartsMonday option (Sunday-Saturday or Monday-Sunday)\n * - Integration with Timeline component via onDayDrillDown\n * \n * @example\n * ```tsx\n * <MissionCalendar\n * events={missionEvents}\n * timelines={[{ id: 'ops', name: 'OPS-1', color: '#2dccff' }]}\n * onEventCreate={(e) => console.log('New event:', e)}\n * onEventClick={(e) => console.log('Clicked:', e)}\n * />\n * ```\n */\n\nimport React, { useState, useMemo, useCallback, memo, useRef } from 'react';\nimport { useTheme } from '../../theme';\nimport { AstroIcon, type AstroIconName } from '../display/AstroIcon';\n\n// =============================================================================\n// Types\n// =============================================================================\n\nexport type CalendarViewMode = 'month' | 'week' | 'day' | 'gantt' | 'list';\n\nexport type ActivityStatus =\n | 'created' | 'scheduled' | 'started' | 'completed'\n | 'paused' | 'stopped' | 'disabled'\n | 'error' | 'failed' | 'crashed';\n\nexport type ActivityType = 'command' | 'script' | 'reserve' | 'metadata' | 'note' | 'contact' | 'eclipse' | 'pass';\n\nexport interface CalendarEvent {\n /** Unique identifier */\n id: string;\n /** Event title */\n title: string;\n /** Start time */\n start: Date;\n /** End time (optional for metadata/point events) */\n end?: Date;\n /** Activity type */\n type: ActivityType;\n /** Execution status */\n status?: ActivityStatus;\n /** Timeline this event belongs to */\n timeline?: string;\n /** Description / notes */\n description?: string;\n /** Command string (for command type) */\n command?: string;\n /** Script path (for script type) */\n script?: string;\n /** Metadata key-value pairs */\n metadata?: Record<string, string | number | boolean>;\n /** Whether this event is recurring */\n recurring?: boolean;\n /** Recurrence pattern */\n recurrenceRule?: string;\n /** Color override */\n color?: string;\n /** Whether the event is editable */\n editable?: boolean;\n}\n\nexport interface CalendarTimeline {\n /** Unique timeline ID */\n id: string;\n /** Display name */\n name: string;\n /** Color for this timeline */\n color?: string;\n /** Whether the timeline is active */\n active?: boolean;\n}\n\nexport interface MissionCalendarProps {\n /** Calendar events */\n events: CalendarEvent[];\n /** Available timelines */\n timelines?: CalendarTimeline[];\n /** Initial view mode (default: 'month') */\n defaultView?: CalendarViewMode;\n /** Initial date to display */\n initialDate?: Date;\n /** Height (default: 600) */\n height?: number | string;\n /** Title */\n title?: string;\n /** Show mini calendar sidebar (default: true) */\n showSidebar?: boolean;\n /** Show timeline selector (default: true) */\n showTimelines?: boolean;\n /** Show event type filter (default: true) */\n showFilters?: boolean;\n /** Show create button (default: true) */\n showCreate?: boolean;\n /** Week starts on Monday (default: true for ops) */\n weekStartsMonday?: boolean;\n /** Called when an event is clicked */\n onEventClick?: (event: CalendarEvent) => void;\n /** Called when creating a new event */\n onEventCreate?: (event: Partial<CalendarEvent>) => void;\n /** Called when navigating to a day (e.g., to open Timeline Gantt view) */\n onDayDrillDown?: (date: Date, events: CalendarEvent[]) => void;\n /** CSS class */\n className?: string;\n}\n\n// =============================================================================\n// Helpers\n// =============================================================================\n\nfunction getStatusColor(status: ActivityStatus | undefined, tokens: ReturnType<typeof useTheme>['tokens']): string {\n if (!status) return tokens.colors.text.muted ?? tokens.colors.text.secondary;\n switch (status) {\n case 'created': case 'scheduled': return tokens.colors.status.standby;\n case 'started': return tokens.colors.status.normal;\n case 'completed': return tokens.colors.status.normal;\n case 'paused': case 'stopped': case 'disabled': return tokens.colors.status.caution;\n case 'error': case 'failed': case 'crashed': return tokens.colors.status.critical;\n }\n}\n\n/**\n * Return Astro UX status shape per status level.\n * off → small dot, standby → ring ◯, normal → filled circle ●,\n * caution → square ■, serious → diamond ◆, critical → triangle down ▼\n */\nfunction getStatusShape(status: ActivityStatus | undefined): string {\n if (!status) return '●';\n switch (status) {\n case 'created': case 'scheduled': return '◯';\n case 'started': case 'completed': return '●';\n case 'paused': case 'stopped': case 'disabled': return '■';\n case 'error': case 'failed': case 'crashed': return '▼';\n }\n}\n\nconst TYPE_ICON_ASTRO: ActivityType[] = ['contact', 'eclipse', 'pass'];\n\nfunction getTypeIcon(type: ActivityType): string {\n switch (type) {\n case 'command': return '⌘';\n case 'script': return '▶';\n case 'reserve': return '▒';\n case 'metadata': return '◆';\n case 'note': return '✎';\n case 'contact': return 'antenna';\n case 'eclipse': return 'brightness-2';\n case 'pass': return 'satellite';\n }\n}\n\nfunction getDaysInMonth(year: number, month: number): number {\n return new Date(year, month + 1, 0).getDate();\n}\n\nfunction getFirstDayOfMonth(year: number, month: number, mondayStart: boolean): number {\n const day = new Date(year, month, 1).getDay();\n if (mondayStart) return day === 0 ? 6 : day - 1;\n return day;\n}\n\nfunction isSameDay(a: Date, b: Date): boolean {\n return a.getFullYear() === b.getFullYear() && a.getMonth() === b.getMonth() && a.getDate() === b.getDate();\n}\n\nfunction formatTime(d: Date): string {\n return d.toLocaleTimeString('en-US', { hour12: false, hour: '2-digit', minute: '2-digit' });\n}\n\nfunction getWeekDates(date: Date, mondayStart: boolean): Date[] {\n const d = new Date(date);\n const day = d.getDay();\n const diff = mondayStart ? (day === 0 ? -6 : 1 - day) : -day;\n const start = new Date(d);\n start.setDate(start.getDate() + diff);\n return Array.from({ length: 7 }, (_, i) => {\n const dt = new Date(start);\n dt.setDate(dt.getDate() + i);\n return dt;\n });\n}\n\n/** ISO week number */\nfunction getWeekNumber(d: Date): number {\n const date = new Date(d.getTime());\n date.setHours(0, 0, 0, 0);\n date.setDate(date.getDate() + 3 - ((date.getDay() + 6) % 7));\n const week1 = new Date(date.getFullYear(), 0, 4);\n return 1 + Math.round(((date.getTime() - week1.getTime()) / 86400000 - 3 + ((week1.getDay() + 6) % 7)) / 7);\n}\n\n/** Day of year (1-366) */\nfunction getDayOfYear(d: Date): number {\n const start = new Date(d.getFullYear(), 0, 0);\n const diff = d.getTime() - start.getTime();\n return Math.floor(diff / 86400000);\n}\n\n/** 30-minute time slots for the time-grid views */\nconst TIME_SLOTS: string[] = [];\nfor (let h = 0; h < 24; h++) {\n TIME_SLOTS.push(`${String(h).padStart(2, '0')}:00`);\n TIME_SLOTS.push(`${String(h).padStart(2, '0')}:30`);\n}\n\n// Row height for time-grid slots (px)\nconst SLOT_HEIGHT = 28;\n\n// =============================================================================\n// Sub-components\n// =============================================================================\n\nconst CalendarEventChip = memo(function CalendarEventChip({\n event, tokens, compact, onClick,\n}: {\n event: CalendarEvent;\n tokens: ReturnType<typeof useTheme>['tokens'];\n compact?: boolean;\n onClick?: () => void;\n}) {\n const color = event.color || getStatusColor(event.status, tokens);\n return (\n <div\n onClick={e => { e.stopPropagation(); onClick?.(); }}\n title={`${event.title}\\n${formatTime(event.start)}${event.end ? ' – ' + formatTime(event.end) : ''}\\n${event.description || ''}`}\n style={{\n background: `${color}22`,\n color: tokens.colors.text.primary,\n padding: compact ? '1px 4px' : '2px 6px',\n borderRadius: tokens.borderRadius.sm,\n fontSize: compact ? tokens.typography.fontSize.micro : tokens.typography.fontSize.xxs,\n lineHeight: compact ? '14px' : '16px',\n cursor: 'pointer',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n display: 'flex',\n alignItems: 'center',\n gap: 3,\n transition: 'background 150ms ease',\n marginBottom: 1,\n }}\n >\n <span style={{ fontSize: tokens.typography.fontSize.micro, opacity: 0.7 }}>\n {TYPE_ICON_ASTRO.includes(event.type) ? (\n <AstroIcon name={getTypeIcon(event.type) as AstroIconName} size=\"extra-small\" label=\"\" />\n ) : (\n getTypeIcon(event.type)\n )}\n </span>\n {!compact && <span style={{ color, fontSize: tokens.typography.fontSize.micro }}>{getStatusShape(event.status)}</span>}\n <span style={{ overflow: 'hidden', textOverflow: 'ellipsis' }}>{event.title}</span>\n </div>\n );\n});\n\n/** Mini calendar for sidebar */\nconst MiniCalendar = memo(function MiniCalendar({\n currentDate, tokens, weekStartsMonday, onDateSelect, getEventsForDay,\n}: {\n currentDate: Date;\n tokens: ReturnType<typeof useTheme>['tokens'];\n weekStartsMonday: boolean;\n onDateSelect: (d: Date) => void;\n getEventsForDay: (d: Date) => CalendarEvent[];\n}) {\n const [miniDate, setMiniDate] = useState(new Date(currentDate));\n const year = miniDate.getFullYear();\n const month = miniDate.getMonth();\n const today = new Date();\n\n const dayLabels = weekStartsMonday\n ? ['M', 'T', 'W', 'T', 'F', 'S', 'S']\n : ['S', 'M', 'T', 'W', 'T', 'F', 'S'];\n\n const grid = useMemo(() => {\n const firstDay = getFirstDayOfMonth(year, month, weekStartsMonday);\n const daysInMonth = getDaysInMonth(year, month);\n const daysInPrevMonth = getDaysInMonth(year, month === 0 ? 11 : month - 1);\n const cells: { date: Date; isCurrentMonth: boolean }[] = [];\n for (let i = firstDay - 1; i >= 0; i--) {\n cells.push({ date: new Date(year, month - 1, daysInPrevMonth - i), isCurrentMonth: false });\n }\n for (let i = 1; i <= daysInMonth; i++) {\n cells.push({ date: new Date(year, month, i), isCurrentMonth: true });\n }\n while (cells.length < 42) {\n cells.push({ date: new Date(year, month + 1, cells.length - firstDay - daysInMonth + 1), isCurrentMonth: false });\n }\n return cells;\n }, [year, month, weekStartsMonday]);\n\n return (\n <div>\n <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between', marginBottom: 6 }}>\n <button onClick={() => setMiniDate(new Date(year, month - 1))} style={{ background: 'none', border: 'none', color: tokens.colors.text.muted, cursor: 'pointer', fontSize: 12, padding: '2px 6px' }}>◀</button>\n <span style={{ fontWeight: 500, fontSize: 11 }}>\n {miniDate.toLocaleDateString('en-US', { month: 'short', year: 'numeric' })}\n </span>\n <button onClick={() => setMiniDate(new Date(year, month + 1))} style={{ background: 'none', border: 'none', color: tokens.colors.text.muted, cursor: 'pointer', fontSize: 12, padding: '2px 6px' }}>▶</button>\n </div>\n <div style={{ display: 'grid', gridTemplateColumns: 'repeat(7, 1fr)', gap: 0 }}>\n {dayLabels.map((d, i) => (\n <div key={i} style={{ textAlign: 'center', fontSize: 9, color: tokens.colors.text.muted, fontWeight: 500, padding: '2px 0' }}>{d}</div>\n ))}\n {grid.map(({ date, isCurrentMonth }, idx) => {\n const isToday = isSameDay(date, today);\n const isSelected = isSameDay(date, currentDate);\n const hasEvents = getEventsForDay(date).length > 0;\n return (\n <div\n key={idx}\n onClick={() => onDateSelect(date)}\n style={{\n textAlign: 'center', fontSize: 10, padding: '3px 0', cursor: 'pointer',\n color: isSelected ? tokens.colors.text.inverse : isCurrentMonth ? tokens.colors.text.primary : tokens.colors.text.muted + '55',\n fontWeight: isToday || isSelected ? 700 : 400,\n background: isSelected ? tokens.colors.interactive.default : isToday ? `${tokens.colors.interactive.default}20` : 'transparent',\n borderRadius: isSelected || isToday ? tokens.borderRadius.full : 0,\n position: 'relative',\n }}\n >\n {date.getDate()}\n {hasEvents && !isSelected && (\n <span style={{\n position: 'absolute', bottom: 0, left: '50%', transform: 'translateX(-50%)',\n width: 3, height: 3, borderRadius: '50%',\n background: tokens.colors.interactive.default,\n }} />\n )}\n </div>\n );\n })}\n </div>\n </div>\n );\n});\n\n// =============================================================================\n// Main Component\n// =============================================================================\n\nexport const MissionCalendar = memo(function MissionCalendar({\n events,\n timelines = [],\n defaultView = 'month',\n initialDate,\n height = 600,\n title,\n showSidebar = true,\n showTimelines = true,\n showFilters = true,\n showCreate = true,\n weekStartsMonday = true,\n onEventClick,\n onEventCreate,\n onDayDrillDown,\n className = '',\n}: MissionCalendarProps): React.ReactElement {\n const { tokens, theme } = useTheme();\n const isTransparentTheme =\n theme === 'transparent' || theme === 'transparent-bold' || theme === 'transparent-minimal';\n const [viewMode, setViewMode] = useState<CalendarViewMode>(defaultView);\n const [currentDate, setCurrentDate] = useState(initialDate || new Date());\n const [selectedTimelines, setSelectedTimelines] = useState<Set<string>>(\n new Set(timelines.map(t => t.id))\n );\n const [typeFilter, setTypeFilter] = useState<Set<ActivityType>>(\n new Set(['command', 'script', 'reserve', 'metadata', 'note', 'contact', 'eclipse', 'pass'])\n );\n const [contextMenu, setContextMenu] = useState<{ x: number; y: number; date: Date } | null>(null);\n const bodyRef = useRef<HTMLDivElement>(null);\n\n const year = currentDate.getFullYear();\n const month = currentDate.getMonth();\n\n // Filter events\n const filteredEvents = useMemo(() =>\n events.filter(e =>\n typeFilter.has(e.type) &&\n (selectedTimelines.size === 0 || !e.timeline || selectedTimelines.has(e.timeline))\n ),\n [events, typeFilter, selectedTimelines]);\n\n // Events by day\n const eventsByDay = useMemo(() => {\n const map = new Map<string, CalendarEvent[]>();\n filteredEvents.forEach(e => {\n const key = `${e.start.getFullYear()}-${e.start.getMonth()}-${e.start.getDate()}`;\n if (!map.has(key)) map.set(key, []);\n map.get(key)!.push(e);\n if (e.end) {\n const days = Math.ceil((e.end.getTime() - e.start.getTime()) / 86400000);\n for (let d = 1; d <= days && d < 30; d++) {\n const next = new Date(e.start);\n next.setDate(next.getDate() + d);\n const nk = `${next.getFullYear()}-${next.getMonth()}-${next.getDate()}`;\n if (!map.has(nk)) map.set(nk, []);\n map.get(nk)!.push(e);\n }\n }\n });\n return map;\n }, [filteredEvents]);\n\n const getEventsForDay = useCallback((d: Date) => {\n const key = `${d.getFullYear()}-${d.getMonth()}-${d.getDate()}`;\n return eventsByDay.get(key) || [];\n }, [eventsByDay]);\n\n // Navigation\n const navigate = useCallback((dir: -1 | 0 | 1) => {\n if (dir === 0) { setCurrentDate(new Date()); return; }\n const d = new Date(currentDate);\n if (viewMode === 'month') d.setMonth(d.getMonth() + dir);\n else if (viewMode === 'week' || viewMode === 'gantt') d.setDate(d.getDate() + dir * 7);\n else d.setDate(d.getDate() + dir);\n setCurrentDate(d);\n }, [currentDate, viewMode]);\n\n const toggleTimeline = useCallback((id: string) => {\n setSelectedTimelines(prev => {\n const next = new Set(prev);\n if (next.has(id)) next.delete(id); else next.add(id);\n return next;\n });\n }, []);\n\n const toggleType = useCallback((type: ActivityType) => {\n setTypeFilter(prev => {\n const next = new Set(prev);\n if (next.has(type)) next.delete(type); else next.add(type);\n return next;\n });\n }, []);\n\n const dayNames = weekStartsMonday\n ? ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']\n : ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'];\n\n const monthLabel = currentDate.toLocaleDateString('en-US', { month: 'long', year: 'numeric' });\n const today = new Date();\n const weekNum = getWeekNumber(currentDate);\n const doy = getDayOfYear(currentDate);\n\n // Month view grid\n const monthGrid = useMemo(() => {\n const firstDay = getFirstDayOfMonth(year, month, weekStartsMonday);\n const daysInMonth = getDaysInMonth(year, month);\n const daysInPrevMonth = getDaysInMonth(year, month === 0 ? 11 : month - 1);\n const cells: { date: Date; isCurrentMonth: boolean }[] = [];\n for (let i = firstDay - 1; i >= 0; i--) {\n cells.push({ date: new Date(year, month - 1, daysInPrevMonth - i), isCurrentMonth: false });\n }\n for (let i = 1; i <= daysInMonth; i++) {\n cells.push({ date: new Date(year, month, i), isCurrentMonth: true });\n }\n while (cells.length < 42) {\n cells.push({ date: new Date(year, month + 1, cells.length - firstDay - daysInMonth + 1), isCurrentMonth: false });\n }\n return cells;\n }, [year, month, weekStartsMonday]);\n\n // Week view dates\n const weekDates = useMemo(() => getWeekDates(currentDate, weekStartsMonday), [currentDate, weekStartsMonday]);\n\n // Day events sorted by time\n const dayEvents = useMemo(() => {\n const evts = getEventsForDay(currentDate);\n return [...evts].sort((a, b) => a.start.getTime() - b.start.getTime());\n }, [currentDate, getEventsForDay]);\n\n // List view\n const listEvents = useMemo(() => {\n const now = new Date();\n const end = new Date(now);\n end.setDate(end.getDate() + 7);\n return filteredEvents\n .filter(e => e.start >= now && e.start <= end)\n .sort((a, b) => a.start.getTime() - b.start.getTime());\n }, [filteredEvents]);\n\n // Gantt: events in the selected week, grouped by timeline\n const ganttData = useMemo(() => {\n const weekStart = new Date(weekDates[0]);\n weekStart.setHours(0, 0, 0, 0);\n const weekEnd = new Date(weekDates[6]);\n weekEnd.setHours(23, 59, 59, 999);\n const weekEvents = filteredEvents.filter(e =>\n e.start <= weekEnd && (e.end || e.start) >= weekStart\n );\n const tlMap = new Map<string, CalendarEvent[]>();\n const noTl: CalendarEvent[] = [];\n weekEvents.forEach(e => {\n const tlId = e.timeline || '';\n if (!tlId) { noTl.push(e); return; }\n if (!tlMap.has(tlId)) tlMap.set(tlId, []);\n tlMap.get(tlId)!.push(e);\n });\n const rows: { label: string; color: string; events: CalendarEvent[] }[] = [];\n timelines.forEach(tl => {\n if (tlMap.has(tl.id)) {\n rows.push({ label: tl.name, color: tl.color || tokens.colors.interactive.default, events: tlMap.get(tl.id)! });\n }\n });\n if (noTl.length > 0) rows.push({ label: 'Unassigned', color: tokens.colors.text.muted ?? tokens.colors.text.secondary, events: noTl });\n return { rows, weekStart, weekEnd };\n }, [filteredEvents, weekDates, timelines, tokens]);\n\n // Right-click handler for time-grid\n const handleContextMenu = useCallback((e: React.MouseEvent, date: Date, slotTime?: string) => {\n e.preventDefault();\n if (!onEventCreate) return;\n const d = new Date(date);\n if (slotTime) {\n const [h, m] = slotTime.split(':').map(Number);\n d.setHours(h, m, 0, 0);\n }\n setContextMenu({ x: e.clientX, y: e.clientY, date: d });\n }, [onEventCreate]);\n\n // Header text\n const headerLabel = useMemo(() => {\n if (viewMode === 'month') return monthLabel;\n if (viewMode === 'week' || viewMode === 'gantt') {\n return `${weekDates[0].toLocaleDateString('en-US', { month: 'short', day: 'numeric' })} – ${weekDates[6].toLocaleDateString('en-US', { month: 'short', day: 'numeric', year: 'numeric' })} Week ${weekNum}`;\n }\n return currentDate.toLocaleDateString('en-US', { weekday: 'long', month: 'long', day: 'numeric', year: 'numeric' });\n }, [viewMode, monthLabel, weekDates, weekNum, currentDate]);\n\n // Sidebar content\n const renderSidebar = () => (\n <div style={{\n width: 190, minWidth: 190, borderRight: `1px solid ${tokens.colors.border.muted}`,\n background: tokens.colors.background.surface, padding: '8px 10px',\n display: 'flex', flexDirection: 'column', gap: 12, overflow: 'auto',\n }}>\n <MiniCalendar\n currentDate={currentDate}\n tokens={tokens}\n weekStartsMonday={weekStartsMonday}\n onDateSelect={(d) => { setCurrentDate(d); if (viewMode === 'month') setViewMode('day'); }}\n getEventsForDay={getEventsForDay}\n />\n\n {/* Event type filters */}\n {showFilters && (\n <div>\n <div style={{ fontSize: 10, fontWeight: 500, color: tokens.colors.text.muted, textTransform: 'uppercase', letterSpacing: 0.5, marginBottom: 4 }}>\n Event Types\n </div>\n {(['command', 'script', 'reserve', 'metadata', 'note', 'contact'] as ActivityType[]).map(type => (\n <label key={type} style={{\n display: 'flex', alignItems: 'center', gap: 6, padding: '2px 0', cursor: 'pointer', fontSize: 11,\n color: typeFilter.has(type) ? tokens.colors.text.primary : tokens.colors.text.muted + '66',\n }}>\n <input\n type=\"checkbox\"\n checked={typeFilter.has(type)}\n onChange={() => toggleType(type)}\n style={{ accentColor: tokens.colors.interactive.default, width: 12, height: 12 }}\n />\n {TYPE_ICON_ASTRO.includes(type) ? (\n <AstroIcon name={getTypeIcon(type) as AstroIconName} size=\"extra-small\" label=\"\" style={{ opacity: 0.7 }} />\n ) : (\n <span style={{ opacity: 0.7, fontSize: 10 }}>{getTypeIcon(type)}</span>\n )}\n <span style={{ textTransform: 'capitalize' }}>{type}</span>\n </label>\n ))}\n </div>\n )}\n\n {/* Timeline filters */}\n {showTimelines && timelines.length > 0 && (\n <div>\n <div style={{ fontSize: 10, fontWeight: 500, color: tokens.colors.text.muted, textTransform: 'uppercase', letterSpacing: 0.5, marginBottom: 4 }}>\n Timelines\n </div>\n {timelines.map(tl => (\n <label key={tl.id} style={{\n display: 'flex', alignItems: 'center', gap: 6, padding: '3px 0', cursor: 'pointer', fontSize: 11,\n color: selectedTimelines.has(tl.id) ? tokens.colors.text.primary : tokens.colors.text.muted + '66',\n }}>\n <input\n type=\"checkbox\"\n checked={selectedTimelines.has(tl.id)}\n onChange={() => toggleTimeline(tl.id)}\n style={{ accentColor: tl.color || tokens.colors.interactive.default, width: 12, height: 12 }}\n />\n <span style={{ width: 8, height: 8, borderRadius: '50%', background: tl.color || tokens.colors.interactive.default, flexShrink: 0 }} />\n <span>{tl.name}</span>\n </label>\n ))}\n </div>\n )}\n\n {/* Quick info */}\n <div style={{\n marginTop: 'auto', fontSize: 10, color: tokens.colors.text.muted,\n borderTop: `1px solid ${tokens.colors.border.muted}`, paddingTop: 8,\n }}>\n <div>DOY: <span style={{ fontFamily: tokens.typography.fontFamily.mono, color: tokens.colors.text.secondary }}>{doy}</span></div>\n <div>Week: <span style={{ fontFamily: tokens.typography.fontFamily.mono, color: tokens.colors.text.secondary }}>{weekNum}</span></div>\n <div>UTC: <span style={{ fontFamily: tokens.typography.fontFamily.mono, color: tokens.colors.text.secondary }}>{today.toISOString().slice(11, 19)}</span></div>\n </div>\n </div>\n );\n\n return (\n <div\n className={`mission-calendar ${className}`}\n onClick={() => setContextMenu(null)}\n style={{\n height: typeof height === 'number' ? height : undefined,\n background: tokens.colors.background.base,\n ...(tokens.colors.border.cardStyle ?? { border: `1px solid ${tokens.colors.border.muted}` }),\n borderRadius: tokens.borderRadius.lg,\n overflow: 'hidden',\n display: 'flex',\n flexDirection: 'column',\n fontFamily: tokens.typography.fontFamily.primary,\n color: tokens.colors.text.primary,\n backdropFilter: isTransparentTheme ? 'blur(10px)' : undefined,\n WebkitBackdropFilter: isTransparentTheme ? 'blur(10px)' : undefined,\n }}\n >\n {/* Header */}\n <div style={{\n padding: '8px 14px',\n borderBottom: `1px solid ${tokens.colors.border.muted}`,\n background: tokens.colors.background.surface,\n backdropFilter: 'blur(8px)',\n display: 'flex', alignItems: 'center', justifyContent: 'space-between',\n flexWrap: 'wrap', gap: 8,\n }}>\n <div style={{ display: 'flex', alignItems: 'center', gap: 10 }}>\n {title && <span style={{ fontWeight: 500, fontSize: tokens.typography.fontSize.sm }}>{title}</span>}\n <div style={{ display: 'flex', gap: 2 }}>\n <button onClick={() => navigate(-1)} style={navBtnStyle(tokens)}>◀</button>\n <button onClick={() => navigate(0)} style={{ ...navBtnStyle(tokens), padding: '3px 10px', fontSize: tokens.typography.fontSize.xs }}>Today</button>\n <button onClick={() => navigate(1)} style={navBtnStyle(tokens)}>▶</button>\n </div>\n <span style={{ fontWeight: 500, fontSize: tokens.typography.fontSize.sm }}>\n {headerLabel}\n </span>\n {/* DOY badge */}\n <span style={{\n fontSize: 9, fontFamily: tokens.typography.fontFamily.mono, color: tokens.colors.text.muted,\n background: `${tokens.colors.text.muted}15`, padding: '1px 6px', borderRadius: tokens.borderRadius.sm,\n }}>\n DOY {doy}\n </span>\n </div>\n <div style={{ display: 'flex', alignItems: 'center', gap: 6 }}>\n {showCreate && (\n <button\n onClick={() => onEventCreate?.({ start: currentDate, type: 'reserve' })}\n style={{\n background: tokens.colors.interactive.default,\n color: tokens.colors.text.inverse, border: 'none', borderRadius: tokens.borderRadius.md,\n padding: '4px 12px', fontSize: tokens.typography.fontSize.xs, fontWeight: 500, cursor: 'pointer',\n }}\n >\n + Activity\n </button>\n )}\n <div style={{\n display: 'flex', borderRadius: tokens.borderRadius.md, overflow: 'hidden',\n border: `1px solid ${tokens.colors.border.muted}`,\n }}>\n {(['month', 'week', 'day', 'gantt', 'list'] as CalendarViewMode[]).map(v => (\n <button\n key={v}\n onClick={() => setViewMode(v)}\n style={{\n background: viewMode === v ? tokens.colors.interactive.default : tokens.colors.background.base,\n color: viewMode === v ? tokens.colors.text.inverse : tokens.colors.text.secondary,\n border: 'none', padding: '3px 10px', fontSize: tokens.typography.fontSize.xxs,\n fontWeight: 500, cursor: 'pointer', textTransform: 'capitalize',\n }}\n >\n {v}\n </button>\n ))}\n </div>\n </div>\n </div>\n\n {/* Body: sidebar + calendar area */}\n <div style={{ flex: 1, display: 'flex', overflow: 'hidden' }}>\n {/* Sidebar */}\n {showSidebar && renderSidebar()}\n\n {/* Main calendar content */}\n <div ref={bodyRef} style={{ flex: 1, overflow: 'auto' }}>\n {/* MONTH VIEW */}\n {viewMode === 'month' && (\n <div style={{ display: 'flex', flexDirection: 'column', height: '100%' }}>\n <div style={{\n display: 'grid', gridTemplateColumns: 'repeat(7, 1fr)',\n borderBottom: `1px solid ${tokens.colors.border.muted}`,\n background: tokens.colors.background.surface,\n }}>\n {dayNames.map(d => (\n <div key={d} style={{\n padding: '4px 6px', textAlign: 'center', fontSize: tokens.typography.fontSize.xxs,\n fontWeight: 500, color: tokens.colors.text.muted, textTransform: 'uppercase',\n }}>{d}</div>\n ))}\n </div>\n <div style={{\n display: 'grid', gridTemplateColumns: 'repeat(7, 1fr)',\n gridTemplateRows: 'repeat(6, 1fr)', flex: 1,\n }}>\n {monthGrid.map(({ date, isCurrentMonth }, idx) => {\n const dayEvts = getEventsForDay(date);\n const isToday = isSameDay(date, today);\n return (\n <div\n key={idx}\n onClick={() => {\n setCurrentDate(date);\n if (onDayDrillDown) onDayDrillDown(date, dayEvts);\n else setViewMode('day');\n }}\n onContextMenu={(e) => handleContextMenu(e, date)}\n style={{\n borderRight: `1px solid ${tokens.colors.border.muted}11`,\n borderBottom: `1px solid ${tokens.colors.border.muted}11`,\n padding: 3, cursor: 'pointer',\n background: isToday ? `${tokens.colors.interactive.default}08` : 'transparent',\n opacity: isCurrentMonth ? 1 : 0.35,\n overflow: 'hidden', minHeight: 70,\n }}\n >\n <div style={{\n fontSize: tokens.typography.fontSize.xs, fontWeight: isToday ? 700 : 400,\n color: isToday ? tokens.colors.interactive.default : tokens.colors.text.primary,\n marginBottom: 2, textAlign: 'right', paddingRight: 2,\n }}>\n {isToday ? (\n <span style={{\n background: tokens.colors.interactive.default,\n color: tokens.colors.text.inverse, borderRadius: tokens.borderRadius.full,\n width: 20, height: 20, display: 'inline-flex',\n alignItems: 'center', justifyContent: 'center', fontSize: tokens.typography.fontSize.xxs,\n }}>{date.getDate()}</span>\n ) : date.getDate()}\n </div>\n {dayEvts.slice(0, 3).map(e => (\n <CalendarEventChip key={e.id} event={e} tokens={tokens} compact onClick={() => onEventClick?.(e)} />\n ))}\n {dayEvts.length > 3 && (\n <div style={{ fontSize: tokens.typography.fontSize.micro, color: tokens.colors.text.muted, textAlign: 'center' }}>\n +{dayEvts.length - 3} more\n </div>\n )}\n </div>\n );\n })}\n </div>\n </div>\n )}\n\n {/* WEEK VIEW — Time-grid with 30-minute rows */}\n {viewMode === 'week' && (\n <div style={{ display: 'flex', flexDirection: 'column', height: '100%' }}>\n {/* Day column headers */}\n <div style={{\n display: 'grid', gridTemplateColumns: `50px repeat(7, 1fr)`,\n borderBottom: `1px solid ${tokens.colors.border.muted}`,\n background: tokens.colors.background.surface, position: 'sticky', top: 0, zIndex: 2,\n }}>\n <div style={{ borderRight: `1px solid ${tokens.colors.border.muted}22` }} />\n {weekDates.map((d, i) => {\n const isToday = isSameDay(d, today);\n return (\n <div key={i} style={{\n padding: '4px 4px', textAlign: 'center',\n background: isToday ? `${tokens.colors.interactive.default}10` : 'transparent',\n borderRight: `1px solid ${tokens.colors.border.muted}11`,\n }}>\n <div style={{ fontSize: 9, color: tokens.colors.text.muted, textTransform: 'uppercase' }}>{dayNames[i]}</div>\n <div style={{\n fontSize: 16, fontWeight: isToday ? 700 : 400,\n color: isToday ? tokens.colors.interactive.default : tokens.colors.text.primary,\n }}>\n {isToday ? (\n <span style={{\n background: tokens.colors.interactive.default, color: tokens.colors.text.inverse,\n borderRadius: tokens.borderRadius.full, width: 24, height: 24, display: 'inline-flex',\n alignItems: 'center', justifyContent: 'center', fontSize: 13,\n }}>{d.getDate()}</span>\n ) : d.getDate()}\n </div>\n </div>\n );\n })}\n </div>\n {/* Time-grid rows */}\n <div style={{ flex: 1, overflow: 'auto' }}>\n {TIME_SLOTS.map((slot, _si) => {\n const isHour = slot.endsWith(':00');\n return (\n <div key={slot} style={{\n display: 'grid', gridTemplateColumns: `50px repeat(7, 1fr)`,\n height: SLOT_HEIGHT,\n borderBottom: `1px solid ${tokens.colors.border.muted}${isHour ? '22' : '0A'}`,\n }}>\n {/* Time label */}\n <div style={{\n fontSize: 9, color: tokens.colors.text.muted, textAlign: 'right', paddingRight: 6,\n fontFamily: tokens.typography.fontFamily.mono,\n borderRight: `1px solid ${tokens.colors.border.muted}22`,\n lineHeight: `${SLOT_HEIGHT}px`,\n visibility: isHour ? 'visible' : 'hidden',\n }}>\n {slot}\n </div>\n {/* Day columns */}\n {weekDates.map((d, di) => {\n const slotStart = new Date(d); slotStart.setHours(parseInt(slot), slot.endsWith(':30') ? 30 : 0, 0, 0);\n const slotEvents = getEventsForDay(d).filter(e => {\n const eStart = e.start.getHours() * 60 + e.start.getMinutes();\n const sStart = parseInt(slot) * 60 + (slot.endsWith(':30') ? 30 : 0);\n return eStart >= sStart && eStart < sStart + 30;\n });\n return (\n <div\n key={di}\n onClick={() => { setCurrentDate(d); setViewMode('day'); }}\n onContextMenu={(e) => handleContextMenu(e, d, slot)}\n style={{\n borderRight: `1px solid ${tokens.colors.border.muted}0A`,\n padding: '0 2px', cursor: 'pointer', overflow: 'hidden',\n background: isSameDay(d, today) ? `${tokens.colors.interactive.default}04` : 'transparent',\n }}\n >\n {slotEvents.map(e => (\n <CalendarEventChip key={e.id} event={e} tokens={tokens} compact onClick={() => onEventClick?.(e)} />\n ))}\n </div>\n );\n })}\n </div>\n );\n })}\n </div>\n </div>\n )}\n\n {/* DAY VIEW — Time-grid with 30-minute rows */}\n {viewMode === 'day' && (\n <div style={{ display: 'flex', flexDirection: 'column', height: '100%' }}>\n <div style={{ flex: 1, overflow: 'auto' }}>\n {TIME_SLOTS.map((slot) => {\n const isHour = slot.endsWith(':00');\n const slotEvents = dayEvents.filter(e => {\n const eStart = e.start.getHours() * 60 + e.start.getMinutes();\n const sStart = parseInt(slot) * 60 + (slot.endsWith(':30') ? 30 : 0);\n return eStart >= sStart && eStart < sStart + 30;\n });\n return (\n <div\n key={slot}\n onContextMenu={(e) => handleContextMenu(e, currentDate, slot)}\n style={{\n display: 'grid', gridTemplateColumns: '50px 1fr',\n minHeight: slotEvents.length > 0 ? Math.max(SLOT_HEIGHT, slotEvents.length * 24 + 4) : SLOT_HEIGHT,\n borderBottom: `1px solid ${tokens.colors.border.muted}${isHour ? '22' : '0A'}`,\n }}\n >\n <div style={{\n fontSize: 10, color: tokens.colors.text.muted, textAlign: 'right', paddingRight: 8,\n fontFamily: tokens.typography.fontFamily.mono,\n borderRight: `1px solid ${tokens.colors.border.muted}22`,\n lineHeight: `${SLOT_HEIGHT}px`,\n visibility: isHour ? 'visible' : 'hidden',\n }}>\n {slot}\n </div>\n <div style={{ padding: '1px 6px', cursor: 'pointer' }}>\n {slotEvents.map(e => {\n const color = e.color || getStatusColor(e.status, tokens);\n return (\n <div\n key={e.id}\n onClick={() => onEventClick?.(e)}\n style={{\n background: `${color}18`,\n borderRadius: tokens.borderRadius.sm, padding: '3px 8px', marginBottom: 2,\n cursor: 'pointer', display: 'flex', alignItems: 'center', gap: 6,\n fontSize: tokens.typography.fontSize.xxs,\n }}\n >\n {TYPE_ICON_ASTRO.includes(e.type) ? (\n <AstroIcon name={getTypeIcon(e.type) as AstroIconName} size=\"extra-small\" label=\"\" style={{ opacity: 0.7 }} />\n ) : (\n <span style={{ opacity: 0.7 }}>{getTypeIcon(e.type)}</span>\n )}\n <span style={{ color, fontSize: tokens.typography.fontSize.micro }}>{getStatusShape(e.status)}</span>\n <span style={{ fontWeight: 500 }}>{e.title}</span>\n <span style={{ color: tokens.colors.text.muted, fontFamily: tokens.typography.fontFamily.mono, fontSize: tokens.typography.fontSize.micro, marginLeft: 'auto' }}>\n {formatTime(e.start)}{e.end ? `–${formatTime(e.end)}` : ''}\n </span>\n {e.status && (\n <span style={{ fontSize: tokens.typography.fontSize.micro, color, fontWeight: 500, textTransform: 'uppercase' }}>\n {e.status}\n </span>\n )}\n </div>\n );\n })}\n </div>\n </div>\n );\n })}\n </div>\n </div>\n )}\n\n {/* GANTT VIEW — Timeline rows with horizontal bars */}\n {viewMode === 'gantt' && (\n <div style={{ display: 'flex', flexDirection: 'column', height: '100%' }}>\n {/* Day headers */}\n <div style={{\n display: 'grid', gridTemplateColumns: `120px repeat(7, 1fr)`,\n borderBottom: `1px solid ${tokens.colors.border.muted}`,\n background: tokens.colors.background.surface, position: 'sticky', top: 0, zIndex: 2,\n }}>\n <div style={{ padding: '6px 8px', fontSize: 10, fontWeight: 500, color: tokens.colors.text.muted, borderRight: `1px solid ${tokens.colors.border.muted}22` }}>\n Timeline\n </div>\n {weekDates.map((d, i) => {\n const isToday = isSameDay(d, today);\n return (\n <div key={i} style={{\n padding: '4px 4px', textAlign: 'center',\n background: isToday ? `${tokens.colors.interactive.default}10` : 'transparent',\n borderRight: `1px solid ${tokens.colors.border.muted}11`,\n fontSize: 10,\n }}>\n <span style={{ color: tokens.colors.text.muted }}>{dayNames[i]} </span>\n <span style={{ fontWeight: isToday ? 700 : 400, color: isToday ? tokens.colors.interactive.default : tokens.colors.text.primary }}>\n {d.getDate()}\n </span>\n </div>\n );\n })}\n </div>\n {/* Gantt rows */}\n <div style={{ flex: 1, overflow: 'auto' }}>\n {ganttData.rows.length === 0 ? (\n <div style={{ textAlign: 'center', color: tokens.colors.text.muted, padding: 40, fontSize: 12 }}>\n No activities this week\n </div>\n ) : ganttData.rows.map((row, ri) => (\n <div key={ri} style={{\n display: 'grid', gridTemplateColumns: `120px repeat(7, 1fr)`,\n borderBottom: `1px solid ${tokens.colors.border.muted}15`,\n minHeight: 36,\n }}>\n {/* Timeline label */}\n <div style={{\n padding: '6px 8px', fontSize: 11, fontWeight: 500,\n borderRight: `1px solid ${tokens.colors.border.muted}22`,\n display: 'flex', alignItems: 'center', gap: 6,\n color: tokens.colors.text.primary,\n }}>\n <span style={{ width: 6, height: 6, borderRadius: '50%', background: row.color, flexShrink: 0 }} />\n {row.label}\n </div>\n {/* Day cells with event bars */}\n {weekDates.map((d, di) => {\n const cellEvents = row.events.filter(e => {\n const eDay = new Date(e.start); eDay.setHours(0, 0, 0, 0);\n const cellDay = new Date(d); cellDay.setHours(0, 0, 0, 0);\n if (e.end) {\n const eEnd = new Date(e.end); eEnd.setHours(23, 59, 59, 999);\n return cellDay >= eDay && cellDay <= eEnd;\n }\n return eDay.getTime() === cellDay.getTime();\n });\n return (\n <div\n key={di}\n onContextMenu={(e) => handleContextMenu(e, d)}\n style={{\n borderRight: `1px solid ${tokens.colors.border.muted}0A`,\n padding: '2px 2px', display: 'flex', flexDirection: 'column', gap: 2,\n background: isSameDay(d, today) ? `${tokens.colors.interactive.default}04` : 'transparent',\n }}\n >\n {cellEvents.map(e => {\n const color = e.color || getStatusColor(e.status, tokens);\n return (\n <div\n key={e.id}\n onClick={() => onEventClick?.(e)}\n style={{\n background: `${color}33`,\n borderRadius: 3, padding: '2px 4px',\n fontSize: 9, fontWeight: 500,\n color: tokens.colors.text.primary,\n cursor: 'pointer',\n whiteSpace: 'nowrap', overflow: 'hidden', textOverflow: 'ellipsis',\n }}\n title={`${e.title}\\n${formatTime(e.start)}${e.end ? ' – ' + formatTime(e.end) : ''}`}\n >\n <span style={{ opacity: 0.7, marginRight: 3 }}>{getStatusShape(e.status)}</span>\n {e.title}\n </div>\n );\n })}\n </div>\n );\n })}\n </div>\n ))}\n </div>\n </div>\n )}\n\n {/* LIST VIEW */}\n {viewMode === 'list' && (\n <div style={{ padding: 12 }}>\n <div style={{ fontSize: tokens.typography.fontSize.xs, color: tokens.colors.text.muted, marginBottom: 8 }}>\n Upcoming 7 days — {listEvents.length} activities\n </div>\n {listEvents.length === 0 ? (\n <div style={{ textAlign: 'center', color: tokens.colors.text.muted, padding: 40, fontSize: tokens.typography.fontSize.sm }}>\n No upcoming activities\n </div>\n ) : (\n <div style={{ display: 'flex', flexDirection: 'column', gap: 4 }}>\n {listEvents.map(e => {\n const color = e.color || getStatusColor(e.status, tokens);\n return (\n <div\n key={e.id}\n onClick={() => onEventClick?.(e)}\n style={{\n display: 'grid', gridTemplateColumns: '100px 1fr auto',\n padding: '6px 10px', borderRadius: tokens.borderRadius.md,\n background: `${color}08`,\n cursor: 'pointer', alignItems: 'center', gap: 10,\n fontSize: tokens.typography.fontSize.xs,\n }}\n >\n <span style={{ fontFamily: tokens.typography.fontFamily.mono, fontSize: tokens.typography.fontSize.xxs, color: tokens.colors.text.muted }}>\n {e.start.toLocaleDateString('en-US', { month: 'short', day: 'numeric' })} {formatTime(e.start)}\n </span>\n <span style={{ display: 'flex', alignItems: 'center', gap: 6 }}>\n {TYPE_ICON_ASTRO.includes(e.type) ? (\n <AstroIcon name={getTypeIcon(e.type) as AstroIconName} size=\"extra-small\" label=\"\" />\n ) : (\n <span>{getTypeIcon(e.type)}</span>\n )}\n <span style={{ fontWeight: 500 }}>{e.title}</span>\n </span>\n {e.status && (\n <span style={{ fontSize: tokens.typography.fontSize.micro, color, fontWeight: 500 }}>\n {getStatusShape(e.status)} {e.status}\n </span>\n )}\n </div>\n );\n })}\n </div>\n )}\n </div>\n )}\n </div>\n </div>\n\n {/* Footer status */}\n <div style={{\n padding: '4px 14px',\n borderTop: `1px solid ${tokens.colors.border.muted}`,\n background: tokens.colors.background.surface,\n fontSize: tokens.typography.fontSize.xxs, color: tokens.colors.text.muted,\n display: 'flex', justifyContent: 'space-between',\n }}>\n <span>{filteredEvents.length} activities | DOY {doy} | Week {weekNum}</span>\n <span>\n {events.filter(e => e.status === 'error' || e.status === 'failed' || e.status === 'crashed').length > 0\n ? `⚠ ${events.filter(e => e.status === 'error' || e.status === 'failed' || e.status === 'crashed').length} errors`\n : '✓ All nominal'}\n </span>\n </div>\n\n {/* Right-click context menu */}\n {contextMenu && (\n <div\n style={{\n position: 'fixed', left: contextMenu.x, top: contextMenu.y, zIndex: 1000,\n background: tokens.colors.background.surface, backdropFilter: 'blur(8px)',\n border: `1px solid ${tokens.colors.border.muted}`, borderRadius: tokens.borderRadius.md,\n boxShadow: '0 4px 16px rgba(0,0,0,0.4)', padding: 4, minWidth: 160,\n }}\n >\n <div style={{ fontSize: 9, color: tokens.colors.text.muted, padding: '4px 8px', fontFamily: tokens.typography.fontFamily.mono }}>\n {contextMenu.date.toLocaleDateString('en-US', { month: 'short', day: 'numeric' })} {formatTime(contextMenu.date)}\n </div>\n {(['command', 'script', 'reserve', 'metadata', 'note'] as ActivityType[]).map(type => (\n <button\n key={type}\n onClick={() => { onEventCreate?.({ start: contextMenu.date, type }); setContextMenu(null); }}\n style={{\n display: 'block', width: '100%', textAlign: 'left', background: 'none', border: 'none',\n color: tokens.colors.text.primary, padding: '5px 8px', fontSize: 11, cursor: 'pointer',\n borderRadius: tokens.borderRadius.sm,\n }}\n onMouseEnter={e => { (e.currentTarget as HTMLButtonElement).style.background = `${tokens.colors.interactive.default}22`; }}\n onMouseLeave={e => { (e.currentTarget as HTMLButtonElement).style.background = 'none'; }}\n >\n {getTypeIcon(type)} Create {type.charAt(0).toUpperCase() + type.slice(1)}\n </button>\n ))}\n </div>\n )}\n </div>\n );\n});\n\nfunction navBtnStyle(tokens: ReturnType<typeof useTheme>['tokens']): React.CSSProperties {\n return {\n background: tokens.colors.background.base,\n color: tokens.colors.text.secondary,\n border: `1px solid ${tokens.colors.border.muted}`,\n borderRadius: tokens.borderRadius.sm, padding: '3px 8px', fontSize: tokens.typography.fontSize.xs, cursor: 'pointer',\n lineHeight: 1,\n };\n}\n\nexport default MissionCalendar;\n"],"names":["CalendarEventChip","MiniCalendar","MissionCalendar"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { jsxs, jsx, Fragment } from "react/jsx-runtime";
|
|
2
2
|
import React, { memo, useState, useMemo, useCallback } from "react";
|
|
3
|
-
import { useTheme } from "
|
|
3
|
+
import { useTheme } from "../../theme/ThemeProvider.js";
|
|
4
4
|
function getLimitsColor(state, tokens) {
|
|
5
5
|
switch (state) {
|
|
6
6
|
case "RED":
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PacketViewer.js","sources":["../../../../src/react/core/widgets/PacketViewer.tsx"],"sourcesContent":["/**\n * @zendir/ui - PacketViewer Component\n * \n * Live telemetry packet viewer for spacecraft data analysis and monitoring.\n * Displays telemetry items with limits coloring, raw/converted/formatted views,\n * item details, and search filtering.\n * \n * Features:\n * - Table of telemetry items with name, value, limits status\n * - Limits coloring (blue, green, yellow, red) on values\n * - View modes: raw, converted, formatted, with-units\n * - Item search/filter\n * - Item details on click (type, conversion, limits, description)\n * - Stale data detection\n * - Configurable refresh rate display\n * - Compact mode for high-density displays\n * \n * @example\n * ```tsx\n * <PacketViewer\n * target=\"INST\"\n * packet=\"HEALTH_STATUS\"\n * items={[\n * { name: 'TEMP1', value: 72.5, limits: { state: 'GREEN', redLow: 0, yellowLow: 20, greenLow: 40, greenHigh: 80, yellowHigh: 90, redHigh: 100 } },\n * { name: 'VOLTAGE', value: 28.1, units: 'V' },\n * ]}\n * />\n * ```\n */\n\nimport React, { useState, useMemo, useCallback, memo } from 'react';\nimport { useTheme } from '../../theme';\n\n// =============================================================================\n// Types\n// =============================================================================\n\nexport type PacketItemLimitsState = 'BLUE' | 'GREEN' | 'YELLOW' | 'YELLOW_LOW' | 'YELLOW_HIGH' | 'RED' | 'RED_LOW' | 'RED_HIGH' | 'STALE' | null;\nexport type PacketViewMode = 'raw' | 'converted' | 'formatted' | 'with_units';\n\nexport interface PacketItemLimits {\n state: PacketItemLimitsState;\n redLow?: number;\n yellowLow?: number;\n greenLow?: number;\n greenHigh?: number;\n yellowHigh?: number;\n redHigh?: number;\n}\n\nexport interface PacketItem {\n /** Item name (e.g., TEMP1, VOLTAGE) */\n name: string;\n /** Raw value */\n value: number | string | boolean;\n /** Converted value (after read conversion) */\n convertedValue?: number | string;\n /** Formatted value (with format string applied) */\n formattedValue?: string;\n /** Units string */\n units?: string;\n /** Limits definition and current state */\n limits?: PacketItemLimits;\n /** Item description */\n description?: string;\n /** Data type (e.g., UINT, INT, FLOAT, STRING, BLOCK, DERIVED) */\n dataType?: string;\n /** Bit size */\n bitSize?: number;\n /** Bit offset */\n bitOffset?: number;\n /** Whether this is a derived item */\n derived?: boolean;\n /** Conversion applied */\n conversion?: string;\n /** States map (for state items) */\n states?: Record<string, number | string>;\n /** Whether value is stale */\n stale?: boolean;\n}\n\nexport interface PacketViewerProps {\n /** Target name */\n target?: string;\n /** Packet name */\n packet?: string;\n /** Array of packet items */\n items: PacketItem[];\n /** View mode (default: 'converted') */\n viewMode?: PacketViewMode;\n /** Height (default: 500) */\n height?: number | string;\n /** Show derived items last (default: true) */\n derivedLast?: boolean;\n /** Show search bar (default: true) */\n showSearch?: boolean;\n /** Show view mode selector (default: true) */\n showViewMode?: boolean;\n /** Compact mode */\n compact?: boolean;\n /** Called when an item is clicked */\n onItemClick?: (item: PacketItem) => void;\n /** CSS class */\n className?: string;\n /** Show outer container border (default: true). Set false when embedded inside a Container/card. */\n bordered?: boolean;\n /** Custom style overrides for the outer container */\n style?: React.CSSProperties;\n}\n\n// =============================================================================\n// Helpers\n// =============================================================================\n\nfunction getLimitsColor(state: PacketItemLimitsState, tokens: ReturnType<typeof useTheme>['tokens']): string {\n switch (state) {\n case 'RED': case 'RED_LOW': case 'RED_HIGH': return tokens.colors.status.critical;\n case 'YELLOW': case 'YELLOW_LOW': case 'YELLOW_HIGH': return tokens.colors.status.caution;\n case 'GREEN': return tokens.colors.status.normal;\n case 'BLUE': return tokens.colors.status.standby;\n case 'STALE': return tokens.colors.status.off;\n default: return tokens.colors.text.primary;\n }\n}\n\nfunction getLimitsBg(state: PacketItemLimitsState, tokens: ReturnType<typeof useTheme>['tokens']): string {\n const color = getLimitsColor(state, tokens);\n return state ? `${color}18` : 'transparent';\n}\n\n/**\n * Return Astro UX-compliant status shape style for a limits state.\n * Maps packet limits levels to the canonical Astro status shapes:\n * BLUE/STALE → off (small circle), GREEN → normal (filled circle),\n * YELLOW → caution (square), RED → critical (triangle down via clip-path)\n */\nfunction getLimitsShapeStyle(state: PacketItemLimitsState, color: string): React.CSSProperties {\n const base: React.CSSProperties = {\n width: 8, height: 8, display: 'inline-block',\n background: color, boxShadow: `0 0 4px ${color}66`,\n };\n switch (state) {\n case 'GREEN':\n return { ...base, borderRadius: '50%' }; // normal → circle\n case 'YELLOW': case 'YELLOW_LOW': case 'YELLOW_HIGH':\n return { ...base, borderRadius: '1px' }; // caution → square\n case 'RED': case 'RED_LOW': case 'RED_HIGH':\n return { ...base, borderRadius: 0, // critical → triangle down\n clipPath: 'polygon(50% 100%, 0% 0%, 100% 0%)' };\n case 'BLUE':\n return { ...base, borderRadius: '50%', width: 6, height: 6, // standby → hollow ring\n background: 'transparent', border: `2px solid ${color}`, boxShadow: 'none' };\n case 'STALE':\n return { ...base, borderRadius: '50%', width: 5, height: 5, // off → small dot\n opacity: 0.6 };\n default:\n return { ...base, borderRadius: '50%' };\n }\n}\n\nfunction getDisplayValue(item: PacketItem, mode: PacketViewMode): string {\n switch (mode) {\n case 'raw': return String(item.value);\n case 'converted': return String(item.convertedValue ?? item.value);\n case 'formatted': return item.formattedValue ?? String(item.convertedValue ?? item.value);\n case 'with_units': {\n const val = item.formattedValue ?? String(item.convertedValue ?? item.value);\n return item.units ? `${val} ${item.units}` : val;\n }\n }\n}\n\n// =============================================================================\n// Component\n// =============================================================================\n\nexport const PacketViewer = memo(function PacketViewer({\n target,\n packet,\n items,\n viewMode: initialViewMode = 'converted',\n height = 500,\n derivedLast = true,\n showSearch = true,\n showViewMode = true,\n compact = false,\n onItemClick,\n className = '',\n bordered = true,\n style: styleProp,\n}: PacketViewerProps): React.ReactElement {\n const { tokens, theme } = useTheme();\n const isTransparentTheme =\n theme === 'transparent' || theme === 'transparent-bold' || theme === 'transparent-minimal';\n const [searchQuery, setSearchQuery] = useState('');\n const [viewMode, setViewMode] = useState(initialViewMode);\n const [selectedItem, setSelectedItem] = useState<PacketItem | null>(null);\n const [showDetails, setShowDetails] = useState(false);\n const [scrollTop, setScrollTop] = useState(0);\n const [viewportHeight, setViewportHeight] = useState(240);\n const listRef = React.useRef<HTMLDivElement>(null);\n\n const sortedItems = useMemo(() => {\n let filtered = items;\n if (searchQuery.trim()) {\n const q = searchQuery.toLowerCase();\n filtered = items.filter(i => i.name.toLowerCase().includes(q) || (i.description && i.description.toLowerCase().includes(q)));\n }\n if (derivedLast) {\n const regular = filtered.filter(i => !i.derived);\n const derived = filtered.filter(i => i.derived);\n return [...regular, ...derived];\n }\n return filtered;\n }, [items, searchQuery, derivedLast]);\n\n const handleItemClick = useCallback((item: PacketItem) => {\n setSelectedItem(item);\n setShowDetails(true);\n onItemClick?.(item);\n }, [onItemClick]);\n\n const rowHeight = compact ? 26 : 32;\n const overscanRows = 12;\n const totalRows = sortedItems.length;\n const startRow = Math.max(0, Math.floor(scrollTop / rowHeight) - overscanRows);\n const visibleRows = Math.ceil(viewportHeight / rowHeight) + overscanRows * 2;\n const endRow = Math.min(totalRows, startRow + visibleRows);\n const visibleItems = useMemo(\n () => sortedItems.slice(startRow, endRow),\n [sortedItems, startRow, endRow],\n );\n\n React.useEffect(() => {\n const el = listRef.current;\n if (!el) return undefined;\n\n const updateHeight = () => setViewportHeight(Math.max(rowHeight * 4, el.clientHeight || 240));\n updateHeight();\n\n if (typeof ResizeObserver !== 'undefined') {\n const observer = new ResizeObserver(updateHeight);\n observer.observe(el);\n return () => observer.disconnect();\n }\n\n window.addEventListener('resize', updateHeight);\n return () => window.removeEventListener('resize', updateHeight);\n }, [rowHeight]);\n\n return (\n <div\n className={`packet-viewer ${className}`}\n style={{\n height: typeof height === 'number' ? height : undefined,\n background: tokens.colors.background.base,\n ...(bordered ? (tokens.colors.border.cardStyle ?? { border: `1px solid ${tokens.colors.border.muted}` }) : { border: 'none' }),\n borderRadius: tokens.borderRadius.lg,\n overflow: 'hidden',\n display: 'flex',\n flexDirection: 'column',\n fontFamily: tokens.typography.fontFamily.primary,\n color: tokens.colors.text.primary,\n backdropFilter: isTransparentTheme ? 'blur(10px)' : undefined,\n WebkitBackdropFilter: isTransparentTheme ? 'blur(10px)' : undefined,\n ...styleProp,\n }}\n >\n {/* Header */}\n <div style={{\n padding: '8px 12px',\n borderBottom: `1px solid ${tokens.colors.border.muted}`,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n background: tokens.colors.background.surface,\n backdropFilter: 'blur(8px)',\n flexWrap: 'wrap',\n gap: 8,\n }}>\n <div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>\n {target && (\n <span style={{\n background: `${tokens.colors.interactive.default}22`,\n color: tokens.colors.interactive.default,\n padding: '2px 8px', borderRadius: tokens.borderRadius.md, fontSize: tokens.typography.fontSize.xxs, fontWeight: 600,\n }}>\n {target}\n </span>\n )}\n {packet && (\n <span style={{ fontWeight: 600, fontSize: tokens.typography.fontSize.sm }}>{packet}</span>\n )}\n <span style={{ fontSize: tokens.typography.fontSize.xxs, color: tokens.colors.text.muted }}>\n {sortedItems.length} items\n </span>\n </div>\n <div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>\n {showViewMode && (\n <select\n value={viewMode}\n onChange={e => setViewMode(e.target.value as PacketViewMode)}\n aria-label=\"Packet view mode\"\n style={{\n background: tokens.colors.background.base,\n color: tokens.colors.text.primary,\n border: `1px solid ${tokens.colors.border.muted}`,\n borderRadius: tokens.borderRadius.md, padding: '3px 8px', fontSize: tokens.typography.fontSize.xxs,\n }}\n >\n <option value=\"raw\">Raw</option>\n <option value=\"converted\">Converted</option>\n <option value=\"formatted\">Formatted</option>\n <option value=\"with_units\">With Units</option>\n </select>\n )}\n {showSearch && (\n <input\n type=\"text\"\n value={searchQuery}\n onChange={e => setSearchQuery(e.target.value)}\n placeholder=\"Filter items...\"\n aria-label=\"Filter packet items\"\n style={{\n background: tokens.colors.background.base,\n color: tokens.colors.text.primary,\n border: `1px solid ${tokens.colors.border.muted}`,\n borderRadius: tokens.borderRadius.md, padding: '3px 8px', fontSize: tokens.typography.fontSize.xxs,\n outline: 'none', minWidth: 120,\n }}\n />\n )}\n </div>\n </div>\n\n {/* Column headers */}\n <div role=\"row\" style={{\n display: 'grid',\n gridTemplateColumns: '1fr 1fr auto',\n padding: `${tokens.spacing.xs} ${tokens.spacing.smd}`,\n borderBottom: `1px solid ${tokens.colors.border.muted}`,\n background: tokens.colors.background.surface,\n fontSize: tokens.typography.fontSize.xxs,\n color: tokens.colors.text.muted,\n textTransform: 'uppercase',\n letterSpacing: '0.5px',\n fontWeight: tokens.typography.fontWeight.medium,\n }}>\n <span role=\"columnheader\">Item</span>\n <span role=\"columnheader\" style={{ textAlign: 'right' }}>Value</span>\n <span role=\"columnheader\" style={{ minWidth: 50, textAlign: 'center' }}>Limits</span>\n </div>\n\n {/* Items list */}\n <div\n ref={listRef}\n role=\"rowgroup\"\n onScroll={e => setScrollTop(e.currentTarget.scrollTop)}\n style={{ flex: 1, overflow: 'auto' }}\n >\n <div style={{ height: totalRows * rowHeight, position: 'relative' }}>\n <div style={{ position: 'absolute', top: startRow * rowHeight, left: 0, right: 0 }}>\n {visibleItems.map((item, visibleIdx) => {\n const idx = startRow + visibleIdx;\n const limitsColor = item.stale\n ? tokens.colors.status.off\n : getLimitsColor(item.limits?.state ?? null, tokens);\n const limitsBg = item.stale\n ? `${tokens.colors.status.off}14`\n : getLimitsBg(item.limits?.state ?? null, tokens);\n\n return (\n <div\n role=\"row\"\n tabIndex={0}\n key={item.name + idx}\n onClick={() => handleItemClick(item)}\n onKeyDown={e => { if (e.key === 'Enter' || e.key === ' ') { e.preventDefault(); handleItemClick(item); } }}\n aria-label={`${item.name}: ${getDisplayValue(item, viewMode)}${item.limits?.state ? `, ${item.limits.state}` : ''}`}\n style={{\n display: 'grid',\n gridTemplateColumns: '1fr 1fr auto',\n padding: `0 ${tokens.spacing.smd}`,\n height: rowHeight,\n alignItems: 'center',\n borderBottom: `1px solid ${tokens.colors.border.muted}`,\n cursor: 'pointer',\n transition: 'background 150ms ease',\n background: item.derived ? `${tokens.colors.background.surface}44` : 'transparent',\n }}\n onMouseEnter={e => { (e.currentTarget as HTMLDivElement).style.background = tokens.colors.background.surface; }}\n onMouseLeave={e => { (e.currentTarget as HTMLDivElement).style.background = item.derived ? `${tokens.colors.background.surface}44` : 'transparent'; }}\n >\n {/* Item name */}\n <span style={{\n fontSize: compact ? tokens.typography.fontSize.xxs : tokens.typography.fontSize.xs,\n fontWeight: 500,\n color: item.derived ? tokens.colors.text.muted : tokens.colors.text.primary,\n fontStyle: item.derived ? 'italic' : 'normal',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}>\n {item.name}\n </span>\n\n {/* Value */}\n <span style={{\n textAlign: 'right',\n fontFamily: tokens.typography.fontFamily.mono,\n fontSize: compact ? tokens.typography.fontSize.xxs : tokens.typography.fontSize.xs,\n fontWeight: 600,\n color: limitsColor,\n background: limitsBg,\n padding: '2px 8px',\n borderRadius: tokens.borderRadius.sm,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}>\n {getDisplayValue(item, viewMode)}\n </span>\n\n {/* Limits indicator — Astro UX status shape */}\n <div style={{ minWidth: 50, display: 'flex', justifyContent: 'center' }}>\n {item.limits?.state && (\n <div style={{\n display: 'flex', alignItems: 'center', gap: 3,\n }}>\n <span style={getLimitsShapeStyle(item.limits.state, limitsColor)} />\n <span style={{ fontSize: tokens.typography.fontSize.micro, color: limitsColor, fontWeight: 600 }}>\n {item.limits.state.replace(/_/g, ' ')}\n </span>\n </div>\n )}\n </div>\n </div>\n );\n })}\n </div>\n </div>\n </div>\n\n {/* Details panel */}\n {showDetails && selectedItem && (\n <div style={{\n borderTop: `1px solid ${tokens.colors.border.muted}`,\n background: tokens.colors.background.surface,\n padding: 12,\n maxHeight: 200,\n overflow: 'auto',\n }}>\n <div style={{ display: 'flex', justifyContent: 'space-between', alignItems: 'center', marginBottom: tokens.spacing.sm }}>\n <span style={{ fontWeight: tokens.typography.fontWeight.bold, fontSize: tokens.typography.fontSize.sm }}>{selectedItem.name}</span>\n <button\n onClick={() => setShowDetails(false)}\n aria-label=\"Close details panel\"\n style={{ background: 'none', border: 'none', color: tokens.colors.text.muted, cursor: 'pointer', fontSize: tokens.typography.fontSize.lg, padding: tokens.spacing.xs, lineHeight: 1 }}\n >\n ✕\n </button>\n </div>\n {selectedItem.description && (\n <p style={{ color: tokens.colors.text.secondary, fontSize: tokens.typography.fontSize.xs, marginBottom: 8 }}>\n {selectedItem.description}\n </p>\n )}\n <div style={{\n display: 'grid', gridTemplateColumns: 'auto 1fr', gap: '4px 12px',\n fontSize: tokens.typography.fontSize.xxs, fontFamily: tokens.typography.fontFamily.mono,\n }}>\n <span style={{ color: tokens.colors.text.muted }}>Raw:</span>\n <span>{String(selectedItem.value)}</span>\n {selectedItem.convertedValue !== undefined && (\n <><span style={{ color: tokens.colors.text.muted }}>Converted:</span><span>{String(selectedItem.convertedValue)}</span></>\n )}\n {selectedItem.units && (\n <><span style={{ color: tokens.colors.text.muted }}>Units:</span><span>{selectedItem.units}</span></>\n )}\n {selectedItem.dataType && (\n <><span style={{ color: tokens.colors.text.muted }}>Type:</span><span>{selectedItem.dataType}</span></>\n )}\n {selectedItem.bitSize !== undefined && (\n <><span style={{ color: tokens.colors.text.muted }}>Bit Size:</span><span>{selectedItem.bitSize}</span></>\n )}\n {selectedItem.bitOffset !== undefined && (\n <><span style={{ color: tokens.colors.text.muted }}>Bit Offset:</span><span>{selectedItem.bitOffset}</span></>\n )}\n {selectedItem.conversion && (\n <><span style={{ color: tokens.colors.text.muted }}>Conversion:</span><span>{selectedItem.conversion}</span></>\n )}\n {selectedItem.limits && (\n <>\n <span style={{ color: tokens.colors.text.muted }}>Limits State:</span>\n <span style={{ color: getLimitsColor(selectedItem.limits.state, tokens) }}>\n {selectedItem.limits.state}\n </span>\n {selectedItem.limits.redLow !== undefined && (\n <><span style={{ color: tokens.colors.text.muted }}>Red Low:</span><span>{selectedItem.limits.redLow}</span></>\n )}\n {selectedItem.limits.yellowLow !== undefined && (\n <><span style={{ color: tokens.colors.text.muted }}>Yellow Low:</span><span>{selectedItem.limits.yellowLow}</span></>\n )}\n {selectedItem.limits.greenHigh !== undefined && (\n <><span style={{ color: tokens.colors.text.muted }}>Green High:</span><span>{selectedItem.limits.greenHigh}</span></>\n )}\n {selectedItem.limits.yellowHigh !== undefined && (\n <><span style={{ color: tokens.colors.text.muted }}>Yellow High:</span><span>{selectedItem.limits.yellowHigh}</span></>\n )}\n {selectedItem.limits.redHigh !== undefined && (\n <><span style={{ color: tokens.colors.text.muted }}>Red High:</span><span>{selectedItem.limits.redHigh}</span></>\n )}\n </>\n )}\n {selectedItem.states && (\n <>\n <span style={{ color: tokens.colors.text.muted }}>States:</span>\n <span>{Object.entries(selectedItem.states).map(([k, v]) => `${k}=${v}`).join(', ')}</span>\n </>\n )}\n </div>\n </div>\n )}\n </div>\n );\n});\n\nexport default PacketViewer;\n"],"names":["PacketViewer"],"mappings":"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"}
|