@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,181 +0,0 @@
1
- import React, { useState, useEffect } from 'react';
2
- import { Button } from '@/components/ui/button';
3
-
4
- export interface HealthGaugeDimension {
5
- name: string;
6
- score: number | null;
7
- weight: number;
8
- }
9
-
10
- export interface HealthGaugeProps {
11
- score: number | null;
12
- dimensions: HealthGaugeDimension[];
13
- totalDimensions?: number;
14
- onDimensionClick?: (dimensionName: string) => void;
15
- isLoading?: boolean;
16
- lastFetchedAt?: number | null;
17
- onRefresh?: () => void;
18
- error?: Error | null;
19
- }
20
-
21
- const GRADE_BANDS: { min: number; grade: string; color: string }[] = [
22
- { min: 90, grade: 'A', color: '#22c55e' },
23
- { min: 75, grade: 'B', color: '#84cc16' },
24
- { min: 60, grade: 'C', color: '#eab308' },
25
- { min: 40, grade: 'D', color: '#f97316' },
26
- { min: 0, grade: 'F', color: '#ef4444' },
27
- ];
28
-
29
- const DIMENSION_LABELS: Record<string, string> = {
30
- churn: 'Churn',
31
- todo_density: 'TODO Density',
32
- complexity: 'Complexity',
33
- test_gaps: 'Test Gaps',
34
- dead_code: 'Dead Code',
35
- deprecation_debt: 'Deprecation Debt',
36
- dependency_freshness: 'Dependency Freshness',
37
- agent_context_efficiency: 'Agent Context Efficiency',
38
- };
39
-
40
- function getGrade(score: number): { grade: string; color: string } {
41
- for (const band of GRADE_BANDS) {
42
- if (score >= band.min) {
43
- return { grade: band.grade, color: band.color };
44
- }
45
- }
46
- return { grade: 'F', color: '#ef4444' };
47
- }
48
-
49
- // SVG arc helper for a semicircle gauge
50
- function describeArc(cx: number, cy: number, r: number, startAngle: number, endAngle: number): string {
51
- const start = polarToCartesian(cx, cy, r, endAngle);
52
- const end = polarToCartesian(cx, cy, r, startAngle);
53
- const largeArc = endAngle - startAngle <= 180 ? '0' : '1';
54
- return `M ${start.x} ${start.y} A ${r} ${r} 0 ${largeArc} 0 ${end.x} ${end.y}`;
55
- }
56
-
57
- function polarToCartesian(cx: number, cy: number, r: number, angleDeg: number) {
58
- const rad = ((angleDeg - 90) * Math.PI) / 180;
59
- return {
60
- x: cx + r * Math.cos(rad),
61
- y: cy + r * Math.sin(rad),
62
- };
63
- }
64
-
65
- function formatAge(ms: number): string {
66
- const seconds = Math.floor(ms / 1000);
67
- if (seconds < 60) return `${seconds}s ago`;
68
- const minutes = Math.floor(seconds / 60);
69
- if (minutes < 60) return `${minutes}m ago`;
70
- const hours = Math.floor(minutes / 60);
71
- return `${hours}h ago`;
72
- }
73
-
74
- export function HealthGauge({ score, dimensions, totalDimensions, onDimensionClick, isLoading, lastFetchedAt, onRefresh, error }: HealthGaugeProps): React.ReactElement {
75
- const hasData = score !== null && score !== undefined;
76
- const gradeInfo = hasData ? getGrade(score) : null;
77
- const fillAngle = hasData ? (score / 100) * 180 : 0;
78
-
79
- // Live-updating age display
80
- const [ageText, setAgeText] = useState<string | null>(null);
81
- useEffect(() => {
82
- if (!lastFetchedAt) {
83
- setAgeText(null);
84
- return;
85
- }
86
- const tick = () => setAgeText(formatAge(Date.now() - lastFetchedAt));
87
- tick();
88
- const id = setInterval(tick, 10_000);
89
- return () => clearInterval(id);
90
- }, [lastFetchedAt]);
91
-
92
- // Use all 8 dimension keys so rows always render (even before data arrives)
93
- const allDimKeys = Object.keys(DIMENSION_LABELS);
94
- const dimMap = new Map(dimensions.map((d) => [d.name, d]));
95
-
96
- return (
97
- <div
98
- data-testid="health-gauge"
99
- data-grade={gradeInfo?.grade ?? null}
100
- >
101
- <div className="health-gauge-header">
102
- <div className="health-gauge-status">
103
- {ageText && <span className="health-gauge-age" data-testid="health-gauge-age">{ageText}</span>}
104
- {error && <span className="health-gauge-error" data-testid="health-gauge-error">Failed</span>}
105
- </div>
106
- {onRefresh && (
107
- <Button
108
- variant="outline"
109
- size="sm"
110
- className="health-gauge-refresh"
111
- data-testid="health-gauge-refresh"
112
- onClick={onRefresh}
113
- disabled={isLoading}
114
- >
115
- {isLoading ? 'Analyzing...' : hasData ? 'Refresh' : 'Analyze'}
116
- </Button>
117
- )}
118
- </div>
119
-
120
- <svg viewBox="0 0 200 120" width="200" height="120" className={isLoading ? 'opacity-50' : ''}>
121
- {/* Background arc (grey) */}
122
- <path
123
- d={describeArc(100, 100, 80, 0, 180)}
124
- fill="none"
125
- stroke="#333"
126
- strokeWidth="12"
127
- strokeLinecap="round"
128
- />
129
- {/* Fill arc (colored by grade) */}
130
- {hasData && fillAngle > 0 && (
131
- <path
132
- d={describeArc(100, 100, 80, 0, fillAngle)}
133
- fill="none"
134
- stroke={gradeInfo!.color}
135
- strokeWidth="12"
136
- strokeLinecap="round"
137
- />
138
- )}
139
- {/* Score text */}
140
- <text x="100" y="85" textAnchor="middle" fontSize="28" fill="currentColor">
141
- {hasData ? String(Math.round(score)) : '--'}
142
- </text>
143
- {/* Grade letter */}
144
- {gradeInfo && (
145
- <text x="100" y="108" textAnchor="middle" fontSize="16" fill={gradeInfo.color}>
146
- {gradeInfo.grade}
147
- </text>
148
- )}
149
- </svg>
150
-
151
- {/* Dimension count for partial data */}
152
- {hasData && totalDimensions && dimensions.length < totalDimensions && (
153
- <div className="health-gauge-partial">
154
- {dimensions.length} of {totalDimensions} dimensions
155
- </div>
156
- )}
157
-
158
- {/* Dimension breakdown — always visible, each row opens its dialog */}
159
- <div data-testid="dimension-breakdown" className="health-gauge-breakdown">
160
- {allDimKeys.map((dimName) => {
161
- const dim = dimMap.get(dimName);
162
- return (
163
- <div
164
- key={dimName}
165
- data-testid={`dimension-${dimName}`}
166
- className="health-gauge-dimension"
167
- onClick={() => onDimensionClick?.(dimName)}
168
- >
169
- <span className="dimension-label">
170
- {DIMENSION_LABELS[dimName] || dimName}
171
- </span>
172
- <span className="dimension-score">
173
- {dim?.score !== null && dim?.score !== undefined ? dim.score.toFixed(1) : '--'}
174
- </span>
175
- </div>
176
- );
177
- })}
178
- </div>
179
- </div>
180
- );
181
- }
@@ -1,225 +0,0 @@
1
- /**
2
- * Message Component
3
- *
4
- * Renders a single message with avatar and content.
5
- * Story MSSCI-12698 - MessageView Component with Streaming
6
- * Story MSSCI-12777 - User Avatar from GitHub
7
- */
8
-
9
- import React, { useState, useEffect, useRef, useCallback } from 'react';
10
- import { Badge } from '@/components/ui/badge';
11
- import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '@/components/ui/tooltip';
12
- import { parseMarkdown } from '../utils/markdown';
13
- import StreamingContent from './StreamingContent';
14
- import { usePersona } from '../hooks/usePersona';
15
- import { useUserAvatar } from '../hooks/useUserAvatar';
16
- import type { MessageData } from '../types/message';
17
-
18
- interface MessageProps {
19
- message: MessageData;
20
- isLastAgentMessage?: boolean;
21
- /** Whether this is the first message in a turn (shows avatar) */
22
- isFirstInTurn?: boolean;
23
- }
24
-
25
- interface AssistantAvatarProps {
26
- isStreaming?: boolean;
27
- agentSlug?: string;
28
- agentTheme?: string;
29
- agentCharacter?: string;
30
- }
31
-
32
- function AssistantAvatar({ isStreaming, agentSlug, agentTheme, agentCharacter }: AssistantAvatarProps): React.ReactElement {
33
- const { persona } = usePersona();
34
- const [imageError, setImageError] = useState(false);
35
-
36
- // Use per-message persona if available, fall back to current global persona
37
- const slug = agentSlug || persona?.slug;
38
- const theme = agentTheme || persona?.theme;
39
- const character = agentCharacter || persona?.character;
40
- const avatarClass = isStreaming ? 'avatar-portrait avatar-thinking' : 'avatar-portrait';
41
-
42
- if (slug && theme && !imageError) {
43
- return (
44
- <img
45
- src={`/portraits/${theme}/small/${slug}.png`}
46
- alt={character || 'Agent'}
47
- className={avatarClass}
48
- onError={() => setImageError(true)}
49
- />
50
- );
51
- }
52
-
53
- return <span className={isStreaming ? 'avatar-emoji avatar-thinking' : 'avatar-emoji'}>🤖</span>;
54
- }
55
-
56
- function UserAvatar(): React.ReactElement {
57
- const { avatarUrl, isLoading } = useUserAvatar();
58
- const [imageError, setImageError] = useState(false);
59
-
60
- if (isLoading) {
61
- return <span className="avatar-emoji">👤</span>;
62
- }
63
-
64
- if (avatarUrl && !imageError) {
65
- return (
66
- <img
67
- src={avatarUrl}
68
- alt="User"
69
- className="avatar-portrait"
70
- onError={() => setImageError(true)}
71
- />
72
- );
73
- }
74
-
75
- return <span className="avatar-emoji">👤</span>;
76
- }
77
-
78
- function useSortableTables(contentRef: React.RefObject<HTMLDivElement | null>) {
79
- const attachSort = useCallback(() => {
80
- const el = contentRef.current;
81
- if (!el) return;
82
- const headers = el.querySelectorAll<HTMLTableCellElement>('th.sortable-th');
83
- headers.forEach((th) => {
84
- if (th.dataset.sortBound) return;
85
- th.dataset.sortBound = '1';
86
- th.style.cursor = 'pointer';
87
- th.addEventListener('click', () => {
88
- const colIdx = parseInt(th.dataset.col || '0', 10);
89
- const table = th.closest('table');
90
- if (!table) return;
91
- const tbody = table.querySelector('tbody');
92
- if (!tbody) return;
93
- const rows = Array.from(tbody.querySelectorAll('tr'));
94
- const currentDir = th.dataset.sortDir === 'asc' ? 'desc' : 'asc';
95
-
96
- // Clear all indicators in this table
97
- table.querySelectorAll<HTMLTableCellElement>('th.sortable-th').forEach((h) => {
98
- h.dataset.sortDir = '';
99
- const ind = h.querySelector('.sort-indicator');
100
- if (ind) ind.textContent = '';
101
- });
102
-
103
- th.dataset.sortDir = currentDir;
104
- const indicator = th.querySelector('.sort-indicator');
105
- if (indicator) indicator.textContent = currentDir === 'asc' ? ' \u25B2' : ' \u25BC';
106
-
107
- rows.sort((a, b) => {
108
- const aText = (a.children[colIdx]?.textContent || '').trim();
109
- const bText = (b.children[colIdx]?.textContent || '').trim();
110
- const aNum = parseFloat(aText);
111
- const bNum = parseFloat(bText);
112
- // Numeric sort if both parse as numbers
113
- if (!isNaN(aNum) && !isNaN(bNum)) {
114
- return currentDir === 'asc' ? aNum - bNum : bNum - aNum;
115
- }
116
- const cmp = aText.localeCompare(bText, undefined, { sensitivity: 'base' });
117
- return currentDir === 'asc' ? cmp : -cmp;
118
- });
119
-
120
- for (const row of rows) {
121
- tbody.appendChild(row);
122
- }
123
- });
124
- });
125
- }, [contentRef]);
126
-
127
- useEffect(() => {
128
- attachSort();
129
- });
130
- }
131
-
132
- export default function Message({ message, isLastAgentMessage, isFirstInTurn = true }: MessageProps): React.ReactElement {
133
- const contentRef = useRef<HTMLDivElement>(null);
134
- useSortableTables(contentRef);
135
- const roleClass = `message-${message.type}`;
136
- const testId = `message-${message.type}`;
137
- const continuationClass = !isFirstInTurn ? ' continuation' : '';
138
-
139
- // For bell-injected messages (queued messages injected via PostToolUse hook)
140
- // Show with 🔔 indicator so user knows it was sent mid-turn
141
- if (message.type === 'bell_injected') {
142
- const html = message.content ? parseMarkdown(message.content) : '';
143
- return (
144
- <TooltipProvider delayDuration={300}>
145
- <div data-testid="message-bell-injected" className={`message message-user message-bell-injected${continuationClass}`}>
146
- <div data-testid="avatar" className="message-avatar">
147
- <UserAvatar />
148
- </div>
149
- <div className="message-content">
150
- <Tooltip>
151
- <TooltipTrigger asChild>
152
- <Badge variant="secondary" className="bell-indicator">🔔</Badge>
153
- </TooltipTrigger>
154
- <TooltipContent>Injected via Bell Mode</TooltipContent>
155
- </Tooltip>
156
- <div dangerouslySetInnerHTML={{ __html: html }} />
157
- {message.imageCount && message.imageCount > 0 && (
158
- <Tooltip>
159
- <TooltipTrigger asChild>
160
- <Badge variant="outline" className="message-attachment-indicator">
161
- 📎 {message.imageCount}
162
- </Badge>
163
- </TooltipTrigger>
164
- <TooltipContent>{`${message.imageCount} image${message.imageCount > 1 ? 's' : ''} attached`}</TooltipContent>
165
- </Tooltip>
166
- )}
167
- </div>
168
- </div>
169
- </TooltipProvider>
170
- );
171
- }
172
-
173
- // For streaming agent messages, use StreamingContent with throbbing avatar
174
- // Only throb the last agent message's avatar
175
- if (message.type === 'agent' && message.isStreaming) {
176
- const showThrob = isLastAgentMessage !== false;
177
- return (
178
- <div data-testid={testId} className={`message ${roleClass}${continuationClass}`}>
179
- <div data-testid="avatar" className="message-avatar">
180
- <AssistantAvatar
181
- isStreaming={showThrob}
182
- agentSlug={message.agentSlug}
183
- agentTheme={message.agentTheme}
184
- agentCharacter={message.agentCharacter}
185
- />
186
- </div>
187
- <div className="message-content">
188
- <StreamingContent content={message.content || ''} isStreaming={message.isStreaming ?? false} />
189
- </div>
190
- </div>
191
- );
192
- }
193
-
194
- // For regular messages, render markdown
195
- const html = message.content ? parseMarkdown(message.content) : '';
196
-
197
- return (
198
- <div data-testid={testId} className={`message ${roleClass}${continuationClass}`} ref={contentRef}>
199
- <div data-testid="avatar" className="message-avatar">
200
- {message.type === 'user' ? <UserAvatar /> : (
201
- <AssistantAvatar
202
- agentSlug={message.agentSlug}
203
- agentTheme={message.agentTheme}
204
- agentCharacter={message.agentCharacter}
205
- />
206
- )}
207
- </div>
208
- <div className="message-content">
209
- <div dangerouslySetInnerHTML={{ __html: html }} />
210
- {message.type === 'user' && message.imageCount && message.imageCount > 0 && (
211
- <TooltipProvider delayDuration={300}>
212
- <Tooltip>
213
- <TooltipTrigger asChild>
214
- <Badge variant="outline" className="message-attachment-indicator">
215
- 📎 {message.imageCount}
216
- </Badge>
217
- </TooltipTrigger>
218
- <TooltipContent>{`${message.imageCount} image${message.imageCount > 1 ? 's' : ''} attached`}</TooltipContent>
219
- </Tooltip>
220
- </TooltipProvider>
221
- )}
222
- </div>
223
- </div>
224
- );
225
- }
@@ -1,98 +0,0 @@
1
- /**
2
- * MessageList Component
3
- *
4
- * Scrolling container for message list with auto-scroll support.
5
- * Story MSSCI-12698 - MessageView Component with Streaming
6
- */
7
-
8
- import React, { useRef, useEffect, useCallback, forwardRef, useImperativeHandle } from 'react';
9
-
10
- interface MessageListProps {
11
- children: React.ReactNode;
12
- onScrollChange?: (isAtBottom: boolean) => void;
13
- autoScroll?: boolean;
14
- }
15
-
16
- export interface MessageListHandle {
17
- scrollToBottom: (behavior?: ScrollBehavior) => void;
18
- }
19
-
20
- const MessageList = forwardRef<MessageListHandle, MessageListProps>(
21
- ({ children, onScrollChange, autoScroll = true }, ref) => {
22
- const containerRef = useRef<HTMLDivElement>(null);
23
- const isAtBottomRef = useRef(true);
24
-
25
- const checkIfAtBottom = useCallback((scrollTopOverride?: number) => {
26
- const container = containerRef.current;
27
- if (!container) return true;
28
-
29
- const scrollTop = scrollTopOverride ?? container.scrollTop;
30
- const scrollHeight = container.scrollHeight || 0;
31
- const clientHeight = container.clientHeight || 0;
32
-
33
- // Test environment: scrollHeight may be 0 but we have children
34
- // If scrollTop is explicitly 0 and we have children, assume not at bottom
35
- if (scrollTop === 0 && scrollHeight === 0 && container.children.length > 0) {
36
- return false;
37
- }
38
-
39
- // If scrollTop is 0 and there's scrollable content, we're at top (not bottom)
40
- if (scrollTop === 0 && scrollHeight > clientHeight) {
41
- return false;
42
- }
43
-
44
- // If there's no scrollable area, consider it at bottom
45
- if (scrollHeight <= clientHeight) {
46
- return true;
47
- }
48
-
49
- const threshold = 50; // pixels from bottom
50
- const isAtBottom = scrollHeight - scrollTop - clientHeight < threshold;
51
- return isAtBottom;
52
- }, []);
53
-
54
- const scrollToBottom = useCallback((behavior: ScrollBehavior = 'auto') => {
55
- const container = containerRef.current;
56
- if (!container) return;
57
-
58
- container.scrollTo({
59
- top: container.scrollHeight,
60
- behavior,
61
- });
62
- }, []);
63
-
64
- // Expose scrollToBottom to parent via ref
65
- useImperativeHandle(ref, () => ({
66
- scrollToBottom,
67
- }));
68
-
69
- const handleScroll = useCallback((event: React.UIEvent<HTMLDivElement>) => {
70
- const target = event.target as HTMLDivElement;
71
- const isAtBottom = checkIfAtBottom(target.scrollTop);
72
- isAtBottomRef.current = isAtBottom;
73
- onScrollChange?.(isAtBottom);
74
- }, [checkIfAtBottom, onScrollChange]);
75
-
76
- // Auto-scroll when children change (new messages)
77
- useEffect(() => {
78
- if (autoScroll && isAtBottomRef.current) {
79
- scrollToBottom();
80
- }
81
- }, [children, autoScroll, scrollToBottom]);
82
-
83
- return (
84
- <div
85
- ref={containerRef}
86
- data-testid="message-list"
87
- className="message-list"
88
- onScroll={handleScroll}
89
- >
90
- {children}
91
- </div>
92
- );
93
- }
94
- );
95
-
96
- MessageList.displayName = 'MessageList';
97
-
98
- export default MessageList;