@alexjbarnes/cockpit 0.2.0 → 0.3.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 (694) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/app-path-routes-manifest.json +16 -3
  3. package/.next/build-manifest.json +3 -3
  4. package/.next/prerender-manifest.json +99 -3
  5. package/.next/react-loadable-manifest.json +18 -2
  6. package/.next/required-server-files.js +3 -0
  7. package/.next/required-server-files.json +3 -0
  8. package/.next/routes-manifest.json +86 -0
  9. package/.next/server/app/(app)/agents/[name]/page.js +2 -2
  10. package/.next/server/app/(app)/agents/[name]/page.js.nft.json +1 -1
  11. package/.next/server/app/(app)/agents/[name]/page_client-reference-manifest.js +1 -1
  12. package/.next/server/app/(app)/agents/page.js +2 -2
  13. package/.next/server/app/(app)/agents/page.js.nft.json +1 -1
  14. package/.next/server/app/(app)/agents/page_client-reference-manifest.js +1 -1
  15. package/.next/server/app/(app)/changes/page.js +2 -2
  16. package/.next/server/app/(app)/changes/page.js.nft.json +1 -1
  17. package/.next/server/app/(app)/changes/page_client-reference-manifest.js +1 -1
  18. package/.next/server/app/(app)/claude-md/edit/page.js +2 -2
  19. package/.next/server/app/(app)/claude-md/edit/page.js.nft.json +1 -1
  20. package/.next/server/app/(app)/claude-md/edit/page_client-reference-manifest.js +1 -1
  21. package/.next/server/app/(app)/claude-md/page.js +2 -2
  22. package/.next/server/app/(app)/claude-md/page.js.nft.json +1 -1
  23. package/.next/server/app/(app)/claude-md/page_client-reference-manifest.js +1 -1
  24. package/.next/server/app/(app)/commands/[name]/page.js +2 -2
  25. package/.next/server/app/(app)/commands/[name]/page.js.nft.json +1 -1
  26. package/.next/server/app/(app)/commands/[name]/page_client-reference-manifest.js +1 -1
  27. package/.next/server/app/(app)/commands/page.js +2 -2
  28. package/.next/server/app/(app)/commands/page.js.nft.json +1 -1
  29. package/.next/server/app/(app)/commands/page_client-reference-manifest.js +1 -1
  30. package/.next/server/app/(app)/files/page.js +2 -2
  31. package/.next/server/app/(app)/files/page.js.nft.json +1 -1
  32. package/.next/server/app/(app)/files/page_client-reference-manifest.js +1 -1
  33. package/.next/server/app/(app)/hooks/[event]/page.js +3 -3
  34. package/.next/server/app/(app)/hooks/[event]/page.js.nft.json +1 -1
  35. package/.next/server/app/(app)/hooks/[event]/page_client-reference-manifest.js +1 -1
  36. package/.next/server/app/(app)/hooks/page.js +2 -2
  37. package/.next/server/app/(app)/hooks/page.js.nft.json +1 -1
  38. package/.next/server/app/(app)/hooks/page_client-reference-manifest.js +1 -1
  39. package/.next/server/app/(app)/inbox/[id]/page.js +2 -2
  40. package/.next/server/app/(app)/inbox/[id]/page.js.nft.json +1 -1
  41. package/.next/server/app/(app)/inbox/[id]/page_client-reference-manifest.js +1 -1
  42. package/.next/server/app/(app)/inbox/page.js +2 -2
  43. package/.next/server/app/(app)/inbox/page.js.nft.json +1 -1
  44. package/.next/server/app/(app)/inbox/page_client-reference-manifest.js +1 -1
  45. package/.next/server/app/(app)/jobs/[id]/edit/page.js +2 -2
  46. package/.next/server/app/(app)/jobs/[id]/edit/page.js.nft.json +1 -1
  47. package/.next/server/app/(app)/jobs/[id]/edit/page_client-reference-manifest.js +1 -1
  48. package/.next/server/app/(app)/jobs/[id]/page.js +2 -2
  49. package/.next/server/app/(app)/jobs/[id]/page.js.nft.json +1 -1
  50. package/.next/server/app/(app)/jobs/[id]/page_client-reference-manifest.js +1 -1
  51. package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page.js +2 -2
  52. package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page.js.nft.json +1 -1
  53. package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page_client-reference-manifest.js +1 -1
  54. package/.next/server/app/(app)/jobs/page.js +2 -2
  55. package/.next/server/app/(app)/jobs/page.js.nft.json +1 -1
  56. package/.next/server/app/(app)/jobs/page_client-reference-manifest.js +1 -1
  57. package/.next/server/app/(app)/mcp-servers/[name]/page.js +2 -2
  58. package/.next/server/app/(app)/mcp-servers/[name]/page.js.nft.json +1 -1
  59. package/.next/server/app/(app)/mcp-servers/[name]/page_client-reference-manifest.js +1 -1
  60. package/.next/server/app/(app)/mcp-servers/page.js +2 -2
  61. package/.next/server/app/(app)/mcp-servers/page.js.nft.json +1 -1
  62. package/.next/server/app/(app)/mcp-servers/page_client-reference-manifest.js +1 -1
  63. package/.next/server/app/(app)/page.js +2 -2
  64. package/.next/server/app/(app)/page.js.nft.json +1 -1
  65. package/.next/server/app/(app)/page_client-reference-manifest.js +1 -1
  66. package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page.js +10 -10
  67. package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page.js.nft.json +1 -1
  68. package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page_client-reference-manifest.js +1 -1
  69. package/.next/server/app/(app)/reviews/[owner]/[repo]/page.js +2 -2
  70. package/.next/server/app/(app)/reviews/[owner]/[repo]/page.js.nft.json +1 -1
  71. package/.next/server/app/(app)/reviews/[owner]/[repo]/page_client-reference-manifest.js +1 -1
  72. package/.next/server/app/(app)/reviews/page.js +2 -2
  73. package/.next/server/app/(app)/reviews/page.js.nft.json +1 -1
  74. package/.next/server/app/(app)/reviews/page_client-reference-manifest.js +1 -1
  75. package/.next/server/app/(app)/sessions/[id]/page.js +2 -2
  76. package/.next/server/app/(app)/sessions/[id]/page.js.nft.json +1 -1
  77. package/.next/server/app/(app)/sessions/[id]/page_client-reference-manifest.js +1 -1
  78. package/.next/server/app/(app)/settings/appearance/page.js +2 -0
  79. package/.next/server/app/(app)/settings/appearance/page.js.nft.json +1 -0
  80. package/.next/server/app/(app)/settings/appearance/page_client-reference-manifest.js +1 -0
  81. package/.next/server/app/(app)/settings/notifications/page.js +2 -2
  82. package/.next/server/app/(app)/settings/notifications/page.js.nft.json +1 -1
  83. package/.next/server/app/(app)/settings/notifications/page_client-reference-manifest.js +1 -1
  84. package/.next/server/app/(app)/settings/page.js +2 -2
  85. package/.next/server/app/(app)/settings/page.js.nft.json +1 -1
  86. package/.next/server/app/(app)/settings/page_client-reference-manifest.js +1 -1
  87. package/.next/server/app/(app)/settings/providers/[id]/page.js +2 -0
  88. package/.next/server/app/(app)/settings/providers/[id]/page.js.nft.json +1 -0
  89. package/.next/server/app/(app)/settings/providers/[id]/page_client-reference-manifest.js +1 -0
  90. package/.next/server/app/(app)/settings/providers/new/page.js +2 -0
  91. package/.next/server/app/(app)/settings/providers/new/page.js.nft.json +1 -0
  92. package/.next/server/app/(app)/settings/providers/new/page_client-reference-manifest.js +1 -0
  93. package/.next/server/app/(app)/settings/providers/page.js +2 -0
  94. package/.next/server/app/(app)/settings/providers/page.js.nft.json +1 -0
  95. package/.next/server/app/(app)/settings/providers/page_client-reference-manifest.js +1 -0
  96. package/.next/server/app/(app)/settings/session/page.js +2 -0
  97. package/.next/server/app/(app)/settings/session/page.js.nft.json +1 -0
  98. package/.next/server/app/(app)/settings/session/page_client-reference-manifest.js +1 -0
  99. package/.next/server/app/(app)/skills/[name]/page.js +3 -3
  100. package/.next/server/app/(app)/skills/[name]/page.js.nft.json +1 -1
  101. package/.next/server/app/(app)/skills/[name]/page_client-reference-manifest.js +1 -1
  102. package/.next/server/app/(app)/skills/page.js +2 -2
  103. package/.next/server/app/(app)/skills/page.js.nft.json +1 -1
  104. package/.next/server/app/(app)/skills/page_client-reference-manifest.js +1 -1
  105. package/.next/server/app/_global-error/page.js +3 -3
  106. package/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  107. package/.next/server/app/_global-error.html +1 -1
  108. package/.next/server/app/_global-error.rsc +1 -1
  109. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  110. package/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  111. package/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  112. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  113. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  114. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  115. package/.next/server/app/_not-found/page.js +2 -2
  116. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  117. package/.next/server/app/_not-found.html +1 -1
  118. package/.next/server/app/_not-found.rsc +2 -2
  119. package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  120. package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  121. package/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  122. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  123. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  124. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  125. package/.next/server/app/agents.html +1 -1
  126. package/.next/server/app/agents.rsc +4 -4
  127. package/.next/server/app/agents.segments/!KGFwcCk/agents/__PAGE__.segment.rsc +2 -2
  128. package/.next/server/app/agents.segments/!KGFwcCk/agents.segment.rsc +1 -1
  129. package/.next/server/app/agents.segments/!KGFwcCk.segment.rsc +2 -2
  130. package/.next/server/app/agents.segments/_full.segment.rsc +4 -4
  131. package/.next/server/app/agents.segments/_head.segment.rsc +1 -1
  132. package/.next/server/app/agents.segments/_index.segment.rsc +2 -2
  133. package/.next/server/app/agents.segments/_tree.segment.rsc +2 -2
  134. package/.next/server/app/api/agents/[name]/route.js +1 -1
  135. package/.next/server/app/api/agents/route.js +1 -1
  136. package/.next/server/app/api/auth/check/route.js +1 -1
  137. package/.next/server/app/api/auth/login/route.js +1 -1
  138. package/.next/server/app/api/auth/setup/route.js +1 -1
  139. package/.next/server/app/api/auth/ws-token/route.js +1 -1
  140. package/.next/server/app/api/btw/route.js +2 -2
  141. package/.next/server/app/api/claude-md/route.js +1 -1
  142. package/.next/server/app/api/commands/[name]/route.js +1 -1
  143. package/.next/server/app/api/commands/route.js +1 -1
  144. package/.next/server/app/api/defaults/route.js +1 -1
  145. package/.next/server/app/api/filesystem/browse/route.js +1 -1
  146. package/.next/server/app/api/filesystem/files/route.js +1 -1
  147. package/.next/server/app/api/filesystem/mkdir/route.js +1 -1
  148. package/.next/server/app/api/filesystem/read/route.js +1 -1
  149. package/.next/server/app/api/git/clone/route.js +1 -1
  150. package/.next/server/app/api/git/commit/route.js +1 -1
  151. package/.next/server/app/api/git/diff/route.js +1 -1
  152. package/.next/server/app/api/git/discard/route.js +1 -1
  153. package/.next/server/app/api/git/generate-message/route.js +2 -2
  154. package/.next/server/app/api/git/push/route.js +1 -1
  155. package/.next/server/app/api/git/status/route.js +1 -1
  156. package/.next/server/app/api/github/file-content/route.js +1 -1
  157. package/.next/server/app/api/github/orgs/route.js +1 -1
  158. package/.next/server/app/api/github/prs/checks/route.js +1 -1
  159. package/.next/server/app/api/github/prs/diff/route.js +1 -1
  160. package/.next/server/app/api/github/prs/review/route.js +1 -1
  161. package/.next/server/app/api/github/prs/route.js +1 -1
  162. package/.next/server/app/api/github/prs/view/route.js +1 -1
  163. package/.next/server/app/api/github/repos/route.js +1 -1
  164. package/.next/server/app/api/github/review-session/route.js +1 -1
  165. package/.next/server/app/api/github/review-session/route.js.nft.json +1 -1
  166. package/.next/server/app/api/health/route.js +1 -1
  167. package/.next/server/app/api/hooks/route.js +1 -1
  168. package/.next/server/app/api/inbox/[id]/route.js +2 -2
  169. package/.next/server/app/api/inbox/route.js +2 -2
  170. package/.next/server/app/api/jobs/[id]/route.js +1 -1
  171. package/.next/server/app/api/jobs/[id]/route.js.nft.json +1 -1
  172. package/.next/server/app/api/jobs/[id]/runs/[runId]/route.js +1 -1
  173. package/.next/server/app/api/jobs/[id]/runs/[runId]/transcript/route.js +1 -1
  174. package/.next/server/app/api/jobs/[id]/runs/route.js +1 -1
  175. package/.next/server/app/api/jobs/[id]/trigger/route.js +1 -1
  176. package/.next/server/app/api/jobs/[id]/trigger/route.js.nft.json +1 -1
  177. package/.next/server/app/api/jobs/mcp-discover/route.js +1 -1
  178. package/.next/server/app/api/jobs/mcp-discover/route.js.nft.json +1 -1
  179. package/.next/server/app/api/jobs/route.js +1 -1
  180. package/.next/server/app/api/jobs/route.js.nft.json +1 -1
  181. package/.next/server/app/api/jobs/status/route.js +1 -1
  182. package/.next/server/app/api/mcp-servers/[name]/route.js +1 -1
  183. package/.next/server/app/api/mcp-servers/[name]/test/route.js +1 -1
  184. package/.next/server/app/api/mcp-servers/route.js +1 -1
  185. package/.next/server/app/api/notifications/route.js +1 -1
  186. package/.next/server/app/api/notifications/test/route.js +1 -1
  187. package/.next/server/app/api/providers/[id]/route.js +1 -0
  188. package/.next/server/app/api/providers/[id]/route.js.nft.json +1 -0
  189. package/.next/server/app/api/providers/[id]/route_client-reference-manifest.js +1 -0
  190. package/.next/server/app/api/providers/route.js +1 -0
  191. package/.next/server/app/api/providers/route.js.nft.json +1 -0
  192. package/.next/server/app/api/providers/route_client-reference-manifest.js +1 -0
  193. package/.next/server/app/api/reviews/pinned/route.js +1 -1
  194. package/.next/server/app/api/sessions/[id]/context/route.js +1 -1
  195. package/.next/server/app/api/sessions/[id]/mcp/route.js +1 -1
  196. package/.next/server/app/api/sessions/[id]/mcp/route.js.nft.json +1 -1
  197. package/.next/server/app/api/sessions/[id]/route.js +1 -1
  198. package/.next/server/app/api/sessions/[id]/route.js.nft.json +1 -1
  199. package/.next/server/app/api/sessions/[id]/search/route.js +1 -1
  200. package/.next/server/app/api/sessions/[id]/tabs/route.js +1 -0
  201. package/.next/server/app/api/sessions/[id]/tabs/route.js.nft.json +1 -0
  202. package/.next/server/app/api/sessions/[id]/tabs/route_client-reference-manifest.js +1 -0
  203. package/.next/server/app/api/sessions/bulk-delete/route.js +1 -1
  204. package/.next/server/app/api/sessions/bulk-delete/route.js.nft.json +1 -1
  205. package/.next/server/app/api/sessions/by-ids/route.js +1 -1
  206. package/.next/server/app/api/sessions/by-ids/route.js.nft.json +1 -1
  207. package/.next/server/app/api/sessions/group/route.js +1 -1
  208. package/.next/server/app/api/sessions/group/route.js.nft.json +1 -1
  209. package/.next/server/app/api/sessions/pinned/route.js +1 -1
  210. package/.next/server/app/api/sessions/route.js +1 -1
  211. package/.next/server/app/api/sessions/route.js.nft.json +1 -1
  212. package/.next/server/app/api/sessions/search/route.js +1 -1
  213. package/.next/server/app/api/sessions/thinking/route.js +1 -0
  214. package/.next/server/app/api/sessions/thinking/route.js.nft.json +1 -0
  215. package/.next/server/app/api/sessions/thinking/route_client-reference-manifest.js +1 -0
  216. package/.next/server/app/api/skills/[name]/route.js +1 -1
  217. package/.next/server/app/api/skills/route.js +1 -1
  218. package/.next/server/app/api/terminal/[id]/route.js +1 -0
  219. package/.next/server/app/api/terminal/[id]/route.js.nft.json +1 -0
  220. package/.next/server/app/api/terminal/[id]/route_client-reference-manifest.js +1 -0
  221. package/.next/server/app/api/terminal/route.js +1 -0
  222. package/.next/server/app/api/terminal/route.js.nft.json +1 -0
  223. package/.next/server/app/api/terminal/route_client-reference-manifest.js +1 -0
  224. package/.next/server/app/api/usage/route.js +1 -1
  225. package/.next/server/app/api/version/changelog/route.js +1 -0
  226. package/.next/server/app/api/version/changelog/route.js.nft.json +1 -0
  227. package/.next/server/app/api/version/changelog/route_client-reference-manifest.js +1 -0
  228. package/.next/server/app/api/version/cockpit/changelog/route.js +1 -0
  229. package/.next/server/app/api/version/cockpit/changelog/route.js.nft.json +1 -0
  230. package/.next/server/app/api/version/cockpit/changelog/route_client-reference-manifest.js +1 -0
  231. package/.next/server/app/api/version/cockpit/route.js +1 -1
  232. package/.next/server/app/api/version/route.js +2 -2
  233. package/.next/server/app/changes.html +1 -1
  234. package/.next/server/app/changes.rsc +4 -4
  235. package/.next/server/app/changes.segments/!KGFwcCk/changes/__PAGE__.segment.rsc +2 -2
  236. package/.next/server/app/changes.segments/!KGFwcCk/changes.segment.rsc +1 -1
  237. package/.next/server/app/changes.segments/!KGFwcCk.segment.rsc +2 -2
  238. package/.next/server/app/changes.segments/_full.segment.rsc +4 -4
  239. package/.next/server/app/changes.segments/_head.segment.rsc +1 -1
  240. package/.next/server/app/changes.segments/_index.segment.rsc +2 -2
  241. package/.next/server/app/changes.segments/_tree.segment.rsc +2 -2
  242. package/.next/server/app/claude-md/edit.html +1 -1
  243. package/.next/server/app/claude-md/edit.rsc +4 -4
  244. package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md/edit/__PAGE__.segment.rsc +2 -2
  245. package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md/edit.segment.rsc +1 -1
  246. package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md.segment.rsc +1 -1
  247. package/.next/server/app/claude-md/edit.segments/!KGFwcCk.segment.rsc +2 -2
  248. package/.next/server/app/claude-md/edit.segments/_full.segment.rsc +4 -4
  249. package/.next/server/app/claude-md/edit.segments/_head.segment.rsc +1 -1
  250. package/.next/server/app/claude-md/edit.segments/_index.segment.rsc +2 -2
  251. package/.next/server/app/claude-md/edit.segments/_tree.segment.rsc +2 -2
  252. package/.next/server/app/claude-md.html +1 -1
  253. package/.next/server/app/claude-md.rsc +4 -4
  254. package/.next/server/app/claude-md.segments/!KGFwcCk/claude-md/__PAGE__.segment.rsc +2 -2
  255. package/.next/server/app/claude-md.segments/!KGFwcCk/claude-md.segment.rsc +1 -1
  256. package/.next/server/app/claude-md.segments/!KGFwcCk.segment.rsc +2 -2
  257. package/.next/server/app/claude-md.segments/_full.segment.rsc +4 -4
  258. package/.next/server/app/claude-md.segments/_head.segment.rsc +1 -1
  259. package/.next/server/app/claude-md.segments/_index.segment.rsc +2 -2
  260. package/.next/server/app/claude-md.segments/_tree.segment.rsc +2 -2
  261. package/.next/server/app/commands.html +1 -1
  262. package/.next/server/app/commands.rsc +4 -4
  263. package/.next/server/app/commands.segments/!KGFwcCk/commands/__PAGE__.segment.rsc +2 -2
  264. package/.next/server/app/commands.segments/!KGFwcCk/commands.segment.rsc +1 -1
  265. package/.next/server/app/commands.segments/!KGFwcCk.segment.rsc +2 -2
  266. package/.next/server/app/commands.segments/_full.segment.rsc +4 -4
  267. package/.next/server/app/commands.segments/_head.segment.rsc +1 -1
  268. package/.next/server/app/commands.segments/_index.segment.rsc +2 -2
  269. package/.next/server/app/commands.segments/_tree.segment.rsc +2 -2
  270. package/.next/server/app/files.html +1 -1
  271. package/.next/server/app/files.rsc +4 -4
  272. package/.next/server/app/files.segments/!KGFwcCk/files/__PAGE__.segment.rsc +2 -2
  273. package/.next/server/app/files.segments/!KGFwcCk/files.segment.rsc +1 -1
  274. package/.next/server/app/files.segments/!KGFwcCk.segment.rsc +2 -2
  275. package/.next/server/app/files.segments/_full.segment.rsc +4 -4
  276. package/.next/server/app/files.segments/_head.segment.rsc +1 -1
  277. package/.next/server/app/files.segments/_index.segment.rsc +2 -2
  278. package/.next/server/app/files.segments/_tree.segment.rsc +2 -2
  279. package/.next/server/app/hooks.html +1 -1
  280. package/.next/server/app/hooks.rsc +4 -4
  281. package/.next/server/app/hooks.segments/!KGFwcCk/hooks/__PAGE__.segment.rsc +2 -2
  282. package/.next/server/app/hooks.segments/!KGFwcCk/hooks.segment.rsc +1 -1
  283. package/.next/server/app/hooks.segments/!KGFwcCk.segment.rsc +2 -2
  284. package/.next/server/app/hooks.segments/_full.segment.rsc +4 -4
  285. package/.next/server/app/hooks.segments/_head.segment.rsc +1 -1
  286. package/.next/server/app/hooks.segments/_index.segment.rsc +2 -2
  287. package/.next/server/app/hooks.segments/_tree.segment.rsc +2 -2
  288. package/.next/server/app/inbox.html +1 -1
  289. package/.next/server/app/inbox.rsc +4 -4
  290. package/.next/server/app/inbox.segments/!KGFwcCk/inbox/__PAGE__.segment.rsc +2 -2
  291. package/.next/server/app/inbox.segments/!KGFwcCk/inbox.segment.rsc +1 -1
  292. package/.next/server/app/inbox.segments/!KGFwcCk.segment.rsc +2 -2
  293. package/.next/server/app/inbox.segments/_full.segment.rsc +4 -4
  294. package/.next/server/app/inbox.segments/_head.segment.rsc +1 -1
  295. package/.next/server/app/inbox.segments/_index.segment.rsc +2 -2
  296. package/.next/server/app/inbox.segments/_tree.segment.rsc +2 -2
  297. package/.next/server/app/index.html +1 -1
  298. package/.next/server/app/index.rsc +4 -4
  299. package/.next/server/app/index.segments/!KGFwcCk/__PAGE__.segment.rsc +2 -2
  300. package/.next/server/app/index.segments/!KGFwcCk.segment.rsc +2 -2
  301. package/.next/server/app/index.segments/_full.segment.rsc +4 -4
  302. package/.next/server/app/index.segments/_head.segment.rsc +1 -1
  303. package/.next/server/app/index.segments/_index.segment.rsc +2 -2
  304. package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  305. package/.next/server/app/jobs.html +1 -1
  306. package/.next/server/app/jobs.rsc +4 -4
  307. package/.next/server/app/jobs.segments/!KGFwcCk/jobs/__PAGE__.segment.rsc +2 -2
  308. package/.next/server/app/jobs.segments/!KGFwcCk/jobs.segment.rsc +1 -1
  309. package/.next/server/app/jobs.segments/!KGFwcCk.segment.rsc +2 -2
  310. package/.next/server/app/jobs.segments/_full.segment.rsc +4 -4
  311. package/.next/server/app/jobs.segments/_head.segment.rsc +1 -1
  312. package/.next/server/app/jobs.segments/_index.segment.rsc +2 -2
  313. package/.next/server/app/jobs.segments/_tree.segment.rsc +2 -2
  314. package/.next/server/app/login/page.js +2 -2
  315. package/.next/server/app/login/page_client-reference-manifest.js +1 -1
  316. package/.next/server/app/login.html +1 -1
  317. package/.next/server/app/login.rsc +2 -2
  318. package/.next/server/app/login.segments/_full.segment.rsc +2 -2
  319. package/.next/server/app/login.segments/_head.segment.rsc +1 -1
  320. package/.next/server/app/login.segments/_index.segment.rsc +2 -2
  321. package/.next/server/app/login.segments/_tree.segment.rsc +2 -2
  322. package/.next/server/app/login.segments/login/__PAGE__.segment.rsc +1 -1
  323. package/.next/server/app/login.segments/login.segment.rsc +1 -1
  324. package/.next/server/app/mcp-servers.html +1 -1
  325. package/.next/server/app/mcp-servers.rsc +4 -4
  326. package/.next/server/app/mcp-servers.segments/!KGFwcCk/mcp-servers/__PAGE__.segment.rsc +2 -2
  327. package/.next/server/app/mcp-servers.segments/!KGFwcCk/mcp-servers.segment.rsc +1 -1
  328. package/.next/server/app/mcp-servers.segments/!KGFwcCk.segment.rsc +2 -2
  329. package/.next/server/app/mcp-servers.segments/_full.segment.rsc +4 -4
  330. package/.next/server/app/mcp-servers.segments/_head.segment.rsc +1 -1
  331. package/.next/server/app/mcp-servers.segments/_index.segment.rsc +2 -2
  332. package/.next/server/app/mcp-servers.segments/_tree.segment.rsc +2 -2
  333. package/.next/server/app/reviews.html +1 -1
  334. package/.next/server/app/reviews.rsc +4 -4
  335. package/.next/server/app/reviews.segments/!KGFwcCk/reviews/__PAGE__.segment.rsc +2 -2
  336. package/.next/server/app/reviews.segments/!KGFwcCk/reviews.segment.rsc +1 -1
  337. package/.next/server/app/reviews.segments/!KGFwcCk.segment.rsc +2 -2
  338. package/.next/server/app/reviews.segments/_full.segment.rsc +4 -4
  339. package/.next/server/app/reviews.segments/_head.segment.rsc +1 -1
  340. package/.next/server/app/reviews.segments/_index.segment.rsc +2 -2
  341. package/.next/server/app/reviews.segments/_tree.segment.rsc +2 -2
  342. package/.next/server/app/settings/appearance.html +1 -0
  343. package/.next/server/app/settings/appearance.meta +17 -0
  344. package/.next/server/app/settings/appearance.rsc +23 -0
  345. package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings/appearance/__PAGE__.segment.rsc +9 -0
  346. package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings/appearance.segment.rsc +5 -0
  347. package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings.segment.rsc +5 -0
  348. package/.next/server/app/settings/appearance.segments/!KGFwcCk.segment.rsc +7 -0
  349. package/.next/server/app/settings/appearance.segments/_full.segment.rsc +23 -0
  350. package/.next/server/app/settings/appearance.segments/_head.segment.rsc +6 -0
  351. package/.next/server/app/settings/appearance.segments/_index.segment.rsc +5 -0
  352. package/.next/server/app/settings/appearance.segments/_tree.segment.rsc +2 -0
  353. package/.next/server/app/settings/notifications.html +1 -1
  354. package/.next/server/app/settings/notifications.rsc +4 -4
  355. package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings/notifications/__PAGE__.segment.rsc +2 -2
  356. package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings/notifications.segment.rsc +1 -1
  357. package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings.segment.rsc +1 -1
  358. package/.next/server/app/settings/notifications.segments/!KGFwcCk.segment.rsc +2 -2
  359. package/.next/server/app/settings/notifications.segments/_full.segment.rsc +4 -4
  360. package/.next/server/app/settings/notifications.segments/_head.segment.rsc +1 -1
  361. package/.next/server/app/settings/notifications.segments/_index.segment.rsc +2 -2
  362. package/.next/server/app/settings/notifications.segments/_tree.segment.rsc +2 -2
  363. package/.next/server/app/settings/providers/new.html +1 -0
  364. package/.next/server/app/settings/providers/new.meta +18 -0
  365. package/.next/server/app/settings/providers/new.rsc +23 -0
  366. package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers/new/__PAGE__.segment.rsc +9 -0
  367. package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers/new.segment.rsc +5 -0
  368. package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers.segment.rsc +5 -0
  369. package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings.segment.rsc +5 -0
  370. package/.next/server/app/settings/providers/new.segments/!KGFwcCk.segment.rsc +7 -0
  371. package/.next/server/app/settings/providers/new.segments/_full.segment.rsc +23 -0
  372. package/.next/server/app/settings/providers/new.segments/_head.segment.rsc +6 -0
  373. package/.next/server/app/settings/providers/new.segments/_index.segment.rsc +5 -0
  374. package/.next/server/app/settings/providers/new.segments/_tree.segment.rsc +2 -0
  375. package/.next/server/app/settings/providers.html +1 -0
  376. package/.next/server/app/settings/providers.meta +17 -0
  377. package/.next/server/app/settings/providers.rsc +23 -0
  378. package/.next/server/app/settings/providers.segments/!KGFwcCk/settings/providers/__PAGE__.segment.rsc +9 -0
  379. package/.next/server/app/settings/providers.segments/!KGFwcCk/settings/providers.segment.rsc +5 -0
  380. package/.next/server/app/settings/providers.segments/!KGFwcCk/settings.segment.rsc +5 -0
  381. package/.next/server/app/settings/providers.segments/!KGFwcCk.segment.rsc +7 -0
  382. package/.next/server/app/settings/providers.segments/_full.segment.rsc +23 -0
  383. package/.next/server/app/settings/providers.segments/_head.segment.rsc +6 -0
  384. package/.next/server/app/settings/providers.segments/_index.segment.rsc +5 -0
  385. package/.next/server/app/settings/providers.segments/_tree.segment.rsc +2 -0
  386. package/.next/server/app/settings/session.html +1 -0
  387. package/.next/server/app/settings/session.meta +17 -0
  388. package/.next/server/app/settings/session.rsc +23 -0
  389. package/.next/server/app/settings/session.segments/!KGFwcCk/settings/session/__PAGE__.segment.rsc +9 -0
  390. package/.next/server/app/settings/session.segments/!KGFwcCk/settings/session.segment.rsc +5 -0
  391. package/.next/server/app/settings/session.segments/!KGFwcCk/settings.segment.rsc +5 -0
  392. package/.next/server/app/settings/session.segments/!KGFwcCk.segment.rsc +7 -0
  393. package/.next/server/app/settings/session.segments/_full.segment.rsc +23 -0
  394. package/.next/server/app/settings/session.segments/_head.segment.rsc +6 -0
  395. package/.next/server/app/settings/session.segments/_index.segment.rsc +5 -0
  396. package/.next/server/app/settings/session.segments/_tree.segment.rsc +2 -0
  397. package/.next/server/app/settings.html +1 -1
  398. package/.next/server/app/settings.rsc +4 -4
  399. package/.next/server/app/settings.segments/!KGFwcCk/settings/__PAGE__.segment.rsc +2 -2
  400. package/.next/server/app/settings.segments/!KGFwcCk/settings.segment.rsc +1 -1
  401. package/.next/server/app/settings.segments/!KGFwcCk.segment.rsc +2 -2
  402. package/.next/server/app/settings.segments/_full.segment.rsc +4 -4
  403. package/.next/server/app/settings.segments/_head.segment.rsc +1 -1
  404. package/.next/server/app/settings.segments/_index.segment.rsc +2 -2
  405. package/.next/server/app/settings.segments/_tree.segment.rsc +2 -2
  406. package/.next/server/app/skills.html +1 -1
  407. package/.next/server/app/skills.rsc +4 -4
  408. package/.next/server/app/skills.segments/!KGFwcCk/skills/__PAGE__.segment.rsc +2 -2
  409. package/.next/server/app/skills.segments/!KGFwcCk/skills.segment.rsc +1 -1
  410. package/.next/server/app/skills.segments/!KGFwcCk.segment.rsc +2 -2
  411. package/.next/server/app/skills.segments/_full.segment.rsc +4 -4
  412. package/.next/server/app/skills.segments/_head.segment.rsc +1 -1
  413. package/.next/server/app/skills.segments/_index.segment.rsc +2 -2
  414. package/.next/server/app/skills.segments/_tree.segment.rsc +2 -2
  415. package/.next/server/app-paths-manifest.json +16 -3
  416. package/.next/server/chunks/1002.js +18 -0
  417. package/.next/server/chunks/1011.js +1 -0
  418. package/.next/server/chunks/1659.js +1 -1
  419. package/.next/server/chunks/1979.js +2 -2
  420. package/.next/server/chunks/2408.js +1 -1
  421. package/.next/server/chunks/{7627.js → 3006.js} +3 -3
  422. package/.next/server/chunks/3434.js +1 -0
  423. package/.next/server/chunks/{5920.js → 4342.js} +1 -1
  424. package/.next/server/chunks/4352.js +1 -0
  425. package/.next/server/chunks/4445.js +1 -1
  426. package/.next/server/chunks/7782.js +6 -0
  427. package/.next/server/chunks/8148.js +1 -0
  428. package/.next/server/chunks/9599.js +11 -0
  429. package/.next/server/middleware-build-manifest.js +1 -1
  430. package/.next/server/middleware-react-loadable-manifest.js +1 -1
  431. package/.next/server/pages/404.html +1 -1
  432. package/.next/server/pages/500.html +1 -1
  433. package/.next/server/server-reference-manifest.json +1 -1
  434. package/.next/static/chunks/{35922.5bdf78a760129504.js → 13541.056c34ca7fde6869.js} +1 -1
  435. package/.next/static/chunks/26126-97874904b42befb8.js +1 -0
  436. package/.next/static/chunks/31010-6e87f77b97544424.js +1 -0
  437. package/.next/static/chunks/3765-d323c6675307a63e.js +20 -0
  438. package/.next/static/chunks/{11242-d240a18d4e59390b.js → 41487-d802643f4a8fad3c.js} +5 -5
  439. package/.next/static/chunks/48273-bbd15bac6733dfc4.js +6 -0
  440. package/.next/static/chunks/63606.a387b0261d6523ab.js +1 -0
  441. package/.next/static/chunks/6935-f436a624267529fb.js +1 -0
  442. package/.next/static/chunks/{69427.0f379c6bdea95405.js → 69427.a0b463c808aa54c8.js} +1 -1
  443. package/.next/static/chunks/86939-dfc6f8eb395caa89.js +1 -0
  444. package/.next/static/chunks/app/(app)/agents/[name]/page-8bdd0359043537d4.js +8 -0
  445. package/.next/static/chunks/app/(app)/agents/page-6fcfd7ab6781814e.js +1 -0
  446. package/.next/static/chunks/app/(app)/changes/page-4549a5bd72d77e3e.js +1 -0
  447. package/.next/static/chunks/app/(app)/claude-md/edit/page-08e6e120e71979f4.js +1 -0
  448. package/.next/static/chunks/app/(app)/claude-md/page-cd9e2176a12ba241.js +1 -0
  449. package/.next/static/chunks/app/(app)/commands/[name]/page-7cdfdef29ded0aa0.js +6 -0
  450. package/.next/static/chunks/app/(app)/commands/page-f126b608b04747ac.js +1 -0
  451. package/.next/static/chunks/app/(app)/files/page-f526eb95821e000e.js +1 -0
  452. package/.next/static/chunks/app/(app)/hooks/[event]/page-28038323fd29adfa.js +6 -0
  453. package/.next/static/chunks/app/(app)/hooks/page-f1f39284e53c0344.js +1 -0
  454. package/.next/static/chunks/app/(app)/inbox/[id]/page-bc1ff3a0db0114a4.js +1 -0
  455. package/.next/static/chunks/app/(app)/inbox/page-82e03870103ce9bd.js +1 -0
  456. package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-7fb788f772ff2129.js +1 -0
  457. package/.next/static/chunks/app/(app)/jobs/[id]/page-a5856b9ae967ff59.js +1 -0
  458. package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-b7c513402db11db6.js +1 -0
  459. package/.next/static/chunks/app/(app)/jobs/page-e9bbd6c116b9699f.js +1 -0
  460. package/.next/static/chunks/app/(app)/{layout-81c1899969de11e6.js → layout-ce9e1be301c60fe5.js} +1 -1
  461. package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-d6d805a27ec0b0c0.js +1 -0
  462. package/.next/static/chunks/app/(app)/mcp-servers/page-4b7276d43451cd43.js +1 -0
  463. package/.next/static/chunks/app/(app)/page-027a5382da30ddb9.js +1 -0
  464. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-9ab2955c455bb5fa.js +13 -0
  465. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/{page-c7473a899c7c59c3.js → page-c5fd013309ab3eba.js} +1 -1
  466. package/.next/static/chunks/app/(app)/reviews/{page-0e6e7395a4f62b50.js → page-47530d93bb9d4a76.js} +1 -1
  467. package/.next/static/chunks/app/(app)/sessions/[id]/page-94f891e1b54fd05f.js +1 -0
  468. package/.next/static/chunks/app/(app)/settings/appearance/page-95902da748ac5f1e.js +1 -0
  469. package/.next/static/chunks/app/(app)/settings/notifications/{page-a28db2ebc9fd0de8.js → page-229f1db6beb1d19c.js} +1 -1
  470. package/.next/static/chunks/app/(app)/settings/page-8ed16a66fdde10cd.js +1 -0
  471. package/.next/static/chunks/app/(app)/settings/providers/[id]/page-13654263246617b3.js +1 -0
  472. package/.next/static/chunks/app/(app)/settings/providers/new/page-e1798e321ccbc6df.js +1 -0
  473. package/.next/static/chunks/app/(app)/settings/providers/page-0bb4c1db2ee35b3d.js +1 -0
  474. package/.next/static/chunks/app/(app)/settings/session/page-ab216a8fa37a0f76.js +1 -0
  475. package/.next/static/chunks/app/(app)/skills/[name]/page-8ab85d5090967ee4.js +6 -0
  476. package/.next/static/chunks/app/(app)/skills/page-c52773eacb27c04e.js +1 -0
  477. package/.next/static/chunks/app/_global-error/page-fc747760bd4c8a4b.js +1 -0
  478. package/.next/static/chunks/app/api/agents/[name]/route-fc747760bd4c8a4b.js +1 -0
  479. package/.next/static/chunks/app/api/agents/route-fc747760bd4c8a4b.js +1 -0
  480. package/.next/static/chunks/app/api/auth/check/route-fc747760bd4c8a4b.js +1 -0
  481. package/.next/static/chunks/app/api/auth/login/route-fc747760bd4c8a4b.js +1 -0
  482. package/.next/static/chunks/app/api/auth/setup/route-fc747760bd4c8a4b.js +1 -0
  483. package/.next/static/chunks/app/api/auth/ws-token/route-fc747760bd4c8a4b.js +1 -0
  484. package/.next/static/chunks/app/api/btw/route-fc747760bd4c8a4b.js +1 -0
  485. package/.next/static/chunks/app/api/claude-md/route-fc747760bd4c8a4b.js +1 -0
  486. package/.next/static/chunks/app/api/commands/[name]/route-fc747760bd4c8a4b.js +1 -0
  487. package/.next/static/chunks/app/api/commands/route-fc747760bd4c8a4b.js +1 -0
  488. package/.next/static/chunks/app/api/defaults/route-fc747760bd4c8a4b.js +1 -0
  489. package/.next/static/chunks/app/api/filesystem/browse/route-fc747760bd4c8a4b.js +1 -0
  490. package/.next/static/chunks/app/api/filesystem/files/route-fc747760bd4c8a4b.js +1 -0
  491. package/.next/static/chunks/app/api/filesystem/mkdir/route-fc747760bd4c8a4b.js +1 -0
  492. package/.next/static/chunks/app/api/filesystem/read/route-fc747760bd4c8a4b.js +1 -0
  493. package/.next/static/chunks/app/api/git/clone/route-fc747760bd4c8a4b.js +1 -0
  494. package/.next/static/chunks/app/api/git/commit/route-fc747760bd4c8a4b.js +1 -0
  495. package/.next/static/chunks/app/api/git/diff/route-fc747760bd4c8a4b.js +1 -0
  496. package/.next/static/chunks/app/api/git/discard/route-fc747760bd4c8a4b.js +1 -0
  497. package/.next/static/chunks/app/api/git/generate-message/route-fc747760bd4c8a4b.js +1 -0
  498. package/.next/static/chunks/app/api/git/push/route-fc747760bd4c8a4b.js +1 -0
  499. package/.next/static/chunks/app/api/git/status/route-fc747760bd4c8a4b.js +1 -0
  500. package/.next/static/chunks/app/api/github/file-content/route-fc747760bd4c8a4b.js +1 -0
  501. package/.next/static/chunks/app/api/github/orgs/route-fc747760bd4c8a4b.js +1 -0
  502. package/.next/static/chunks/app/api/github/prs/checks/route-fc747760bd4c8a4b.js +1 -0
  503. package/.next/static/chunks/app/api/github/prs/diff/route-fc747760bd4c8a4b.js +1 -0
  504. package/.next/static/chunks/app/api/github/prs/review/route-fc747760bd4c8a4b.js +1 -0
  505. package/.next/static/chunks/app/api/github/prs/route-fc747760bd4c8a4b.js +1 -0
  506. package/.next/static/chunks/app/api/github/prs/view/route-fc747760bd4c8a4b.js +1 -0
  507. package/.next/static/chunks/app/api/github/repos/route-fc747760bd4c8a4b.js +1 -0
  508. package/.next/static/chunks/app/api/github/review-session/route-fc747760bd4c8a4b.js +1 -0
  509. package/.next/static/chunks/app/api/health/route-fc747760bd4c8a4b.js +1 -0
  510. package/.next/static/chunks/app/api/hooks/route-fc747760bd4c8a4b.js +1 -0
  511. package/.next/static/chunks/app/api/inbox/[id]/route-fc747760bd4c8a4b.js +1 -0
  512. package/.next/static/chunks/app/api/inbox/route-fc747760bd4c8a4b.js +1 -0
  513. package/.next/static/chunks/app/api/jobs/[id]/route-fc747760bd4c8a4b.js +1 -0
  514. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-fc747760bd4c8a4b.js +1 -0
  515. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-fc747760bd4c8a4b.js +1 -0
  516. package/.next/static/chunks/app/api/jobs/[id]/runs/route-fc747760bd4c8a4b.js +1 -0
  517. package/.next/static/chunks/app/api/jobs/[id]/trigger/route-fc747760bd4c8a4b.js +1 -0
  518. package/.next/static/chunks/app/api/jobs/mcp-discover/route-fc747760bd4c8a4b.js +1 -0
  519. package/.next/static/chunks/app/api/jobs/route-fc747760bd4c8a4b.js +1 -0
  520. package/.next/static/chunks/app/api/jobs/status/route-fc747760bd4c8a4b.js +1 -0
  521. package/.next/static/chunks/app/api/mcp-servers/[name]/route-fc747760bd4c8a4b.js +1 -0
  522. package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-fc747760bd4c8a4b.js +1 -0
  523. package/.next/static/chunks/app/api/mcp-servers/route-fc747760bd4c8a4b.js +1 -0
  524. package/.next/static/chunks/app/api/notifications/route-fc747760bd4c8a4b.js +1 -0
  525. package/.next/static/chunks/app/api/notifications/test/route-fc747760bd4c8a4b.js +1 -0
  526. package/.next/static/chunks/app/api/providers/[id]/route-fc747760bd4c8a4b.js +1 -0
  527. package/.next/static/chunks/app/api/providers/route-fc747760bd4c8a4b.js +1 -0
  528. package/.next/static/chunks/app/api/reviews/pinned/route-fc747760bd4c8a4b.js +1 -0
  529. package/.next/static/chunks/app/api/sessions/[id]/context/route-fc747760bd4c8a4b.js +1 -0
  530. package/.next/static/chunks/app/api/sessions/[id]/mcp/route-fc747760bd4c8a4b.js +1 -0
  531. package/.next/static/chunks/app/api/sessions/[id]/route-fc747760bd4c8a4b.js +1 -0
  532. package/.next/static/chunks/app/api/sessions/[id]/search/route-fc747760bd4c8a4b.js +1 -0
  533. package/.next/static/chunks/app/api/sessions/[id]/tabs/route-fc747760bd4c8a4b.js +1 -0
  534. package/.next/static/chunks/app/api/sessions/bulk-delete/route-fc747760bd4c8a4b.js +1 -0
  535. package/.next/static/chunks/app/api/sessions/by-ids/route-fc747760bd4c8a4b.js +1 -0
  536. package/.next/static/chunks/app/api/sessions/group/route-fc747760bd4c8a4b.js +1 -0
  537. package/.next/static/chunks/app/api/sessions/pinned/route-fc747760bd4c8a4b.js +1 -0
  538. package/.next/static/chunks/app/api/sessions/route-fc747760bd4c8a4b.js +1 -0
  539. package/.next/static/chunks/app/api/sessions/search/route-fc747760bd4c8a4b.js +1 -0
  540. package/.next/static/chunks/app/api/sessions/thinking/route-fc747760bd4c8a4b.js +1 -0
  541. package/.next/static/chunks/app/api/skills/[name]/route-fc747760bd4c8a4b.js +1 -0
  542. package/.next/static/chunks/app/api/skills/route-fc747760bd4c8a4b.js +1 -0
  543. package/.next/static/chunks/app/api/terminal/[id]/route-fc747760bd4c8a4b.js +1 -0
  544. package/.next/static/chunks/app/api/terminal/route-fc747760bd4c8a4b.js +1 -0
  545. package/.next/static/chunks/app/api/usage/route-fc747760bd4c8a4b.js +1 -0
  546. package/.next/static/chunks/app/api/version/changelog/route-fc747760bd4c8a4b.js +1 -0
  547. package/.next/static/chunks/app/api/version/cockpit/changelog/route-fc747760bd4c8a4b.js +1 -0
  548. package/.next/static/chunks/app/api/version/cockpit/route-fc747760bd4c8a4b.js +1 -0
  549. package/.next/static/chunks/app/api/version/route-fc747760bd4c8a4b.js +1 -0
  550. package/.next/static/chunks/e868780c.f24b6da08e62c7b2.js +18 -0
  551. package/.next/static/chunks/next/dist/client/components/builtin/app-error-fc747760bd4c8a4b.js +1 -0
  552. package/.next/static/chunks/next/dist/client/components/builtin/forbidden-fc747760bd4c8a4b.js +1 -0
  553. package/.next/static/chunks/next/dist/client/components/builtin/not-found-fc747760bd4c8a4b.js +1 -0
  554. package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-fc747760bd4c8a4b.js +1 -0
  555. package/.next/static/chunks/webpack-e31bb45fa59caed8.js +1 -0
  556. package/.next/static/css/3f8af4ae6f812d5c.css +1 -0
  557. package/.next/static/zr8XZzqb74eHitdlkpo-C/_buildManifest.js +1 -0
  558. package/bin/cockpit-hook-bridge.mjs +101 -0
  559. package/dist/server.js +11 -1
  560. package/dist/src/lib/models.js +48 -7
  561. package/dist/src/server/auth.js +32 -10
  562. package/dist/src/server/claude-settings.js +153 -0
  563. package/dist/src/server/cli-init-fetch.js +86 -0
  564. package/dist/src/server/cron-utils.js +16 -5
  565. package/dist/src/server/debug-logger.js +2 -2
  566. package/dist/src/server/defaults.js +16 -7
  567. package/dist/src/server/fs-watcher.js +50 -0
  568. package/dist/src/server/hook-bridge-path.js +34 -0
  569. package/dist/src/server/hook-event-translator.js +211 -0
  570. package/dist/src/server/hook-router.js +150 -0
  571. package/dist/src/server/inbox.js +14 -10
  572. package/dist/src/server/job-lock.js +103 -0
  573. package/dist/src/server/job-scheduler.js +23 -8
  574. package/dist/src/server/job-storage.js +28 -13
  575. package/dist/src/server/notification-settings.js +13 -9
  576. package/dist/src/server/paths.js +23 -0
  577. package/dist/src/server/plans.js +8 -5
  578. package/dist/src/server/providers.js +128 -0
  579. package/dist/src/server/pty-runtime.js +324 -0
  580. package/dist/src/server/pty-session.js +178 -0
  581. package/dist/src/server/session-manager.js +727 -144
  582. package/dist/src/server/session-prefs.js +33 -8
  583. package/dist/src/server/singleton.js +18 -0
  584. package/dist/src/server/stream-processor.js +61 -48
  585. package/dist/src/server/terminal-manager.js +153 -0
  586. package/dist/src/server/todo-watcher.js +178 -0
  587. package/dist/src/server/transcript-watcher.js +91 -0
  588. package/dist/src/server/transcript.js +177 -11
  589. package/dist/src/server/ws-handler.js +235 -61
  590. package/next.config.ts +1 -0
  591. package/package.json +10 -3
  592. package/public/fonts/symbols-nerd-font-mono.woff2 +0 -0
  593. package/.next/server/chunks/1941.js +0 -9
  594. package/.next/server/chunks/2444.js +0 -6
  595. package/.next/static/brzairTqHmHwvfgKpdkYX/_buildManifest.js +0 -1
  596. package/.next/static/chunks/3765-a4c7a493ec83f918.js +0 -20
  597. package/.next/static/chunks/75866-76a3987dda1295ae.js +0 -1
  598. package/.next/static/chunks/93273-87110c1449e1e7fd.js +0 -6
  599. package/.next/static/chunks/app/(app)/agents/[name]/page-3ec9a3460e8e9006.js +0 -8
  600. package/.next/static/chunks/app/(app)/agents/page-d6d504e7d7757ea2.js +0 -1
  601. package/.next/static/chunks/app/(app)/changes/page-a09bf4742aa8b5ce.js +0 -1
  602. package/.next/static/chunks/app/(app)/claude-md/edit/page-ab42921ba2618dc3.js +0 -1
  603. package/.next/static/chunks/app/(app)/claude-md/page-c4c8b20aa002a94a.js +0 -1
  604. package/.next/static/chunks/app/(app)/commands/[name]/page-2124ffed9a4e95a3.js +0 -6
  605. package/.next/static/chunks/app/(app)/commands/page-d5bf1bddd17e31dd.js +0 -1
  606. package/.next/static/chunks/app/(app)/files/page-04e4e5bf1ca89945.js +0 -1
  607. package/.next/static/chunks/app/(app)/hooks/[event]/page-d988623e739973b5.js +0 -6
  608. package/.next/static/chunks/app/(app)/hooks/page-818242d7db432578.js +0 -1
  609. package/.next/static/chunks/app/(app)/inbox/[id]/page-c33dc94e309ff117.js +0 -1
  610. package/.next/static/chunks/app/(app)/inbox/page-ca3e1724b5072734.js +0 -1
  611. package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-3a1c927d76333bf0.js +0 -1
  612. package/.next/static/chunks/app/(app)/jobs/[id]/page-8e698e00b90968b0.js +0 -1
  613. package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-f942df0b7c1d280b.js +0 -1
  614. package/.next/static/chunks/app/(app)/jobs/page-7a88cc6ac34550c2.js +0 -1
  615. package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-3541bf3ccdef9145.js +0 -1
  616. package/.next/static/chunks/app/(app)/mcp-servers/page-3927dfd03d921040.js +0 -1
  617. package/.next/static/chunks/app/(app)/page-594120e0ea1df527.js +0 -1
  618. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-74c23b04f5c3ff88.js +0 -13
  619. package/.next/static/chunks/app/(app)/sessions/[id]/page-435e9fb4dd34007d.js +0 -1
  620. package/.next/static/chunks/app/(app)/settings/page-f8ada7997c0d5b03.js +0 -1
  621. package/.next/static/chunks/app/(app)/skills/[name]/page-5dbe1e7682880145.js +0 -6
  622. package/.next/static/chunks/app/(app)/skills/page-fd1986ad7e060f4d.js +0 -1
  623. package/.next/static/chunks/app/_global-error/page-65c661eddfc65f5b.js +0 -1
  624. package/.next/static/chunks/app/api/agents/[name]/route-65c661eddfc65f5b.js +0 -1
  625. package/.next/static/chunks/app/api/agents/route-65c661eddfc65f5b.js +0 -1
  626. package/.next/static/chunks/app/api/auth/check/route-65c661eddfc65f5b.js +0 -1
  627. package/.next/static/chunks/app/api/auth/login/route-65c661eddfc65f5b.js +0 -1
  628. package/.next/static/chunks/app/api/auth/setup/route-65c661eddfc65f5b.js +0 -1
  629. package/.next/static/chunks/app/api/auth/ws-token/route-65c661eddfc65f5b.js +0 -1
  630. package/.next/static/chunks/app/api/btw/route-65c661eddfc65f5b.js +0 -1
  631. package/.next/static/chunks/app/api/claude-md/route-65c661eddfc65f5b.js +0 -1
  632. package/.next/static/chunks/app/api/commands/[name]/route-65c661eddfc65f5b.js +0 -1
  633. package/.next/static/chunks/app/api/commands/route-65c661eddfc65f5b.js +0 -1
  634. package/.next/static/chunks/app/api/defaults/route-65c661eddfc65f5b.js +0 -1
  635. package/.next/static/chunks/app/api/filesystem/browse/route-65c661eddfc65f5b.js +0 -1
  636. package/.next/static/chunks/app/api/filesystem/files/route-65c661eddfc65f5b.js +0 -1
  637. package/.next/static/chunks/app/api/filesystem/mkdir/route-65c661eddfc65f5b.js +0 -1
  638. package/.next/static/chunks/app/api/filesystem/read/route-65c661eddfc65f5b.js +0 -1
  639. package/.next/static/chunks/app/api/git/clone/route-65c661eddfc65f5b.js +0 -1
  640. package/.next/static/chunks/app/api/git/commit/route-65c661eddfc65f5b.js +0 -1
  641. package/.next/static/chunks/app/api/git/diff/route-65c661eddfc65f5b.js +0 -1
  642. package/.next/static/chunks/app/api/git/discard/route-65c661eddfc65f5b.js +0 -1
  643. package/.next/static/chunks/app/api/git/generate-message/route-65c661eddfc65f5b.js +0 -1
  644. package/.next/static/chunks/app/api/git/push/route-65c661eddfc65f5b.js +0 -1
  645. package/.next/static/chunks/app/api/git/status/route-65c661eddfc65f5b.js +0 -1
  646. package/.next/static/chunks/app/api/github/file-content/route-65c661eddfc65f5b.js +0 -1
  647. package/.next/static/chunks/app/api/github/orgs/route-65c661eddfc65f5b.js +0 -1
  648. package/.next/static/chunks/app/api/github/prs/checks/route-65c661eddfc65f5b.js +0 -1
  649. package/.next/static/chunks/app/api/github/prs/diff/route-65c661eddfc65f5b.js +0 -1
  650. package/.next/static/chunks/app/api/github/prs/review/route-65c661eddfc65f5b.js +0 -1
  651. package/.next/static/chunks/app/api/github/prs/route-65c661eddfc65f5b.js +0 -1
  652. package/.next/static/chunks/app/api/github/prs/view/route-65c661eddfc65f5b.js +0 -1
  653. package/.next/static/chunks/app/api/github/repos/route-65c661eddfc65f5b.js +0 -1
  654. package/.next/static/chunks/app/api/github/review-session/route-65c661eddfc65f5b.js +0 -1
  655. package/.next/static/chunks/app/api/health/route-65c661eddfc65f5b.js +0 -1
  656. package/.next/static/chunks/app/api/hooks/route-65c661eddfc65f5b.js +0 -1
  657. package/.next/static/chunks/app/api/inbox/[id]/route-65c661eddfc65f5b.js +0 -1
  658. package/.next/static/chunks/app/api/inbox/route-65c661eddfc65f5b.js +0 -1
  659. package/.next/static/chunks/app/api/jobs/[id]/route-65c661eddfc65f5b.js +0 -1
  660. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-65c661eddfc65f5b.js +0 -1
  661. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-65c661eddfc65f5b.js +0 -1
  662. package/.next/static/chunks/app/api/jobs/[id]/runs/route-65c661eddfc65f5b.js +0 -1
  663. package/.next/static/chunks/app/api/jobs/[id]/trigger/route-65c661eddfc65f5b.js +0 -1
  664. package/.next/static/chunks/app/api/jobs/mcp-discover/route-65c661eddfc65f5b.js +0 -1
  665. package/.next/static/chunks/app/api/jobs/route-65c661eddfc65f5b.js +0 -1
  666. package/.next/static/chunks/app/api/jobs/status/route-65c661eddfc65f5b.js +0 -1
  667. package/.next/static/chunks/app/api/mcp-servers/[name]/route-65c661eddfc65f5b.js +0 -1
  668. package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-65c661eddfc65f5b.js +0 -1
  669. package/.next/static/chunks/app/api/mcp-servers/route-65c661eddfc65f5b.js +0 -1
  670. package/.next/static/chunks/app/api/notifications/route-65c661eddfc65f5b.js +0 -1
  671. package/.next/static/chunks/app/api/notifications/test/route-65c661eddfc65f5b.js +0 -1
  672. package/.next/static/chunks/app/api/reviews/pinned/route-65c661eddfc65f5b.js +0 -1
  673. package/.next/static/chunks/app/api/sessions/[id]/context/route-65c661eddfc65f5b.js +0 -1
  674. package/.next/static/chunks/app/api/sessions/[id]/mcp/route-65c661eddfc65f5b.js +0 -1
  675. package/.next/static/chunks/app/api/sessions/[id]/route-65c661eddfc65f5b.js +0 -1
  676. package/.next/static/chunks/app/api/sessions/[id]/search/route-65c661eddfc65f5b.js +0 -1
  677. package/.next/static/chunks/app/api/sessions/bulk-delete/route-65c661eddfc65f5b.js +0 -1
  678. package/.next/static/chunks/app/api/sessions/by-ids/route-65c661eddfc65f5b.js +0 -1
  679. package/.next/static/chunks/app/api/sessions/group/route-65c661eddfc65f5b.js +0 -1
  680. package/.next/static/chunks/app/api/sessions/pinned/route-65c661eddfc65f5b.js +0 -1
  681. package/.next/static/chunks/app/api/sessions/route-65c661eddfc65f5b.js +0 -1
  682. package/.next/static/chunks/app/api/sessions/search/route-65c661eddfc65f5b.js +0 -1
  683. package/.next/static/chunks/app/api/skills/[name]/route-65c661eddfc65f5b.js +0 -1
  684. package/.next/static/chunks/app/api/skills/route-65c661eddfc65f5b.js +0 -1
  685. package/.next/static/chunks/app/api/usage/route-65c661eddfc65f5b.js +0 -1
  686. package/.next/static/chunks/app/api/version/cockpit/route-65c661eddfc65f5b.js +0 -1
  687. package/.next/static/chunks/app/api/version/route-65c661eddfc65f5b.js +0 -1
  688. package/.next/static/chunks/next/dist/client/components/builtin/app-error-65c661eddfc65f5b.js +0 -1
  689. package/.next/static/chunks/next/dist/client/components/builtin/forbidden-65c661eddfc65f5b.js +0 -1
  690. package/.next/static/chunks/next/dist/client/components/builtin/not-found-65c661eddfc65f5b.js +0 -1
  691. package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-65c661eddfc65f5b.js +0 -1
  692. package/.next/static/chunks/webpack-3461a05957b13f46.js +0 -1
  693. package/.next/static/css/f04f303b5708dd90.css +0 -1
  694. /package/.next/static/{brzairTqHmHwvfgKpdkYX → zr8XZzqb74eHitdlkpo-C}/_ssgManifest.js +0 -0
@@ -5,16 +5,21 @@ exports.setSessionPrefs = setSessionPrefs;
5
5
  exports.deleteSessionPrefs = deleteSessionPrefs;
6
6
  exports.findChainForCliSession = findChainForCliSession;
7
7
  const node_fs_1 = require("node:fs");
8
- const node_os_1 = require("node:os");
9
8
  const node_path_1 = require("node:path");
10
- const PREFS_DIR = (0, node_path_1.join)((0, node_os_1.homedir)(), ".cockpit");
11
- const PREFS_FILE = (0, node_path_1.join)(PREFS_DIR, "session-prefs.json");
9
+ const models_1 = require("../lib/models");
10
+ const paths_1 = require("../server/paths");
11
+ function prefsDir() {
12
+ return (0, paths_1.getCockpitDir)();
13
+ }
14
+ function prefsFile() {
15
+ return (0, node_path_1.join)(prefsDir(), "session-prefs.json");
16
+ }
12
17
  let cache = null;
13
18
  function load() {
14
19
  if (cache)
15
20
  return cache;
16
21
  try {
17
- cache = JSON.parse((0, node_fs_1.readFileSync)(PREFS_FILE, "utf-8"));
22
+ cache = JSON.parse((0, node_fs_1.readFileSync)(prefsFile(), "utf-8"));
18
23
  return cache;
19
24
  }
20
25
  catch {
@@ -26,13 +31,33 @@ function save() {
26
31
  if (!cache)
27
32
  return;
28
33
  try {
29
- (0, node_fs_1.mkdirSync)(PREFS_DIR, { recursive: true });
30
- (0, node_fs_1.writeFileSync)(PREFS_FILE, JSON.stringify(cache, null, 2) + "\n");
34
+ (0, node_fs_1.mkdirSync)(prefsDir(), { recursive: true });
35
+ (0, node_fs_1.writeFileSync)(prefsFile(), JSON.stringify(cache, null, 2) + "\n");
31
36
  }
32
37
  catch {
33
38
  // best effort
34
39
  }
35
40
  }
41
+ function normalize(raw) {
42
+ if (!raw)
43
+ return raw;
44
+ const next = { ...raw };
45
+ if (next.model?.includes("[")) {
46
+ const split = (0, models_1.splitLegacyModel)(next.model);
47
+ next.model = split.model;
48
+ if (next.contextSize === undefined)
49
+ next.contextSize = split.contextSize;
50
+ }
51
+ if (next.modelSlots?.main?.includes("[")) {
52
+ const split = (0, models_1.splitLegacyModel)(next.modelSlots.main);
53
+ next.modelSlots = {
54
+ ...next.modelSlots,
55
+ main: split.model,
56
+ mainContext: next.modelSlots.mainContext ?? split.contextSize,
57
+ };
58
+ }
59
+ return next;
60
+ }
36
61
  function getSessionPrefs(sessionId) {
37
62
  const all = load();
38
63
  // Prefer chain resolution. The sidebar lists entries keyed by CLI id (one
@@ -42,8 +67,8 @@ function getSessionPrefs(sessionId) {
42
67
  // from before chain resolution was applied at write time.
43
68
  const chain = findChainForCliSession(sessionId);
44
69
  if (chain && all[chain.cockpitId])
45
- return all[chain.cockpitId];
46
- return all[sessionId];
70
+ return normalize(all[chain.cockpitId]);
71
+ return normalize(all[sessionId]);
47
72
  }
48
73
  function setSessionPrefs(sessionId, prefs) {
49
74
  const all = load();
@@ -4,9 +4,15 @@ exports.getSessionManager = getSessionManager;
4
4
  exports.setSessionManager = setSessionManager;
5
5
  exports.getJobScheduler = getJobScheduler;
6
6
  exports.setJobScheduler = setJobScheduler;
7
+ exports.getTerminalManager = getTerminalManager;
8
+ exports.setTerminalManager = setTerminalManager;
9
+ exports.getHookRouter = getHookRouter;
10
+ exports.setHookRouter = setHookRouter;
7
11
  const session_manager_1 = require("./session-manager");
8
12
  const smKey = "__cockpit_session_manager__";
9
13
  const jsKey = "__cockpit_job_scheduler__";
14
+ const tmKey = "__cockpit_terminal_manager__";
15
+ const hrKey = "__cockpit_hook_router__";
10
16
  function getSessionManager() {
11
17
  const g = globalThis;
12
18
  if (!g[smKey]) {
@@ -23,3 +29,15 @@ function getJobScheduler() {
23
29
  function setJobScheduler(scheduler) {
24
30
  globalThis[jsKey] = scheduler;
25
31
  }
32
+ function getTerminalManager() {
33
+ return globalThis[tmKey] || null;
34
+ }
35
+ function setTerminalManager(manager) {
36
+ globalThis[tmKey] = manager;
37
+ }
38
+ function getHookRouter() {
39
+ return globalThis[hrKey] || null;
40
+ }
41
+ function setHookRouter(router) {
42
+ globalThis[hrKey] = router;
43
+ }
@@ -128,7 +128,6 @@ function processEvents(events, state, options) {
128
128
  intermediateMessages: [],
129
129
  snapshot: null,
130
130
  permissionActions: [],
131
- todoInputs: [],
132
131
  compactDone: false,
133
132
  };
134
133
  for (const event of events) {
@@ -198,9 +197,6 @@ function processEvents(events, state, options) {
198
197
  status: "running",
199
198
  };
200
199
  const isAgent = tool.name === "Agent";
201
- if (tool.name === "TodoWrite") {
202
- result.todoInputs.push(tool.input);
203
- }
204
200
  const isFromMainThread = event.assistantMessageId === state.currentAssistantMsgId;
205
201
  event.isMainThread = isFromMainThread;
206
202
  if (state.agentStack.length > 0 && !isFromMainThread) {
@@ -286,6 +282,7 @@ function processEvents(events, state, options) {
286
282
  }
287
283
  else if (event.type === "message_done" && event.message) {
288
284
  state.thinkingStartedAt = null;
285
+ console.log(`[stream-processor] message_done: interrupted=${!!event.interrupted}, pendingBlocks=${state.pendingBlocks.length}, pendingToolUses=${state.pendingToolUses.length}, currentMsgId=${state.currentAssistantMsgId?.slice(0, 8) ?? "null"}, clearPending=${!!event.clearPending}`);
289
286
  if (event.interrupted) {
290
287
  if (state.currentAssistantMsgId) {
291
288
  event.message.id = state.currentAssistantMsgId;
@@ -319,54 +316,67 @@ function processEvents(events, state, options) {
319
316
  result.snapshot = null;
320
317
  continue;
321
318
  }
322
- if (state.currentAssistantMsgId) {
323
- event.message.id = state.currentAssistantMsgId;
324
- }
325
- const hasStreamedText = state.pendingBlocks.some((b) => b.type === "text");
326
- if (event.message.content && !hasStreamedText) {
327
- state.pendingBlocks.push({ type: "text", text: event.message.content });
319
+ if (event.clearPending) {
320
+ // Transcript-loaded message: blocks are already correct; just clear pending state.
321
+ state.pendingToolUses.length = 0;
322
+ state.pendingBlocks.length = 0;
323
+ state.agentStack.length = 0;
324
+ state.currentAssistantMsgId = null;
325
+ result.statusChange = "idle";
326
+ if (options.compacting)
327
+ result.compactDone = true;
328
+ state.flushedOnMessageDone = true;
328
329
  }
329
- if (state.pendingToolUses.length === 0) {
330
- const fullText = state.pendingBlocks
331
- .filter((b) => b.type === "text")
332
- .map((b) => b.text)
333
- .join("")
334
- .trim();
335
- if (fullText === "No response requested.") {
336
- state.pendingBlocks.length = 0;
337
- state.currentAssistantMsgId = null;
338
- result.statusChange = "idle";
339
- state.flushedOnMessageDone = true;
340
- result.snapshot = null;
341
- continue;
330
+ else {
331
+ if (state.currentAssistantMsgId) {
332
+ event.message.id = state.currentAssistantMsgId;
342
333
  }
343
- const apiErrMatch = fullText.match(/^API Error: (\d+)\s/);
344
- if (apiErrMatch) {
345
- const msgMatch = fullText.match(/"message"\s*:\s*"([^"]+)"/);
346
- const errMsg = msgMatch ? `${msgMatch[1]} (HTTP ${apiErrMatch[1]})` : fullText.slice(0, 200);
347
- state.pendingBlocks.length = 0;
348
- state.pendingToolUses.length = 0;
349
- state.agentStack.length = 0;
350
- state.currentAssistantMsgId = null;
351
- result.statusChange = "idle";
352
- result.errors.push(errMsg);
353
- state.flushedOnMessageDone = true;
354
- result.snapshot = null;
355
- continue;
334
+ const hasStreamedText = state.pendingBlocks.some((b) => b.type === "text");
335
+ if (event.message.content && !hasStreamedText) {
336
+ state.pendingBlocks.push({ type: "text", text: event.message.content });
356
337
  }
338
+ if (state.pendingToolUses.length === 0) {
339
+ const fullText = state.pendingBlocks
340
+ .filter((b) => b.type === "text")
341
+ .map((b) => b.text)
342
+ .join("")
343
+ .trim();
344
+ if (fullText === "No response requested.") {
345
+ state.pendingBlocks.length = 0;
346
+ state.currentAssistantMsgId = null;
347
+ result.statusChange = "idle";
348
+ state.flushedOnMessageDone = true;
349
+ result.snapshot = null;
350
+ continue;
351
+ }
352
+ const apiErrMatch = fullText.match(/^API Error: (\d+)\s/);
353
+ if (apiErrMatch) {
354
+ const msgMatch = fullText.match(/"message"\s*:\s*"([^"]+)"/);
355
+ const errMsg = msgMatch ? `${msgMatch[1]} (HTTP ${apiErrMatch[1]})` : fullText.slice(0, 200);
356
+ state.pendingBlocks.length = 0;
357
+ state.pendingToolUses.length = 0;
358
+ state.agentStack.length = 0;
359
+ state.currentAssistantMsgId = null;
360
+ result.statusChange = "idle";
361
+ result.errors.push(errMsg);
362
+ state.flushedOnMessageDone = true;
363
+ result.snapshot = null;
364
+ continue;
365
+ }
366
+ }
367
+ event.message.blocks = [...state.pendingBlocks];
368
+ if (event.message.toolUses.length === 0 && state.pendingToolUses.length > 0) {
369
+ event.message.toolUses = [...state.pendingToolUses];
370
+ }
371
+ state.pendingToolUses.length = 0;
372
+ state.pendingBlocks.length = 0;
373
+ state.agentStack.length = 0;
374
+ state.currentAssistantMsgId = null;
375
+ result.statusChange = "idle";
376
+ if (options.compacting)
377
+ result.compactDone = true;
378
+ state.flushedOnMessageDone = true;
357
379
  }
358
- event.message.blocks = [...state.pendingBlocks];
359
- if (event.message.toolUses.length === 0 && state.pendingToolUses.length > 0) {
360
- event.message.toolUses = [...state.pendingToolUses];
361
- }
362
- state.pendingToolUses.length = 0;
363
- state.pendingBlocks.length = 0;
364
- state.agentStack.length = 0;
365
- state.currentAssistantMsgId = null;
366
- result.statusChange = "idle";
367
- if (options.compacting)
368
- result.compactDone = true;
369
- state.flushedOnMessageDone = true;
370
380
  }
371
381
  if (event.type === "permission_request" && event.requestId) {
372
382
  const toolName = event.toolName || "";
@@ -418,5 +428,8 @@ function processEvents(events, state, options) {
418
428
  result.emit.push(event);
419
429
  result.snapshot = buildSnapshot(state);
420
430
  }
431
+ if (result.statusChange) {
432
+ console.log(`[stream-processor] statusChange=${result.statusChange}, emitting ${result.emit.length} events: [${result.emit.map((e) => e.type).join(", ")}]`);
433
+ }
421
434
  return result;
422
435
  }
@@ -0,0 +1,153 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.TerminalManager = void 0;
7
+ const node_child_process_1 = require("node:child_process");
8
+ const node_os_1 = __importDefault(require("node:os"));
9
+ const node_pty_1 = require("node-pty");
10
+ const uuid_1 = require("uuid");
11
+ const MAX_BUFFER = 100 * 1024;
12
+ function getLoginShell() {
13
+ if (process.platform === "win32") {
14
+ return process.env.COMSPEC || "cmd.exe";
15
+ }
16
+ try {
17
+ const entry = (0, node_child_process_1.execSync)(`getent passwd ${node_os_1.default.userInfo().username}`, { encoding: "utf8" }).trim();
18
+ const shell = entry.split(":").pop();
19
+ if (shell)
20
+ return shell;
21
+ }
22
+ catch {
23
+ // getent not available (macOS)
24
+ }
25
+ try {
26
+ const shell = (0, node_child_process_1.execSync)(`dscl . -read /Users/${node_os_1.default.userInfo().username} UserShell`, { encoding: "utf8" });
27
+ const match = shell.match(/UserShell:\s*(.+)/);
28
+ if (match)
29
+ return match[1].trim();
30
+ }
31
+ catch {
32
+ // not macOS
33
+ }
34
+ return process.env.SHELL || "/bin/bash";
35
+ }
36
+ class TerminalManager {
37
+ terminals = new Map();
38
+ constructor() {
39
+ setInterval(() => {
40
+ for (const [id, term] of this.terminals) {
41
+ try {
42
+ process.kill(term.pty.pid, 0);
43
+ }
44
+ catch {
45
+ this.terminals.delete(id);
46
+ }
47
+ }
48
+ }, 15000);
49
+ }
50
+ createTerminal(cwd, shell, cols = 120, rows = 40) {
51
+ const id = (0, uuid_1.v4)();
52
+ const resolvedShell = shell || getLoginShell();
53
+ const pty = (0, node_pty_1.spawn)(resolvedShell, ["-l"], {
54
+ name: "xterm-256color",
55
+ cols,
56
+ rows,
57
+ cwd,
58
+ env: process.env,
59
+ });
60
+ const instance = { id, pty, cwd, cols, rows, buffer: "", detachOffset: 0, client: null };
61
+ this.terminals.set(id, instance);
62
+ pty.onData((data) => {
63
+ instance.buffer += data;
64
+ if (instance.buffer.length > MAX_BUFFER) {
65
+ instance.buffer = instance.buffer.slice(-MAX_BUFFER);
66
+ if (instance.detachOffset > 0) {
67
+ instance.detachOffset = Math.max(0, instance.detachOffset - (instance.buffer.length - MAX_BUFFER));
68
+ }
69
+ }
70
+ if (instance.client) {
71
+ instance.client(data);
72
+ }
73
+ });
74
+ pty.onExit(() => {
75
+ instance.client = null;
76
+ this.terminals.delete(id);
77
+ });
78
+ return id;
79
+ }
80
+ attachClient(id, sendFn) {
81
+ const term = this.terminals.get(id);
82
+ if (!term)
83
+ return false;
84
+ console.log(`[terminal] attachClient ${id.slice(0, 8)} buffer=${term.buffer.length}b detachOffset=${term.detachOffset} cols=${term.cols} rows=${term.rows}`);
85
+ term.client = sendFn;
86
+ return true;
87
+ }
88
+ getBuffer(id) {
89
+ return this.terminals.get(id)?.buffer ?? "";
90
+ }
91
+ getDelta(id) {
92
+ const term = this.terminals.get(id);
93
+ if (!term)
94
+ return "";
95
+ if (term.detachOffset >= term.buffer.length)
96
+ return "";
97
+ return term.buffer.slice(term.detachOffset);
98
+ }
99
+ detachClient(id) {
100
+ const term = this.terminals.get(id);
101
+ if (term) {
102
+ term.detachOffset = term.buffer.length;
103
+ term.client = null;
104
+ }
105
+ }
106
+ getTerminal(id) {
107
+ return this.terminals.get(id);
108
+ }
109
+ writeToTerminal(id, data) {
110
+ const term = this.terminals.get(id);
111
+ if (!term)
112
+ return false;
113
+ term.pty.write(data);
114
+ return true;
115
+ }
116
+ resizeTerminal(id, cols, rows) {
117
+ const term = this.terminals.get(id);
118
+ if (!term)
119
+ return false;
120
+ if (term.cols === cols && term.rows === rows) {
121
+ console.log(`[terminal] resize ${id.slice(0, 8)} no-op (already ${cols}x${rows})`);
122
+ return true;
123
+ }
124
+ const colsChanged = term.cols !== cols;
125
+ console.log(`[terminal] resize ${id.slice(0, 8)} ${term.cols}x${term.rows} -> ${cols}x${rows}${colsChanged ? " (cols changed, clearing buffer)" : ""}`);
126
+ if (colsChanged) {
127
+ term.buffer = "";
128
+ term.detachOffset = 0;
129
+ }
130
+ term.pty.resize(cols, rows);
131
+ term.cols = cols;
132
+ term.rows = rows;
133
+ return true;
134
+ }
135
+ destroyTerminal(id) {
136
+ const term = this.terminals.get(id);
137
+ if (!term)
138
+ return false;
139
+ term.client = null;
140
+ try {
141
+ term.pty.kill();
142
+ }
143
+ catch {
144
+ // already dead
145
+ }
146
+ this.terminals.delete(id);
147
+ return true;
148
+ }
149
+ listTerminals() {
150
+ return Array.from(this.terminals.values()).map((t) => ({ id: t.id, cwd: t.cwd }));
151
+ }
152
+ }
153
+ exports.TerminalManager = TerminalManager;
@@ -0,0 +1,178 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TodoWatcher = void 0;
4
+ const node_fs_1 = require("node:fs");
5
+ const node_path_1 = require("node:path");
6
+ const paths_1 = require("../server/paths");
7
+ const DEBOUNCE_MS = 300;
8
+ const POLL_INTERVAL_MS = 1000;
9
+ /**
10
+ * Watches both ~/.claude/todos/<sessionId>-agent-*.json (TodoWrite) and
11
+ * ~/.claude/tasks/<sessionId>/*.json (TaskCreate/TaskUpdate) for changes,
12
+ * normalizes them to TodoItem[], and calls onUpdate when the list changes.
13
+ */
14
+ class TodoWatcher {
15
+ cliSessionId;
16
+ onUpdate;
17
+ watchers = [];
18
+ polling = false;
19
+ timer = null;
20
+ lastJson = "";
21
+ stopped = false;
22
+ todosDir;
23
+ tasksDir;
24
+ constructor(cliSessionId, onUpdate) {
25
+ this.cliSessionId = cliSessionId;
26
+ this.onUpdate = onUpdate;
27
+ const base = (0, paths_1.getClaudeDir)();
28
+ this.todosDir = (0, node_path_1.join)(base, "todos");
29
+ this.tasksDir = (0, node_path_1.join)(base, "tasks", cliSessionId);
30
+ }
31
+ start() {
32
+ this.watchDir(this.todosDir);
33
+ this.watchDir(this.tasksDir);
34
+ this.reload();
35
+ }
36
+ stop() {
37
+ this.stopped = true;
38
+ if (this.timer) {
39
+ clearTimeout(this.timer);
40
+ this.timer = null;
41
+ }
42
+ for (const w of this.watchers) {
43
+ w.close();
44
+ }
45
+ this.watchers = [];
46
+ if (this.polling) {
47
+ try {
48
+ (0, node_fs_1.unwatchFile)(this.todosDir);
49
+ }
50
+ catch {
51
+ /* noop */
52
+ }
53
+ try {
54
+ (0, node_fs_1.unwatchFile)(this.tasksDir);
55
+ }
56
+ catch {
57
+ /* noop */
58
+ }
59
+ this.polling = false;
60
+ }
61
+ }
62
+ watchDir(dir) {
63
+ if (!(0, node_fs_1.existsSync)(dir)) {
64
+ this.pollDir(dir);
65
+ return;
66
+ }
67
+ try {
68
+ const w = (0, node_fs_1.watch)(dir, () => this.scheduleReload());
69
+ this.watchers.push(w);
70
+ }
71
+ catch {
72
+ this.pollDir(dir);
73
+ }
74
+ }
75
+ pollDir(dir) {
76
+ this.polling = true;
77
+ (0, node_fs_1.watchFile)(dir, { interval: POLL_INTERVAL_MS }, () => {
78
+ if (this.stopped)
79
+ return;
80
+ if ((0, node_fs_1.existsSync)(dir)) {
81
+ (0, node_fs_1.unwatchFile)(dir);
82
+ try {
83
+ const w = (0, node_fs_1.watch)(dir, () => this.scheduleReload());
84
+ this.watchers.push(w);
85
+ }
86
+ catch {
87
+ /* stay on poll */
88
+ }
89
+ }
90
+ this.scheduleReload();
91
+ });
92
+ }
93
+ scheduleReload() {
94
+ if (this.stopped)
95
+ return;
96
+ if (this.timer)
97
+ clearTimeout(this.timer);
98
+ this.timer = setTimeout(() => this.reload(), DEBOUNCE_MS);
99
+ }
100
+ readOnce() {
101
+ const todos = this.readTodos();
102
+ const tasks = this.readTasks();
103
+ return todos.length > 0 ? todos : tasks;
104
+ }
105
+ reload() {
106
+ const todos = this.readTodos();
107
+ const tasks = this.readTasks();
108
+ const merged = todos.length > 0 ? todos : tasks;
109
+ if (merged.length === 0 && this.lastJson === "")
110
+ return;
111
+ const json = JSON.stringify(merged);
112
+ if (json !== this.lastJson) {
113
+ this.lastJson = json;
114
+ this.onUpdate(merged);
115
+ }
116
+ }
117
+ readTodos() {
118
+ try {
119
+ if (!(0, node_fs_1.existsSync)(this.todosDir))
120
+ return [];
121
+ const prefix = `${this.cliSessionId}-agent-`;
122
+ const files = (0, node_fs_1.readdirSync)(this.todosDir).filter((f) => f.startsWith(prefix) && f.endsWith(".json"));
123
+ if (files.length === 0)
124
+ return [];
125
+ const latest = files.sort().pop();
126
+ const raw = JSON.parse((0, node_fs_1.readFileSync)((0, node_path_1.join)(this.todosDir, latest), "utf-8"));
127
+ if (!Array.isArray(raw))
128
+ return [];
129
+ return raw
130
+ .filter((t) => t.content && t.status)
131
+ .map((t) => ({
132
+ content: t.content,
133
+ status: t.status,
134
+ activeForm: t.activeForm || undefined,
135
+ }));
136
+ }
137
+ catch {
138
+ return [];
139
+ }
140
+ }
141
+ readTasks() {
142
+ try {
143
+ if (!(0, node_fs_1.existsSync)(this.tasksDir))
144
+ return [];
145
+ const files = (0, node_fs_1.readdirSync)(this.tasksDir).filter((f) => f.endsWith(".json"));
146
+ if (files.length === 0)
147
+ return [];
148
+ const tasks = [];
149
+ for (const file of files) {
150
+ try {
151
+ const raw = JSON.parse((0, node_fs_1.readFileSync)((0, node_path_1.join)(this.tasksDir, file), "utf-8"));
152
+ if (raw.status === "deleted")
153
+ continue;
154
+ tasks.push({
155
+ content: raw.subject || raw.description || "",
156
+ status: mapTaskStatus(raw.status),
157
+ activeForm: raw.activeForm || undefined,
158
+ });
159
+ }
160
+ catch {
161
+ // skip malformed file
162
+ }
163
+ }
164
+ return tasks;
165
+ }
166
+ catch {
167
+ return [];
168
+ }
169
+ }
170
+ }
171
+ exports.TodoWatcher = TodoWatcher;
172
+ function mapTaskStatus(status) {
173
+ if (status === "in_progress")
174
+ return "in_progress";
175
+ if (status === "completed")
176
+ return "completed";
177
+ return "pending";
178
+ }
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TranscriptWatcher = void 0;
4
+ const node_fs_1 = require("node:fs");
5
+ const transcript_1 = require("./transcript");
6
+ const DEBOUNCE_MS = 250;
7
+ const POLL_INTERVAL_MS = 500;
8
+ class TranscriptWatcher {
9
+ sessionId;
10
+ cwd;
11
+ onUpdate;
12
+ watcher = null;
13
+ polling = false;
14
+ timer = null;
15
+ lastSize = 0;
16
+ stopped = false;
17
+ filePath;
18
+ constructor(sessionId, cwd, onUpdate) {
19
+ this.sessionId = sessionId;
20
+ this.cwd = cwd;
21
+ this.onUpdate = onUpdate;
22
+ this.filePath = (0, transcript_1.getTranscriptPath)(sessionId, cwd);
23
+ }
24
+ start() {
25
+ if ((0, node_fs_1.existsSync)(this.filePath)) {
26
+ this.watchWithInotify();
27
+ }
28
+ else {
29
+ this.watchWithPoll();
30
+ }
31
+ }
32
+ async stop() {
33
+ this.stopped = true;
34
+ if (this.timer) {
35
+ clearTimeout(this.timer);
36
+ this.timer = null;
37
+ }
38
+ if (this.watcher) {
39
+ this.watcher.close();
40
+ this.watcher = null;
41
+ }
42
+ if (this.polling) {
43
+ (0, node_fs_1.unwatchFile)(this.filePath);
44
+ this.polling = false;
45
+ }
46
+ await this.reload();
47
+ }
48
+ watchWithInotify() {
49
+ try {
50
+ this.watcher = (0, node_fs_1.watch)(this.filePath, () => this.scheduleReload());
51
+ }
52
+ catch {
53
+ this.watchWithPoll();
54
+ }
55
+ }
56
+ watchWithPoll() {
57
+ this.polling = true;
58
+ (0, node_fs_1.watchFile)(this.filePath, { interval: POLL_INTERVAL_MS }, () => {
59
+ if (this.stopped)
60
+ return;
61
+ if (!this.watcher && (0, node_fs_1.existsSync)(this.filePath)) {
62
+ (0, node_fs_1.unwatchFile)(this.filePath);
63
+ this.polling = false;
64
+ this.watchWithInotify();
65
+ }
66
+ this.scheduleReload();
67
+ });
68
+ }
69
+ scheduleReload() {
70
+ if (this.stopped)
71
+ return;
72
+ if (this.timer)
73
+ clearTimeout(this.timer);
74
+ this.timer = setTimeout(() => this.reload(), DEBOUNCE_MS);
75
+ }
76
+ async reload() {
77
+ try {
78
+ const result = await (0, transcript_1.loadTranscript)(this.sessionId, this.cwd, { tailLines: 150 });
79
+ if (result.totalSize !== this.lastSize) {
80
+ this.lastSize = result.totalSize;
81
+ this.onUpdate(result.messages, result.lastUsage);
82
+ }
83
+ }
84
+ catch {
85
+ if (!this.stopped) {
86
+ this.timer = setTimeout(() => this.reload(), 100);
87
+ }
88
+ }
89
+ }
90
+ }
91
+ exports.TranscriptWatcher = TranscriptWatcher;