@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.
Files changed (384) hide show
  1. package/dist/api/agent-load.d.ts +1 -2
  2. package/dist/api/agent-load.d.ts.map +1 -1
  3. package/dist/api/agent-load.js +2 -123
  4. package/dist/api/agent-load.js.map +1 -1
  5. package/dist/api/audit-log.d.ts +1 -17
  6. package/dist/api/audit-log.d.ts.map +1 -1
  7. package/dist/api/audit-log.js +2 -162
  8. package/dist/api/audit-log.js.map +1 -1
  9. package/dist/api/background-tasks.d.ts +1 -26
  10. package/dist/api/background-tasks.d.ts.map +1 -1
  11. package/dist/api/background-tasks.js +2 -55
  12. package/dist/api/background-tasks.js.map +1 -1
  13. package/dist/api/bell.d.ts +1 -18
  14. package/dist/api/bell.d.ts.map +1 -1
  15. package/dist/api/bell.js +2 -33
  16. package/dist/api/bell.js.map +1 -1
  17. package/dist/api/code-markers.d.ts +1 -8
  18. package/dist/api/code-markers.d.ts.map +1 -1
  19. package/dist/api/code-markers.js +2 -61
  20. package/dist/api/code-markers.js.map +1 -1
  21. package/dist/api/complexity.d.ts +1 -2
  22. package/dist/api/complexity.d.ts.map +1 -1
  23. package/dist/api/complexity.js +2 -46
  24. package/dist/api/complexity.js.map +1 -1
  25. package/dist/api/context.d.ts +1 -37
  26. package/dist/api/context.d.ts.map +1 -1
  27. package/dist/api/context.js +2 -143
  28. package/dist/api/context.js.map +1 -1
  29. package/dist/api/dead-code.d.ts +1 -2
  30. package/dist/api/dead-code.d.ts.map +1 -1
  31. package/dist/api/dead-code.js +2 -69
  32. package/dist/api/dead-code.js.map +1 -1
  33. package/dist/api/dependencies.d.ts +1 -2
  34. package/dist/api/dependencies.d.ts.map +1 -1
  35. package/dist/api/dependencies.js +2 -42
  36. package/dist/api/dependencies.js.map +1 -1
  37. package/dist/api/evaluation.d.ts +1 -19
  38. package/dist/api/evaluation.d.ts.map +1 -1
  39. package/dist/api/evaluation.js +2 -127
  40. package/dist/api/evaluation.js.map +1 -1
  41. package/dist/api/file-browser.d.ts +1 -8
  42. package/dist/api/file-browser.d.ts.map +1 -1
  43. package/dist/api/file-browser.js +2 -114
  44. package/dist/api/file-browser.js.map +1 -1
  45. package/dist/api/git.d.ts +1 -46
  46. package/dist/api/git.d.ts.map +1 -1
  47. package/dist/api/git.js +2 -354
  48. package/dist/api/git.js.map +1 -1
  49. package/dist/api/health-score.d.ts +1 -2
  50. package/dist/api/health-score.d.ts.map +1 -1
  51. package/dist/api/health-score.js +2 -46
  52. package/dist/api/health-score.js.map +1 -1
  53. package/dist/api/hook-request.d.ts +1 -40
  54. package/dist/api/hook-request.d.ts.map +1 -1
  55. package/dist/api/hook-request.js +2 -277
  56. package/dist/api/hook-request.js.map +1 -1
  57. package/dist/api/hotspots.d.ts +1 -2
  58. package/dist/api/hotspots.d.ts.map +1 -1
  59. package/dist/api/hotspots.js +2 -61
  60. package/dist/api/hotspots.js.map +1 -1
  61. package/dist/api/identity.d.ts +1 -16
  62. package/dist/api/identity.d.ts.map +1 -1
  63. package/dist/api/identity.js +2 -78
  64. package/dist/api/identity.js.map +1 -1
  65. package/dist/api/index.d.ts +1 -34
  66. package/dist/api/index.d.ts.map +1 -1
  67. package/dist/api/index.js +2 -44
  68. package/dist/api/index.js.map +1 -1
  69. package/dist/api/mode.d.ts +1 -22
  70. package/dist/api/mode.d.ts.map +1 -1
  71. package/dist/api/mode.js +2 -37
  72. package/dist/api/mode.js.map +1 -1
  73. package/dist/api/otlp.d.ts +1 -2
  74. package/dist/api/otlp.d.ts.map +1 -1
  75. package/dist/api/otlp.js +2 -46
  76. package/dist/api/otlp.js.map +1 -1
  77. package/dist/api/permissions.d.ts +1 -15
  78. package/dist/api/permissions.d.ts.map +1 -1
  79. package/dist/api/permissions.js +2 -66
  80. package/dist/api/permissions.js.map +1 -1
  81. package/dist/api/persona.d.ts +1 -8
  82. package/dist/api/persona.d.ts.map +1 -1
  83. package/dist/api/persona.js +2 -67
  84. package/dist/api/persona.js.map +1 -1
  85. package/dist/api/portrait.d.ts +1 -5
  86. package/dist/api/portrait.d.ts.map +1 -1
  87. package/dist/api/portrait.js +2 -27
  88. package/dist/api/portrait.js.map +1 -1
  89. package/dist/api/settings.d.ts +1 -53
  90. package/dist/api/settings.d.ts.map +1 -1
  91. package/dist/api/settings.js +2 -464
  92. package/dist/api/settings.js.map +1 -1
  93. package/dist/api/spans.d.ts +1 -16
  94. package/dist/api/spans.d.ts.map +1 -1
  95. package/dist/api/spans.js +2 -244
  96. package/dist/api/spans.js.map +1 -1
  97. package/dist/api/stats.d.ts +1 -12
  98. package/dist/api/stats.d.ts.map +1 -1
  99. package/dist/api/stats.js +2 -84
  100. package/dist/api/stats.js.map +1 -1
  101. package/dist/api/story.d.ts +1 -2
  102. package/dist/api/story.d.ts.map +1 -1
  103. package/dist/api/story.js +2 -14
  104. package/dist/api/story.js.map +1 -1
  105. package/dist/api/telemetry.d.ts +1 -18
  106. package/dist/api/telemetry.d.ts.map +1 -1
  107. package/dist/api/telemetry.js +2 -164
  108. package/dist/api/telemetry.js.map +1 -1
  109. package/dist/api/theme-agents.d.ts +1 -60
  110. package/dist/api/theme-agents.d.ts.map +1 -1
  111. package/dist/api/theme-agents.js +2 -213
  112. package/dist/api/theme-agents.js.map +1 -1
  113. package/dist/api/todos.d.ts +1 -32
  114. package/dist/api/todos.d.ts.map +1 -1
  115. package/dist/api/todos.js +2 -43
  116. package/dist/api/todos.js.map +1 -1
  117. package/dist/api/token-stats.d.ts +1 -7
  118. package/dist/api/token-stats.d.ts.map +1 -1
  119. package/dist/api/token-stats.js +2 -35
  120. package/dist/api/token-stats.js.map +1 -1
  121. package/dist/api/welcome.d.ts +1 -21
  122. package/dist/api/welcome.d.ts.map +1 -1
  123. package/dist/api/welcome.js +2 -34
  124. package/dist/api/welcome.js.map +1 -1
  125. package/dist/bikerack.js +2 -2
  126. package/dist/bikerack.js.map +1 -1
  127. package/dist/env.d.ts +6 -0
  128. package/dist/env.d.ts.map +1 -0
  129. package/dist/env.js +10 -0
  130. package/dist/env.js.map +1 -0
  131. package/dist/focus.d.ts +53 -0
  132. package/dist/focus.d.ts.map +1 -0
  133. package/dist/focus.js +122 -0
  134. package/dist/focus.js.map +1 -0
  135. package/dist/git-cache.d.ts +1 -0
  136. package/dist/git-cache.d.ts.map +1 -1
  137. package/dist/git-cache.js +3 -1
  138. package/dist/git-cache.js.map +1 -1
  139. package/dist/menu-builder.d.ts.map +1 -1
  140. package/dist/menu-builder.js +0 -1
  141. package/dist/menu-builder.js.map +1 -1
  142. package/dist/prime.d.ts +3 -3
  143. package/dist/prime.d.ts.map +1 -1
  144. package/dist/prime.js +38 -14
  145. package/dist/prime.js.map +1 -1
  146. package/dist/public/css/react.css +1 -1
  147. package/dist/public/js/react/react.js +53 -61
  148. package/dist/server.d.ts +18 -85
  149. package/dist/server.d.ts.map +1 -1
  150. package/dist/server.js +105 -405
  151. package/dist/server.js.map +1 -1
  152. package/dist/sprint-data.d.ts +1 -1
  153. package/dist/sprint-data.d.ts.map +1 -1
  154. package/dist/sprint-data.js +2 -2
  155. package/dist/sprint-data.js.map +1 -1
  156. package/dist/theme-metadata.d.ts +3 -3
  157. package/dist/theme-metadata.d.ts.map +1 -1
  158. package/dist/theme-metadata.js +4 -4
  159. package/dist/theme-metadata.js.map +1 -1
  160. package/dist/websocket.d.ts +2 -0
  161. package/dist/websocket.d.ts.map +1 -1
  162. package/dist/websocket.js +53 -75
  163. package/dist/websocket.js.map +1 -1
  164. package/package.json +2 -6
  165. package/portraits/hogans-heroes/large/burkhalter-35312.png +0 -0
  166. package/portraits/hogans-heroes/large/carter-34352.png +0 -0
  167. package/portraits/hogans-heroes/large/hochstetter-45314.png +0 -0
  168. package/portraits/hogans-heroes/large/hogan-44541.png +0 -0
  169. package/portraits/hogans-heroes/large/kinch-35241.png +0 -0
  170. package/portraits/hogans-heroes/large/klink-23434.png +0 -0
  171. package/portraits/hogans-heroes/large/lebeau-45443.png +0 -0
  172. package/portraits/hogans-heroes/large/marya-53543.png +0 -0
  173. package/portraits/hogans-heroes/large/newkirk-54432.png +0 -0
  174. package/portraits/hogans-heroes/large/schultz-42453.png +0 -0
  175. package/portraits/hogans-heroes/large/underground-55131.png +0 -0
  176. package/portraits/hogans-heroes/medium/burkhalter-35312.png +0 -0
  177. package/portraits/hogans-heroes/medium/carter-34352.png +0 -0
  178. package/portraits/hogans-heroes/medium/hochstetter-45314.png +0 -0
  179. package/portraits/hogans-heroes/medium/hogan-44541.png +0 -0
  180. package/portraits/hogans-heroes/medium/kinch-35241.png +0 -0
  181. package/portraits/hogans-heroes/medium/klink-23434.png +0 -0
  182. package/portraits/hogans-heroes/medium/lebeau-45443.png +0 -0
  183. package/portraits/hogans-heroes/medium/marya-53543.png +0 -0
  184. package/portraits/hogans-heroes/medium/newkirk-54432.png +0 -0
  185. package/portraits/hogans-heroes/medium/schultz-42453.png +0 -0
  186. package/portraits/hogans-heroes/medium/underground-55131.png +0 -0
  187. package/portraits/monty-python/large/announcer-44441.png +0 -0
  188. package/portraits/monty-python/large/arguer-35412.png +0 -0
  189. package/portraits/monty-python/large/bicycle-repair-man-35241.png +0 -0
  190. package/portraits/monty-python/large/colonel-35423.png +0 -0
  191. package/portraits/monty-python/large/counsellor-45341.png +0 -0
  192. package/portraits/monty-python/large/gumbys-23524.png +0 -0
  193. package/portraits/monty-python/large/nudge-43533.png +0 -0
  194. package/portraits/monty-python/large/praline-45413.png +0 -0
  195. package/portraits/monty-python/large/silly-walks-55322.png +0 -0
  196. package/portraits/monty-python/large/wensleydale-54451.png +0 -0
  197. package/portraits/monty-python/large/xim-nez-43534.png +0 -0
  198. package/portraits/monty-python/medium/announcer-44441.png +0 -0
  199. package/portraits/monty-python/medium/arguer-35412.png +0 -0
  200. package/portraits/monty-python/medium/bicycle-repair-man-35241.png +0 -0
  201. package/portraits/monty-python/medium/colonel-35423.png +0 -0
  202. package/portraits/monty-python/medium/counsellor-45341.png +0 -0
  203. package/portraits/monty-python/medium/gumbys-23524.png +0 -0
  204. package/portraits/monty-python/medium/nudge-43533.png +0 -0
  205. package/portraits/monty-python/medium/praline-45413.png +0 -0
  206. package/portraits/monty-python/medium/silly-walks-55322.png +0 -0
  207. package/portraits/monty-python/medium/wensleydale-54451.png +0 -0
  208. package/portraits/monty-python/medium/xim-nez-43534.png +0 -0
  209. package/portraits/stephen-king/large/andy-55231.png +0 -0
  210. package/portraits/stephen-king/large/christine-25112.png +0 -0
  211. package/portraits/stephen-king/large/danny-53243.png +0 -0
  212. package/portraits/stephen-king/large/flagg-55311.png +0 -0
  213. package/portraits/stephen-king/large/gaunt-54421.png +0 -0
  214. package/portraits/stephen-king/large/jack-44224.png +0 -0
  215. package/portraits/stephen-king/large/johnny-44353.png +0 -0
  216. package/portraits/stephen-king/large/margaret-15415.png +0 -0
  217. package/portraits/stephen-king/large/paul-45233.png +0 -0
  218. package/portraits/stephen-king/large/pennywise-54411.png +0 -0
  219. package/portraits/stephen-king/large/roland-35121.png +0 -0
  220. package/portraits/stephen-king/medium/andy-55231.png +0 -0
  221. package/portraits/stephen-king/medium/christine-25112.png +0 -0
  222. package/portraits/stephen-king/medium/danny-53243.png +0 -0
  223. package/portraits/stephen-king/medium/flagg-55311.png +0 -0
  224. package/portraits/stephen-king/medium/gaunt-54421.png +0 -0
  225. package/portraits/stephen-king/medium/jack-44224.png +0 -0
  226. package/portraits/stephen-king/medium/johnny-44353.png +0 -0
  227. package/portraits/stephen-king/medium/margaret-15415.png +0 -0
  228. package/portraits/stephen-king/medium/paul-45233.png +0 -0
  229. package/portraits/stephen-king/medium/pennywise-54411.png +0 -0
  230. package/portraits/stephen-king/medium/roland-35121.png +0 -0
  231. package/portraits/star-trek-tng/large/beverly-44352.png +0 -0
  232. package/portraits/star-trek-tng/large/data-55241.png +0 -0
  233. package/portraits/star-trek-tng/large/deanna-43353.png +0 -0
  234. package/portraits/star-trek-tng/large/geordi-54342.png +0 -0
  235. package/portraits/star-trek-tng/large/jean-luc-45342.png +0 -0
  236. package/portraits/star-trek-tng/large/kathryn-45332.png +0 -0
  237. package/portraits/star-trek-tng/large/miles-35342.png +0 -0
  238. package/portraits/star-trek-tng/large/q-53521.png +0 -0
  239. package/portraits/star-trek-tng/large/spock-45231.png +0 -0
  240. package/portraits/star-trek-tng/large/troi-44352.png +0 -0
  241. package/portraits/star-trek-tng/medium/beverly-44352.png +0 -0
  242. package/portraits/star-trek-tng/medium/data-55241.png +0 -0
  243. package/portraits/star-trek-tng/medium/deanna-43353.png +0 -0
  244. package/portraits/star-trek-tng/medium/geordi-54342.png +0 -0
  245. package/portraits/star-trek-tng/medium/jean-luc-45342.png +0 -0
  246. package/portraits/star-trek-tng/medium/kathryn-45332.png +0 -0
  247. package/portraits/star-trek-tng/medium/miles-35342.png +0 -0
  248. package/portraits/star-trek-tng/medium/q-53521.png +0 -0
  249. package/portraits/star-trek-tng/medium/spock-45231.png +0 -0
  250. package/portraits/star-trek-tng/medium/troi-44352.png +0 -0
  251. package/src/public/App.tsx +0 -340
  252. package/src/public/components/AgentLoadDialog.tsx +0 -202
  253. package/src/public/components/AgentPopup.tsx +0 -308
  254. package/src/public/components/ApprovalModal/ApprovalModal.css +0 -35
  255. package/src/public/components/ApprovalModal/index.tsx +0 -632
  256. package/src/public/components/BikeRackIndex.tsx +0 -54
  257. package/src/public/components/BikeRackWorkspace.tsx +0 -142
  258. package/src/public/components/CommandPalette.tsx +0 -555
  259. package/src/public/components/ConfirmDialog.tsx +0 -168
  260. package/src/public/components/ContextIndicator/ContextIndicator.css +0 -85
  261. package/src/public/components/ContextIndicator/index.tsx +0 -330
  262. package/src/public/components/ContextSparkline.tsx +0 -56
  263. package/src/public/components/ControlBar.tsx +0 -636
  264. package/src/public/components/DeadCodeDialog.tsx +0 -169
  265. package/src/public/components/DiffViewer.tsx +0 -585
  266. package/src/public/components/DockviewWorkspace.tsx +0 -737
  267. package/src/public/components/Editor.tsx +0 -630
  268. package/src/public/components/ErrorBoundary.tsx +0 -67
  269. package/src/public/components/FileTree.tsx +0 -379
  270. package/src/public/components/FontPicker/FontPicker.css +0 -276
  271. package/src/public/components/FontPicker/index.tsx +0 -430
  272. package/src/public/components/FullFileTree.tsx +0 -237
  273. package/src/public/components/HealthGauge.tsx +0 -181
  274. package/src/public/components/Message.tsx +0 -225
  275. package/src/public/components/MessageList.tsx +0 -98
  276. package/src/public/components/MessageView.tsx +0 -400
  277. package/src/public/components/ModeSwitch/ModeSwitch.css +0 -165
  278. package/src/public/components/ModeSwitch/index.tsx +0 -372
  279. package/src/public/components/PersonaHeader.tsx +0 -240
  280. package/src/public/components/QuickActions.tsx +0 -267
  281. package/src/public/components/SpanTimeline.tsx +0 -352
  282. package/src/public/components/StandalonePanel.tsx +0 -84
  283. package/src/public/components/StatsStrip.tsx +0 -162
  284. package/src/public/components/StreamingContent.tsx +0 -77
  285. package/src/public/components/SubagentSpan.tsx +0 -180
  286. package/src/public/components/TandemPortrait.tsx +0 -72
  287. package/src/public/components/ThemePalette/ThemePalette.css +0 -179
  288. package/src/public/components/ThemePalette/index.tsx +0 -326
  289. package/src/public/components/ToolCallBlock.tsx +0 -252
  290. package/src/public/components/ToolStack.tsx +0 -209
  291. package/src/public/components/ToolStatus.tsx +0 -57
  292. package/src/public/components/dialogs/CodeMarkersDialog.tsx +0 -169
  293. package/src/public/components/dialogs/ComplexityDialog.tsx +0 -163
  294. package/src/public/components/dialogs/DependenciesDialog.tsx +0 -120
  295. package/src/public/components/dialogs/HotspotsDialog.tsx +0 -451
  296. package/src/public/components/dialogs/ToolDialog.tsx +0 -43
  297. package/src/public/components/panel-registry.ts +0 -11
  298. package/src/public/components/panels/ACPanel.tsx +0 -93
  299. package/src/public/components/panels/AcceptanceCriteriaPanel.tsx +0 -104
  300. package/src/public/components/panels/AuditLogPanel.tsx +0 -465
  301. package/src/public/components/panels/BackgroundPanel.tsx +0 -115
  302. package/src/public/components/panels/BikeLanePanel.tsx +0 -214
  303. package/src/public/components/panels/ChangedPanel.tsx +0 -65
  304. package/src/public/components/panels/DebugPanel.tsx +0 -344
  305. package/src/public/components/panels/DiffsPanel.tsx +0 -155
  306. package/src/public/components/panels/GitPanel.tsx +0 -216
  307. package/src/public/components/panels/HotspotsPanel.tsx +0 -365
  308. package/src/public/components/panels/MessagePanel.tsx +0 -497
  309. package/src/public/components/panels/SettingsPanel.tsx +0 -453
  310. package/src/public/components/panels/SprintPanel.tsx +0 -670
  311. package/src/public/components/panels/TTYPanel.tsx +0 -299
  312. package/src/public/components/panels/TodoPanel.tsx +0 -142
  313. package/src/public/components/panels/WorkflowPanel.tsx +0 -224
  314. package/src/public/components/panels/index.ts +0 -24
  315. package/src/public/components/ui/alert-dialog.tsx +0 -139
  316. package/src/public/components/ui/badge.tsx +0 -36
  317. package/src/public/components/ui/button.tsx +0 -57
  318. package/src/public/components/ui/checkbox.tsx +0 -28
  319. package/src/public/components/ui/collapsible.tsx +0 -9
  320. package/src/public/components/ui/command.tsx +0 -151
  321. package/src/public/components/ui/dialog.tsx +0 -120
  322. package/src/public/components/ui/popover.tsx +0 -31
  323. package/src/public/components/ui/progress.tsx +0 -28
  324. package/src/public/components/ui/scroll-area.tsx +0 -46
  325. package/src/public/components/ui/select.tsx +0 -157
  326. package/src/public/components/ui/separator.tsx +0 -29
  327. package/src/public/components/ui/skeleton.tsx +0 -15
  328. package/src/public/components/ui/switch.tsx +0 -27
  329. package/src/public/components/ui/toggle-group.tsx +0 -59
  330. package/src/public/components/ui/toggle.tsx +0 -43
  331. package/src/public/components/ui/tooltip.tsx +0 -30
  332. package/src/public/contexts/ClaudeContext.tsx +0 -311
  333. package/src/public/contexts/MessageQueueContext.tsx +0 -143
  334. package/src/public/css/theme-browser.css +0 -550
  335. package/src/public/css/theme-system.css +0 -630
  336. package/src/public/hooks/index.ts +0 -49
  337. package/src/public/hooks/useAgentLoad.ts +0 -105
  338. package/src/public/hooks/useBackgroundTasks.ts +0 -131
  339. package/src/public/hooks/useClaude.ts +0 -234
  340. package/src/public/hooks/useCodeMarkers.ts +0 -101
  341. package/src/public/hooks/useColorScheme.ts +0 -42
  342. package/src/public/hooks/useCommandHistory.ts +0 -99
  343. package/src/public/hooks/useComplexity.ts +0 -80
  344. package/src/public/hooks/useDeadCode.ts +0 -99
  345. package/src/public/hooks/useDependencies.ts +0 -82
  346. package/src/public/hooks/useDiffs.ts +0 -143
  347. package/src/public/hooks/useFileBrowser.ts +0 -71
  348. package/src/public/hooks/useGitStatus.ts +0 -233
  349. package/src/public/hooks/useHealthScore.ts +0 -69
  350. package/src/public/hooks/useHotspots.ts +0 -123
  351. package/src/public/hooks/useLayoutPersistence.ts +0 -138
  352. package/src/public/hooks/useMarkdownParser.ts +0 -36
  353. package/src/public/hooks/useMarkerActions.ts +0 -234
  354. package/src/public/hooks/useMessageQueue.ts +0 -380
  355. package/src/public/hooks/useMessageStream.ts +0 -131
  356. package/src/public/hooks/usePersona.ts +0 -112
  357. package/src/public/hooks/usePlanModeExit.ts +0 -105
  358. package/src/public/hooks/useResponsiveLayout.ts +0 -173
  359. package/src/public/hooks/useSprint.ts +0 -147
  360. package/src/public/hooks/useStatsStrip.ts +0 -204
  361. package/src/public/hooks/useStory.ts +0 -135
  362. package/src/public/hooks/useSubagentHelper.ts +0 -64
  363. package/src/public/hooks/useSyntaxHighlighter.ts +0 -52
  364. package/src/public/hooks/useTabCompletion.ts +0 -124
  365. package/src/public/hooks/useTodos.ts +0 -93
  366. package/src/public/hooks/useUserAvatar.ts +0 -54
  367. package/src/public/index.tsx +0 -10
  368. package/src/public/lib/utils.ts +0 -6
  369. package/src/public/styles/dockview-theme.css +0 -459
  370. package/src/public/styles/tailwind.css +0 -4396
  371. package/src/public/types/electron.d.ts +0 -18
  372. package/src/public/types/message.ts +0 -51
  373. package/src/public/utils/avatar-service.ts +0 -73
  374. package/src/public/utils/color-presets.ts +0 -940
  375. package/src/public/utils/font-presets.ts +0 -362
  376. package/src/public/utils/formatDuration.ts +0 -14
  377. package/src/public/utils/markdown.ts +0 -249
  378. package/src/public/utils/messageFilters.ts +0 -128
  379. package/src/public/utils/slash-commands.ts +0 -353
  380. package/src/public/utils/subagent-display.ts +0 -146
  381. package/src/public/utils/syntax.ts +0 -219
  382. package/src/public/utils/toolIntentSummarizer.ts +0 -199
  383. package/src/public/utils/toolStackGrouper.ts +0 -106
  384. 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
- }