@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,93 +0,0 @@
1
- /**
2
- * ACPanel - Acceptance criteria checklist panel
3
- *
4
- * Extracted from ProgressPanel as part of MSSCI-14188.
5
- * Shows acceptance criteria with completion status and progress bar.
6
- *
7
- * Story: MSSCI-14188 - Split Progress panel into Workflow, AC, and Todo panels
8
- * Epic: epic-76 (Dockview Panel Migration)
9
- */
10
-
11
- import React from 'react';
12
- import { Skeleton } from '@/components/ui/skeleton';
13
- import { useStory } from '../../hooks/useStory';
14
- import type { CriteriaItem } from '../../../story-parser.js';
15
-
16
- // =============================================================================
17
- // Criteria Item Component
18
- // =============================================================================
19
-
20
- function CriteriaItemView({ item }: { item: CriteriaItem }): React.ReactElement {
21
- const statusClass = item.completed ? 'ac-item ac-done' : 'ac-item';
22
- const icon = item.completed ? '\u2713' : '\u25CB';
23
-
24
- return (
25
- <div className={statusClass}>
26
- <span className="ac-icon">{icon}</span>
27
- <span className="ac-text">{item.text}</span>
28
- </div>
29
- );
30
- }
31
-
32
- // =============================================================================
33
- // ACPanel Component
34
- // =============================================================================
35
-
36
- export function ACPanel(): React.ReactElement {
37
- const { story, isLoading, error } = useStory();
38
-
39
- if (isLoading) {
40
- return (
41
- <div className="ac-panel loading" data-testid="ac-panel">
42
- <div className="space-y-2 p-2">
43
- <Skeleton className="h-3 w-full" />
44
- <Skeleton className="h-4 w-3/4" />
45
- <Skeleton className="h-4 w-5/6" />
46
- <Skeleton className="h-4 w-2/3" />
47
- </div>
48
- </div>
49
- );
50
- }
51
-
52
- if (error) {
53
- return (
54
- <div className="ac-panel error" data-testid="ac-panel">
55
- <div className="error-message">{error.message}</div>
56
- </div>
57
- );
58
- }
59
-
60
- const criteria = story?.criteria ?? null;
61
-
62
- if (!criteria || criteria.length === 0) {
63
- return (
64
- <div className="ac-panel" data-testid="ac-panel">
65
- <div className="placeholder">No acceptance criteria</div>
66
- </div>
67
- );
68
- }
69
-
70
- const completedCount = criteria.filter(c => c.completed).length;
71
- const totalCount = criteria.length;
72
-
73
- return (
74
- <div className="ac-panel" data-testid="ac-panel">
75
- <div className="ac-content">
76
- <span className="progress-text">{completedCount}/{totalCount}</span>
77
- <div className="progress-bar-container">
78
- <div
79
- className="progress-bar"
80
- style={{ width: `${(completedCount / totalCount) * 100}%` }}
81
- />
82
- </div>
83
- <div className="ac-list">
84
- {criteria.map((item, index) => (
85
- <CriteriaItemView key={index} item={item} />
86
- ))}
87
- </div>
88
- </div>
89
- </div>
90
- );
91
- }
92
-
93
- export default ACPanel;
@@ -1,104 +0,0 @@
1
- /**
2
- * AcceptanceCriteriaPanel - Display acceptance criteria checklist
3
- *
4
- * Story MSSCI-12849 - Missing AC & BikeLane panels in Progress tab
5
- *
6
- * Reference: Deleted vanilla JS in commit 9aea4f371
7
- * - js/sidebar/acceptance-criteria.js
8
- */
9
-
10
- import React from 'react';
11
- import { Skeleton } from '@/components/ui/skeleton';
12
- import type { CriteriaItem } from '../../../story-parser.js';
13
- import { useStory } from '../../hooks/useStory.js';
14
-
15
- export interface AcceptanceCriteriaPanelProps {
16
- criteria: CriteriaItem[] | null;
17
- collapsed?: boolean;
18
- onToggle?: () => void;
19
- }
20
-
21
- /**
22
- * Individual acceptance criteria item
23
- */
24
- function CriteriaItemView({ item }: { item: CriteriaItem }): React.ReactElement {
25
- const statusClass = `todo-item ${item.completed ? 'todo-completed' : ''}`;
26
- return (
27
- <div className={statusClass}>
28
- <span className="todo-status">{item.completed ? '\u2713' : '\u25CB'}</span>
29
- <span className="todo-subject">{item.text}</span>
30
- </div>
31
- );
32
- }
33
-
34
- /**
35
- * AcceptanceCriteriaPanel - Displays acceptance criteria checklist with progress
36
- */
37
- export function AcceptanceCriteriaPanel({
38
- criteria,
39
- }: AcceptanceCriteriaPanelProps): React.ReactElement {
40
- // Handle empty state
41
- if (!criteria || criteria.length === 0) {
42
- return (
43
- <div className="todo-panel" data-testid="ac-panel">
44
- <div className="placeholder">No acceptance criteria</div>
45
- </div>
46
- );
47
- }
48
-
49
- // Calculate progress
50
- const completedCount = criteria.filter(c => c.completed).length;
51
- const totalCount = criteria.length;
52
- const progressPercent = totalCount > 0 ? Math.round((completedCount / totalCount) * 100) : 0;
53
-
54
- return (
55
- <div className="todo-panel" data-testid="ac-panel">
56
- <div className="progress-bar-container">
57
- <div
58
- className="progress-bar"
59
- style={{ width: `${progressPercent}%` }}
60
- />
61
- <span className="progress-text">{completedCount}/{totalCount}</span>
62
- </div>
63
- <div className="todo-section">
64
- {criteria.map((item, index) => (
65
- <CriteriaItemView key={index} item={item} />
66
- ))}
67
- </div>
68
- </div>
69
- );
70
- }
71
-
72
- /**
73
- * ConnectedAcceptanceCriteriaPanel - Self-contained panel that fetches its own data
74
- *
75
- * Used by DockingWorkspace via registerPanelComponent
76
- */
77
- export function ConnectedAcceptanceCriteriaPanel(): React.ReactElement {
78
- const { story, isLoading, error } = useStory();
79
-
80
- if (isLoading) {
81
- return (
82
- <div className="todo-panel loading" data-testid="ac-panel">
83
- <div className="space-y-2 p-2">
84
- <Skeleton className="h-3 w-full" />
85
- <Skeleton className="h-4 w-3/4" />
86
- <Skeleton className="h-4 w-5/6" />
87
- <Skeleton className="h-4 w-2/3" />
88
- </div>
89
- </div>
90
- );
91
- }
92
-
93
- if (error) {
94
- return (
95
- <div className="todo-panel error" data-testid="ac-panel">
96
- <div className="error-message">{error.message}</div>
97
- </div>
98
- );
99
- }
100
-
101
- return <AcceptanceCriteriaPanel criteria={story?.criteria ?? null} />;
102
- }
103
-
104
- export default AcceptanceCriteriaPanel;
@@ -1,465 +0,0 @@
1
- /**
2
- * AuditLogPanel - Tool execution audit log viewer
3
- *
4
- * Features:
5
- * - View tool events with filtering by type and status
6
- * - Real-time updates via WebSocket
7
- * - Export as JSON or CSV
8
- * - Statistics display
9
- */
10
-
11
- import React, { useState, useEffect, useCallback } from 'react';
12
- import { Button } from '@/components/ui/button';
13
- import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '@/components/ui/tooltip';
14
- import { Separator } from '@/components/ui/separator';
15
- import { Skeleton } from '@/components/ui/skeleton';
16
- import { ScrollArea } from '@/components/ui/scroll-area';
17
-
18
- // =============================================================================
19
- // Types
20
- // =============================================================================
21
-
22
- interface DiffSummary {
23
- added: number;
24
- removed: number;
25
- }
26
-
27
- interface OutputSummary {
28
- firstLines: string[];
29
- lastLines: string[];
30
- totalLines: number;
31
- truncated: boolean;
32
- }
33
-
34
- interface ToolEvent {
35
- toolName: string;
36
- input?: string;
37
- output?: string;
38
- durationMs?: number;
39
- success: boolean;
40
- error?: string;
41
- timestamp: number;
42
- // File enrichment (Read/Edit/Write)
43
- filePath?: string;
44
- fileSize?: number;
45
- lineCount?: number;
46
- language?: string;
47
- gitStatus?: 'clean' | 'modified' | 'new' | 'untracked' | null;
48
- diff?: DiffSummary;
49
- // Bash enrichment
50
- command?: string;
51
- exitCode?: number | null;
52
- outputSummary?: OutputSummary;
53
- workingDirectory?: string;
54
- // Task enrichment
55
- subagentType?: string;
56
- promptSummary?: string;
57
- resultSummary?: string;
58
- isBackground?: boolean;
59
- }
60
-
61
- interface AuditLogStats {
62
- total: number;
63
- byType: Record<string, number>;
64
- successCount: number;
65
- errorCount: number;
66
- }
67
-
68
- // =============================================================================
69
- // Helper Functions
70
- // =============================================================================
71
-
72
- function formatTimestamp(timestamp: number): string {
73
- return new Date(timestamp).toLocaleTimeString();
74
- }
75
-
76
- function formatDuration(ms: number | undefined): string {
77
- if (ms === undefined) return '-';
78
- if (ms < 1000) return `${ms}ms`;
79
- return `${(ms / 1000).toFixed(1)}s`;
80
- }
81
-
82
- function truncateInput(input: string | undefined, maxLength = 60): string {
83
- if (!input) return '-';
84
- if (input.length <= maxLength) return input;
85
- return input.substring(0, maxLength) + '...';
86
- }
87
-
88
- function formatBytes(bytes: number | undefined): string {
89
- if (bytes === undefined) return '';
90
- if (bytes < 1024) return `${bytes} B`;
91
- if (bytes < 1024 * 1024) return `${(bytes / 1024).toFixed(1)} KB`;
92
- return `${(bytes / (1024 * 1024)).toFixed(1)} MB`;
93
- }
94
-
95
- function formatFilePath(path: string | undefined): string {
96
- if (!path) return '';
97
- // Show last 3 segments for brevity
98
- const parts = path.split('/');
99
- if (parts.length <= 3) return path;
100
- return '.../' + parts.slice(-3).join('/');
101
- }
102
-
103
- /** Render enrichment detail rows as label/value pairs */
104
- function DetailRow({ label, value, mono }: { label: string; value: React.ReactNode; mono?: boolean }) {
105
- if (value === undefined || value === null || value === '') return null;
106
- return (
107
- <div className="detail-row">
108
- <span className="detail-label">{label}</span>
109
- <span className={mono ? 'detail-value font-mono' : 'detail-value'}>{value}</span>
110
- </div>
111
- );
112
- }
113
-
114
- // =============================================================================
115
- // Component
116
- // =============================================================================
117
-
118
- export function AuditLogPanel(): React.ReactElement {
119
- const [entries, setEntries] = useState<ToolEvent[]>([]);
120
- const [stats, setStats] = useState<AuditLogStats | null>(null);
121
- const [toolTypes, setToolTypes] = useState<string[]>([]);
122
- const [selectedType, setSelectedType] = useState<string>('');
123
- const [selectedStatus, setSelectedStatus] = useState<string>('');
124
- const [loading, setLoading] = useState(true);
125
- const [error, setError] = useState<string | null>(null);
126
- const [expandedEntry, setExpandedEntry] = useState<number | null>(null);
127
-
128
- // Fetch entries
129
- const fetchEntries = useCallback(async () => {
130
- try {
131
- const params = new URLSearchParams();
132
- if (selectedType) params.set('toolType', selectedType);
133
- if (selectedStatus) params.set('status', selectedStatus);
134
- params.set('limit', '200');
135
-
136
- const response = await fetch(`/api/audit-log?${params}`);
137
- if (!response.ok) throw new Error('Failed to fetch audit log');
138
- const data = await response.json();
139
- setEntries(data.entries || []);
140
- setError(null);
141
- } catch (err) {
142
- setError(err instanceof Error ? err.message : 'Unknown error');
143
- }
144
- }, [selectedType, selectedStatus]);
145
-
146
- // Fetch stats
147
- const fetchStats = useCallback(async () => {
148
- try {
149
- const response = await fetch('/api/audit-log/stats');
150
- if (!response.ok) throw new Error('Failed to fetch stats');
151
- const data = await response.json();
152
- setStats(data);
153
- } catch (err) {
154
- console.error('[AuditLogPanel] Stats error:', err);
155
- }
156
- }, []);
157
-
158
- // Fetch tool types
159
- const fetchTypes = useCallback(async () => {
160
- try {
161
- const response = await fetch('/api/audit-log/types');
162
- if (!response.ok) throw new Error('Failed to fetch types');
163
- const data = await response.json();
164
- setToolTypes(data.types || []);
165
- } catch (err) {
166
- console.error('[AuditLogPanel] Types error:', err);
167
- }
168
- }, []);
169
-
170
- // Initial load and WebSocket subscription
171
- useEffect(() => {
172
- setLoading(true);
173
- Promise.all([fetchEntries(), fetchStats(), fetchTypes()]).finally(() => {
174
- setLoading(false);
175
- });
176
-
177
- // Subscribe to real-time updates via spans WebSocket
178
- const ws = new WebSocket(`ws://${window.location.host}/ws/spans`);
179
- ws.onmessage = (event) => {
180
- try {
181
- const data = JSON.parse(event.data);
182
- if (data.type === 'span' && data.span) {
183
- // Add new entry at the beginning
184
- setEntries(prev => [data.span, ...prev].slice(0, 200));
185
- // Refresh stats
186
- fetchStats();
187
- }
188
- } catch (err) {
189
- console.error('[AuditLogPanel] WebSocket parse error:', err);
190
- }
191
- };
192
-
193
- return () => ws.close();
194
- }, [fetchEntries, fetchStats, fetchTypes]);
195
-
196
- // Refetch when filters change
197
- useEffect(() => {
198
- fetchEntries();
199
- }, [selectedType, selectedStatus, fetchEntries]);
200
-
201
- // Export handler
202
- const handleExport = async (format: 'json' | 'csv') => {
203
- try {
204
- const params = new URLSearchParams();
205
- params.set('format', format);
206
- params.set('download', 'true');
207
- if (selectedType) params.set('toolType', selectedType);
208
-
209
- const response = await fetch(`/api/audit-log/export?${params}`);
210
- if (!response.ok) throw new Error('Export failed');
211
-
212
- const blob = await response.blob();
213
- const url = URL.createObjectURL(blob);
214
- const a = document.createElement('a');
215
- a.href = url;
216
- a.download = `audit-log.${format}`;
217
- a.click();
218
- URL.revokeObjectURL(url);
219
- } catch (err) {
220
- console.error('[AuditLogPanel] Export error:', err);
221
- }
222
- };
223
-
224
- // Clear handler
225
- const handleClear = async () => {
226
- if (!confirm('Clear all audit log entries?')) return;
227
- try {
228
- const response = await fetch('/api/audit-log', { method: 'DELETE' });
229
- if (!response.ok) throw new Error('Clear failed');
230
- setEntries([]);
231
- fetchStats();
232
- } catch (err) {
233
- console.error('[AuditLogPanel] Clear error:', err);
234
- }
235
- };
236
-
237
- if (loading) {
238
- return (
239
- <div className="audit-log-panel p-4 space-y-3">
240
- <div className="flex gap-4">
241
- <Skeleton className="h-4 w-20" />
242
- <Skeleton className="h-4 w-24" />
243
- <Skeleton className="h-4 w-20" />
244
- </div>
245
- <Separator />
246
- <div className="space-y-2">
247
- <Skeleton className="h-6 w-full" />
248
- <Skeleton className="h-6 w-full" />
249
- <Skeleton className="h-6 w-full" />
250
- <Skeleton className="h-6 w-3/4" />
251
- </div>
252
- </div>
253
- );
254
- }
255
-
256
- if (error) {
257
- return (
258
- <div className="audit-log-panel p-4">
259
- <div className="text-error">Error: {error}</div>
260
- </div>
261
- );
262
- }
263
-
264
- return (
265
- <div className="audit-log-panel flex flex-col h-full">
266
- <TooltipProvider delayDuration={300}>
267
- {/* Stats Bar */}
268
- {stats && (
269
- <>
270
- <div className="audit-log-stats flex gap-4 p-2 text-sm">
271
- <span className="text-muted">Total: <strong>{stats.total}</strong></span>
272
- <span className="text-success">Success: <strong>{stats.successCount}</strong></span>
273
- <span className="text-error">Errors: <strong>{stats.errorCount}</strong></span>
274
- </div>
275
- <Separator />
276
- </>
277
- )}
278
-
279
- {/* Filters and Actions */}
280
- <div className="audit-log-toolbar flex p-2 items-center">
281
- <select
282
- value={selectedType}
283
- onChange={(e) => setSelectedType(e.target.value)}
284
- >
285
- <option value="">All Tools</option>
286
- {toolTypes.map(type => (
287
- <option key={type} value={type}>{type}</option>
288
- ))}
289
- </select>
290
-
291
- <select
292
- value={selectedStatus}
293
- onChange={(e) => setSelectedStatus(e.target.value)}
294
- >
295
- <option value="">All Status</option>
296
- <option value="success">Success</option>
297
- <option value="error">Errors</option>
298
- </select>
299
-
300
- <div className="flex-1" />
301
-
302
- <Tooltip>
303
- <TooltipTrigger asChild>
304
- <Button variant="ghost" size="sm" className="audit-log-btn" onClick={() => handleExport('json')}>
305
- JSON
306
- </Button>
307
- </TooltipTrigger>
308
- <TooltipContent>Export as JSON</TooltipContent>
309
- </Tooltip>
310
- <Tooltip>
311
- <TooltipTrigger asChild>
312
- <Button variant="ghost" size="sm" className="audit-log-btn" onClick={() => handleExport('csv')}>
313
- CSV
314
- </Button>
315
- </TooltipTrigger>
316
- <TooltipContent>Export as CSV</TooltipContent>
317
- </Tooltip>
318
- <Tooltip>
319
- <TooltipTrigger asChild>
320
- <Button variant="ghost" size="sm" className="audit-log-btn audit-log-btn-clear" onClick={handleClear}>
321
- Clear
322
- </Button>
323
- </TooltipTrigger>
324
- <TooltipContent>Clear audit log</TooltipContent>
325
- </Tooltip>
326
- </div>
327
-
328
- {/* Entries List */}
329
- <ScrollArea className="audit-log-entries flex-1">
330
- {entries.length === 0 ? (
331
- <div className="p-4 text-muted text-center">No entries</div>
332
- ) : (
333
- <table>
334
- <thead>
335
- <tr>
336
- <th className="text-left">Time</th>
337
- <th className="text-left">Tool</th>
338
- <th className="text-left">Input</th>
339
- <th className="text-right">Duration</th>
340
- <th className="text-center">Status</th>
341
- </tr>
342
- </thead>
343
- <tbody>
344
- {entries.map((entry, idx) => (
345
- <React.Fragment key={`${entry.timestamp}-${idx}`}>
346
- <tr
347
- className={expandedEntry === idx ? 'expanded' : ''}
348
- onClick={() => setExpandedEntry(expandedEntry === idx ? null : idx)}
349
- >
350
- <td className="whitespace-nowrap">
351
- {formatTimestamp(entry.timestamp)}
352
- </td>
353
- <td className="tool-name font-mono" data-tool={entry.toolName.toLowerCase()}>{entry.toolName}</td>
354
- <td className="truncate max-w-[200px]">
355
- {entry.input ? (
356
- <Tooltip>
357
- <TooltipTrigger asChild>
358
- <span>{truncateInput(entry.input)}</span>
359
- </TooltipTrigger>
360
- <TooltipContent>{entry.input}</TooltipContent>
361
- </Tooltip>
362
- ) : (
363
- truncateInput(entry.input)
364
- )}
365
- </td>
366
- <td className="text-right whitespace-nowrap">
367
- {formatDuration(entry.durationMs)}
368
- </td>
369
- <td className="text-center">
370
- {entry.success ? (
371
- <span className="status-ok">✓</span>
372
- ) : (
373
- <Tooltip>
374
- <TooltipTrigger asChild>
375
- <span className="status-err">✗</span>
376
- </TooltipTrigger>
377
- <TooltipContent>{entry.error}</TooltipContent>
378
- </Tooltip>
379
- )}
380
- </td>
381
- </tr>
382
- {expandedEntry === idx && (
383
- <tr className="expanded-detail">
384
- <td colSpan={5}>
385
- <div className="detail-grid">
386
- {/* Common fields */}
387
- <DetailRow label="Tool" value={entry.toolName} />
388
- <DetailRow label="Duration" value={entry.durationMs !== undefined ? formatDuration(entry.durationMs) : undefined} />
389
- {entry.exitCode !== undefined && entry.exitCode !== null && (
390
- <DetailRow label="Exit Code" value={entry.exitCode} mono />
391
- )}
392
-
393
- {/* File enrichment (Read/Edit/Write) */}
394
- <DetailRow label="File" value={entry.filePath} mono />
395
- {entry.language && <DetailRow label="Language" value={entry.language} />}
396
- {entry.fileSize !== undefined && <DetailRow label="Size" value={formatBytes(entry.fileSize)} />}
397
- {entry.lineCount !== undefined && <DetailRow label="Lines" value={entry.lineCount.toLocaleString()} />}
398
- {entry.gitStatus && <DetailRow label="Git" value={entry.gitStatus} />}
399
- {entry.diff && (
400
- <DetailRow label="Diff" value={
401
- <span>
402
- <span style={{color: 'var(--success, #22c55e)'}}>+{entry.diff.added}</span>
403
- {' '}
404
- <span style={{color: 'var(--error, #ef4444)'}}>-{entry.diff.removed}</span>
405
- </span>
406
- } />
407
- )}
408
-
409
- {/* Bash enrichment */}
410
- {entry.command && <DetailRow label="Command" value={entry.command} mono />}
411
- {entry.workingDirectory && <DetailRow label="CWD" value={formatFilePath(entry.workingDirectory)} mono />}
412
-
413
- {/* Task enrichment */}
414
- {entry.subagentType && <DetailRow label="Agent" value={entry.subagentType} />}
415
- {entry.isBackground && <DetailRow label="Background" value="Yes" />}
416
- {entry.promptSummary && <DetailRow label="Prompt" value={entry.promptSummary} />}
417
- {entry.resultSummary && <DetailRow label="Result" value={entry.resultSummary} />}
418
- </div>
419
-
420
- {/* Output summary (Bash) */}
421
- {entry.outputSummary && entry.outputSummary.totalLines > 0 && (
422
- <div className="detail-output">
423
- <div className="detail-label">Output ({entry.outputSummary.totalLines} lines{entry.outputSummary.truncated ? ', truncated' : ''})</div>
424
- <pre>{entry.outputSummary.firstLines.join('\n')}{entry.outputSummary.truncated && entry.outputSummary.lastLines.length > 0 ? '\n...\n' + entry.outputSummary.lastLines.join('\n') : ''}</pre>
425
- </div>
426
- )}
427
-
428
- {/* Raw input (fallback when no enrichment) */}
429
- {entry.input && !entry.command && !entry.filePath && !entry.subagentType && (
430
- <div className="detail-output">
431
- <div className="detail-label">Input</div>
432
- <pre>{entry.input}</pre>
433
- </div>
434
- )}
435
-
436
- {/* Raw output (when no outputSummary) */}
437
- {entry.output && !entry.outputSummary && (
438
- <div className="detail-output">
439
- <div className="detail-label">Output</div>
440
- <pre>{entry.output.substring(0, 500)}{entry.output.length > 500 && '...'}</pre>
441
- </div>
442
- )}
443
-
444
- {/* Error */}
445
- {entry.error && (
446
- <div className="detail-output">
447
- <div className="detail-label status-err">Error</div>
448
- <pre className="status-err">{entry.error}</pre>
449
- </div>
450
- )}
451
- </td>
452
- </tr>
453
- )}
454
- </React.Fragment>
455
- ))}
456
- </tbody>
457
- </table>
458
- )}
459
- </ScrollArea>
460
- </TooltipProvider>
461
- </div>
462
- );
463
- }
464
-
465
- export default AuditLogPanel;