@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,453 +0,0 @@
1
- /**
2
- * SettingsPanel - Settings/preferences panel
3
- *
4
- * Story MSSCI-12717 - React Migration
5
- * Updated to match actual config.local.yaml structure
6
- * Story MSSCI-12817 - Added Color Palette section with ThemePalette
7
- * Story MSSCI-12769 - Added Fonts section with FontPicker
8
- * Story MSSCI-14243 - Added Panel Visibility section
9
- */
10
-
11
- import React, { useState, useEffect, useCallback, useMemo, useRef } from 'react';
12
- import { Switch } from '@/components/ui/switch';
13
- import { Separator } from '@/components/ui/separator';
14
- import { Skeleton } from '@/components/ui/skeleton';
15
- import { ThemePalette } from '../ThemePalette';
16
- import { FontPicker, FontSizePicker } from '../FontPicker';
17
- import {
18
- applyPreset,
19
- savePresetToProject,
20
- loadPresetFromProject,
21
- DEFAULT_PRESET,
22
- } from '../../utils/color-presets';
23
- import {
24
- loadFontSettings,
25
- saveFontSettings,
26
- applyFontSettings,
27
- DEFAULT_FONT_SETTINGS,
28
- FontSettings,
29
- FontSize,
30
- } from '../../utils/font-presets';
31
- import {
32
- PANEL_INVENTORY,
33
- getDockviewApi,
34
- restorePanel,
35
- } from '../DockviewWorkspace';
36
-
37
- interface Settings {
38
- workflow?: {
39
- permission_mode?: 'plan' | 'manual' | 'accept';
40
- bell_mode?: boolean;
41
- relay_mode?: boolean;
42
- handoff_mode?: string;
43
- };
44
- display?: {
45
- show_flow?: boolean;
46
- sidebar_width?: number;
47
- };
48
- pennyfarthing?: {
49
- theme?: string;
50
- };
51
- }
52
-
53
- interface ThemeMetadata {
54
- id: string;
55
- name: string;
56
- tier: string;
57
- }
58
-
59
- // Tier sort order: S=0, A=1, B=2, unranked=3
60
- const TIER_ORDER: Record<string, number> = { S: 0, A: 1, B: 2 };
61
-
62
- // Panel display names for the visibility toggles
63
- const PANEL_DISPLAY_NAMES: Record<string, string> = {
64
- changed: 'Changed Files',
65
- diffs: 'Diffs',
66
- debug: 'Debug',
67
- 'audit-log': 'Audit Log',
68
- tty: 'Terminal',
69
- message: 'Message',
70
- sprint: 'Sprint',
71
- workflow: 'Workflow',
72
- ac: 'AC',
73
- todo: 'Todo',
74
- background: 'Background',
75
- git: 'Git',
76
- settings: 'Settings',
77
- };
78
-
79
- // Panels that cannot be hidden
80
- const PROTECTED_PANELS = new Set<string>();
81
-
82
- export function SettingsPanel(): React.ReactElement {
83
- const [settings, setSettings] = useState<Settings | null>(null);
84
- const [themes, setThemes] = useState<ThemeMetadata[]>([]);
85
- const [saving, setSaving] = useState(false);
86
- const [colorPreset, setColorPreset] = useState<string>(DEFAULT_PRESET);
87
- const [fontSettings, setFontSettings] = useState<FontSettings>(DEFAULT_FONT_SETTINGS);
88
- const [panelVisibility, setPanelVisibility] = useState<Record<string, boolean>>({});
89
- const pendingToggles = useRef<Record<string, number>>({});
90
-
91
- useEffect(() => {
92
- // Load settings via REST
93
- async function loadSettings() {
94
- try {
95
- console.log('[SettingsPanel] Loading settings via REST');
96
- const response = await fetch('/api/settings');
97
- if (response.ok) {
98
- const data = await response.json();
99
- console.log('[SettingsPanel] Settings loaded:', data);
100
- setSettings(data as Settings);
101
- }
102
- } catch (err) {
103
- console.error('[SettingsPanel] Failed to load settings:', err);
104
- }
105
- }
106
-
107
- // Load theme metadata via REST
108
- async function loadThemes() {
109
- try {
110
- const response = await fetch('/api/settings/themes');
111
- if (response.ok) {
112
- const data = await response.json();
113
- setThemes((data || []) as ThemeMetadata[]);
114
- }
115
- } catch (err) {
116
- console.error('[SettingsPanel] Failed to load themes:', err);
117
- }
118
- }
119
-
120
- loadSettings();
121
- loadThemes();
122
-
123
- // WebSocket subscription for real-time sync
124
- console.log('[SettingsPanel] Connecting to /ws/settings for real-time sync');
125
- const protocol = window.location.protocol === 'https:' ? 'wss:' : 'ws:';
126
- const ws = new WebSocket(`${protocol}//${window.location.host}/ws/settings`);
127
-
128
- ws.onmessage = (event) => {
129
- try {
130
- const data = JSON.parse(event.data);
131
- if (data.type === 'init' || data.type === 'update') {
132
- console.log('[SettingsPanel] Settings update via WebSocket:', data.settings);
133
- setSettings(data.settings as Settings);
134
- }
135
- } catch (err) {
136
- console.error('[SettingsPanel] Failed to parse WebSocket message:', err);
137
- }
138
- };
139
-
140
- ws.onerror = (err) => {
141
- console.error('[SettingsPanel] WebSocket error:', err);
142
- };
143
-
144
- // Load color preset from project config
145
- loadPresetFromProject().then(presetId => {
146
- applyPreset(presetId);
147
- setColorPreset(presetId);
148
- });
149
-
150
- // Load font settings
151
- loadFontSettings().then(settings => {
152
- setFontSettings(settings);
153
- applyFontSettings(settings);
154
- });
155
-
156
- return () => ws.close();
157
- }, []);
158
-
159
- // Track panel visibility from Dockview API
160
- useEffect(() => {
161
- const updatePanelVisibility = () => {
162
- const api = getDockviewApi();
163
- if (!api) return;
164
-
165
- const visibility: Record<string, boolean> = {};
166
- const allPanelIds = Object.values(PANEL_INVENTORY);
167
- const now = Date.now();
168
-
169
- for (const panelId of allPanelIds) {
170
- // Skip panels with pending toggles (wait for Dockview to catch up)
171
- const pendingUntil = pendingToggles.current[panelId];
172
- if (pendingUntil && now < pendingUntil) {
173
- continue; // Keep current state, don't overwrite
174
- }
175
- // Clear expired pending toggle
176
- if (pendingUntil) {
177
- delete pendingToggles.current[panelId];
178
- }
179
- // Panel is visible if it exists in the Dockview
180
- visibility[panelId] = api.getPanel(panelId) !== undefined;
181
- }
182
-
183
- setPanelVisibility(prev => ({ ...prev, ...visibility }));
184
- };
185
-
186
- // Initial update
187
- updatePanelVisibility();
188
-
189
- // Poll for changes (Dockview API events are subscribed in DockviewWorkspace)
190
- const interval = setInterval(updatePanelVisibility, 500);
191
-
192
- return () => clearInterval(interval);
193
- }, []);
194
-
195
- // Handle panel visibility toggle
196
- const handlePanelToggle = useCallback((panelId: string, visible: boolean) => {
197
- const api = getDockviewApi();
198
- if (!api) return;
199
-
200
- // Mark this panel as having a pending toggle for 1 second
201
- // This prevents the polling interval from overwriting the state
202
- // before Dockview has finished adding/removing the panel
203
- pendingToggles.current[panelId] = Date.now() + 1000;
204
-
205
- if (visible) {
206
- // Show panel by restoring it
207
- restorePanel(panelId);
208
- } else {
209
- // Hide panel by removing it
210
- const panel = api.getPanel(panelId);
211
- if (panel) {
212
- panel.api.close();
213
- }
214
- }
215
-
216
- // Update local state immediately for responsive UI
217
- setPanelVisibility(prev => ({ ...prev, [panelId]: visible }));
218
- }, []);
219
-
220
- // Sort themes: by tier (S > A > B > U), then alphabetically by name
221
- const sortedThemes = useMemo(() => {
222
- return [...themes].sort((a, b) => {
223
- const tierDiff = (TIER_ORDER[a.tier] ?? 3) - (TIER_ORDER[b.tier] ?? 3);
224
- if (tierDiff !== 0) return tierDiff;
225
- return a.name.localeCompare(b.name);
226
- });
227
- }, [themes]);
228
-
229
- const handleThemeChange = useCallback(async (theme: string) => {
230
- if (!settings) return;
231
-
232
- setSaving(true);
233
- try {
234
- const updated = {
235
- ...settings,
236
- pennyfarthing: { ...settings.pennyfarthing, theme },
237
- };
238
-
239
- // Use REST API
240
- await fetch('/api/settings', {
241
- method: 'PATCH',
242
- headers: { 'Content-Type': 'application/json' },
243
- body: JSON.stringify({ pennyfarthing: { theme } }),
244
- });
245
- setSettings(updated);
246
- } finally {
247
- setSaving(false);
248
- }
249
- }, [settings]);
250
-
251
- const handleToggle = useCallback(async (section: string, key: string, value: boolean) => {
252
- if (!settings) return;
253
-
254
- console.log(`[SettingsPanel] Toggle ${section}.${key} = ${value}`);
255
- setSaving(true);
256
- try {
257
- const updated = {
258
- ...settings,
259
- [section]: { ...(settings as Record<string, Record<string, unknown>>)[section], [key]: value },
260
- };
261
-
262
- // Use REST API
263
- console.log('[SettingsPanel] Saving via REST');
264
- await fetch('/api/settings', {
265
- method: 'PATCH',
266
- headers: { 'Content-Type': 'application/json' },
267
- body: JSON.stringify({ [section]: { [key]: value } }),
268
- });
269
- console.log('[SettingsPanel] Save complete, updating local state');
270
- setSettings(updated);
271
- } finally {
272
- setSaving(false);
273
- }
274
- }, [settings]);
275
-
276
- const handleColorPresetChange = useCallback(async (presetId: string) => {
277
- setSaving(true);
278
- try {
279
- applyPreset(presetId);
280
- await savePresetToProject(presetId);
281
- setColorPreset(presetId);
282
- } finally {
283
- setSaving(false);
284
- }
285
- }, []);
286
-
287
- const handleFontChange = useCallback(async (
288
- type: 'ui' | 'code',
289
- presetId: string,
290
- customFamily?: string
291
- ) => {
292
- setSaving(true);
293
- try {
294
- const updated: FontSettings = {
295
- ...fontSettings,
296
- [type === 'ui' ? 'uiFont' : 'codeFont']: presetId,
297
- ...(presetId === 'custom' && customFamily
298
- ? { [type === 'ui' ? 'customUiFont' : 'customCodeFont']: customFamily }
299
- : {}),
300
- };
301
- applyFontSettings(updated);
302
- await saveFontSettings(updated);
303
- setFontSettings(updated);
304
- } finally {
305
- setSaving(false);
306
- }
307
- }, [fontSettings]);
308
-
309
- const handleFontSizeChange = useCallback(async (type: 'ui' | 'code', size: FontSize) => {
310
- setSaving(true);
311
- try {
312
- const updated: FontSettings = {
313
- ...fontSettings,
314
- [type === 'ui' ? 'uiFontSize' : 'codeFontSize']: size,
315
- };
316
- applyFontSettings(updated);
317
- await saveFontSettings(updated);
318
- setFontSettings(updated);
319
- } finally {
320
- setSaving(false);
321
- }
322
- }, [fontSettings]);
323
-
324
- if (!settings) {
325
- return (
326
- <div className="settings-panel loading" data-testid="settings-panel">
327
- <div className="space-y-4 p-2">
328
- <Skeleton className="h-4 w-24" />
329
- <Skeleton className="h-8 w-full" />
330
- <Skeleton className="h-4 w-32" />
331
- <Skeleton className="h-8 w-full" />
332
- <Skeleton className="h-4 w-20" />
333
- <Skeleton className="h-6 w-48" />
334
- </div>
335
- </div>
336
- );
337
- }
338
-
339
- return (
340
- <div className="settings-panel" data-testid="settings-panel">
341
- <section className="settings-section">
342
- <h4>Theme</h4>
343
- <select
344
- value={settings.pennyfarthing?.theme || ''}
345
- onChange={(e) => handleThemeChange(e.target.value)}
346
- disabled={saving}
347
- className="theme-select"
348
- >
349
- {sortedThemes.map(theme => (
350
- <option key={theme.id} value={theme.id}>
351
- [{theme.tier || 'Unranked'}] {theme.name}
352
- </option>
353
- ))}
354
- </select>
355
- </section>
356
-
357
- <Separator className="my-2" />
358
-
359
- <section className="settings-section">
360
- <h4>Color Palette</h4>
361
- <ThemePalette
362
- currentPreset={colorPreset}
363
- onSelect={handleColorPresetChange}
364
- />
365
- </section>
366
-
367
- <Separator className="my-2" />
368
-
369
- <section className="settings-section">
370
- <h4>Fonts</h4>
371
- <div className="font-setting">
372
- <label>UI Font</label>
373
- <FontPicker
374
- type="ui"
375
- currentFont={fontSettings.uiFont}
376
- customFont={fontSettings.customUiFont}
377
- onSelect={(id, custom) => handleFontChange('ui', id, custom)}
378
- />
379
- <FontSizePicker
380
- currentSize={fontSettings.uiFontSize}
381
- onSelect={(size) => handleFontSizeChange('ui', size)}
382
- />
383
- </div>
384
- <div className="font-setting">
385
- <label>Code Font</label>
386
- <FontPicker
387
- type="code"
388
- currentFont={fontSettings.codeFont}
389
- customFont={fontSettings.customCodeFont}
390
- onSelect={(id, custom) => handleFontChange('code', id, custom)}
391
- />
392
- <FontSizePicker
393
- currentSize={fontSettings.codeFontSize}
394
- onSelect={(size) => handleFontSizeChange('code', size)}
395
- />
396
- </div>
397
- </section>
398
-
399
- <Separator className="my-2" />
400
-
401
- <section className="settings-section">
402
- <h4>Workflow</h4>
403
- <div className="toggle-setting">
404
- <Switch
405
- checked={settings.workflow?.bell_mode || false}
406
- onCheckedChange={(checked: boolean) => handleToggle('workflow', 'bell_mode', checked)}
407
- disabled={saving}
408
- />
409
- Bell Mode
410
- <span className="setting-description">Inject queued messages via PostToolUse hook instead of waiting</span>
411
- </div>
412
- <div className="toggle-setting">
413
- <Switch
414
- checked={settings.workflow?.relay_mode || false}
415
- onCheckedChange={(checked: boolean) => handleToggle('workflow', 'relay_mode', checked)}
416
- disabled={saving}
417
- />
418
- Relay Mode
419
- <span className="setting-description">Auto-handoff to next agent</span>
420
- </div>
421
- </section>
422
-
423
- <Separator className="my-2" />
424
-
425
- <section className="settings-section">
426
- <h4>Panel Visibility</h4>
427
- <div className="panel-visibility-list">
428
- {Object.values(PANEL_INVENTORY).map((panelId) => {
429
- const isProtected = PROTECTED_PANELS.has(panelId);
430
- const isVisible = panelVisibility[panelId] ?? true;
431
- const displayName = PANEL_DISPLAY_NAMES[panelId] || panelId;
432
-
433
- return (
434
- <div key={panelId} className="toggle-setting">
435
- <Switch
436
- checked={isVisible}
437
- onCheckedChange={(checked: boolean) => handlePanelToggle(panelId, checked)}
438
- disabled={isProtected}
439
- />
440
- {displayName}
441
- {isProtected && (
442
- <span className="setting-description">(always visible)</span>
443
- )}
444
- </div>
445
- );
446
- })}
447
- </div>
448
- </section>
449
- </div>
450
- );
451
- }
452
-
453
- export default SettingsPanel;