@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,340 +0,0 @@
1
- /**
2
- * Root React component for Cyclist
3
- * Story MSSCI-12717 - React Migration
4
- * Story MSSCI-12706 - Layout Persistence
5
- * Story MSSCI-12769 - Font Customization
6
- * Story MSSCI-12771 - Accessibility Compliance
7
- *
8
- * Renders the DockingWorkspace with all panels registered.
9
- * Persists layout changes to config.local.yaml.
10
- */
11
-
12
- import React, { useEffect, useCallback, useState } from 'react';
13
- import {
14
- DockviewWorkspace,
15
- registerPanelComponent,
16
- PANEL_INVENTORY,
17
- } from './components/DockviewWorkspace';
18
- import { CommandPaletteProvider } from './components/CommandPalette';
19
- import { ClaudeProvider } from './contexts/ClaudeContext';
20
- import ClaudeContext from './contexts/ClaudeContext';
21
- import { MessageQueueProvider } from './contexts/MessageQueueContext';
22
- import { useLayoutPersistence } from './hooks/useLayoutPersistence';
23
- import { loadFontSettings, applyFontSettings } from './utils/font-presets';
24
- import { loadPresetFromProject, applyPreset } from './utils/color-presets';
25
- import { ErrorBoundary } from './components/ErrorBoundary';
26
- import { StandalonePanel, getStandalonePanelName } from './components/StandalonePanel';
27
- import { BikeRackWorkspace } from './components/BikeRackWorkspace';
28
- import ApprovalModal, { useApprovalModal } from './components/ApprovalModal';
29
- import { subscribeToPermissionRequests, sendPermissionResponse, createApprovalResponse } from './components/ApprovalModal';
30
- import type { ApprovalRequest, GrantScope } from './components/ApprovalModal';
31
-
32
- // Import all panel components
33
- // Note: ProgressPanel split into Workflow/AC/Todo panels (MSSCI-14188)
34
- import {
35
- MessagePanel,
36
- EnhancedSprintPanel,
37
- GitPanel,
38
- WorkflowPanel,
39
- ACPanel,
40
- TodoPanel,
41
- BackgroundPanel,
42
- ChangedPanel,
43
- DiffsPanel,
44
- DebugPanel,
45
- SettingsPanel,
46
- AuditLogPanel,
47
- TTYPanel,
48
- } from './components/panels';
49
-
50
- // =============================================================================
51
- // Panel Registration
52
- // =============================================================================
53
-
54
- // Register all panels BEFORE render
55
- // Center panel (sacred)
56
- registerPanelComponent(PANEL_INVENTORY.MESSAGE, MessagePanel);
57
-
58
- // Left sidebar panels
59
- registerPanelComponent(PANEL_INVENTORY.CHANGED, ChangedPanel);
60
- registerPanelComponent(PANEL_INVENTORY.DIFFS, DiffsPanel);
61
- registerPanelComponent(PANEL_INVENTORY.DEBUG, DebugPanel);
62
- registerPanelComponent(PANEL_INVENTORY.AUDIT_LOG, AuditLogPanel);
63
- registerPanelComponent(PANEL_INVENTORY.TTY, TTYPanel);
64
-
65
- // Right sidebar panels
66
- // Note: ProgressPanel split into Workflow/AC/Todo panels (MSSCI-14188)
67
- registerPanelComponent(PANEL_INVENTORY.SPRINT, EnhancedSprintPanel);
68
- registerPanelComponent(PANEL_INVENTORY.WORKFLOW, WorkflowPanel);
69
- registerPanelComponent(PANEL_INVENTORY.AC, ACPanel);
70
- registerPanelComponent(PANEL_INVENTORY.TODO, TodoPanel);
71
- registerPanelComponent(PANEL_INVENTORY.BACKGROUND, BackgroundPanel);
72
- registerPanelComponent(PANEL_INVENTORY.GIT, GitPanel);
73
- registerPanelComponent(PANEL_INVENTORY.SETTINGS, SettingsPanel);
74
-
75
- // =============================================================================
76
- // Skip Link Component
77
- // =============================================================================
78
-
79
- interface SkipLinkProps {
80
- href: string;
81
- children: React.ReactNode;
82
- }
83
-
84
- function SkipLink({ href, children }: SkipLinkProps): React.ReactElement {
85
- const handleClick = useCallback((e: React.MouseEvent<HTMLAnchorElement>) => {
86
- e.preventDefault();
87
- const target = document.querySelector(href);
88
- if (target) {
89
- (target as HTMLElement).focus();
90
- }
91
- }, [href]);
92
-
93
- return (
94
- <a
95
- href={href}
96
- className="sr-only skip-link"
97
- onClick={handleClick}
98
- onFocus={(e) => e.currentTarget.classList.add('skip-link-visible')}
99
- onBlur={(e) => e.currentTarget.classList.remove('skip-link-visible')}
100
- >
101
- {children}
102
- </a>
103
- );
104
- }
105
-
106
- // =============================================================================
107
- // Reduced Motion Hook
108
- // =============================================================================
109
-
110
- function useReducedMotion(): void {
111
- useEffect(() => {
112
- // Check for prefers-reduced-motion
113
- const mediaQuery = window.matchMedia('(prefers-reduced-motion: reduce)');
114
-
115
- const updateReducedMotion = (matches: boolean) => {
116
- if (matches) {
117
- document.documentElement.classList.add('reduced-motion');
118
- } else {
119
- document.documentElement.classList.remove('reduced-motion');
120
- }
121
- };
122
-
123
- // Set initial value
124
- updateReducedMotion(mediaQuery.matches);
125
-
126
- // Listen for changes
127
- const listener = (e: MediaQueryListEvent) => {
128
- updateReducedMotion(e.matches);
129
- };
130
-
131
- mediaQuery.addEventListener('change', listener);
132
- return () => mediaQuery.removeEventListener('change', listener);
133
- }, []);
134
- }
135
-
136
- // =============================================================================
137
- // App Component
138
- // =============================================================================
139
-
140
- // =============================================================================
141
- // Root Error Fallback
142
- // =============================================================================
143
-
144
- /**
145
- * Root-level error fallback UI - shown when the entire app crashes
146
- */
147
- function RootErrorFallback(): React.ReactElement {
148
- const handleReload = useCallback(() => {
149
- window.location.reload();
150
- }, []);
151
-
152
- return (
153
- <div style={{
154
- display: 'flex',
155
- flexDirection: 'column',
156
- alignItems: 'center',
157
- justifyContent: 'center',
158
- height: '100vh',
159
- backgroundColor: 'var(--bg-primary, #0a0a0f)',
160
- color: 'var(--text-primary, #e2e8f0)',
161
- fontFamily: 'system-ui, -apple-system, sans-serif',
162
- padding: '24px',
163
- textAlign: 'center',
164
- }}>
165
- <h1 style={{
166
- fontSize: '24px',
167
- fontWeight: 600,
168
- marginBottom: '16px',
169
- color: 'var(--status-error, #ef4444)',
170
- }}>
171
- Something went wrong
172
- </h1>
173
- <p style={{
174
- fontSize: '14px',
175
- color: 'var(--text-secondary, #94a3b8)',
176
- marginBottom: '24px',
177
- maxWidth: '400px',
178
- }}>
179
- Cyclist encountered an unexpected error. Check the console for details.
180
- </p>
181
- <button
182
- onClick={handleReload}
183
- style={{
184
- padding: '8px 16px',
185
- fontSize: '14px',
186
- backgroundColor: 'var(--accent-primary, #6366f1)',
187
- color: 'white',
188
- border: 'none',
189
- borderRadius: '6px',
190
- cursor: 'pointer',
191
- }}
192
- >
193
- Reload Cyclist
194
- </button>
195
- </div>
196
- );
197
- }
198
-
199
- // =============================================================================
200
- // App Component
201
- // =============================================================================
202
-
203
- export default function App(): React.ReactElement {
204
- // Detect route mode (computed before hooks, used after)
205
- const isBikeRackIndex = window.location.pathname === '/bikerack';
206
- const standalonePanelName = getStandalonePanelName();
207
-
208
- // --- All hooks called unconditionally (React rules of hooks) ---
209
-
210
- const { layout, isLoading, saveLayout } = useLayoutPersistence();
211
-
212
- // Set up reduced motion support
213
- useReducedMotion();
214
-
215
- // Load and apply font settings on startup (MSSCI-12769)
216
- useEffect(() => {
217
- loadFontSettings().then(settings => {
218
- applyFontSettings(settings);
219
- });
220
- }, []);
221
-
222
- // Load and apply color preset on startup
223
- useEffect(() => {
224
- loadPresetFromProject().then(presetId => {
225
- applyPreset(presetId);
226
- });
227
- }, []);
228
-
229
- // ApprovalModal state management (MSSCI-14322)
230
- const [requestQueue, setRequestQueue] = useState<ApprovalRequest[]>([]);
231
- const { request, isOpen, show, hide } = useApprovalModal();
232
-
233
- // Subscribe to permission requests via WebSocket
234
- useEffect(() => {
235
- const unsub = subscribeToPermissionRequests((incoming: ApprovalRequest) => {
236
- setRequestQueue((prev) => [...prev, incoming]);
237
- });
238
- return unsub;
239
- }, []);
240
-
241
- // Show the next queued request when the current one is resolved
242
- useEffect(() => {
243
- if (!isOpen && requestQueue.length > 0) {
244
- const [next, ...rest] = requestQueue;
245
- setRequestQueue(rest);
246
- show(next);
247
- }
248
- }, [isOpen, requestQueue, show]);
249
-
250
- const handleApprove = useCallback((grantScope: GrantScope) => {
251
- if (request) {
252
- const response = createApprovalResponse(request.toolId, true, grantScope);
253
- sendPermissionResponse(response);
254
- }
255
- hide();
256
- }, [request, hide]);
257
-
258
- const handleReject = useCallback(() => {
259
- if (request) {
260
- const response = createApprovalResponse(request.toolId, false);
261
- sendPermissionResponse(response);
262
- }
263
- hide();
264
- }, [request, hide]);
265
-
266
- // --- BikeRack routes (after all hooks) ---
267
-
268
- // BikeRack Dockview workspace (MSSCI-14877) — /bikerack renders Dockview layout
269
- // No-op ClaudeContext: BikeRack has no Claude CLI subprocess, skip WebSocket
270
- if (isBikeRackIndex) {
271
- const noop = () => () => {};
272
- return (
273
- <ClaudeContext.Provider value={{
274
- send: () => {}, abort: () => {}, clear: () => {},
275
- clearAndReload: () => {}, setMode: () => {},
276
- isConnected: false, mode: 'default',
277
- onMessage: noop, onComplete: noop, onError: noop,
278
- onUserMessage: noop, onClear: noop,
279
- }}>
280
- <BikeRackWorkspace />
281
- </ClaudeContext.Provider>
282
- );
283
- }
284
-
285
- // BikeRack standalone panel routing (MSSCI-14821)
286
- // URL-based detection only (Rule 10) — ?panel=X renders single panel full-screen
287
- if (standalonePanelName) {
288
- return <StandalonePanel />;
289
- }
290
-
291
- return (
292
- <ErrorBoundary fallback={<RootErrorFallback />} panelName="App">
293
- <ClaudeProvider>
294
- <MessageQueueProvider>
295
- <CommandPaletteProvider>
296
- <div className="cyclist-app">
297
- {/* Skip links for keyboard navigation (AC7) - always render first */}
298
- <SkipLink href="#main-content">Skip to main content</SkipLink>
299
- <SkipLink href="#message-input">Skip to input</SkipLink>
300
- <SkipLink href="#sidebar-nav">Skip to navigation</SkipLink>
301
-
302
- {/* Loading state - only show while actually loading */}
303
- {isLoading ? (
304
- <main id="main-content" tabIndex={-1}>
305
- <div className="cyclist-loading">
306
- <div className="loading-spinner" aria-label="Loading layout..." />
307
- </div>
308
- </main>
309
- ) : (
310
- /* Main content area - layout can be null for first-time users */
311
- <main id="main-content" tabIndex={-1}>
312
- <DockviewWorkspace
313
- initialLayout={layout ?? undefined}
314
- onLayoutChange={saveLayout}
315
- />
316
- </main>
317
- )}
318
-
319
- {/* Sidebar navigation target (for skip link) */}
320
- <nav id="sidebar-nav" tabIndex={-1} style={{ display: 'contents' }} aria-hidden="true" />
321
-
322
- {/* Message input target (for skip link) */}
323
- <div id="message-input" tabIndex={-1} style={{ display: 'contents' }} aria-hidden="true" />
324
- </div>
325
-
326
- {/* ApprovalModal - renders via Radix Portal outside the React tree (MSSCI-14322) */}
327
- <ApprovalModal
328
- isOpen={isOpen}
329
- toolName={request?.toolName ?? ''}
330
- toolId={request?.toolId ?? ''}
331
- input={request?.input ?? {}}
332
- onApprove={handleApprove}
333
- onReject={handleReject}
334
- />
335
- </CommandPaletteProvider>
336
- </MessageQueueProvider>
337
- </ClaudeProvider>
338
- </ErrorBoundary>
339
- );
340
- }
@@ -1,202 +0,0 @@
1
- import React, { useState, useEffect, useMemo } from 'react';
2
- import { Button } from '@/components/ui/button';
3
- import { Progress } from '@/components/ui/progress';
4
- import { Skeleton } from '@/components/ui/skeleton';
5
- import { Collapsible, CollapsibleTrigger, CollapsibleContent } from '@/components/ui/collapsible';
6
- import { ToolDialog } from './dialogs/ToolDialog';
7
- import { ConfirmDialog, useConfirmDialog } from './ConfirmDialog';
8
- import { useAgentLoad } from '../hooks/useAgentLoad.js';
9
- import type { AgentLoadEntry } from '../hooks/useAgentLoad.js';
10
- import { formatComponentName } from './panels/DebugPanel';
11
-
12
- const SIDECAR_FILES = ['patterns.md', 'gotchas.md', 'decisions.md'] as const;
13
-
14
- export interface AgentLoadDialogProps {
15
- isOpen: boolean;
16
- onClose: () => void;
17
- }
18
-
19
- export function AgentLoadDialog({ isOpen, onClose }: AgentLoadDialogProps): React.ReactElement {
20
- const { data, isLoading, error, refresh, pruneSidecar, pruneResult } = useAgentLoad();
21
- const [expandedAgent, setExpandedAgent] = useState<string | null>(null);
22
- const [pendingPrune, setPendingPrune] = useState<{ agent: string; file: string } | null>(null);
23
-
24
- const { confirm, dialogProps } = useConfirmDialog({
25
- title: 'Clear Sidecar',
26
- message: pendingPrune
27
- ? `Reset ${pendingPrune.file} for ${pendingPrune.agent}? This will replace the sidecar with its default template.`
28
- : '',
29
- confirmLabel: 'Confirm',
30
- isDanger: true,
31
- });
32
-
33
- useEffect(() => {
34
- if (isOpen) {
35
- refresh();
36
- }
37
- }, [isOpen, refresh]);
38
-
39
- const sortedAgents = useMemo(() => {
40
- if (!data) return [];
41
- return [...data.agents].sort((a, b) => (b.totalTokens ?? 0) - (a.totalTokens ?? 0));
42
- }, [data]);
43
-
44
- const maxTokens = useMemo(() => {
45
- if (!sortedAgents.length) return 0;
46
- return sortedAgents[0]?.totalTokens ?? 0;
47
- }, [sortedAgents]);
48
-
49
- const handleRowClick = (agent: string) => {
50
- setExpandedAgent((prev) => (prev === agent ? null : agent));
51
- };
52
-
53
- const handleClear = async (agent: string, file: string) => {
54
- setPendingPrune({ agent, file });
55
- const confirmed = await confirm();
56
- if (confirmed) {
57
- await pruneSidecar(agent, file);
58
- }
59
- setPendingPrune(null);
60
- };
61
-
62
- const renderAgentRow = (entry: AgentLoadEntry) => {
63
- const tokens = entry.totalTokens ?? 0;
64
- const progressValue = maxTokens > 0 ? (tokens / maxTokens) * 100 : 0;
65
- const isExpanded = expandedAgent === entry.agent;
66
- // Color by token threshold: <3k green, <5k orange, >=5k red
67
- const barColor = tokens >= 5000
68
- ? 'bg-[var(--status-error,#f14c4c)]'
69
- : tokens >= 3000
70
- ? 'bg-[var(--status-warning,#cca700)]'
71
- : 'bg-[var(--status-success,#4ec9b0)]';
72
-
73
- return (
74
- <Collapsible
75
- key={entry.agent}
76
- open={isExpanded}
77
- onOpenChange={() => handleRowClick(entry.agent)}
78
- >
79
- <CollapsibleTrigger asChild>
80
- <div
81
- className="px-4 py-2 cursor-pointer hover:bg-muted/50 rounded-md transition-colors"
82
- data-testid={`agent-row-${entry.agent}`}
83
- >
84
- <div className="flex items-center justify-between mb-1">
85
- <span className="font-mono text-sm font-medium">{entry.agent}</span>
86
- <span className="font-mono text-sm tabular-nums text-text-secondary">
87
- {tokens.toLocaleString()}
88
- </span>
89
- </div>
90
- <Progress
91
- value={progressValue}
92
- className="h-2.5 bg-[var(--border)]"
93
- indicatorClassName={barColor}
94
- />
95
- </div>
96
- </CollapsibleTrigger>
97
- <CollapsibleContent>
98
- <div className="mx-4 mb-3 rounded-md bg-muted/30 p-3 space-y-1">
99
- {entry.components && entry.components.length > 0 ? (
100
- entry.components.map((comp) => (
101
- <div key={comp.name} className="flex items-center justify-between text-xs text-text-secondary">
102
- <span>{formatComponentName(comp.name)}</span>
103
- <span className="tabular-nums">{comp.tokens.toLocaleString()}</span>
104
- </div>
105
- ))
106
- ) : (
107
- <div className="text-xs text-text-secondary">No component breakdown available</div>
108
- )}
109
- <div className="pt-2 border-t border-muted/50 mt-2">
110
- <div className="text-xs font-medium mb-1.5 text-text-secondary">Sidecars</div>
111
- <div className="flex gap-2">
112
- {SIDECAR_FILES.map((file) => (
113
- <Button
114
- key={file}
115
- variant="ghost"
116
- size="sm"
117
- className="text-xs h-6"
118
- onClick={(e) => {
119
- e.stopPropagation();
120
- handleClear(entry.agent, file);
121
- }}
122
- >
123
- Clear {file}
124
- </Button>
125
- ))}
126
- </div>
127
- </div>
128
- </div>
129
- </CollapsibleContent>
130
- </Collapsible>
131
- );
132
- };
133
-
134
- const renderContent = () => {
135
- if (isLoading) {
136
- return (
137
- <div className="space-y-3 p-4">
138
- {Array.from({ length: 5 }).map((_, i) => (
139
- <div key={i} data-testid={`skeleton-${i}`} className="space-y-1.5 px-4">
140
- <div className="flex justify-between">
141
- <Skeleton className="h-4 w-24" />
142
- <Skeleton className="h-4 w-16" />
143
- </div>
144
- <Skeleton className="h-2.5 w-full rounded-full" />
145
- </div>
146
- ))}
147
- </div>
148
- );
149
- }
150
-
151
- if (error) {
152
- return (
153
- <div className="p-4 space-y-3">
154
- <div className="p-4 rounded border border-[var(--status-error)]/20 bg-[var(--status-error)]/5 text-[var(--status-error)] text-sm">
155
- {error.message}
156
- </div>
157
- <div className="text-center">
158
- <Button variant="outline" size="sm" onClick={refresh}>
159
- Retry
160
- </Button>
161
- </div>
162
- </div>
163
- );
164
- }
165
-
166
- if (!data) return null;
167
-
168
- return (
169
- <div className="space-y-0.5">
170
- {pruneResult?.success && pruneResult.tokensFreed != null && (
171
- <div className="text-xs text-green-600 px-4 py-1">
172
- Freed {pruneResult.tokensFreed.toLocaleString()} tokens from {pruneResult.agent}/{pruneResult.file}
173
- </div>
174
- )}
175
- <div className="flex items-center justify-between px-4 py-2">
176
- <span data-testid="cached-at" className="text-xs text-[var(--text-muted)]">
177
- Cached: {new Date(data.cachedAt).toLocaleString()}
178
- </span>
179
- <Button variant="ghost" size="sm" className="text-xs h-6 text-[var(--text-muted)] hover:text-[var(--text-primary)]" onClick={refresh}>
180
- Refresh
181
- </Button>
182
- </div>
183
- {sortedAgents.map((entry) => renderAgentRow(entry))}
184
- </div>
185
- );
186
- };
187
-
188
- return (
189
- <>
190
- <ToolDialog
191
- open={isOpen}
192
- onOpenChange={(open) => { if (!open) onClose(); }}
193
- title="Agent Load Analysis"
194
- description="Token usage breakdown for all agents"
195
- className="max-w-2xl"
196
- >
197
- {renderContent()}
198
- </ToolDialog>
199
- <ConfirmDialog {...dialogProps} />
200
- </>
201
- );
202
- }