@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,344 +0,0 @@
1
- /**
2
- * DebugPanel - Context usage and token stats display
3
- *
4
- * Story MSSCI-12717 - React Migration
5
- * Story MSSCI-12799 - Tier display
6
- * Story MSSCI-12782 - Token stats formatting
7
- *
8
- * Note: Tool call display moved to AuditLogPanel for comprehensive view.
9
- */
10
-
11
- import React, { useState, useEffect, useRef, useCallback } from 'react';
12
- import { Button } from '@/components/ui/button';
13
- import { Badge } from '@/components/ui/badge';
14
- import { Separator } from '@/components/ui/separator';
15
- import { HotspotsDialog } from '../dialogs/HotspotsDialog';
16
- import { CodeMarkersDialog } from '../dialogs/CodeMarkersDialog';
17
- import { ComplexityDialog } from '../dialogs/ComplexityDialog';
18
- import { DependenciesDialog } from '../dialogs/DependenciesDialog';
19
- import { AgentLoadDialog } from '../AgentLoadDialog';
20
- import { DeadCodeDialog } from '../DeadCodeDialog';
21
- import { HealthGauge } from '../HealthGauge';
22
- import { ContextSparkline, SparklinePoint } from '../ContextSparkline';
23
- import { useHealthScore } from '../../hooks/useHealthScore';
24
-
25
- /** Context tier type */
26
- type ContextTier = 'FULL' | 'REFRESH' | 'HANDOFF' | 'MINIMAL';
27
-
28
- /** Matches ContextInfo shape from api/context.ts */
29
- interface ContextData {
30
- /** Used tokens (from check-context.sh CONTEXT_TOKENS) */
31
- tokens?: number | null;
32
- percent?: number | null;
33
- status?: string | null;
34
- error?: string | null;
35
- /** System prompt overhead (first turn tokens) */
36
- baseline?: number | null;
37
- /** Tokens used by conversation (total - baseline) */
38
- usableTokens?: number | null;
39
- /** Conversation usage as % of available capacity */
40
- usablePercent?: number | null;
41
- /** Available capacity (max - baseline) */
42
- available?: number | null;
43
- /** Current context tier */
44
- tier?: ContextTier;
45
- /** Per-component token counts (MSSCI-12800) */
46
- tokenCounts?: Record<string, number>;
47
- /** Total tokens across all injected components (MSSCI-12800) */
48
- totalTokens?: number;
49
- }
50
-
51
- /**
52
- * Format a component name from snake_case to Title Case
53
- *
54
- * Examples:
55
- * - agent_definition → Agent Definition
56
- * - behavior_guide → Behavior Guide
57
- * - persona_compressed → Persona (Compressed)
58
- * - session_header → Session Header
59
- *
60
- * @param name - Component name in snake_case
61
- * @returns Formatted component name in Title Case
62
- */
63
- export function formatComponentName(name: string): string {
64
- // Handle special case for compressed persona
65
- if (name === 'persona_compressed') {
66
- return 'Persona (Compressed)';
67
- }
68
-
69
- // Convert snake_case to Title Case
70
- return name
71
- .split('_')
72
- .map(word => word.charAt(0).toUpperCase() + word.slice(1))
73
- .join(' ');
74
- }
75
-
76
- /**
77
- * Calculate token savings percentage for a given tier vs FULL
78
- *
79
- * Token estimates:
80
- * - FULL: ~4000 tokens (baseline)
81
- * - REFRESH: ~600 tokens (85% savings)
82
- * - HANDOFF: ~700 tokens (82% savings)
83
- * - MINIMAL: ~200 tokens (95% savings)
84
- */
85
- export function calculateTierSavings(tier: ContextTier | undefined): number {
86
- if (!tier) return 0;
87
-
88
- switch (tier) {
89
- case 'FULL':
90
- return 0;
91
- case 'REFRESH':
92
- return 85;
93
- case 'HANDOFF':
94
- return 82;
95
- case 'MINIMAL':
96
- return 95;
97
- default:
98
- return 0;
99
- }
100
- }
101
-
102
- export function DebugPanel(): React.ReactElement {
103
- const [context, setContext] = useState<ContextData | null>(null);
104
- const [tokenStats, setTokenStats] = useState<Record<string, unknown> | null>(null);
105
- const [breakdownExpanded, setBreakdownExpanded] = useState(false);
106
- const [hotspotsOpen, setHotspotsOpen] = useState(false);
107
- const [codeMarkersOpen, setCodeMarkersOpen] = useState(false);
108
- const [complexityOpen, setComplexityOpen] = useState(false);
109
- const [dependenciesOpen, setDependenciesOpen] = useState(false);
110
- const [agentLoadOpen, setAgentLoadOpen] = useState(false);
111
- const [deadCodeOpen, setDeadCodeOpen] = useState(false);
112
- const healthScore = useHealthScore();
113
- const sparklineRef = useRef<SparklinePoint[]>([]);
114
- const [sparklineVersion, setSparklineVersion] = useState(0);
115
-
116
- const pushSparklinePoint = useCallback((percent: number, tokens: number) => {
117
- const buf = sparklineRef.current;
118
- buf.push({ percent, tokens, timestamp: Date.now() });
119
- if (buf.length > 50) buf.shift();
120
- setSparklineVersion(v => v + 1);
121
- }, []);
122
-
123
- const handleDimensionClick = (dimensionName: string) => {
124
- switch (dimensionName) {
125
- case 'churn':
126
- setHotspotsOpen(true);
127
- break;
128
- case 'test_gaps':
129
- // TODO: TestGapsDialog — for now no drill-down
130
- break;
131
- case 'todo_density':
132
- case 'deprecation_debt':
133
- setCodeMarkersOpen(true);
134
- break;
135
- case 'complexity':
136
- setComplexityOpen(true);
137
- break;
138
- case 'dead_code':
139
- setDeadCodeOpen(true);
140
- break;
141
- case 'dependency_freshness':
142
- setDependenciesOpen(true);
143
- break;
144
- case 'agent_context_efficiency':
145
- setAgentLoadOpen(true);
146
- break;
147
- }
148
- };
149
-
150
- useEffect(() => {
151
- const protocol = window.location.protocol === 'https:' ? 'wss:' : 'ws:';
152
-
153
- // Connect to context WebSocket
154
- const contextWs = new WebSocket(`${protocol}//${window.location.host}/ws/context`);
155
- contextWs.onmessage = (event) => {
156
- try {
157
- const data = JSON.parse(event.data);
158
- if (data.type === 'init' || data.type === 'update') {
159
- const ctx = data.context as ContextData;
160
- setContext(ctx);
161
- if (ctx.percent != null) {
162
- pushSparklinePoint(ctx.percent, ctx.tokens ?? 0);
163
- }
164
- }
165
- } catch {
166
- // Ignore parse errors
167
- }
168
- };
169
-
170
- // Connect to token-stats WebSocket
171
- const tokenWs = new WebSocket(`${protocol}//${window.location.host}/ws/token-stats`);
172
- tokenWs.onmessage = (event) => {
173
- try {
174
- const data = JSON.parse(event.data);
175
- setTokenStats(data as Record<string, unknown>);
176
- } catch {
177
- // Ignore parse errors
178
- }
179
- };
180
-
181
- return () => {
182
- contextWs.close();
183
- tokenWs.close();
184
- };
185
- }, [pushSparklinePoint]);
186
-
187
- // Compute tier-specific CSS class
188
- const tierClass = context?.tier ? `tier-${context.tier.toLowerCase()}` : '';
189
- const tierSavings = calculateTierSavings(context?.tier);
190
-
191
- return (
192
- <div className="debug-panel" data-testid="debug-panel">
193
- <HealthGauge
194
- score={healthScore.data?.composite_score ?? null}
195
- dimensions={healthScore.data?.dimensions ?? []}
196
- totalDimensions={8}
197
- onDimensionClick={handleDimensionClick}
198
- isLoading={healthScore.isLoading}
199
- lastFetchedAt={healthScore.lastFetchedAt}
200
- onRefresh={healthScore.refresh}
201
- error={healthScore.error}
202
- />
203
-
204
- <Separator className="my-3" />
205
-
206
- <h4>Context Usage</h4>
207
- {context ? (
208
- <div className="context-info">
209
- {context.tier && (
210
- <div className="tier-display">
211
- <Badge
212
- variant="outline"
213
- className={`tier-badge ${tierClass}`}
214
- data-testid="tier-badge"
215
- >
216
- {context.tier}
217
- </Badge>
218
- <span className="tier-savings" data-testid="tier-savings">
219
- {tierSavings}% savings
220
- </span>
221
- </div>
222
- )}
223
- {context.tokenCounts && Object.keys(context.tokenCounts).length > 0 && (
224
- <div className="component-breakdown" data-testid="component-breakdown">
225
- <div className="breakdown-header">
226
- <Button
227
- variant="ghost"
228
- size="sm"
229
- className="breakdown-toggle"
230
- data-testid="breakdown-toggle"
231
- onClick={() => setBreakdownExpanded(!breakdownExpanded)}
232
- aria-expanded={breakdownExpanded}
233
- >
234
- {breakdownExpanded ? '▼' : '▶'} Injected Context
235
- </Button>
236
- <span className="total-tokens" data-testid="total-tokens">
237
- {context.totalTokens?.toLocaleString()} tokens
238
- </span>
239
- </div>
240
- <div
241
- className={`component-list ${breakdownExpanded ? 'expanded' : 'collapsed'}`}
242
- data-testid="component-list"
243
- aria-expanded={breakdownExpanded}
244
- >
245
- {/* Sort components by token count descending, filter out zero values */}
246
- {Object.entries(context.tokenCounts)
247
- .filter(([, count]) => count > 0)
248
- .sort(([, a], [, b]) => b - a)
249
- .map(([name, count]) => (
250
- <div
251
- key={name}
252
- className="component-item"
253
- data-testid={`component-${name}`}
254
- >
255
- <span className="component-name">
256
- {formatComponentName(name)}
257
- </span>
258
- <span className="component-tokens">
259
- {count.toLocaleString()}
260
- </span>
261
- </div>
262
- ))}
263
- </div>
264
- </div>
265
- )}
266
- <div className="context-bar">
267
- <div
268
- className="context-fill"
269
- style={{ width: `${context.percent || 0}%` }}
270
- />
271
- </div>
272
- <ContextSparkline history={sparklineRef.current} key={sparklineVersion} />
273
- <span className="context-text">
274
- {(context.tokens ?? 0).toLocaleString()} / {context.baseline != null && context.available != null
275
- ? (context.baseline + context.available).toLocaleString()
276
- : '—'} tokens
277
- ({context.percent || 0}%)
278
- </span>
279
- {context.baseline != null && (
280
- <dl className="context-breakdown">
281
- <dt>System Prompt</dt>
282
- <dd>{context.baseline.toLocaleString()} tokens</dd>
283
- <dt>Conversation</dt>
284
- <dd>{context.usableTokens?.toLocaleString() ?? '—'} tokens</dd>
285
- <dt>Available</dt>
286
- <dd>{context.available?.toLocaleString() ?? '—'} tokens</dd>
287
- </dl>
288
- )}
289
- </div>
290
- ) : (
291
- <div className="placeholder">No context data</div>
292
- )}
293
-
294
- <Separator className="my-3" />
295
-
296
- <h4>Token Stats</h4>
297
- {tokenStats ? (
298
- <dl className="token-stats">
299
- {tokenStats.inputTokens !== undefined && (
300
- <div className="token-stat-card" data-testid="token-stat-input">
301
- <dt>Input</dt>
302
- <dd>{Number(tokenStats.inputTokens).toLocaleString()}</dd>
303
- </div>
304
- )}
305
- {tokenStats.outputTokens !== undefined && (
306
- <div className="token-stat-card" data-testid="token-stat-output">
307
- <dt>Output</dt>
308
- <dd>{Number(tokenStats.outputTokens).toLocaleString()}</dd>
309
- </div>
310
- )}
311
- {tokenStats.cacheReadTokens !== undefined && (
312
- <div className="token-stat-card" data-testid="token-stat-cache-read">
313
- <dt>Cache Read</dt>
314
- <dd>{Number(tokenStats.cacheReadTokens).toLocaleString()}</dd>
315
- </div>
316
- )}
317
- {tokenStats.cacheCreationTokens !== undefined && (
318
- <div className="token-stat-card" data-testid="token-stat-cache-write">
319
- <dt>Cache Write</dt>
320
- <dd>{Number(tokenStats.cacheCreationTokens).toLocaleString()}</dd>
321
- </div>
322
- )}
323
- {tokenStats.totalCostUsd !== undefined && Number(tokenStats.totalCostUsd) > 0 && (
324
- <div className="token-stat-card" data-testid="token-stat-cost">
325
- <dt>Cost</dt>
326
- <dd>${Number(tokenStats.totalCostUsd).toFixed(4)}</dd>
327
- </div>
328
- )}
329
- </dl>
330
- ) : (
331
- <div className="placeholder">No token stats</div>
332
- )}
333
-
334
- <HotspotsDialog open={hotspotsOpen} onOpenChange={setHotspotsOpen} />
335
- <CodeMarkersDialog open={codeMarkersOpen} onOpenChange={setCodeMarkersOpen} />
336
- <ComplexityDialog open={complexityOpen} onOpenChange={setComplexityOpen} />
337
- <DependenciesDialog open={dependenciesOpen} onOpenChange={setDependenciesOpen} />
338
- <AgentLoadDialog isOpen={agentLoadOpen} onClose={() => setAgentLoadOpen(false)} />
339
- <DeadCodeDialog isOpen={deadCodeOpen} onClose={() => setDeadCodeOpen(false)} />
340
- </div>
341
- );
342
- }
343
-
344
- export default DebugPanel;
@@ -1,155 +0,0 @@
1
- /**
2
- * DiffsPanel - Display file diffs
3
- *
4
- * Story MSSCI-12717 - React Migration
5
- * Story MSSCI-14238 - Git-based diffs (renders raw unified diff format)
6
- */
7
-
8
- import React from 'react';
9
- import { Button } from '@/components/ui/button';
10
- import { useDiffs, DiffData } from '../../hooks/useDiffs';
11
-
12
- interface DiffLineProps {
13
- line: string;
14
- type: 'added' | 'removed' | 'context' | 'header' | 'hunk';
15
- lineNum?: number;
16
- }
17
-
18
- function DiffLine({ line, type, lineNum }: DiffLineProps): React.ReactElement {
19
- return (
20
- <div className={`diff-line diff-${type}`}>
21
- {lineNum !== undefined && <span className="line-num">{lineNum}</span>}
22
- <span className="line-content">{line}</span>
23
- </div>
24
- );
25
- }
26
-
27
- /**
28
- * Parse raw git diff output into renderable lines
29
- */
30
- function parseGitDiffLines(rawDiff: string): Array<{ line: string; type: DiffLineProps['type']; lineNum?: number }> {
31
- const lines = rawDiff.split('\n');
32
- const result: Array<{ line: string; type: DiffLineProps['type']; lineNum?: number }> = [];
33
- let lineNum = 0;
34
-
35
- for (const line of lines) {
36
- if (line.startsWith('diff --git') || line.startsWith('index ') ||
37
- line.startsWith('---') || line.startsWith('+++')) {
38
- result.push({ line, type: 'header' });
39
- } else if (line.startsWith('@@')) {
40
- // Hunk header - extract starting line number
41
- const match = line.match(/@@ -\d+(?:,\d+)? \+(\d+)/);
42
- if (match) {
43
- lineNum = parseInt(match[1], 10) - 1;
44
- }
45
- result.push({ line, type: 'hunk' });
46
- } else if (line.startsWith('+')) {
47
- lineNum++;
48
- result.push({ line: line.substring(1), type: 'added', lineNum });
49
- } else if (line.startsWith('-')) {
50
- result.push({ line: line.substring(1), type: 'removed' });
51
- } else if (line.startsWith(' ') || line === '') {
52
- lineNum++;
53
- result.push({ line: line.substring(1) || '', type: 'context', lineNum });
54
- } else {
55
- // Binary file notice or other content
56
- result.push({ line, type: 'context' });
57
- }
58
- }
59
-
60
- return result;
61
- }
62
-
63
- function DiffView({ diff }: { diff: DiffData }): React.ReactElement {
64
- // MSSCI-14238: Prefer raw git diff if available
65
- const hasGitDiff = diff.diff && diff.diff.trim().length > 0;
66
-
67
- let lines: Array<{ line: string; type: DiffLineProps['type']; lineNum?: number }>;
68
-
69
- if (hasGitDiff) {
70
- // Use git diff output directly
71
- lines = parseGitDiffLines(diff.diff!);
72
- } else {
73
- // Fallback to legacy original/modified comparison (deprecated)
74
- const originalLines = (diff.original || '').split('\n');
75
- const modifiedLines = (diff.modified || '').split('\n');
76
- lines = [];
77
-
78
- originalLines.forEach((line, i) => {
79
- if (!modifiedLines.includes(line)) {
80
- lines.push({ line, type: 'removed', lineNum: i + 1 });
81
- }
82
- });
83
-
84
- modifiedLines.forEach((line, i) => {
85
- const type = originalLines.includes(line) ? 'context' : 'added';
86
- lines.push({ line, type, lineNum: i + 1 });
87
- });
88
- }
89
-
90
- // Stats display for git diffs
91
- const statsDisplay = diff.additions !== undefined && diff.deletions !== undefined
92
- ? `+${diff.additions} -${diff.deletions}`
93
- : null;
94
-
95
- return (
96
- <div className="diff-view" data-testid="diff-view">
97
- <div className="diff-header">
98
- <span className="diff-path">{diff.path}</span>
99
- {diff.status && <span className={`diff-status diff-status-${diff.status}`}>{diff.status}</span>}
100
- {statsDisplay && <span className="diff-stats">{statsDisplay}</span>}
101
- <span className="diff-tool">{diff.toolName}</span>
102
- </div>
103
- <div className="diff-content">
104
- {lines.map((l, i) => (
105
- <DiffLine key={i} line={l.line} type={l.type} lineNum={l.lineNum} />
106
- ))}
107
- </div>
108
- </div>
109
- );
110
- }
111
-
112
- export function DiffsPanel(): React.ReactElement {
113
- const { diffs, selectedDiff, selectDiff, clearDiffs } = useDiffs();
114
-
115
- if (diffs.length === 0) {
116
- return (
117
- <div className="diffs-panel empty" data-testid="diffs-panel">
118
- <div className="placeholder">No diffs yet</div>
119
- <p className="hint">Diffs appear when files are modified</p>
120
- </div>
121
- );
122
- }
123
-
124
- return (
125
- <div className="diffs-panel" data-testid="diffs-panel">
126
- <div className="panel-header">
127
- <span className="diff-count">{diffs.length} file(s)</span>
128
- <Button variant="ghost" size="sm" type="button" className="clear-button" onClick={clearDiffs}>
129
- Clear
130
- </Button>
131
- </div>
132
-
133
- {diffs.length > 1 && (
134
- <div className="diff-tabs">
135
- {diffs.map(diff => (
136
- <Button
137
- variant={selectedDiff?.path === diff.path ? 'secondary' : 'ghost'}
138
- size="sm"
139
- key={diff.path}
140
- type="button"
141
- className={`diff-tab ${selectedDiff?.path === diff.path ? 'active' : ''}`}
142
- onClick={() => selectDiff(diff.path)}
143
- >
144
- {diff.path.split('/').pop()}
145
- </Button>
146
- ))}
147
- </div>
148
- )}
149
-
150
- {selectedDiff && <DiffView diff={selectedDiff} />}
151
- </div>
152
- );
153
- }
154
-
155
- export default DiffsPanel;