@pennyfarthing/cyclist 10.4.0 → 11.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api/agent-load.d.ts +1 -2
- package/dist/api/agent-load.d.ts.map +1 -1
- package/dist/api/agent-load.js +2 -123
- package/dist/api/agent-load.js.map +1 -1
- package/dist/api/audit-log.d.ts +1 -17
- package/dist/api/audit-log.d.ts.map +1 -1
- package/dist/api/audit-log.js +2 -162
- package/dist/api/audit-log.js.map +1 -1
- package/dist/api/background-tasks.d.ts +1 -26
- package/dist/api/background-tasks.d.ts.map +1 -1
- package/dist/api/background-tasks.js +2 -55
- package/dist/api/background-tasks.js.map +1 -1
- package/dist/api/bell.d.ts +1 -18
- package/dist/api/bell.d.ts.map +1 -1
- package/dist/api/bell.js +2 -33
- package/dist/api/bell.js.map +1 -1
- package/dist/api/code-markers.d.ts +1 -8
- package/dist/api/code-markers.d.ts.map +1 -1
- package/dist/api/code-markers.js +2 -61
- package/dist/api/code-markers.js.map +1 -1
- package/dist/api/complexity.d.ts +1 -2
- package/dist/api/complexity.d.ts.map +1 -1
- package/dist/api/complexity.js +2 -46
- package/dist/api/complexity.js.map +1 -1
- package/dist/api/context.d.ts +1 -37
- package/dist/api/context.d.ts.map +1 -1
- package/dist/api/context.js +2 -143
- package/dist/api/context.js.map +1 -1
- package/dist/api/dead-code.d.ts +1 -2
- package/dist/api/dead-code.d.ts.map +1 -1
- package/dist/api/dead-code.js +2 -69
- package/dist/api/dead-code.js.map +1 -1
- package/dist/api/dependencies.d.ts +1 -2
- package/dist/api/dependencies.d.ts.map +1 -1
- package/dist/api/dependencies.js +2 -42
- package/dist/api/dependencies.js.map +1 -1
- package/dist/api/evaluation.d.ts +1 -19
- package/dist/api/evaluation.d.ts.map +1 -1
- package/dist/api/evaluation.js +2 -127
- package/dist/api/evaluation.js.map +1 -1
- package/dist/api/file-browser.d.ts +1 -8
- package/dist/api/file-browser.d.ts.map +1 -1
- package/dist/api/file-browser.js +2 -114
- package/dist/api/file-browser.js.map +1 -1
- package/dist/api/git.d.ts +1 -46
- package/dist/api/git.d.ts.map +1 -1
- package/dist/api/git.js +2 -354
- package/dist/api/git.js.map +1 -1
- package/dist/api/health-score.d.ts +1 -2
- package/dist/api/health-score.d.ts.map +1 -1
- package/dist/api/health-score.js +2 -46
- package/dist/api/health-score.js.map +1 -1
- package/dist/api/hook-request.d.ts +1 -40
- package/dist/api/hook-request.d.ts.map +1 -1
- package/dist/api/hook-request.js +2 -277
- package/dist/api/hook-request.js.map +1 -1
- package/dist/api/hotspots.d.ts +1 -2
- package/dist/api/hotspots.d.ts.map +1 -1
- package/dist/api/hotspots.js +2 -61
- package/dist/api/hotspots.js.map +1 -1
- package/dist/api/identity.d.ts +1 -16
- package/dist/api/identity.d.ts.map +1 -1
- package/dist/api/identity.js +2 -78
- package/dist/api/identity.js.map +1 -1
- package/dist/api/index.d.ts +1 -34
- package/dist/api/index.d.ts.map +1 -1
- package/dist/api/index.js +2 -44
- package/dist/api/index.js.map +1 -1
- package/dist/api/mode.d.ts +1 -22
- package/dist/api/mode.d.ts.map +1 -1
- package/dist/api/mode.js +2 -37
- package/dist/api/mode.js.map +1 -1
- package/dist/api/otlp.d.ts +1 -2
- package/dist/api/otlp.d.ts.map +1 -1
- package/dist/api/otlp.js +2 -46
- package/dist/api/otlp.js.map +1 -1
- package/dist/api/permissions.d.ts +1 -15
- package/dist/api/permissions.d.ts.map +1 -1
- package/dist/api/permissions.js +2 -66
- package/dist/api/permissions.js.map +1 -1
- package/dist/api/persona.d.ts +1 -8
- package/dist/api/persona.d.ts.map +1 -1
- package/dist/api/persona.js +2 -67
- package/dist/api/persona.js.map +1 -1
- package/dist/api/portrait.d.ts +1 -5
- package/dist/api/portrait.d.ts.map +1 -1
- package/dist/api/portrait.js +2 -27
- package/dist/api/portrait.js.map +1 -1
- package/dist/api/settings.d.ts +1 -53
- package/dist/api/settings.d.ts.map +1 -1
- package/dist/api/settings.js +2 -464
- package/dist/api/settings.js.map +1 -1
- package/dist/api/spans.d.ts +1 -16
- package/dist/api/spans.d.ts.map +1 -1
- package/dist/api/spans.js +2 -244
- package/dist/api/spans.js.map +1 -1
- package/dist/api/stats.d.ts +1 -12
- package/dist/api/stats.d.ts.map +1 -1
- package/dist/api/stats.js +2 -84
- package/dist/api/stats.js.map +1 -1
- package/dist/api/story.d.ts +1 -2
- package/dist/api/story.d.ts.map +1 -1
- package/dist/api/story.js +2 -14
- package/dist/api/story.js.map +1 -1
- package/dist/api/telemetry.d.ts +1 -18
- package/dist/api/telemetry.d.ts.map +1 -1
- package/dist/api/telemetry.js +2 -164
- package/dist/api/telemetry.js.map +1 -1
- package/dist/api/theme-agents.d.ts +1 -60
- package/dist/api/theme-agents.d.ts.map +1 -1
- package/dist/api/theme-agents.js +2 -213
- package/dist/api/theme-agents.js.map +1 -1
- package/dist/api/todos.d.ts +1 -32
- package/dist/api/todos.d.ts.map +1 -1
- package/dist/api/todos.js +2 -43
- package/dist/api/todos.js.map +1 -1
- package/dist/api/token-stats.d.ts +1 -7
- package/dist/api/token-stats.d.ts.map +1 -1
- package/dist/api/token-stats.js +2 -35
- package/dist/api/token-stats.js.map +1 -1
- package/dist/api/welcome.d.ts +1 -21
- package/dist/api/welcome.d.ts.map +1 -1
- package/dist/api/welcome.js +2 -34
- package/dist/api/welcome.js.map +1 -1
- package/dist/bikerack.js +2 -2
- package/dist/bikerack.js.map +1 -1
- package/dist/env.d.ts +6 -0
- package/dist/env.d.ts.map +1 -0
- package/dist/env.js +10 -0
- package/dist/env.js.map +1 -0
- package/dist/focus.d.ts +53 -0
- package/dist/focus.d.ts.map +1 -0
- package/dist/focus.js +122 -0
- package/dist/focus.js.map +1 -0
- package/dist/git-cache.d.ts +1 -0
- package/dist/git-cache.d.ts.map +1 -1
- package/dist/git-cache.js +3 -1
- package/dist/git-cache.js.map +1 -1
- package/dist/menu-builder.d.ts.map +1 -1
- package/dist/menu-builder.js +0 -1
- package/dist/menu-builder.js.map +1 -1
- package/dist/prime.d.ts +3 -3
- package/dist/prime.d.ts.map +1 -1
- package/dist/prime.js +38 -14
- package/dist/prime.js.map +1 -1
- package/dist/public/css/react.css +1 -1
- package/dist/public/js/react/react.js +53 -61
- package/dist/server.d.ts +18 -85
- package/dist/server.d.ts.map +1 -1
- package/dist/server.js +105 -405
- package/dist/server.js.map +1 -1
- package/dist/sprint-data.d.ts +1 -1
- package/dist/sprint-data.d.ts.map +1 -1
- package/dist/sprint-data.js +2 -2
- package/dist/sprint-data.js.map +1 -1
- package/dist/theme-metadata.d.ts +3 -3
- package/dist/theme-metadata.d.ts.map +1 -1
- package/dist/theme-metadata.js +4 -4
- package/dist/theme-metadata.js.map +1 -1
- package/dist/websocket.d.ts +2 -0
- package/dist/websocket.d.ts.map +1 -1
- package/dist/websocket.js +53 -75
- package/dist/websocket.js.map +1 -1
- package/package.json +2 -6
- package/portraits/hogans-heroes/large/burkhalter-35312.png +0 -0
- package/portraits/hogans-heroes/large/carter-34352.png +0 -0
- package/portraits/hogans-heroes/large/hochstetter-45314.png +0 -0
- package/portraits/hogans-heroes/large/hogan-44541.png +0 -0
- package/portraits/hogans-heroes/large/kinch-35241.png +0 -0
- package/portraits/hogans-heroes/large/klink-23434.png +0 -0
- package/portraits/hogans-heroes/large/lebeau-45443.png +0 -0
- package/portraits/hogans-heroes/large/marya-53543.png +0 -0
- package/portraits/hogans-heroes/large/newkirk-54432.png +0 -0
- package/portraits/hogans-heroes/large/schultz-42453.png +0 -0
- package/portraits/hogans-heroes/large/underground-55131.png +0 -0
- package/portraits/hogans-heroes/medium/burkhalter-35312.png +0 -0
- package/portraits/hogans-heroes/medium/carter-34352.png +0 -0
- package/portraits/hogans-heroes/medium/hochstetter-45314.png +0 -0
- package/portraits/hogans-heroes/medium/hogan-44541.png +0 -0
- package/portraits/hogans-heroes/medium/kinch-35241.png +0 -0
- package/portraits/hogans-heroes/medium/klink-23434.png +0 -0
- package/portraits/hogans-heroes/medium/lebeau-45443.png +0 -0
- package/portraits/hogans-heroes/medium/marya-53543.png +0 -0
- package/portraits/hogans-heroes/medium/newkirk-54432.png +0 -0
- package/portraits/hogans-heroes/medium/schultz-42453.png +0 -0
- package/portraits/hogans-heroes/medium/underground-55131.png +0 -0
- package/portraits/monty-python/large/announcer-44441.png +0 -0
- package/portraits/monty-python/large/arguer-35412.png +0 -0
- package/portraits/monty-python/large/bicycle-repair-man-35241.png +0 -0
- package/portraits/monty-python/large/colonel-35423.png +0 -0
- package/portraits/monty-python/large/counsellor-45341.png +0 -0
- package/portraits/monty-python/large/gumbys-23524.png +0 -0
- package/portraits/monty-python/large/nudge-43533.png +0 -0
- package/portraits/monty-python/large/praline-45413.png +0 -0
- package/portraits/monty-python/large/silly-walks-55322.png +0 -0
- package/portraits/monty-python/large/wensleydale-54451.png +0 -0
- package/portraits/monty-python/large/xim-nez-43534.png +0 -0
- package/portraits/monty-python/medium/announcer-44441.png +0 -0
- package/portraits/monty-python/medium/arguer-35412.png +0 -0
- package/portraits/monty-python/medium/bicycle-repair-man-35241.png +0 -0
- package/portraits/monty-python/medium/colonel-35423.png +0 -0
- package/portraits/monty-python/medium/counsellor-45341.png +0 -0
- package/portraits/monty-python/medium/gumbys-23524.png +0 -0
- package/portraits/monty-python/medium/nudge-43533.png +0 -0
- package/portraits/monty-python/medium/praline-45413.png +0 -0
- package/portraits/monty-python/medium/silly-walks-55322.png +0 -0
- package/portraits/monty-python/medium/wensleydale-54451.png +0 -0
- package/portraits/monty-python/medium/xim-nez-43534.png +0 -0
- package/portraits/stephen-king/large/andy-55231.png +0 -0
- package/portraits/stephen-king/large/christine-25112.png +0 -0
- package/portraits/stephen-king/large/danny-53243.png +0 -0
- package/portraits/stephen-king/large/flagg-55311.png +0 -0
- package/portraits/stephen-king/large/gaunt-54421.png +0 -0
- package/portraits/stephen-king/large/jack-44224.png +0 -0
- package/portraits/stephen-king/large/johnny-44353.png +0 -0
- package/portraits/stephen-king/large/margaret-15415.png +0 -0
- package/portraits/stephen-king/large/paul-45233.png +0 -0
- package/portraits/stephen-king/large/pennywise-54411.png +0 -0
- package/portraits/stephen-king/large/roland-35121.png +0 -0
- package/portraits/stephen-king/medium/andy-55231.png +0 -0
- package/portraits/stephen-king/medium/christine-25112.png +0 -0
- package/portraits/stephen-king/medium/danny-53243.png +0 -0
- package/portraits/stephen-king/medium/flagg-55311.png +0 -0
- package/portraits/stephen-king/medium/gaunt-54421.png +0 -0
- package/portraits/stephen-king/medium/jack-44224.png +0 -0
- package/portraits/stephen-king/medium/johnny-44353.png +0 -0
- package/portraits/stephen-king/medium/margaret-15415.png +0 -0
- package/portraits/stephen-king/medium/paul-45233.png +0 -0
- package/portraits/stephen-king/medium/pennywise-54411.png +0 -0
- package/portraits/stephen-king/medium/roland-35121.png +0 -0
- package/portraits/star-trek-tng/large/beverly-44352.png +0 -0
- package/portraits/star-trek-tng/large/data-55241.png +0 -0
- package/portraits/star-trek-tng/large/deanna-43353.png +0 -0
- package/portraits/star-trek-tng/large/geordi-54342.png +0 -0
- package/portraits/star-trek-tng/large/jean-luc-45342.png +0 -0
- package/portraits/star-trek-tng/large/kathryn-45332.png +0 -0
- package/portraits/star-trek-tng/large/miles-35342.png +0 -0
- package/portraits/star-trek-tng/large/q-53521.png +0 -0
- package/portraits/star-trek-tng/large/spock-45231.png +0 -0
- package/portraits/star-trek-tng/large/troi-44352.png +0 -0
- package/portraits/star-trek-tng/medium/beverly-44352.png +0 -0
- package/portraits/star-trek-tng/medium/data-55241.png +0 -0
- package/portraits/star-trek-tng/medium/deanna-43353.png +0 -0
- package/portraits/star-trek-tng/medium/geordi-54342.png +0 -0
- package/portraits/star-trek-tng/medium/jean-luc-45342.png +0 -0
- package/portraits/star-trek-tng/medium/kathryn-45332.png +0 -0
- package/portraits/star-trek-tng/medium/miles-35342.png +0 -0
- package/portraits/star-trek-tng/medium/q-53521.png +0 -0
- package/portraits/star-trek-tng/medium/spock-45231.png +0 -0
- package/portraits/star-trek-tng/medium/troi-44352.png +0 -0
- package/src/public/App.tsx +0 -340
- package/src/public/components/AgentLoadDialog.tsx +0 -202
- package/src/public/components/AgentPopup.tsx +0 -308
- package/src/public/components/ApprovalModal/ApprovalModal.css +0 -35
- package/src/public/components/ApprovalModal/index.tsx +0 -632
- package/src/public/components/BikeRackIndex.tsx +0 -54
- package/src/public/components/BikeRackWorkspace.tsx +0 -142
- package/src/public/components/CommandPalette.tsx +0 -555
- package/src/public/components/ConfirmDialog.tsx +0 -168
- package/src/public/components/ContextIndicator/ContextIndicator.css +0 -85
- package/src/public/components/ContextIndicator/index.tsx +0 -330
- package/src/public/components/ContextSparkline.tsx +0 -56
- package/src/public/components/ControlBar.tsx +0 -636
- package/src/public/components/DeadCodeDialog.tsx +0 -169
- package/src/public/components/DiffViewer.tsx +0 -585
- package/src/public/components/DockviewWorkspace.tsx +0 -737
- package/src/public/components/Editor.tsx +0 -630
- package/src/public/components/ErrorBoundary.tsx +0 -67
- package/src/public/components/FileTree.tsx +0 -379
- package/src/public/components/FontPicker/FontPicker.css +0 -276
- package/src/public/components/FontPicker/index.tsx +0 -430
- package/src/public/components/FullFileTree.tsx +0 -237
- package/src/public/components/HealthGauge.tsx +0 -181
- package/src/public/components/Message.tsx +0 -225
- package/src/public/components/MessageList.tsx +0 -98
- package/src/public/components/MessageView.tsx +0 -400
- package/src/public/components/ModeSwitch/ModeSwitch.css +0 -165
- package/src/public/components/ModeSwitch/index.tsx +0 -372
- package/src/public/components/PersonaHeader.tsx +0 -240
- package/src/public/components/QuickActions.tsx +0 -267
- package/src/public/components/SpanTimeline.tsx +0 -352
- package/src/public/components/StandalonePanel.tsx +0 -84
- package/src/public/components/StatsStrip.tsx +0 -162
- package/src/public/components/StreamingContent.tsx +0 -77
- package/src/public/components/SubagentSpan.tsx +0 -180
- package/src/public/components/TandemPortrait.tsx +0 -72
- package/src/public/components/ThemePalette/ThemePalette.css +0 -179
- package/src/public/components/ThemePalette/index.tsx +0 -326
- package/src/public/components/ToolCallBlock.tsx +0 -252
- package/src/public/components/ToolStack.tsx +0 -209
- package/src/public/components/ToolStatus.tsx +0 -57
- package/src/public/components/dialogs/CodeMarkersDialog.tsx +0 -169
- package/src/public/components/dialogs/ComplexityDialog.tsx +0 -163
- package/src/public/components/dialogs/DependenciesDialog.tsx +0 -120
- package/src/public/components/dialogs/HotspotsDialog.tsx +0 -451
- package/src/public/components/dialogs/ToolDialog.tsx +0 -43
- package/src/public/components/panel-registry.ts +0 -11
- package/src/public/components/panels/ACPanel.tsx +0 -93
- package/src/public/components/panels/AcceptanceCriteriaPanel.tsx +0 -104
- package/src/public/components/panels/AuditLogPanel.tsx +0 -465
- package/src/public/components/panels/BackgroundPanel.tsx +0 -115
- package/src/public/components/panels/BikeLanePanel.tsx +0 -214
- package/src/public/components/panels/ChangedPanel.tsx +0 -65
- package/src/public/components/panels/DebugPanel.tsx +0 -344
- package/src/public/components/panels/DiffsPanel.tsx +0 -155
- package/src/public/components/panels/GitPanel.tsx +0 -216
- package/src/public/components/panels/HotspotsPanel.tsx +0 -365
- package/src/public/components/panels/MessagePanel.tsx +0 -497
- package/src/public/components/panels/SettingsPanel.tsx +0 -453
- package/src/public/components/panels/SprintPanel.tsx +0 -670
- package/src/public/components/panels/TTYPanel.tsx +0 -299
- package/src/public/components/panels/TodoPanel.tsx +0 -142
- package/src/public/components/panels/WorkflowPanel.tsx +0 -224
- package/src/public/components/panels/index.ts +0 -24
- package/src/public/components/ui/alert-dialog.tsx +0 -139
- package/src/public/components/ui/badge.tsx +0 -36
- package/src/public/components/ui/button.tsx +0 -57
- package/src/public/components/ui/checkbox.tsx +0 -28
- package/src/public/components/ui/collapsible.tsx +0 -9
- package/src/public/components/ui/command.tsx +0 -151
- package/src/public/components/ui/dialog.tsx +0 -120
- package/src/public/components/ui/popover.tsx +0 -31
- package/src/public/components/ui/progress.tsx +0 -28
- package/src/public/components/ui/scroll-area.tsx +0 -46
- package/src/public/components/ui/select.tsx +0 -157
- package/src/public/components/ui/separator.tsx +0 -29
- package/src/public/components/ui/skeleton.tsx +0 -15
- package/src/public/components/ui/switch.tsx +0 -27
- package/src/public/components/ui/toggle-group.tsx +0 -59
- package/src/public/components/ui/toggle.tsx +0 -43
- package/src/public/components/ui/tooltip.tsx +0 -30
- package/src/public/contexts/ClaudeContext.tsx +0 -311
- package/src/public/contexts/MessageQueueContext.tsx +0 -143
- package/src/public/css/theme-browser.css +0 -550
- package/src/public/css/theme-system.css +0 -630
- package/src/public/hooks/index.ts +0 -49
- package/src/public/hooks/useAgentLoad.ts +0 -105
- package/src/public/hooks/useBackgroundTasks.ts +0 -131
- package/src/public/hooks/useClaude.ts +0 -234
- package/src/public/hooks/useCodeMarkers.ts +0 -101
- package/src/public/hooks/useColorScheme.ts +0 -42
- package/src/public/hooks/useCommandHistory.ts +0 -99
- package/src/public/hooks/useComplexity.ts +0 -80
- package/src/public/hooks/useDeadCode.ts +0 -99
- package/src/public/hooks/useDependencies.ts +0 -82
- package/src/public/hooks/useDiffs.ts +0 -143
- package/src/public/hooks/useFileBrowser.ts +0 -71
- package/src/public/hooks/useGitStatus.ts +0 -233
- package/src/public/hooks/useHealthScore.ts +0 -69
- package/src/public/hooks/useHotspots.ts +0 -123
- package/src/public/hooks/useLayoutPersistence.ts +0 -138
- package/src/public/hooks/useMarkdownParser.ts +0 -36
- package/src/public/hooks/useMarkerActions.ts +0 -234
- package/src/public/hooks/useMessageQueue.ts +0 -380
- package/src/public/hooks/useMessageStream.ts +0 -131
- package/src/public/hooks/usePersona.ts +0 -112
- package/src/public/hooks/usePlanModeExit.ts +0 -105
- package/src/public/hooks/useResponsiveLayout.ts +0 -173
- package/src/public/hooks/useSprint.ts +0 -147
- package/src/public/hooks/useStatsStrip.ts +0 -204
- package/src/public/hooks/useStory.ts +0 -135
- package/src/public/hooks/useSubagentHelper.ts +0 -64
- package/src/public/hooks/useSyntaxHighlighter.ts +0 -52
- package/src/public/hooks/useTabCompletion.ts +0 -124
- package/src/public/hooks/useTodos.ts +0 -93
- package/src/public/hooks/useUserAvatar.ts +0 -54
- package/src/public/index.tsx +0 -10
- package/src/public/lib/utils.ts +0 -6
- package/src/public/styles/dockview-theme.css +0 -459
- package/src/public/styles/tailwind.css +0 -4396
- package/src/public/types/electron.d.ts +0 -18
- package/src/public/types/message.ts +0 -51
- package/src/public/utils/avatar-service.ts +0 -73
- package/src/public/utils/color-presets.ts +0 -940
- package/src/public/utils/font-presets.ts +0 -362
- package/src/public/utils/formatDuration.ts +0 -14
- package/src/public/utils/markdown.ts +0 -249
- package/src/public/utils/messageFilters.ts +0 -128
- package/src/public/utils/slash-commands.ts +0 -353
- package/src/public/utils/subagent-display.ts +0 -146
- package/src/public/utils/syntax.ts +0 -219
- package/src/public/utils/toolIntentSummarizer.ts +0 -199
- package/src/public/utils/toolStackGrouper.ts +0 -106
- package/src/public/utils/toolTypeColors.ts +0 -45
|
@@ -1,400 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MessageView Component
|
|
3
|
-
*
|
|
4
|
-
* Main container component for displaying conversation messages.
|
|
5
|
-
* Story MSSCI-12698 - MessageView Component with Streaming
|
|
6
|
-
*
|
|
7
|
-
* Features:
|
|
8
|
-
* - Render messages list with proper roles
|
|
9
|
-
* - Handle streaming content display
|
|
10
|
-
* - Markdown rendering with syntax highlighting
|
|
11
|
-
* - Tool call blocks with stacking
|
|
12
|
-
* - Subagent span grouping
|
|
13
|
-
* - Turn-based grouping with speaker labels
|
|
14
|
-
* - Auto-scroll behavior
|
|
15
|
-
*/
|
|
16
|
-
|
|
17
|
-
import React, { useRef, useState, useCallback, useMemo } from 'react';
|
|
18
|
-
import { Badge } from '@/components/ui/badge';
|
|
19
|
-
import { Button } from '@/components/ui/button';
|
|
20
|
-
import MessageList, { MessageListHandle } from './MessageList';
|
|
21
|
-
import Message from './Message';
|
|
22
|
-
import ToolCallBlock from './ToolCallBlock';
|
|
23
|
-
import ToolStack from './ToolStack';
|
|
24
|
-
import SubagentSpan from './SubagentSpan';
|
|
25
|
-
import QuickActions from './QuickActions';
|
|
26
|
-
import { Separator } from '@/components/ui/separator';
|
|
27
|
-
import { isSkillContent, extractSkillLabel } from '../utils/messageFilters';
|
|
28
|
-
import { groupToolsIntoStacks, ToolStackData } from '../utils/toolStackGrouper';
|
|
29
|
-
import { usePersona } from '../hooks/usePersona';
|
|
30
|
-
import { useColorScheme } from '../hooks/useColorScheme';
|
|
31
|
-
import { useStatsStrip } from '../hooks/useStatsStrip';
|
|
32
|
-
import type { MessageData } from '../types/message';
|
|
33
|
-
|
|
34
|
-
// Agent colors matching CLI statusbar (from PersonaHeader)
|
|
35
|
-
const AGENT_COLORS: Record<string, string> = {
|
|
36
|
-
pm: '#a78bfa', sm: '#60a5fa', dev: '#4ade80', tea: '#2dd4bf',
|
|
37
|
-
reviewer: '#f87171', architect: '#fb923c', devops: '#22d3ee',
|
|
38
|
-
'ux-designer': '#f0abfc', 'tech-writer': '#e5e5e5', orchestrator: '#e879f9',
|
|
39
|
-
ba: '#a3e635',
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
const AGENT_ABBREV: Record<string, string> = {
|
|
43
|
-
pm: 'PM', sm: 'SM', dev: 'DEV', tea: 'TEA', reviewer: 'REV',
|
|
44
|
-
architect: 'ARC', devops: 'OPS', 'ux-designer': 'UX', 'tech-writer': 'TW',
|
|
45
|
-
orchestrator: 'ORC', ba: 'BA',
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
interface MessageViewProps {
|
|
49
|
-
messages: MessageData[];
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
interface SubagentGroup {
|
|
53
|
-
parent_id: string;
|
|
54
|
-
type: string;
|
|
55
|
-
name: string;
|
|
56
|
-
messages: MessageData[];
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
interface ToolStackGroup {
|
|
60
|
-
isToolStack: true;
|
|
61
|
-
stack: ToolStackData;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
type RenderItem = MessageData | SubagentGroup | ToolStackGroup;
|
|
65
|
-
|
|
66
|
-
interface Turn {
|
|
67
|
-
speaker: 'user' | 'agent' | 'system';
|
|
68
|
-
items: RenderItem[];
|
|
69
|
-
timestamp: number;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
function formatTurnTime(timestamp: number): string {
|
|
73
|
-
return new Date(timestamp).toLocaleTimeString([], { hour: '2-digit', minute: '2-digit' });
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
/**
|
|
77
|
-
* Classify an item as 'user' or 'agent' for turn grouping.
|
|
78
|
-
* Tools, subagents, and stacks are all part of the agent's turn.
|
|
79
|
-
*/
|
|
80
|
-
function speakerOf(item: RenderItem): 'user' | 'agent' | 'system' {
|
|
81
|
-
if ('isToolStack' in item || 'messages' in item) return 'agent';
|
|
82
|
-
const msg = item as MessageData;
|
|
83
|
-
if (msg.type === 'context_cleared') return 'system';
|
|
84
|
-
return (msg.type === 'user' || msg.type === 'bell_injected') ? 'user' : 'agent';
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
export default function MessageView({ messages }: MessageViewProps): React.ReactElement {
|
|
88
|
-
const messageListRef = useRef<MessageListHandle>(null);
|
|
89
|
-
const [isAtBottom, setIsAtBottom] = useState(true);
|
|
90
|
-
const { persona } = usePersona();
|
|
91
|
-
const colorScheme = useColorScheme();
|
|
92
|
-
const { projectInfo } = useStatsStrip();
|
|
93
|
-
|
|
94
|
-
// Persist subagent collapsed state across re-renders/remounts
|
|
95
|
-
const subagentCollapsedRef = useRef<Map<string, boolean>>(new Map());
|
|
96
|
-
|
|
97
|
-
const handleScrollChange = useCallback((atBottom: boolean) => {
|
|
98
|
-
setIsAtBottom(atBottom);
|
|
99
|
-
}, []);
|
|
100
|
-
|
|
101
|
-
const handleScrollToBottom = useCallback(() => {
|
|
102
|
-
messageListRef.current?.scrollToBottom('smooth');
|
|
103
|
-
}, []);
|
|
104
|
-
|
|
105
|
-
// Find the last non-streaming assistant message for QuickActions
|
|
106
|
-
const lastAssistantMessage = useMemo(() => {
|
|
107
|
-
for (let i = messages.length - 1; i >= 0; i--) {
|
|
108
|
-
if (messages[i].type === 'agent' && !messages[i].isStreaming) return messages[i];
|
|
109
|
-
}
|
|
110
|
-
return null;
|
|
111
|
-
}, [messages]);
|
|
112
|
-
|
|
113
|
-
// Single memo: messages → flat render items → turns
|
|
114
|
-
const { turns, toolResults, lastAgentItemIndex } = useMemo(() => {
|
|
115
|
-
// 1. Index tool results by ID
|
|
116
|
-
const results = new Map<string, MessageData>();
|
|
117
|
-
for (const msg of messages) {
|
|
118
|
-
if (msg.type === 'tool_result' && msg.tool_id) results.set(msg.tool_id, msg);
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// 2. Filter and collect subagent groups in one pass
|
|
122
|
-
const filtered: MessageData[] = [];
|
|
123
|
-
const subagentGroups = new Map<string, SubagentGroup>();
|
|
124
|
-
|
|
125
|
-
// Track whether we've already emitted a skill label for this skill invocation.
|
|
126
|
-
// The first skill message gets replaced with a label; subsequent ones are dropped.
|
|
127
|
-
let pendingSkillLabel = false;
|
|
128
|
-
|
|
129
|
-
for (const msg of messages) {
|
|
130
|
-
if (msg.type === 'tool_result') continue;
|
|
131
|
-
if (msg.type === 'user' && isSkillContent(msg.content)) {
|
|
132
|
-
const label = extractSkillLabel(msg.content);
|
|
133
|
-
if (label && !pendingSkillLabel) {
|
|
134
|
-
// Replace the first skill message with a short label
|
|
135
|
-
pendingSkillLabel = true;
|
|
136
|
-
filtered.push({ ...msg, content: label });
|
|
137
|
-
}
|
|
138
|
-
// Drop all other skill body messages (pf agent start, <purpose>, etc.)
|
|
139
|
-
continue;
|
|
140
|
-
}
|
|
141
|
-
// Any non-skill user message resets the skill label tracker
|
|
142
|
-
if (msg.type === 'user') {
|
|
143
|
-
pendingSkillLabel = false;
|
|
144
|
-
}
|
|
145
|
-
if (msg.parent_id) {
|
|
146
|
-
let group = subagentGroups.get(msg.parent_id);
|
|
147
|
-
if (!group) {
|
|
148
|
-
group = { parent_id: msg.parent_id, type: msg.subagent_type || 'unknown', name: msg.subagent_name || 'unnamed', messages: [] };
|
|
149
|
-
subagentGroups.set(msg.parent_id, group);
|
|
150
|
-
}
|
|
151
|
-
group.messages.push(msg);
|
|
152
|
-
continue;
|
|
153
|
-
}
|
|
154
|
-
filtered.push(msg);
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
// 3. Build flat render list, replacing consecutive tool_use runs with stacks
|
|
158
|
-
const stacks = groupToolsIntoStacks(filtered);
|
|
159
|
-
const stackByToolId = new Map<string, ToolStackData>();
|
|
160
|
-
for (const stack of stacks) {
|
|
161
|
-
for (const tool of stack.tools) stackByToolId.set(tool.tool_id, stack);
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
const items: RenderItem[] = [];
|
|
165
|
-
const emittedStacks = new Set<string>();
|
|
166
|
-
const emittedSubagents = new Set<string>();
|
|
167
|
-
|
|
168
|
-
for (const msg of filtered) {
|
|
169
|
-
if (msg.type === 'tool_use' && msg.tool_id && stackByToolId.has(msg.tool_id)) {
|
|
170
|
-
const stack = stackByToolId.get(msg.tool_id)!;
|
|
171
|
-
if (!emittedStacks.has(stack.stackId)) {
|
|
172
|
-
emittedStacks.add(stack.stackId);
|
|
173
|
-
items.push({ isToolStack: true, stack });
|
|
174
|
-
}
|
|
175
|
-
} else {
|
|
176
|
-
items.push(msg);
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
// Insert subagent groups at the position of their first parent_id occurrence
|
|
181
|
-
// (They appear in the agent's turn, after the Task tool_use that spawned them)
|
|
182
|
-
// For now, just append them — they'll naturally land in the agent turn
|
|
183
|
-
for (const [, group] of subagentGroups) {
|
|
184
|
-
if (!emittedSubagents.has(group.parent_id)) {
|
|
185
|
-
emittedSubagents.add(group.parent_id);
|
|
186
|
-
items.push(group);
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
// 4. Find last agent message index (for throb control)
|
|
191
|
-
let lastAgent = -1;
|
|
192
|
-
for (let i = items.length - 1; i >= 0; i--) {
|
|
193
|
-
const item = items[i];
|
|
194
|
-
if (!('isToolStack' in item) && !('messages' in item) && (item as MessageData).type === 'agent') {
|
|
195
|
-
lastAgent = i;
|
|
196
|
-
break;
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
// 5. Group into turns
|
|
201
|
-
const turnList: Turn[] = [];
|
|
202
|
-
for (const item of items) {
|
|
203
|
-
const speaker = speakerOf(item);
|
|
204
|
-
const last = turnList[turnList.length - 1];
|
|
205
|
-
if (last && last.speaker === speaker) {
|
|
206
|
-
last.items.push(item);
|
|
207
|
-
} else {
|
|
208
|
-
turnList.push({
|
|
209
|
-
speaker,
|
|
210
|
-
items: [item],
|
|
211
|
-
timestamp: ('timestamp' in item) ? (item as MessageData).timestamp : Date.now(),
|
|
212
|
-
});
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
return { turns: turnList, toolResults: results, lastAgentItemIndex: lastAgent };
|
|
217
|
-
}, [messages]);
|
|
218
|
-
|
|
219
|
-
const renderItem = (item: RenderItem, globalIndex: number, isFirstInTurn: boolean) => {
|
|
220
|
-
if ('isToolStack' in item) {
|
|
221
|
-
return (
|
|
222
|
-
<ToolStack
|
|
223
|
-
key={`stack-${item.stack.stackId}`}
|
|
224
|
-
stack={item.stack}
|
|
225
|
-
toolResults={toolResults as Map<string, { type: 'tool_result'; tool_id: string; content: string; timestamp: number }>}
|
|
226
|
-
/>
|
|
227
|
-
);
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
if ('messages' in item && 'parent_id' in item) {
|
|
231
|
-
const group = item as SubagentGroup;
|
|
232
|
-
const collapsed = subagentCollapsedRef.current.get(group.parent_id) ?? true;
|
|
233
|
-
return (
|
|
234
|
-
<SubagentSpan
|
|
235
|
-
key={`subagent-${group.parent_id}`}
|
|
236
|
-
type={group.type}
|
|
237
|
-
name={group.name}
|
|
238
|
-
messages={group.messages as any}
|
|
239
|
-
defaultCollapsed={collapsed}
|
|
240
|
-
onCollapseChange={(c) => subagentCollapsedRef.current.set(group.parent_id, c)}
|
|
241
|
-
/>
|
|
242
|
-
);
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
const msg = item as MessageData;
|
|
246
|
-
|
|
247
|
-
if (msg.type === 'tool_use' && msg.tool_name && msg.tool_id) {
|
|
248
|
-
// AskUserQuestion is handled by the Reflector system (CYCLIST markers → QuickActions)
|
|
249
|
-
if (msg.tool_name === 'AskUserQuestion') return null;
|
|
250
|
-
const result = toolResults.get(msg.tool_id);
|
|
251
|
-
return (
|
|
252
|
-
<ToolCallBlock
|
|
253
|
-
key={`tool-${msg.tool_id}`}
|
|
254
|
-
toolUse={{
|
|
255
|
-
type: 'tool_use',
|
|
256
|
-
tool_name: msg.tool_name,
|
|
257
|
-
tool_id: msg.tool_id,
|
|
258
|
-
input: msg.input || {},
|
|
259
|
-
timestamp: msg.timestamp,
|
|
260
|
-
}}
|
|
261
|
-
result={result ? {
|
|
262
|
-
type: 'tool_result',
|
|
263
|
-
tool_id: result.tool_id!,
|
|
264
|
-
content: result.content || '',
|
|
265
|
-
timestamp: result.timestamp,
|
|
266
|
-
is_error: result.is_error,
|
|
267
|
-
durationMs: result.durationMs,
|
|
268
|
-
} : undefined}
|
|
269
|
-
/>
|
|
270
|
-
);
|
|
271
|
-
}
|
|
272
|
-
|
|
273
|
-
return (
|
|
274
|
-
<Message
|
|
275
|
-
key={`msg-${globalIndex}-${msg.timestamp}`}
|
|
276
|
-
message={msg}
|
|
277
|
-
isLastAgentMessage={globalIndex === lastAgentItemIndex}
|
|
278
|
-
isFirstInTurn={isFirstInTurn}
|
|
279
|
-
/>
|
|
280
|
-
);
|
|
281
|
-
};
|
|
282
|
-
|
|
283
|
-
// Empty state
|
|
284
|
-
if (messages.length === 0) {
|
|
285
|
-
return (
|
|
286
|
-
<div data-testid="message-view" className="message-view">
|
|
287
|
-
<div className="message-view-empty">
|
|
288
|
-
<div>
|
|
289
|
-
<img
|
|
290
|
-
src={colorScheme === 'dark' ? '/images/cyclist-dark.png' : '/images/cyclist-light.png'}
|
|
291
|
-
alt="Cyclist"
|
|
292
|
-
style={{ height: '2.5rem', opacity: 0.6, display: 'block', margin: '0 auto 0.5rem' }}
|
|
293
|
-
/>
|
|
294
|
-
<div>Type <code style={{
|
|
295
|
-
background: 'var(--bg-tertiary, #0f0f1a)',
|
|
296
|
-
padding: '2px 6px',
|
|
297
|
-
borderRadius: '3px',
|
|
298
|
-
fontFamily: 'var(--font-mono, monospace)'
|
|
299
|
-
}}>/sm</code> to start</div>
|
|
300
|
-
</div>
|
|
301
|
-
</div>
|
|
302
|
-
</div>
|
|
303
|
-
);
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
// Track a running global index across turns for lastAgentItemIndex matching
|
|
307
|
-
let globalIdx = 0;
|
|
308
|
-
|
|
309
|
-
return (
|
|
310
|
-
<div data-testid="message-view" className="message-view" role="log" aria-live="polite">
|
|
311
|
-
<MessageList
|
|
312
|
-
ref={messageListRef}
|
|
313
|
-
onScrollChange={handleScrollChange}
|
|
314
|
-
autoScroll={isAtBottom}
|
|
315
|
-
>
|
|
316
|
-
{turns.map((turn, turnIndex) => {
|
|
317
|
-
// System turns (context_cleared) render as a divider bar
|
|
318
|
-
if (turn.speaker === 'system') {
|
|
319
|
-
// Still increment globalIdx for system items
|
|
320
|
-
turn.items.forEach(() => globalIdx++);
|
|
321
|
-
return (
|
|
322
|
-
<div key={`turn-${turnIndex}`} className="turn-group turn-system">
|
|
323
|
-
<div className="context-cleared-bar">
|
|
324
|
-
<Separator className="context-cleared-line" />
|
|
325
|
-
<span className="context-cleared-label">
|
|
326
|
-
Context cleared
|
|
327
|
-
</span>
|
|
328
|
-
<span className="context-cleared-time">
|
|
329
|
-
{formatTurnTime(turn.timestamp)}
|
|
330
|
-
</span>
|
|
331
|
-
<Separator className="context-cleared-line" />
|
|
332
|
-
</div>
|
|
333
|
-
</div>
|
|
334
|
-
);
|
|
335
|
-
}
|
|
336
|
-
|
|
337
|
-
// Track which items in this turn are "first message" (non-tool, non-stack)
|
|
338
|
-
let seenMessage = false;
|
|
339
|
-
|
|
340
|
-
const agentName = persona?.character || 'Agent';
|
|
341
|
-
const role = persona?.role || null;
|
|
342
|
-
const roleAbbrev = role ? (AGENT_ABBREV[role] || role) : null;
|
|
343
|
-
const roleColor = role ? (AGENT_COLORS[role] || '#e879f9') : undefined;
|
|
344
|
-
const userName = projectInfo?.githubUsername || 'You';
|
|
345
|
-
|
|
346
|
-
return (
|
|
347
|
-
<div key={`turn-${turnIndex}`} className={`turn-group turn-${turn.speaker}`}>
|
|
348
|
-
<div className="turn-label">
|
|
349
|
-
<span className="turn-speaker">
|
|
350
|
-
{turn.speaker === 'user' ? userName : agentName}
|
|
351
|
-
</span>
|
|
352
|
-
{turn.speaker === 'agent' && roleAbbrev && (
|
|
353
|
-
<Badge
|
|
354
|
-
variant="default"
|
|
355
|
-
className="turn-role-badge"
|
|
356
|
-
style={{ backgroundColor: roleColor }}
|
|
357
|
-
>
|
|
358
|
-
{roleAbbrev}
|
|
359
|
-
</Badge>
|
|
360
|
-
)}
|
|
361
|
-
<span className="turn-timestamp">
|
|
362
|
-
{formatTurnTime(turn.timestamp)}
|
|
363
|
-
</span>
|
|
364
|
-
</div>
|
|
365
|
-
{turn.items.map((item) => {
|
|
366
|
-
const idx = globalIdx++;
|
|
367
|
-
const isMessage = !('isToolStack' in item) && !('messages' in item) && (item as MessageData).type !== 'tool_use';
|
|
368
|
-
const isFirst = isMessage && !seenMessage;
|
|
369
|
-
if (isMessage) seenMessage = true;
|
|
370
|
-
return renderItem(item, idx, isFirst);
|
|
371
|
-
})}
|
|
372
|
-
</div>
|
|
373
|
-
);
|
|
374
|
-
})}
|
|
375
|
-
</MessageList>
|
|
376
|
-
|
|
377
|
-
{lastAssistantMessage && (
|
|
378
|
-
<QuickActions message={lastAssistantMessage} />
|
|
379
|
-
)}
|
|
380
|
-
|
|
381
|
-
<div
|
|
382
|
-
data-testid="auto-scroll-indicator"
|
|
383
|
-
data-active={isAtBottom.toString()}
|
|
384
|
-
className="auto-scroll-indicator"
|
|
385
|
-
style={{ display: 'none' }}
|
|
386
|
-
/>
|
|
387
|
-
|
|
388
|
-
<Button
|
|
389
|
-
variant="ghost"
|
|
390
|
-
size="icon"
|
|
391
|
-
data-testid="scroll-to-bottom-button"
|
|
392
|
-
className="scroll-to-bottom-button"
|
|
393
|
-
onClick={handleScrollToBottom}
|
|
394
|
-
style={{ visibility: isAtBottom ? 'hidden' : 'visible' }}
|
|
395
|
-
>
|
|
396
|
-
↓
|
|
397
|
-
</Button>
|
|
398
|
-
</div>
|
|
399
|
-
);
|
|
400
|
-
}
|
|
@@ -1,165 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ModeSwitch Component Styles
|
|
3
|
-
*
|
|
4
|
-
* Story MSSCI-12773 - ModeSwitch Component
|
|
5
|
-
*
|
|
6
|
-
* Color scheme:
|
|
7
|
-
* - Plan: Teal (#14b8a6)
|
|
8
|
-
* - Manual: Gray (#6b7280)
|
|
9
|
-
* - Accept: Purple/Lavender (#a78bfa)
|
|
10
|
-
*
|
|
11
|
-
* Note: The mode-option buttons are rendered as shadcn ToggleGroupItems which
|
|
12
|
-
* apply Tailwind utility classes from toggleVariants. We override those defaults
|
|
13
|
-
* here to preserve the custom ModeSwitch appearance and sliding highlight effect.
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
.mode-switch {
|
|
17
|
-
display: flex;
|
|
18
|
-
position: relative;
|
|
19
|
-
background: var(--bg-tertiary, rgba(0, 0, 0, 0.3));
|
|
20
|
-
border-radius: 6px;
|
|
21
|
-
padding: 2px;
|
|
22
|
-
gap: 0;
|
|
23
|
-
width: fit-content;
|
|
24
|
-
border: 1px solid rgba(255, 255, 255, 0.1);
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
.mode-switch--disabled {
|
|
28
|
-
opacity: 0.5;
|
|
29
|
-
pointer-events: none;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
/* Sliding highlight element */
|
|
33
|
-
.mode-switch__highlight {
|
|
34
|
-
position: absolute;
|
|
35
|
-
top: 2px;
|
|
36
|
-
left: 2px;
|
|
37
|
-
width: calc(33.333% - 1.33px);
|
|
38
|
-
height: calc(100% - 4px);
|
|
39
|
-
border-radius: 4px;
|
|
40
|
-
transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1),
|
|
41
|
-
background-color 0.2s ease;
|
|
42
|
-
pointer-events: none;
|
|
43
|
-
z-index: 0;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/* Highlight colors based on mode */
|
|
47
|
-
.mode-switch__highlight[data-mode="plan"] {
|
|
48
|
-
background: var(--color-plan, #14b8a6);
|
|
49
|
-
box-shadow: 0 0 8px rgba(20, 184, 166, 0.4);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
.mode-switch__highlight[data-mode="manual"] {
|
|
53
|
-
background: var(--color-manual, #6b7280);
|
|
54
|
-
box-shadow: 0 0 8px rgba(107, 114, 128, 0.3);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
.mode-switch__highlight[data-mode="accept"] {
|
|
58
|
-
background: var(--color-accept, #a78bfa);
|
|
59
|
-
box-shadow: 0 0 8px rgba(167, 139, 250, 0.4);
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
/*
|
|
63
|
-
* Mode option buttons (ToggleGroupItem overrides)
|
|
64
|
-
*
|
|
65
|
-
* The shadcn ToggleGroupItem applies toggleVariants Tailwind classes including
|
|
66
|
-
* bg-transparent, hover:bg-muted, data-[state=on]:bg-accent, rounded-md, h-9, etc.
|
|
67
|
-
* We reset those here so the custom sliding highlight + color scheme takes effect.
|
|
68
|
-
*/
|
|
69
|
-
.mode-option {
|
|
70
|
-
position: relative;
|
|
71
|
-
z-index: 1;
|
|
72
|
-
flex: 1;
|
|
73
|
-
padding: 6px 12px !important;
|
|
74
|
-
height: auto !important;
|
|
75
|
-
min-height: unset !important;
|
|
76
|
-
border: none !important;
|
|
77
|
-
border-radius: 0 !important;
|
|
78
|
-
background: transparent !important;
|
|
79
|
-
color: var(--text-secondary, rgba(255, 255, 255, 0.6));
|
|
80
|
-
font-size: 12px;
|
|
81
|
-
font-family: var(--font-ui, -apple-system, BlinkMacSystemFont, sans-serif);
|
|
82
|
-
font-weight: 500;
|
|
83
|
-
cursor: pointer;
|
|
84
|
-
transition: color 0.15s ease;
|
|
85
|
-
white-space: nowrap;
|
|
86
|
-
min-width: 60px;
|
|
87
|
-
text-align: center;
|
|
88
|
-
/* Reset shadcn shadow */
|
|
89
|
-
box-shadow: none !important;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
/* Subtle color hints for inactive options */
|
|
93
|
-
.mode-option[data-mode="plan"]:not(.active) {
|
|
94
|
-
color: rgba(20, 184, 166, 0.7);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
.mode-option[data-mode="manual"]:not(.active) {
|
|
98
|
-
color: rgba(156, 163, 175, 0.8);
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
.mode-option[data-mode="accept"]:not(.active) {
|
|
102
|
-
color: rgba(167, 139, 250, 0.7);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
.mode-option:hover:not(.active):not(:disabled) {
|
|
106
|
-
background: transparent !important;
|
|
107
|
-
filter: brightness(1.3);
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
.mode-option.active {
|
|
111
|
-
color: var(--text-on-highlight, #ffffff);
|
|
112
|
-
background: transparent !important;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
.mode-option:focus {
|
|
116
|
-
outline: none;
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
.mode-option:focus-visible {
|
|
120
|
-
outline: 2px solid var(--color-focus, #60a5fa) !important;
|
|
121
|
-
outline-offset: 2px;
|
|
122
|
-
border-radius: 4px !important;
|
|
123
|
-
/* Override shadcn ring styles */
|
|
124
|
-
box-shadow: none !important;
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
.mode-option:disabled {
|
|
128
|
-
cursor: not-allowed;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
/*
|
|
132
|
-
* Text color adjustments for active states (contrast).
|
|
133
|
-
*
|
|
134
|
-
* The ToggleGroupItems are now nested inside a ToggleGroup wrapper (not direct
|
|
135
|
-
* siblings of the highlight div), so we use parent-scoped descendant selectors.
|
|
136
|
-
*/
|
|
137
|
-
.mode-switch:has(.mode-switch__highlight[data-mode="plan"]) .mode-option[data-mode="plan"].active {
|
|
138
|
-
color: #ffffff;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
.mode-switch:has(.mode-switch__highlight[data-mode="manual"]) .mode-option[data-mode="manual"].active {
|
|
142
|
-
color: #ffffff;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
.mode-switch:has(.mode-switch__highlight[data-mode="accept"]) .mode-option[data-mode="accept"].active {
|
|
146
|
-
color: #1a1a2e;
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
/* Editor-specific positioning */
|
|
150
|
-
.editor-mode-switch {
|
|
151
|
-
margin-bottom: 8px;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
/* Screen reader only text */
|
|
155
|
-
.visually-hidden {
|
|
156
|
-
position: absolute;
|
|
157
|
-
width: 1px;
|
|
158
|
-
height: 1px;
|
|
159
|
-
padding: 0;
|
|
160
|
-
margin: -1px;
|
|
161
|
-
overflow: hidden;
|
|
162
|
-
clip: rect(0, 0, 0, 0);
|
|
163
|
-
white-space: nowrap;
|
|
164
|
-
border: 0;
|
|
165
|
-
}
|