@seqyuan/annodex 0.1.10 → 0.1.12

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 (519) hide show
  1. package/app/api/agent/[id]/events/route.ts +94 -0
  2. package/app/api/agent/[id]/route.ts +83 -0
  3. package/app/api/agent/new/route.ts +53 -0
  4. package/app/api/auth/all-providers/route.ts +21 -0
  5. package/app/api/auth/api-key/[provider]/route.ts +7 -0
  6. package/app/api/auth/login/[provider]/route.ts +7 -0
  7. package/app/api/auth/login/route.ts +22 -0
  8. package/app/api/auth/logout/[provider]/route.ts +7 -0
  9. package/app/api/auth/providers/route.ts +15 -0
  10. package/app/api/auth/status/route.ts +6 -0
  11. package/app/api/default-cwd/route.ts +22 -0
  12. package/app/api/files/[...path]/route.ts +621 -0
  13. package/app/api/harness/route.ts +47 -0
  14. package/app/api/home/route.ts +6 -0
  15. package/app/api/internal/runtime/route.ts +26 -0
  16. package/app/api/models/route.ts +67 -0
  17. package/app/api/models-config/discover/route.ts +42 -0
  18. package/app/api/models-config/route.ts +152 -0
  19. package/app/api/models-config/test/route.ts +154 -0
  20. package/app/api/projects/browse/route.ts +51 -0
  21. package/app/api/projects/route.ts +83 -0
  22. package/app/api/reports/[id]/route.ts +108 -0
  23. package/app/api/search/route.ts +122 -0
  24. package/app/api/sessions/[id]/context/route.ts +23 -0
  25. package/app/api/sessions/[id]/route.ts +124 -0
  26. package/app/api/sessions/new/route.ts +5 -0
  27. package/app/api/sessions/route.ts +16 -0
  28. package/app/api/settings/route.ts +51 -0
  29. package/app/api/skills/install/route.ts +249 -0
  30. package/app/api/skills/route.ts +161 -0
  31. package/app/api/skills/search/route.ts +121 -0
  32. package/app/api/soul/route.ts +47 -0
  33. package/app/api/version/route.ts +55 -0
  34. package/app/globals.css +736 -0
  35. package/app/layout.tsx +40 -0
  36. package/app/login/page.tsx +133 -0
  37. package/app/page.tsx +10 -0
  38. package/components/AppShell.tsx +1058 -0
  39. package/components/ChatInput.tsx +1103 -0
  40. package/components/ChatMinimap.tsx +381 -0
  41. package/components/ChatWindow.tsx +576 -0
  42. package/components/CodeMirrorEditor.tsx +137 -0
  43. package/components/ConversationSearch.tsx +369 -0
  44. package/components/DataTableViewer.tsx +248 -0
  45. package/components/FileExplorer.tsx +758 -0
  46. package/components/FileIcons.tsx +241 -0
  47. package/components/FileViewer.tsx +1273 -0
  48. package/components/GlobalFileEditor.tsx +98 -0
  49. package/components/MarkdownRenderer.tsx +331 -0
  50. package/components/MermaidDiagram.tsx +80 -0
  51. package/components/MessageView.tsx +1141 -0
  52. package/components/ModelsConfig.tsx +1991 -0
  53. package/components/ProjectContext.tsx +252 -0
  54. package/components/ProjectFolderPicker.tsx +202 -0
  55. package/components/ProjectsConfig.tsx +288 -0
  56. package/components/ProviderIcons.tsx +91 -0
  57. package/components/ReportPanel.tsx +237 -0
  58. package/components/ResizeHandle.tsx +105 -0
  59. package/components/SessionSidebar.tsx +1464 -0
  60. package/components/SettingsDialog.tsx +287 -0
  61. package/components/SkillsConfig.tsx +1093 -0
  62. package/components/SubagentPanel.tsx +191 -0
  63. package/components/TabBar.tsx +115 -0
  64. package/components/ToolPanel.tsx +131 -0
  65. package/components/WidgetRenderer.tsx +505 -0
  66. package/components/viewers/DocumentToolbar.tsx +78 -0
  67. package/components/viewers/DocxViewer.tsx +97 -0
  68. package/components/viewers/PdfViewer.tsx +206 -0
  69. package/components/viewers/PptxViewer.tsx +240 -0
  70. package/components/viewers/XlsxViewer.tsx +143 -0
  71. package/hooks/useAgentSession.ts +710 -0
  72. package/hooks/useAudio.ts +50 -0
  73. package/hooks/useDragDrop.ts +52 -0
  74. package/hooks/useResizable.ts +60 -0
  75. package/hooks/useTheme.ts +85 -0
  76. package/lib/agent-client.ts +39 -0
  77. package/lib/annodex-config.ts +556 -0
  78. package/lib/auth-token.ts +74 -0
  79. package/lib/auth.ts +90 -0
  80. package/lib/brand.ts +5 -0
  81. package/lib/code-theme.ts +32 -0
  82. package/lib/codex-compat-proxy.ts +1603 -0
  83. package/lib/codex-home.ts +6 -0
  84. package/lib/codex-server.ts +796 -0
  85. package/lib/codex-session.ts +590 -0
  86. package/lib/codex-usage.ts +213 -0
  87. package/lib/file-paths.ts +34 -0
  88. package/lib/model-discovery.ts +379 -0
  89. package/lib/normalize.ts +30 -0
  90. package/lib/npx.ts +87 -0
  91. package/lib/pi-types.ts +49 -0
  92. package/lib/projects.ts +269 -0
  93. package/lib/provider-api.ts +88 -0
  94. package/lib/report-prompt.ts +61 -0
  95. package/lib/report-store.ts +597 -0
  96. package/lib/report-update-parser.ts +66 -0
  97. package/lib/rpc-manager.ts +668 -0
  98. package/lib/runtime-state.ts +117 -0
  99. package/lib/session-reader.ts +903 -0
  100. package/lib/session-runtime.ts +105 -0
  101. package/lib/subagent-progress.ts +279 -0
  102. package/lib/types.ts +241 -0
  103. package/lib/widget-export.ts +318 -0
  104. package/lib/widget-guidelines.ts +288 -0
  105. package/lib/widget-prompt.ts +76 -0
  106. package/lib/widget-utils.ts +523 -0
  107. package/package.json +23 -18
  108. package/postcss.config.mjs +8 -0
  109. package/proxy.ts +64 -0
  110. package/scripts/postinstall.cjs +25 -0
  111. package/tsconfig.json +41 -0
  112. package/.next/BUILD_ID +0 -1
  113. package/.next/app-path-routes-manifest.json +0 -39
  114. package/.next/build-manifest.json +0 -20
  115. package/.next/diagnostics/build-diagnostics.json +0 -6
  116. package/.next/diagnostics/framework.json +0 -1
  117. package/.next/export-marker.json +0 -6
  118. package/.next/images-manifest.json +0 -68
  119. package/.next/next-minimal-server.js.nft.json +0 -1
  120. package/.next/next-server.js.nft.json +0 -1
  121. package/.next/package.json +0 -1
  122. package/.next/prerender-manifest.json +0 -109
  123. package/.next/react-loadable-manifest.json +0 -2320
  124. package/.next/required-server-files.js +0 -343
  125. package/.next/required-server-files.json +0 -343
  126. package/.next/routes-manifest.json +0 -286
  127. package/.next/server/app/_global-error/page.js +0 -32
  128. package/.next/server/app/_global-error/page.js.nft.json +0 -1
  129. package/.next/server/app/_global-error/page_client-reference-manifest.js +0 -1
  130. package/.next/server/app/_global-error.html +0 -1
  131. package/.next/server/app/_global-error.meta +0 -16
  132. package/.next/server/app/_global-error.rsc +0 -14
  133. package/.next/server/app/_global-error.segments/_full.segment.rsc +0 -14
  134. package/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +0 -5
  135. package/.next/server/app/_global-error.segments/_global-error.segment.rsc +0 -5
  136. package/.next/server/app/_global-error.segments/_head.segment.rsc +0 -5
  137. package/.next/server/app/_global-error.segments/_index.segment.rsc +0 -5
  138. package/.next/server/app/_global-error.segments/_tree.segment.rsc +0 -1
  139. package/.next/server/app/_not-found/page.js +0 -2
  140. package/.next/server/app/_not-found/page.js.nft.json +0 -1
  141. package/.next/server/app/_not-found/page_client-reference-manifest.js +0 -1
  142. package/.next/server/app/_not-found.html +0 -1
  143. package/.next/server/app/_not-found.meta +0 -16
  144. package/.next/server/app/_not-found.rsc +0 -18
  145. package/.next/server/app/_not-found.segments/_full.segment.rsc +0 -18
  146. package/.next/server/app/_not-found.segments/_head.segment.rsc +0 -6
  147. package/.next/server/app/_not-found.segments/_index.segment.rsc +0 -5
  148. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +0 -5
  149. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +0 -5
  150. package/.next/server/app/_not-found.segments/_tree.segment.rsc +0 -4
  151. package/.next/server/app/api/agent/[id]/events/route.js +0 -3
  152. package/.next/server/app/api/agent/[id]/events/route.js.nft.json +0 -1
  153. package/.next/server/app/api/agent/[id]/events/route_client-reference-manifest.js +0 -1
  154. package/.next/server/app/api/agent/[id]/route.js +0 -1
  155. package/.next/server/app/api/agent/[id]/route.js.nft.json +0 -1
  156. package/.next/server/app/api/agent/[id]/route_client-reference-manifest.js +0 -1
  157. package/.next/server/app/api/agent/new/route.js +0 -1
  158. package/.next/server/app/api/agent/new/route.js.nft.json +0 -1
  159. package/.next/server/app/api/agent/new/route_client-reference-manifest.js +0 -1
  160. package/.next/server/app/api/auth/all-providers/route.js +0 -1
  161. package/.next/server/app/api/auth/all-providers/route.js.nft.json +0 -1
  162. package/.next/server/app/api/auth/all-providers/route_client-reference-manifest.js +0 -1
  163. package/.next/server/app/api/auth/api-key/[provider]/route.js +0 -1
  164. package/.next/server/app/api/auth/api-key/[provider]/route.js.nft.json +0 -1
  165. package/.next/server/app/api/auth/api-key/[provider]/route_client-reference-manifest.js +0 -1
  166. package/.next/server/app/api/auth/login/[provider]/route.js +0 -1
  167. package/.next/server/app/api/auth/login/[provider]/route.js.nft.json +0 -1
  168. package/.next/server/app/api/auth/login/[provider]/route_client-reference-manifest.js +0 -1
  169. package/.next/server/app/api/auth/login/route.js +0 -1
  170. package/.next/server/app/api/auth/login/route.js.nft.json +0 -1
  171. package/.next/server/app/api/auth/login/route_client-reference-manifest.js +0 -1
  172. package/.next/server/app/api/auth/logout/[provider]/route.js +0 -1
  173. package/.next/server/app/api/auth/logout/[provider]/route.js.nft.json +0 -1
  174. package/.next/server/app/api/auth/logout/[provider]/route_client-reference-manifest.js +0 -1
  175. package/.next/server/app/api/auth/providers/route.js +0 -1
  176. package/.next/server/app/api/auth/providers/route.js.nft.json +0 -1
  177. package/.next/server/app/api/auth/providers/route_client-reference-manifest.js +0 -1
  178. package/.next/server/app/api/auth/status/route.js +0 -1
  179. package/.next/server/app/api/auth/status/route.js.nft.json +0 -1
  180. package/.next/server/app/api/auth/status/route_client-reference-manifest.js +0 -1
  181. package/.next/server/app/api/default-cwd/route.js +0 -1
  182. package/.next/server/app/api/default-cwd/route.js.nft.json +0 -1
  183. package/.next/server/app/api/default-cwd/route_client-reference-manifest.js +0 -1
  184. package/.next/server/app/api/files/[...path]/route.js +0 -4
  185. package/.next/server/app/api/files/[...path]/route.js.nft.json +0 -1
  186. package/.next/server/app/api/files/[...path]/route_client-reference-manifest.js +0 -1
  187. package/.next/server/app/api/harness/route.js +0 -1
  188. package/.next/server/app/api/harness/route.js.nft.json +0 -1
  189. package/.next/server/app/api/harness/route_client-reference-manifest.js +0 -1
  190. package/.next/server/app/api/home/route.js +0 -1
  191. package/.next/server/app/api/home/route.js.nft.json +0 -1
  192. package/.next/server/app/api/home/route_client-reference-manifest.js +0 -1
  193. package/.next/server/app/api/internal/runtime/route.js +0 -1
  194. package/.next/server/app/api/internal/runtime/route.js.nft.json +0 -1
  195. package/.next/server/app/api/internal/runtime/route_client-reference-manifest.js +0 -1
  196. package/.next/server/app/api/models/route.js +0 -1
  197. package/.next/server/app/api/models/route.js.nft.json +0 -1
  198. package/.next/server/app/api/models/route_client-reference-manifest.js +0 -1
  199. package/.next/server/app/api/models-config/discover/route.js +0 -1
  200. package/.next/server/app/api/models-config/discover/route.js.nft.json +0 -1
  201. package/.next/server/app/api/models-config/discover/route_client-reference-manifest.js +0 -1
  202. package/.next/server/app/api/models-config/route.js +0 -1
  203. package/.next/server/app/api/models-config/route.js.nft.json +0 -1
  204. package/.next/server/app/api/models-config/route_client-reference-manifest.js +0 -1
  205. package/.next/server/app/api/models-config/test/route.js +0 -1
  206. package/.next/server/app/api/models-config/test/route.js.nft.json +0 -1
  207. package/.next/server/app/api/models-config/test/route_client-reference-manifest.js +0 -1
  208. package/.next/server/app/api/projects/browse/route.js +0 -1
  209. package/.next/server/app/api/projects/browse/route.js.nft.json +0 -1
  210. package/.next/server/app/api/projects/browse/route_client-reference-manifest.js +0 -1
  211. package/.next/server/app/api/projects/route.js +0 -1
  212. package/.next/server/app/api/projects/route.js.nft.json +0 -1
  213. package/.next/server/app/api/projects/route_client-reference-manifest.js +0 -1
  214. package/.next/server/app/api/reports/[id]/route.js +0 -10
  215. package/.next/server/app/api/reports/[id]/route.js.nft.json +0 -1
  216. package/.next/server/app/api/reports/[id]/route_client-reference-manifest.js +0 -1
  217. package/.next/server/app/api/search/route.js +0 -1
  218. package/.next/server/app/api/search/route.js.nft.json +0 -1
  219. package/.next/server/app/api/search/route_client-reference-manifest.js +0 -1
  220. package/.next/server/app/api/sessions/[id]/context/route.js +0 -1
  221. package/.next/server/app/api/sessions/[id]/context/route.js.nft.json +0 -1
  222. package/.next/server/app/api/sessions/[id]/context/route_client-reference-manifest.js +0 -1
  223. package/.next/server/app/api/sessions/[id]/route.js +0 -1
  224. package/.next/server/app/api/sessions/[id]/route.js.nft.json +0 -1
  225. package/.next/server/app/api/sessions/[id]/route_client-reference-manifest.js +0 -1
  226. package/.next/server/app/api/sessions/new/route.js +0 -1
  227. package/.next/server/app/api/sessions/new/route.js.nft.json +0 -1
  228. package/.next/server/app/api/sessions/new/route_client-reference-manifest.js +0 -1
  229. package/.next/server/app/api/sessions/route.js +0 -1
  230. package/.next/server/app/api/sessions/route.js.nft.json +0 -1
  231. package/.next/server/app/api/sessions/route_client-reference-manifest.js +0 -1
  232. package/.next/server/app/api/settings/route.js +0 -1
  233. package/.next/server/app/api/settings/route.js.nft.json +0 -1
  234. package/.next/server/app/api/settings/route_client-reference-manifest.js +0 -1
  235. package/.next/server/app/api/skills/install/route.js +0 -5
  236. package/.next/server/app/api/skills/install/route.js.nft.json +0 -1
  237. package/.next/server/app/api/skills/install/route_client-reference-manifest.js +0 -1
  238. package/.next/server/app/api/skills/route.js +0 -6
  239. package/.next/server/app/api/skills/route.js.nft.json +0 -1
  240. package/.next/server/app/api/skills/route_client-reference-manifest.js +0 -1
  241. package/.next/server/app/api/skills/search/route.js +0 -1
  242. package/.next/server/app/api/skills/search/route.js.nft.json +0 -1
  243. package/.next/server/app/api/skills/search/route_client-reference-manifest.js +0 -1
  244. package/.next/server/app/api/soul/route.js +0 -1
  245. package/.next/server/app/api/soul/route.js.nft.json +0 -1
  246. package/.next/server/app/api/soul/route_client-reference-manifest.js +0 -1
  247. package/.next/server/app/api/version/route.js +0 -1
  248. package/.next/server/app/api/version/route.js.nft.json +0 -1
  249. package/.next/server/app/api/version/route_client-reference-manifest.js +0 -1
  250. package/.next/server/app/index.html +0 -1
  251. package/.next/server/app/index.meta +0 -14
  252. package/.next/server/app/index.rsc +0 -17
  253. package/.next/server/app/index.segments/__PAGE__.segment.rsc +0 -6
  254. package/.next/server/app/index.segments/_full.segment.rsc +0 -17
  255. package/.next/server/app/index.segments/_head.segment.rsc +0 -6
  256. package/.next/server/app/index.segments/_index.segment.rsc +0 -5
  257. package/.next/server/app/index.segments/_tree.segment.rsc +0 -4
  258. package/.next/server/app/login/page.js +0 -2
  259. package/.next/server/app/login/page.js.nft.json +0 -1
  260. package/.next/server/app/login/page_client-reference-manifest.js +0 -1
  261. package/.next/server/app/login.html +0 -1
  262. package/.next/server/app/login.meta +0 -15
  263. package/.next/server/app/login.rsc +0 -22
  264. package/.next/server/app/login.segments/_full.segment.rsc +0 -22
  265. package/.next/server/app/login.segments/_head.segment.rsc +0 -6
  266. package/.next/server/app/login.segments/_index.segment.rsc +0 -5
  267. package/.next/server/app/login.segments/_tree.segment.rsc +0 -4
  268. package/.next/server/app/login.segments/login/__PAGE__.segment.rsc +0 -9
  269. package/.next/server/app/login.segments/login.segment.rsc +0 -5
  270. package/.next/server/app/page.js +0 -261
  271. package/.next/server/app/page.js.nft.json +0 -1
  272. package/.next/server/app/page_client-reference-manifest.js +0 -1
  273. package/.next/server/app-paths-manifest.json +0 -39
  274. package/.next/server/chunks/1048.js +0 -1
  275. package/.next/server/chunks/1367.js +0 -77
  276. package/.next/server/chunks/1381.js +0 -1
  277. package/.next/server/chunks/165.js +0 -1
  278. package/.next/server/chunks/1681.js +0 -215
  279. package/.next/server/chunks/1688.js +0 -45
  280. package/.next/server/chunks/1703.js +0 -79
  281. package/.next/server/chunks/1712.js +0 -43
  282. package/.next/server/chunks/1813.js +0 -1
  283. package/.next/server/chunks/2325.js +0 -80
  284. package/.next/server/chunks/258.js +0 -1
  285. package/.next/server/chunks/2671.js +0 -287
  286. package/.next/server/chunks/2778.js +0 -1
  287. package/.next/server/chunks/2943.js +0 -1
  288. package/.next/server/chunks/3031.js +0 -226
  289. package/.next/server/chunks/3181.js +0 -1
  290. package/.next/server/chunks/3493.js +0 -1
  291. package/.next/server/chunks/3672.js +0 -1
  292. package/.next/server/chunks/3701.js +0 -104
  293. package/.next/server/chunks/4013.js +0 -1
  294. package/.next/server/chunks/402.js +0 -2
  295. package/.next/server/chunks/4035.js +0 -80
  296. package/.next/server/chunks/4248.js +0 -153
  297. package/.next/server/chunks/4367.js +0 -1
  298. package/.next/server/chunks/4406.js +0 -141
  299. package/.next/server/chunks/4741.js +0 -18
  300. package/.next/server/chunks/4768.js +0 -1
  301. package/.next/server/chunks/4858.js +0 -148
  302. package/.next/server/chunks/4980.js +0 -1
  303. package/.next/server/chunks/5155.js +0 -5
  304. package/.next/server/chunks/5293.js +0 -166
  305. package/.next/server/chunks/5399.js +0 -8
  306. package/.next/server/chunks/5409.js +0 -1
  307. package/.next/server/chunks/5797.js +0 -93
  308. package/.next/server/chunks/5851.js +0 -36
  309. package/.next/server/chunks/6206.js +0 -1
  310. package/.next/server/chunks/6296.js +0 -1
  311. package/.next/server/chunks/63.js +0 -45
  312. package/.next/server/chunks/6346.js +0 -1
  313. package/.next/server/chunks/6406.js +0 -23
  314. package/.next/server/chunks/642.js +0 -1
  315. package/.next/server/chunks/6429.js +0 -50
  316. package/.next/server/chunks/6729.js +0 -64
  317. package/.next/server/chunks/6907.js +0 -115
  318. package/.next/server/chunks/6980.js +0 -1
  319. package/.next/server/chunks/7073.js +0 -24
  320. package/.next/server/chunks/7233.js +0 -24
  321. package/.next/server/chunks/7307.js +0 -1
  322. package/.next/server/chunks/7362.js +0 -9
  323. package/.next/server/chunks/7567.js +0 -29
  324. package/.next/server/chunks/7765.js +0 -1
  325. package/.next/server/chunks/7890.js +0 -1
  326. package/.next/server/chunks/8065.js +0 -1
  327. package/.next/server/chunks/8238.js +0 -34
  328. package/.next/server/chunks/8276.js +0 -1
  329. package/.next/server/chunks/8336.js +0 -1
  330. package/.next/server/chunks/8477.js +0 -3
  331. package/.next/server/chunks/8490.js +0 -1
  332. package/.next/server/chunks/8916.js +0 -1
  333. package/.next/server/chunks/9280.js +0 -252
  334. package/.next/server/chunks/9315.js +0 -1
  335. package/.next/server/chunks/9537.js +0 -90
  336. package/.next/server/chunks/966.js +0 -1
  337. package/.next/server/chunks/9818.js +0 -21
  338. package/.next/server/chunks/static/media/pdf.worker.min.c476e1a0.mjs +0 -6
  339. package/.next/server/functions-config-manifest.json +0 -16
  340. package/.next/server/interception-route-rewrite-manifest.js +0 -1
  341. package/.next/server/middleware-build-manifest.js +0 -1
  342. package/.next/server/middleware-manifest.json +0 -6
  343. package/.next/server/middleware-react-loadable-manifest.js +0 -1
  344. package/.next/server/middleware.js +0 -18
  345. package/.next/server/middleware.js.nft.json +0 -1
  346. package/.next/server/next-font-manifest.js +0 -1
  347. package/.next/server/next-font-manifest.json +0 -1
  348. package/.next/server/pages/404.html +0 -1
  349. package/.next/server/pages/500.html +0 -1
  350. package/.next/server/pages-manifest.json +0 -4
  351. package/.next/server/prefetch-hints.json +0 -1
  352. package/.next/server/server-reference-manifest.js +0 -1
  353. package/.next/server/server-reference-manifest.json +0 -1
  354. package/.next/server/webpack-runtime.js +0 -1
  355. package/.next/static/6cuMSvcr0FVO-GiK5RJZh/_buildManifest.js +0 -1
  356. package/.next/static/6cuMSvcr0FVO-GiK5RJZh/_ssgManifest.js +0 -1
  357. package/.next/static/chunks/0b9a0da7.9075af772487e743.js +0 -62
  358. package/.next/static/chunks/1413.922d232de90c0c41.js +0 -115
  359. package/.next/static/chunks/1643.467a526a1f24f54d.js +0 -24
  360. package/.next/static/chunks/1852.5543122f11aa7fed.js +0 -1
  361. package/.next/static/chunks/1960.b1e26436d7a5f586.js +0 -1
  362. package/.next/static/chunks/2170a4aa.4213bb2183c9cdf9.js +0 -1
  363. package/.next/static/chunks/2274.6cd173f80a1405a2.js +0 -21
  364. package/.next/static/chunks/2419.347fdfe3c170854d.js +0 -166
  365. package/.next/static/chunks/2619.9aac8983f30c7c8a.js +0 -1
  366. package/.next/static/chunks/2623.d20fabd8e18197c6.js +0 -287
  367. package/.next/static/chunks/2729.f5365061a849d659.js +0 -34
  368. package/.next/static/chunks/2821.934bcf60fbdc28c6.js +0 -1
  369. package/.next/static/chunks/2918becc.abff2ece1de37bc1.js +0 -153
  370. package/.next/static/chunks/2947.114e51cb06d1c01a.js +0 -23
  371. package/.next/static/chunks/3079.4c511fa1144e3adf.js +0 -79
  372. package/.next/static/chunks/3274.208ca44844cd7d95.js +0 -148
  373. package/.next/static/chunks/3308.465a94263d04bfea.js +0 -73
  374. package/.next/static/chunks/3325.e4bfe1ca657f3b5b.js +0 -80
  375. package/.next/static/chunks/3506.2a7eaa08b9f55337.js +0 -90
  376. package/.next/static/chunks/363642f4-043c1475ab9af70e.js +0 -1
  377. package/.next/static/chunks/3794-123fdf632563f469.js +0 -32
  378. package/.next/static/chunks/3837.a755ccfe6f9c1c1c.js +0 -5
  379. package/.next/static/chunks/394.91597771688df6d0.js +0 -1
  380. package/.next/static/chunks/3997.1009c06025691712.js +0 -1
  381. package/.next/static/chunks/4453.91a357dc43c21745.js +0 -1
  382. package/.next/static/chunks/4491.44fdf20580ac72bd.js +0 -24
  383. package/.next/static/chunks/4829.cf1d50e43e6d9db5.js +0 -1
  384. package/.next/static/chunks/498.fe1d9da9ecad6c36.js +0 -1
  385. package/.next/static/chunks/4bd1b696-e356ca5ba0218e27.js +0 -1
  386. package/.next/static/chunks/5019.b5a1a2b8daf17525.js +0 -1
  387. package/.next/static/chunks/5034.8f16c3fa3ce75411.js +0 -1
  388. package/.next/static/chunks/5074.d16651da01ec4e02.js +0 -1
  389. package/.next/static/chunks/51fb665c.0950e1b79671348d.js +0 -45
  390. package/.next/static/chunks/532.5956ed631aff722b.js +0 -9
  391. package/.next/static/chunks/5326.69460442bdcd6cd3.js +0 -1
  392. package/.next/static/chunks/5403.ff110bf5bf600758.js +0 -64
  393. package/.next/static/chunks/547.902a733488cfe3f7.js +0 -77
  394. package/.next/static/chunks/5567.540d7fc108ad6ee5.js +0 -215
  395. package/.next/static/chunks/5590.ef62922166d308b4.js +0 -1
  396. package/.next/static/chunks/5690.9d6eb1edb1399995.js +0 -1
  397. package/.next/static/chunks/5749.25faee4a1e55b854.js +0 -226
  398. package/.next/static/chunks/58bb9007.1ccb6bba34b4c635.js +0 -80
  399. package/.next/static/chunks/6121.f3f43f1896ea0cd9.js +0 -1
  400. package/.next/static/chunks/6600.583c88eef37aa524.js +0 -1
  401. package/.next/static/chunks/6696.a41aec266e657d54.js +0 -141
  402. package/.next/static/chunks/6922.42148793782d2fe7.js +0 -1
  403. package/.next/static/chunks/7006.e191611ffc2b9528.js +0 -43
  404. package/.next/static/chunks/7343.9fbb58204d8ac681.js +0 -1
  405. package/.next/static/chunks/73972abe.25a4cffa03b2bcef.js +0 -119
  406. package/.next/static/chunks/7547.58bda8a2aabba0d4.js +0 -93
  407. package/.next/static/chunks/7648.4ae2f183b4db0353.js +0 -1
  408. package/.next/static/chunks/7874.8db6929b94cdf697.js +0 -1
  409. package/.next/static/chunks/7959.1f20a35df316216a.js +0 -104
  410. package/.next/static/chunks/83.85d62d7fc9850b75.js +0 -29
  411. package/.next/static/chunks/8436.cab94b59cca0a8ff.js +0 -1
  412. package/.next/static/chunks/8451.ff6ff72b57dc52e1.js +0 -1
  413. package/.next/static/chunks/8489.45f22859734f514f.js +0 -36
  414. package/.next/static/chunks/8568.f85d8b36fc9a9037.js +0 -1
  415. package/.next/static/chunks/8771-3e14b6810486df1f.js +0 -1
  416. package/.next/static/chunks/8863.be51033a67436277.js +0 -1
  417. package/.next/static/chunks/90542734.dc1a2723e4f6affb.js +0 -1
  418. package/.next/static/chunks/9500.1488aec06ee78127.js +0 -1
  419. package/.next/static/chunks/9633.155548b5fca6e580.js +0 -1
  420. package/.next/static/chunks/9779.673004a62d70e36a.js +0 -1
  421. package/.next/static/chunks/app/_global-error/page-cc518af6b1ffb191.js +0 -1
  422. package/.next/static/chunks/app/_not-found/page-c72daab99269beff.js +0 -1
  423. package/.next/static/chunks/app/api/agent/[id]/events/route-cc518af6b1ffb191.js +0 -1
  424. package/.next/static/chunks/app/api/agent/[id]/route-cc518af6b1ffb191.js +0 -1
  425. package/.next/static/chunks/app/api/agent/new/route-cc518af6b1ffb191.js +0 -1
  426. package/.next/static/chunks/app/api/auth/all-providers/route-cc518af6b1ffb191.js +0 -1
  427. package/.next/static/chunks/app/api/auth/api-key/[provider]/route-cc518af6b1ffb191.js +0 -1
  428. package/.next/static/chunks/app/api/auth/login/[provider]/route-cc518af6b1ffb191.js +0 -1
  429. package/.next/static/chunks/app/api/auth/login/route-cc518af6b1ffb191.js +0 -1
  430. package/.next/static/chunks/app/api/auth/logout/[provider]/route-cc518af6b1ffb191.js +0 -1
  431. package/.next/static/chunks/app/api/auth/providers/route-cc518af6b1ffb191.js +0 -1
  432. package/.next/static/chunks/app/api/auth/status/route-cc518af6b1ffb191.js +0 -1
  433. package/.next/static/chunks/app/api/default-cwd/route-cc518af6b1ffb191.js +0 -1
  434. package/.next/static/chunks/app/api/files/[...path]/route-cc518af6b1ffb191.js +0 -1
  435. package/.next/static/chunks/app/api/harness/route-cc518af6b1ffb191.js +0 -1
  436. package/.next/static/chunks/app/api/home/route-cc518af6b1ffb191.js +0 -1
  437. package/.next/static/chunks/app/api/internal/runtime/route-cc518af6b1ffb191.js +0 -1
  438. package/.next/static/chunks/app/api/models/route-cc518af6b1ffb191.js +0 -1
  439. package/.next/static/chunks/app/api/models-config/discover/route-cc518af6b1ffb191.js +0 -1
  440. package/.next/static/chunks/app/api/models-config/route-cc518af6b1ffb191.js +0 -1
  441. package/.next/static/chunks/app/api/models-config/test/route-cc518af6b1ffb191.js +0 -1
  442. package/.next/static/chunks/app/api/projects/browse/route-cc518af6b1ffb191.js +0 -1
  443. package/.next/static/chunks/app/api/projects/route-cc518af6b1ffb191.js +0 -1
  444. package/.next/static/chunks/app/api/reports/[id]/route-cc518af6b1ffb191.js +0 -1
  445. package/.next/static/chunks/app/api/search/route-cc518af6b1ffb191.js +0 -1
  446. package/.next/static/chunks/app/api/sessions/[id]/context/route-cc518af6b1ffb191.js +0 -1
  447. package/.next/static/chunks/app/api/sessions/[id]/route-cc518af6b1ffb191.js +0 -1
  448. package/.next/static/chunks/app/api/sessions/new/route-cc518af6b1ffb191.js +0 -1
  449. package/.next/static/chunks/app/api/sessions/route-cc518af6b1ffb191.js +0 -1
  450. package/.next/static/chunks/app/api/settings/route-cc518af6b1ffb191.js +0 -1
  451. package/.next/static/chunks/app/api/skills/install/route-cc518af6b1ffb191.js +0 -1
  452. package/.next/static/chunks/app/api/skills/route-cc518af6b1ffb191.js +0 -1
  453. package/.next/static/chunks/app/api/skills/search/route-cc518af6b1ffb191.js +0 -1
  454. package/.next/static/chunks/app/api/soul/route-cc518af6b1ffb191.js +0 -1
  455. package/.next/static/chunks/app/api/version/route-cc518af6b1ffb191.js +0 -1
  456. package/.next/static/chunks/app/layout-be148b7ae915b22a.js +0 -1
  457. package/.next/static/chunks/app/login/page-ebf0e6de99062783.js +0 -1
  458. package/.next/static/chunks/app/page-c45d98ea81c548ca.js +0 -260
  459. package/.next/static/chunks/d3ac728e.7964f816a1ca64e5.js +0 -1
  460. package/.next/static/chunks/framework-711ef29bc66f648c.js +0 -1
  461. package/.next/static/chunks/main-app-45a0f19af99d61b6.js +0 -1
  462. package/.next/static/chunks/main-f74964b7ae52493e.js +0 -5
  463. package/.next/static/chunks/next/dist/client/components/builtin/app-error-cc518af6b1ffb191.js +0 -1
  464. package/.next/static/chunks/next/dist/client/components/builtin/forbidden-cc518af6b1ffb191.js +0 -1
  465. package/.next/static/chunks/next/dist/client/components/builtin/global-error-9bfa08b9491621f2.js +0 -1
  466. package/.next/static/chunks/next/dist/client/components/builtin/not-found-cc518af6b1ffb191.js +0 -1
  467. package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-cc518af6b1ffb191.js +0 -1
  468. package/.next/static/chunks/polyfills-42372ed130431b0a.js +0 -1
  469. package/.next/static/chunks/webpack-fcf4a889ecbd753c.js +0 -1
  470. package/.next/static/css/45029451a1d7255d.css +0 -3
  471. package/.next/static/media/15605e25b523335c-s.woff2 +0 -0
  472. package/.next/static/media/1a3dce5cfb5f7760-s.woff2 +0 -0
  473. package/.next/static/media/1cdd02902f937a18-s.woff2 +0 -0
  474. package/.next/static/media/4c4b3b30b6bcb2be-s.woff2 +0 -0
  475. package/.next/static/media/641a7b8a5800ee0e-s.woff2 +0 -0
  476. package/.next/static/media/7deddc85b7ffd1dc-s.p.woff2 +0 -0
  477. package/.next/static/media/ec14413c594b3356-s.p.woff2 +0 -0
  478. package/.next/static/media/pdf.worker.min.29aaf158.mjs +0 -6
  479. package/.next/trace +0 -74
  480. package/.next/trace-build +0 -1
  481. package/.next/types/app/api/agent/[id]/events/route.ts +0 -351
  482. package/.next/types/app/api/agent/[id]/route.ts +0 -351
  483. package/.next/types/app/api/agent/new/route.ts +0 -351
  484. package/.next/types/app/api/auth/all-providers/route.ts +0 -351
  485. package/.next/types/app/api/auth/api-key/[provider]/route.ts +0 -351
  486. package/.next/types/app/api/auth/login/[provider]/route.ts +0 -351
  487. package/.next/types/app/api/auth/login/route.ts +0 -351
  488. package/.next/types/app/api/auth/logout/[provider]/route.ts +0 -351
  489. package/.next/types/app/api/auth/providers/route.ts +0 -351
  490. package/.next/types/app/api/auth/status/route.ts +0 -351
  491. package/.next/types/app/api/default-cwd/route.ts +0 -351
  492. package/.next/types/app/api/files/[...path]/route.ts +0 -351
  493. package/.next/types/app/api/harness/route.ts +0 -351
  494. package/.next/types/app/api/home/route.ts +0 -351
  495. package/.next/types/app/api/internal/runtime/route.ts +0 -351
  496. package/.next/types/app/api/models/route.ts +0 -351
  497. package/.next/types/app/api/models-config/discover/route.ts +0 -351
  498. package/.next/types/app/api/models-config/route.ts +0 -351
  499. package/.next/types/app/api/models-config/test/route.ts +0 -351
  500. package/.next/types/app/api/projects/browse/route.ts +0 -351
  501. package/.next/types/app/api/projects/route.ts +0 -351
  502. package/.next/types/app/api/reports/[id]/route.ts +0 -351
  503. package/.next/types/app/api/search/route.ts +0 -351
  504. package/.next/types/app/api/sessions/[id]/context/route.ts +0 -351
  505. package/.next/types/app/api/sessions/[id]/route.ts +0 -351
  506. package/.next/types/app/api/sessions/new/route.ts +0 -351
  507. package/.next/types/app/api/sessions/route.ts +0 -351
  508. package/.next/types/app/api/settings/route.ts +0 -351
  509. package/.next/types/app/api/skills/install/route.ts +0 -351
  510. package/.next/types/app/api/skills/route.ts +0 -351
  511. package/.next/types/app/api/skills/search/route.ts +0 -351
  512. package/.next/types/app/api/soul/route.ts +0 -351
  513. package/.next/types/app/api/version/route.ts +0 -351
  514. package/.next/types/app/layout.ts +0 -87
  515. package/.next/types/app/login/page.ts +0 -87
  516. package/.next/types/app/page.ts +0 -87
  517. package/.next/types/package.json +0 -1
  518. package/.next/types/routes.d.ts +0 -106
  519. package/.next/types/validator.ts +0 -376
@@ -0,0 +1,105 @@
1
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from "fs";
2
+ import { dirname, join } from "path";
3
+ import { homedir } from "os";
4
+
5
+ export interface StoredSessionRuntime {
6
+ sessionId: string;
7
+ cwd?: string;
8
+ provider?: string;
9
+ modelId?: string;
10
+ thinkingLevel?: string;
11
+ updatedAt: string;
12
+ }
13
+
14
+ interface RuntimeStoreFile {
15
+ version: 1;
16
+ sessions: Record<string, StoredSessionRuntime>;
17
+ }
18
+
19
+ function getAnnodexConfigDir(): string {
20
+ return process.env.ANNODEX_CONFIG_DIR
21
+ ?? process.env.ANNOVIBE_CONFIG_DIR
22
+ ?? join(homedir(), ".config", "annodex");
23
+ }
24
+
25
+ function getRuntimeStorePath(): string {
26
+ return join(getAnnodexConfigDir(), "session-runtime.json");
27
+ }
28
+
29
+ function emptyStore(): RuntimeStoreFile {
30
+ return { version: 1, sessions: {} };
31
+ }
32
+
33
+ function isRecord(value: unknown): value is Record<string, unknown> {
34
+ return typeof value === "object" && value !== null && !Array.isArray(value);
35
+ }
36
+
37
+ function normalizeRuntime(value: unknown): StoredSessionRuntime | null {
38
+ if (!isRecord(value) || typeof value.sessionId !== "string") return null;
39
+ const sessionId = value.sessionId.trim();
40
+ if (!sessionId) return null;
41
+ return {
42
+ sessionId,
43
+ cwd: typeof value.cwd === "string" && value.cwd.trim() ? value.cwd : undefined,
44
+ provider: typeof value.provider === "string" && value.provider.trim() ? value.provider : undefined,
45
+ modelId: typeof value.modelId === "string" && value.modelId.trim() ? value.modelId : undefined,
46
+ thinkingLevel: typeof value.thinkingLevel === "string" && value.thinkingLevel.trim() ? value.thinkingLevel : undefined,
47
+ updatedAt: typeof value.updatedAt === "string" ? value.updatedAt : new Date(0).toISOString(),
48
+ };
49
+ }
50
+
51
+ function readStore(): RuntimeStoreFile {
52
+ const path = getRuntimeStorePath();
53
+ if (!existsSync(path)) return emptyStore();
54
+ try {
55
+ const parsed = JSON.parse(readFileSync(path, "utf-8")) as unknown;
56
+ if (!isRecord(parsed) || !isRecord(parsed.sessions)) return emptyStore();
57
+ const sessions: Record<string, StoredSessionRuntime> = {};
58
+ for (const [id, entry] of Object.entries(parsed.sessions)) {
59
+ const normalized = normalizeRuntime(entry);
60
+ if (normalized && normalized.sessionId === id) sessions[id] = normalized;
61
+ }
62
+ return { version: 1, sessions };
63
+ } catch {
64
+ return emptyStore();
65
+ }
66
+ }
67
+
68
+ function writeStore(store: RuntimeStoreFile): void {
69
+ const path = getRuntimeStorePath();
70
+ const dir = dirname(path);
71
+ if (!existsSync(dir)) mkdirSync(dir, { recursive: true });
72
+ writeFileSync(path, JSON.stringify(store, null, 2), "utf-8");
73
+ }
74
+
75
+ export function readSessionRuntime(sessionId: string): StoredSessionRuntime | null {
76
+ if (!sessionId) return null;
77
+ return readStore().sessions[sessionId] ?? null;
78
+ }
79
+
80
+ export function upsertSessionRuntime(
81
+ sessionId: string,
82
+ patch: Partial<Omit<StoredSessionRuntime, "sessionId" | "updatedAt">>,
83
+ ): StoredSessionRuntime {
84
+ const store = readStore();
85
+ const previous = store.sessions[sessionId] ?? { sessionId, updatedAt: new Date(0).toISOString() };
86
+ const next: StoredSessionRuntime = {
87
+ ...previous,
88
+ sessionId,
89
+ updatedAt: new Date().toISOString(),
90
+ };
91
+ if (patch.cwd !== undefined) next.cwd = patch.cwd;
92
+ if (patch.provider !== undefined) next.provider = patch.provider;
93
+ if (patch.modelId !== undefined) next.modelId = patch.modelId;
94
+ if (patch.thinkingLevel !== undefined) next.thinkingLevel = patch.thinkingLevel;
95
+ store.sessions[sessionId] = next;
96
+ writeStore(store);
97
+ return next;
98
+ }
99
+
100
+ export function deleteSessionRuntime(sessionId: string): void {
101
+ const store = readStore();
102
+ if (!store.sessions[sessionId]) return;
103
+ delete store.sessions[sessionId];
104
+ writeStore(store);
105
+ }
@@ -0,0 +1,279 @@
1
+ import type { SubagentRun, SubagentRunStatus } from "./types";
2
+
3
+ function isRecord(value: unknown): value is Record<string, unknown> {
4
+ return typeof value === "object" && value !== null && !Array.isArray(value);
5
+ }
6
+
7
+ function stringValue(value: unknown): string | undefined {
8
+ return typeof value === "string" && value.trim() ? value : undefined;
9
+ }
10
+
11
+ function numberTimestamp(value: unknown): number | undefined {
12
+ if (typeof value !== "string" || !value) return undefined;
13
+ const time = Date.parse(value);
14
+ return Number.isFinite(time) ? time : undefined;
15
+ }
16
+
17
+ function limitText(value: string, maxLength = 1200): string {
18
+ return value.length > maxLength ? `${value.slice(0, maxLength)}...` : value;
19
+ }
20
+
21
+ function stableJson(value: unknown): string | undefined {
22
+ if (typeof value === "string") return limitText(value);
23
+ if (value === null || value === undefined) return undefined;
24
+ try {
25
+ return limitText(JSON.stringify(value));
26
+ } catch {
27
+ return limitText(String(value));
28
+ }
29
+ }
30
+
31
+ export function normalizeSubagentStatus(value: unknown): SubagentRunStatus {
32
+ if (isRecord(value)) {
33
+ if ("completed" in value) return "completed";
34
+ if ("failed" in value || "error" in value) return "failed";
35
+ if ("paused" in value || "blocked" in value) return "paused";
36
+ if ("not_found" in value) return "not_found";
37
+ if ("running" in value || "in_progress" in value || "pending" in value) return "running";
38
+ }
39
+
40
+ const raw = typeof value === "string" ? value.toLowerCase().trim() : "";
41
+ if (raw === "completed" || raw === "complete" || raw === "done" || raw === "success" || raw === "succeeded") return "completed";
42
+ if (raw === "failed" || raw === "failure" || raw === "error" || raw === "cancelled" || raw === "canceled") return "failed";
43
+ if (raw === "paused" || raw === "blocked" || raw === "interrupted") return "paused";
44
+ if (raw === "not_found" || raw === "not-found" || raw === "missing") return "not_found";
45
+ if (raw === "pending" || raw === "pending_init" || raw === "starting" || raw === "started" || raw === "in_progress" || raw === "running") return "running";
46
+ return "running";
47
+ }
48
+
49
+ function summaryFromStatus(status: unknown): string | undefined {
50
+ if (isRecord(status)) {
51
+ const candidate = status.completed ?? status.failed ?? status.error ?? status.blocked ?? status.paused ?? status.running ?? status.pending;
52
+ return stableJson(candidate);
53
+ }
54
+ return undefined;
55
+ }
56
+
57
+ function toolLabel(tool: unknown): string | undefined {
58
+ if (typeof tool === "string" && tool.trim()) return tool;
59
+ if (!isRecord(tool)) return undefined;
60
+ return stringValue(tool.name)
61
+ ?? stringValue(tool.agent)
62
+ ?? stringValue(tool.agent_nickname)
63
+ ?? stringValue(tool.agentNickname)
64
+ ?? stringValue(tool.nickname);
65
+ }
66
+
67
+ function runFromRecord(record: Record<string, unknown>, fallback: Partial<SubagentRun>): SubagentRun {
68
+ const threadId = stringValue(record.thread_id) ?? stringValue(record.threadId) ?? stringValue(record.id) ?? fallback.threadId;
69
+ const agent = stringValue(record.agent_nickname)
70
+ ?? stringValue(record.agentNickname)
71
+ ?? stringValue(record.nickname)
72
+ ?? stringValue(record.agent)
73
+ ?? fallback.agent
74
+ ?? "agent";
75
+ const statusSource = record.status ?? record.state ?? fallback.status;
76
+ return {
77
+ id: stringValue(record.call_id) ?? stringValue(record.callId) ?? threadId ?? fallback.id ?? agent,
78
+ agent,
79
+ status: normalizeSubagentStatus(statusSource),
80
+ role: stringValue(record.agent_role) ?? stringValue(record.agentRole) ?? stringValue(record.role) ?? fallback.role,
81
+ task: stringValue(record.prompt) ?? stringValue(record.task) ?? fallback.task,
82
+ summary: summaryFromStatus(statusSource) ?? stringValue(record.summary) ?? fallback.summary,
83
+ threadId,
84
+ parentThreadId: stringValue(record.parent_thread_id) ?? stringValue(record.parentThreadId) ?? fallback.parentThreadId,
85
+ model: stringValue(record.model) ?? fallback.model,
86
+ reasoningEffort: stringValue(record.reasoning_effort) ?? stringValue(record.reasoningEffort) ?? fallback.reasoningEffort,
87
+ timestamp: numberTimestamp(record.timestamp) ?? fallback.timestamp,
88
+ };
89
+ }
90
+
91
+ function runsFromAgentStates(states: unknown, fallback: Partial<SubagentRun>): SubagentRun[] {
92
+ if (Array.isArray(states)) {
93
+ return states
94
+ .filter(isRecord)
95
+ .map((state, index) => runFromRecord(state, { ...fallback, id: `${fallback.id ?? "agent"}:${index}` }));
96
+ }
97
+ if (!isRecord(states)) return [];
98
+
99
+ const agentStatuses = states.agent_statuses ?? states.agentStatuses;
100
+ if (Array.isArray(agentStatuses)) {
101
+ return agentStatuses
102
+ .filter(isRecord)
103
+ .map((state, index) => runFromRecord(state, { ...fallback, id: `${fallback.id ?? "agent"}:${index}` }));
104
+ }
105
+
106
+ const statuses = states.statuses;
107
+ if (isRecord(statuses)) return runsFromStatusMap(statuses, fallback);
108
+
109
+ return Object.entries(states).map(([threadId, state]) => {
110
+ if (isRecord(state)) return runFromRecord(state, { ...fallback, id: threadId, threadId });
111
+ return {
112
+ id: threadId,
113
+ agent: fallback.agent ?? "agent",
114
+ status: normalizeSubagentStatus(state),
115
+ role: fallback.role,
116
+ task: fallback.task,
117
+ summary: summaryFromStatus(state),
118
+ threadId,
119
+ parentThreadId: fallback.parentThreadId,
120
+ model: fallback.model,
121
+ reasoningEffort: fallback.reasoningEffort,
122
+ timestamp: fallback.timestamp,
123
+ };
124
+ });
125
+ }
126
+
127
+ function runsFromStatusMap(statuses: Record<string, unknown>, fallback: Partial<SubagentRun>): SubagentRun[] {
128
+ return Object.entries(statuses).map(([threadId, status]) => {
129
+ if (isRecord(status)) return runFromRecord({ ...status, thread_id: threadId }, { ...fallback, id: threadId, threadId });
130
+ return {
131
+ id: threadId,
132
+ agent: fallback.agent ?? "agent",
133
+ status: normalizeSubagentStatus(status),
134
+ role: fallback.role,
135
+ task: fallback.task,
136
+ summary: summaryFromStatus(status),
137
+ threadId,
138
+ parentThreadId: fallback.parentThreadId,
139
+ model: fallback.model,
140
+ reasoningEffort: fallback.reasoningEffort,
141
+ timestamp: fallback.timestamp,
142
+ };
143
+ });
144
+ }
145
+
146
+ export function subagentRunsFromCollabItem(item: unknown, timestamp?: number): SubagentRun[] {
147
+ if (!isRecord(item) || item.type !== "collabAgentToolCall") return [];
148
+
149
+ const fallback: Partial<SubagentRun> = {
150
+ id: stringValue(item.id),
151
+ agent: (() => {
152
+ const label = toolLabel(item.tool);
153
+ if (!label) return "agent";
154
+ return label.toLowerCase().endsWith("agent") ? "agent" : label;
155
+ })(),
156
+ status: normalizeSubagentStatus(item.status),
157
+ task: stringValue(item.prompt),
158
+ parentThreadId: stringValue(item.senderThreadId) ?? stringValue(item.sender_thread_id),
159
+ model: stringValue(item.model),
160
+ reasoningEffort: stableJson(item.reasoningEffort ?? item.reasoning_effort),
161
+ timestamp,
162
+ };
163
+
164
+ const fromStates = runsFromAgentStates(item.agentsStates ?? item.agents_states, fallback);
165
+ if (fromStates.length > 0) return fromStates;
166
+
167
+ const receiverThreadIds = Array.isArray(item.receiverThreadIds)
168
+ ? item.receiverThreadIds.filter((id): id is string => typeof id === "string" && !!id)
169
+ : [];
170
+ if (receiverThreadIds.length > 0) {
171
+ return receiverThreadIds.map((threadId, index) => ({
172
+ id: `${stringValue(item.id) ?? "agents"}:${threadId}`,
173
+ agent: fallback.agent ?? `agent ${index + 1}`,
174
+ status: fallback.status ?? "running",
175
+ task: fallback.task,
176
+ threadId,
177
+ parentThreadId: fallback.parentThreadId,
178
+ model: fallback.model,
179
+ reasoningEffort: fallback.reasoningEffort,
180
+ timestamp,
181
+ }));
182
+ }
183
+
184
+ return [{
185
+ id: stringValue(item.id) ?? `agents:${timestamp ?? Date.now()}`,
186
+ agent: fallback.agent ?? "agents",
187
+ status: fallback.status ?? "running",
188
+ task: fallback.task,
189
+ parentThreadId: fallback.parentThreadId,
190
+ model: fallback.model,
191
+ reasoningEffort: fallback.reasoningEffort,
192
+ timestamp,
193
+ }];
194
+ }
195
+
196
+ export function subagentRunsFromCollabEvent(payload: unknown, timestamp?: number): SubagentRun[] {
197
+ if (!isRecord(payload)) return [];
198
+ const type = stringValue(payload.type);
199
+ if (!type?.startsWith("collab_")) return [];
200
+
201
+ const base: Partial<SubagentRun> = {
202
+ id: stringValue(payload.call_id) ?? stringValue(payload.callId),
203
+ parentThreadId: stringValue(payload.sender_thread_id) ?? stringValue(payload.senderThreadId),
204
+ task: stringValue(payload.prompt),
205
+ model: stringValue(payload.model),
206
+ reasoningEffort: stringValue(payload.reasoning_effort) ?? stringValue(payload.reasoningEffort),
207
+ timestamp,
208
+ };
209
+
210
+ const agentStatuses = payload.agent_statuses ?? payload.agentStatuses;
211
+ if (Array.isArray(agentStatuses)) {
212
+ return agentStatuses
213
+ .filter(isRecord)
214
+ .map((status, index) => runFromRecord(status, { ...base, id: `${base.id ?? "agent"}:${index}` }));
215
+ }
216
+ if (isRecord(payload.statuses)) return runsFromStatusMap(payload.statuses, base);
217
+
218
+ if (type === "collab_agent_spawn_end") {
219
+ return [runFromRecord({
220
+ call_id: payload.call_id,
221
+ thread_id: payload.new_thread_id,
222
+ agent_nickname: payload.new_agent_nickname,
223
+ agent_role: payload.new_agent_role,
224
+ prompt: payload.prompt,
225
+ model: payload.model,
226
+ reasoning_effort: payload.reasoning_effort,
227
+ status: payload.status,
228
+ }, base)];
229
+ }
230
+
231
+ if (type === "collab_close_end" || type === "collab_agent_interaction_end") {
232
+ return [runFromRecord({
233
+ call_id: payload.call_id,
234
+ thread_id: payload.receiver_thread_id,
235
+ agent_nickname: payload.receiver_agent_nickname,
236
+ agent_role: payload.receiver_agent_role,
237
+ prompt: payload.prompt,
238
+ status: payload.status,
239
+ }, base)];
240
+ }
241
+
242
+ return [];
243
+ }
244
+
245
+ export function coerceSubagentRuns(value: unknown): SubagentRun[] {
246
+ const rawRuns = Array.isArray(value) ? value : (isRecord(value) ? [value] : []);
247
+ return rawRuns.filter(isRecord).map((run, index) => ({
248
+ id: stringValue(run.id) ?? stringValue(run.threadId) ?? stringValue(run.thread_id) ?? `agent:${index}`,
249
+ agent: stringValue(run.agent) ?? stringValue(run.agent_nickname) ?? "agent",
250
+ status: normalizeSubagentStatus(run.status),
251
+ role: stringValue(run.role) ?? stringValue(run.agent_role),
252
+ task: stringValue(run.task) ?? stringValue(run.prompt),
253
+ summary: stringValue(run.summary),
254
+ threadId: stringValue(run.threadId) ?? stringValue(run.thread_id),
255
+ parentThreadId: stringValue(run.parentThreadId) ?? stringValue(run.parent_thread_id),
256
+ model: stringValue(run.model),
257
+ reasoningEffort: stringValue(run.reasoningEffort) ?? stringValue(run.reasoning_effort),
258
+ timestamp: typeof run.timestamp === "number" ? run.timestamp : numberTimestamp(run.timestamp),
259
+ }));
260
+ }
261
+
262
+ export function mergeSubagentRuns(...groups: Array<SubagentRun[] | undefined>): SubagentRun[] {
263
+ const merged = new Map<string, SubagentRun>();
264
+ for (const group of groups) {
265
+ for (const run of group ?? []) {
266
+ const previous = merged.get(run.id);
267
+ merged.set(run.id, {
268
+ ...previous,
269
+ ...run,
270
+ timestamp: Math.max(previous?.timestamp ?? 0, run.timestamp ?? 0) || previous?.timestamp || run.timestamp,
271
+ summary: run.summary ?? previous?.summary,
272
+ task: run.task ?? previous?.task,
273
+ role: run.role ?? previous?.role,
274
+ threadId: run.threadId ?? previous?.threadId,
275
+ });
276
+ }
277
+ }
278
+ return [...merged.values()].sort((a, b) => (b.timestamp ?? 0) - (a.timestamp ?? 0));
279
+ }
package/lib/types.ts ADDED
@@ -0,0 +1,241 @@
1
+ // Types for annodex session format
2
+
3
+ export interface SessionHeader {
4
+ type: "session";
5
+ version?: number;
6
+ id: string;
7
+ timestamp: string;
8
+ cwd: string;
9
+ parentSession?: string;
10
+ }
11
+
12
+ export interface SessionEntryBase {
13
+ type: string;
14
+ id: string;
15
+ parentId: string | null;
16
+ timestamp: string;
17
+ }
18
+
19
+ export interface TextContent {
20
+ type: "text";
21
+ text: string;
22
+ }
23
+
24
+ export interface ImageContent {
25
+ type: "image";
26
+ source?: {
27
+ type: "base64" | "url";
28
+ media_type?: string;
29
+ data?: string;
30
+ url?: string;
31
+ };
32
+ data?: string;
33
+ mimeType?: string;
34
+ }
35
+
36
+ export interface ThinkingContent {
37
+ type: "thinking";
38
+ thinking: string;
39
+ }
40
+
41
+ export interface ToolCallContent {
42
+ type: "toolCall";
43
+ toolCallId: string;
44
+ toolName: string;
45
+ input: Record<string, unknown>;
46
+ }
47
+
48
+ export type AssistantContentBlock = TextContent | ImageContent | ThinkingContent | ToolCallContent;
49
+
50
+ export interface UserMessage {
51
+ role: "user";
52
+ content: string | (TextContent | ImageContent)[];
53
+ timestamp?: number;
54
+ }
55
+
56
+ export interface AssistantMessage {
57
+ role: "assistant";
58
+ content: AssistantContentBlock[];
59
+ model: string;
60
+ provider: string;
61
+ stopReason?: string;
62
+ errorMessage?: string;
63
+ timestamp?: number;
64
+ usage?: {
65
+ input: number;
66
+ output: number;
67
+ cacheRead: number;
68
+ cacheWrite: number;
69
+ cost: {
70
+ input: number;
71
+ output: number;
72
+ cacheRead: number;
73
+ cacheWrite: number;
74
+ total: number;
75
+ };
76
+ };
77
+ }
78
+
79
+ export interface ToolResultMessage {
80
+ role: "toolResult";
81
+ toolCallId: string;
82
+ toolName?: string;
83
+ content: (TextContent | ImageContent)[];
84
+ isError?: boolean;
85
+ timestamp?: number;
86
+ }
87
+
88
+ export interface CustomMessage {
89
+ role: "custom";
90
+ customType: string;
91
+ content: string | (TextContent | ImageContent)[];
92
+ display: boolean;
93
+ details?: unknown;
94
+ timestamp?: number;
95
+ }
96
+
97
+ export type AgentMessage = UserMessage | AssistantMessage | ToolResultMessage | CustomMessage;
98
+
99
+ export type SubagentRunStatus = "pending" | "running" | "completed" | "failed" | "paused" | "not_found";
100
+
101
+ export interface SubagentRun {
102
+ id: string;
103
+ agent: string;
104
+ status: SubagentRunStatus;
105
+ role?: string;
106
+ task?: string;
107
+ summary?: string;
108
+ threadId?: string;
109
+ parentThreadId?: string;
110
+ model?: string;
111
+ reasoningEffort?: string;
112
+ timestamp?: number;
113
+ }
114
+
115
+ export interface SessionMessageEntry extends SessionEntryBase {
116
+ type: "message";
117
+ message: AgentMessage;
118
+ }
119
+
120
+ export interface ThinkingLevelChangeEntry extends SessionEntryBase {
121
+ type: "thinking_level_change";
122
+ thinkingLevel: string;
123
+ }
124
+
125
+ export interface ModelChangeEntry extends SessionEntryBase {
126
+ type: "model_change";
127
+ provider: string;
128
+ modelId: string;
129
+ }
130
+
131
+ export interface CompactionEntry extends SessionEntryBase {
132
+ type: "compaction";
133
+ summary: string;
134
+ firstKeptEntryId: string;
135
+ tokensBefore: number;
136
+ details?: unknown;
137
+ fromHook?: boolean;
138
+ }
139
+
140
+ export interface BranchSummaryEntry extends SessionEntryBase {
141
+ type: "branch_summary";
142
+ fromId: string;
143
+ summary: string;
144
+ details?: unknown;
145
+ fromHook?: boolean;
146
+ }
147
+
148
+ export interface CustomEntry extends SessionEntryBase {
149
+ type: "custom";
150
+ customType: string;
151
+ data?: unknown;
152
+ }
153
+
154
+ export interface CustomMessageEntry extends SessionEntryBase {
155
+ type: "custom_message";
156
+ customType: string;
157
+ content: string | (TextContent | ImageContent)[];
158
+ details?: unknown;
159
+ display: boolean;
160
+ }
161
+
162
+ export interface LabelEntry extends SessionEntryBase {
163
+ type: "label";
164
+ targetId: string;
165
+ label: string | undefined;
166
+ }
167
+
168
+ export interface SessionInfoEntry extends SessionEntryBase {
169
+ type: "session_info";
170
+ name?: string;
171
+ }
172
+
173
+ export type SessionEntry =
174
+ | SessionMessageEntry
175
+ | ThinkingLevelChangeEntry
176
+ | ModelChangeEntry
177
+ | CompactionEntry
178
+ | BranchSummaryEntry
179
+ | CustomEntry
180
+ | CustomMessageEntry
181
+ | LabelEntry
182
+ | SessionInfoEntry;
183
+
184
+ export type FileEntry = SessionHeader | SessionEntry;
185
+
186
+ export interface SessionTreeNode {
187
+ entry: SessionEntry;
188
+ children: SessionTreeNode[];
189
+ label?: string;
190
+ }
191
+
192
+ export interface SessionInfo {
193
+ path: string;
194
+ id: string;
195
+ cwd: string;
196
+ cwdExists?: boolean;
197
+ name?: string;
198
+ created: string;
199
+ modified: string;
200
+ messageCount: number;
201
+ firstMessage: string;
202
+ parentSessionId?: string; // set if this session was forked from another
203
+ }
204
+
205
+ export interface ProjectInfo {
206
+ cwd: string;
207
+ name?: string;
208
+ displayName: string;
209
+ chatCount: number;
210
+ lastAccessed: string | null;
211
+ created: string | null;
212
+ hidden?: boolean;
213
+ exists: boolean;
214
+ source: "session" | "manual" | "both";
215
+ }
216
+
217
+ export interface SessionContext {
218
+ messages: AgentMessage[];
219
+ entryIds: string[]; // parallel to messages — the session entry id for each message
220
+ thinkingLevel: string;
221
+ model: { provider: string; modelId: string } | null;
222
+ subagentRuns?: SubagentRun[];
223
+ sessionStats?: {
224
+ tokens: { input: number; output: number; cacheRead: number; cacheWrite: number };
225
+ cost?: number;
226
+ } | null;
227
+ contextUsage?: { percent: number | null; contextWindow: number; tokens: number | null } | null;
228
+ }
229
+
230
+ // RPC types
231
+ export interface RpcSessionState {
232
+ model?: { provider: string; id: string; contextWindow?: number };
233
+ thinkingLevel: string;
234
+ isStreaming: boolean;
235
+ isCompacting: boolean;
236
+ sessionFile?: string;
237
+ sessionId: string;
238
+ sessionName?: string;
239
+ messageCount: number;
240
+ contextUsage?: { percent: number | null; contextWindow: number; tokens: number | null } | null;
241
+ }