@creativeintelligence/abbie 0.1.3 → 0.1.5

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 (537) hide show
  1. package/dist/cli/commands/start.js +2 -1
  2. package/oclif.manifest.json +1 -1
  3. package/package.json +13 -7
  4. package/dist/cli/base-command.d.ts.map +0 -1
  5. package/dist/cli/commands/agent/list.d.ts.map +0 -1
  6. package/dist/cli/commands/annotation/ack.d.ts.map +0 -1
  7. package/dist/cli/commands/annotation/create.d.ts.map +0 -1
  8. package/dist/cli/commands/annotation/events.d.ts.map +0 -1
  9. package/dist/cli/commands/annotation/export.d.ts.map +0 -1
  10. package/dist/cli/commands/annotation/import.d.ts.map +0 -1
  11. package/dist/cli/commands/annotation/ingest.d.ts.map +0 -1
  12. package/dist/cli/commands/annotation/list.d.ts.map +0 -1
  13. package/dist/cli/commands/annotation/reply.d.ts.map +0 -1
  14. package/dist/cli/commands/annotation/resolve.d.ts.map +0 -1
  15. package/dist/cli/commands/auto/index.d.ts.map +0 -1
  16. package/dist/cli/commands/backlog/add.d.ts.map +0 -1
  17. package/dist/cli/commands/backlog/claim.d.ts.map +0 -1
  18. package/dist/cli/commands/backlog/complete.d.ts.map +0 -1
  19. package/dist/cli/commands/backlog/list.d.ts.map +0 -1
  20. package/dist/cli/commands/backlog/pick.d.ts.map +0 -1
  21. package/dist/cli/commands/backlog/sync.d.ts.map +0 -1
  22. package/dist/cli/commands/bootstrap.d.ts.map +0 -1
  23. package/dist/cli/commands/bridge.d.ts.map +0 -1
  24. package/dist/cli/commands/context/inject.d.ts.map +0 -1
  25. package/dist/cli/commands/context/list.d.ts.map +0 -1
  26. package/dist/cli/commands/context/publish.d.ts.map +0 -1
  27. package/dist/cli/commands/context/read.d.ts.map +0 -1
  28. package/dist/cli/commands/daemon.d.ts.map +0 -1
  29. package/dist/cli/commands/digest/index.d.ts.map +0 -1
  30. package/dist/cli/commands/docs/lint.d.ts.map +0 -1
  31. package/dist/cli/commands/docs/sync.d.ts.map +0 -1
  32. package/dist/cli/commands/doctor.d.ts.map +0 -1
  33. package/dist/cli/commands/find/index.d.ts.map +0 -1
  34. package/dist/cli/commands/gc.d.ts.map +0 -1
  35. package/dist/cli/commands/history/index.d.ts.map +0 -1
  36. package/dist/cli/commands/hooks/guard.d.ts.map +0 -1
  37. package/dist/cli/commands/hooks/list.d.ts.map +0 -1
  38. package/dist/cli/commands/hooks/lock.d.ts.map +0 -1
  39. package/dist/cli/commands/hooks/status.d.ts.map +0 -1
  40. package/dist/cli/commands/hooks/test.d.ts.map +0 -1
  41. package/dist/cli/commands/hooks/unlock.d.ts.map +0 -1
  42. package/dist/cli/commands/index.d.ts.map +0 -1
  43. package/dist/cli/commands/list.d.ts.map +0 -1
  44. package/dist/cli/commands/list.e2e.test.d.ts +0 -1
  45. package/dist/cli/commands/list.e2e.test.js +0 -47
  46. package/dist/cli/commands/login.d.ts.map +0 -1
  47. package/dist/cli/commands/logout.d.ts.map +0 -1
  48. package/dist/cli/commands/panes/broker.d.ts.map +0 -1
  49. package/dist/cli/commands/panes/pipe-sink.d.ts.map +0 -1
  50. package/dist/cli/commands/panes/snapshot.d.ts.map +0 -1
  51. package/dist/cli/commands/plan.d.ts.map +0 -1
  52. package/dist/cli/commands/plan.e2e.test.d.ts +0 -1
  53. package/dist/cli/commands/plan.e2e.test.js +0 -74
  54. package/dist/cli/commands/preview/index.d.ts.map +0 -1
  55. package/dist/cli/commands/preview/init.d.ts.map +0 -1
  56. package/dist/cli/commands/preview/list.d.ts.map +0 -1
  57. package/dist/cli/commands/preview/status.d.ts.map +0 -1
  58. package/dist/cli/commands/preview/stop.d.ts.map +0 -1
  59. package/dist/cli/commands/preview/sync.d.ts.map +0 -1
  60. package/dist/cli/commands/preview/watch.d.ts.map +0 -1
  61. package/dist/cli/commands/project/add.d.ts.map +0 -1
  62. package/dist/cli/commands/project/list.d.ts.map +0 -1
  63. package/dist/cli/commands/project/remove.d.ts.map +0 -1
  64. package/dist/cli/commands/push.d.ts.map +0 -1
  65. package/dist/cli/commands/reference/add.d.ts.map +0 -1
  66. package/dist/cli/commands/reference/delete.d.ts.map +0 -1
  67. package/dist/cli/commands/reference/extract.d.ts.map +0 -1
  68. package/dist/cli/commands/reference/list.d.ts.map +0 -1
  69. package/dist/cli/commands/reference/normalize.d.ts.map +0 -1
  70. package/dist/cli/commands/reference/open.d.ts.map +0 -1
  71. package/dist/cli/commands/reference/save.d.ts.map +0 -1
  72. package/dist/cli/commands/reference/search.d.ts.map +0 -1
  73. package/dist/cli/commands/reference/show.d.ts.map +0 -1
  74. package/dist/cli/commands/reference/update-index.d.ts.map +0 -1
  75. package/dist/cli/commands/reference/update.d.ts.map +0 -1
  76. package/dist/cli/commands/report/blocked.d.ts.map +0 -1
  77. package/dist/cli/commands/report/complete.d.ts.map +0 -1
  78. package/dist/cli/commands/report/progress.d.ts.map +0 -1
  79. package/dist/cli/commands/report/start.d.ts.map +0 -1
  80. package/dist/cli/commands/resource/acquire.d.ts.map +0 -1
  81. package/dist/cli/commands/resource/list.d.ts.map +0 -1
  82. package/dist/cli/commands/resource/release.d.ts.map +0 -1
  83. package/dist/cli/commands/resource/wait.d.ts.map +0 -1
  84. package/dist/cli/commands/review.d.ts.map +0 -1
  85. package/dist/cli/commands/session/attach.d.ts.map +0 -1
  86. package/dist/cli/commands/session/await.d.ts.map +0 -1
  87. package/dist/cli/commands/session/complete.d.ts.map +0 -1
  88. package/dist/cli/commands/session/create.d.ts.map +0 -1
  89. package/dist/cli/commands/session/heartbeat.d.ts.map +0 -1
  90. package/dist/cli/commands/session/list.d.ts.map +0 -1
  91. package/dist/cli/commands/session/mark-done.d.ts.map +0 -1
  92. package/dist/cli/commands/session/mine.d.ts.map +0 -1
  93. package/dist/cli/commands/session/replay.d.ts.map +0 -1
  94. package/dist/cli/commands/session/run.d.ts.map +0 -1
  95. package/dist/cli/commands/session/show.d.ts.map +0 -1
  96. package/dist/cli/commands/session/start.d.ts.map +0 -1
  97. package/dist/cli/commands/session/state/cleanup.d.ts.map +0 -1
  98. package/dist/cli/commands/session/state/end.d.ts.map +0 -1
  99. package/dist/cli/commands/session/state/get.d.ts.map +0 -1
  100. package/dist/cli/commands/session/state/init.d.ts.map +0 -1
  101. package/dist/cli/commands/session/state/list.d.ts.map +0 -1
  102. package/dist/cli/commands/session/state/update.d.ts.map +0 -1
  103. package/dist/cli/commands/session/stop.d.ts.map +0 -1
  104. package/dist/cli/commands/session/view.d.ts.map +0 -1
  105. package/dist/cli/commands/start.d.ts.map +0 -1
  106. package/dist/cli/commands/state/dump.d.ts.map +0 -1
  107. package/dist/cli/commands/status.d.ts.map +0 -1
  108. package/dist/cli/commands/sync.d.ts.map +0 -1
  109. package/dist/cli/commands/trace/export.d.ts.map +0 -1
  110. package/dist/cli/commands/triage/claim.d.ts.map +0 -1
  111. package/dist/cli/commands/triage/list.d.ts.map +0 -1
  112. package/dist/cli/commands/triage/next.d.ts.map +0 -1
  113. package/dist/cli/commands/triage/pull.d.ts.map +0 -1
  114. package/dist/cli/commands/triage/stats.d.ts.map +0 -1
  115. package/dist/cli/commands/tunnel/list.d.ts.map +0 -1
  116. package/dist/cli/commands/tunnel/start.d.ts.map +0 -1
  117. package/dist/cli/commands/tunnel/stop.d.ts.map +0 -1
  118. package/dist/cli/commands/tunnel/url.d.ts.map +0 -1
  119. package/dist/cli/commands/web/start.d.ts.map +0 -1
  120. package/dist/cli/commands/windows/context.d.ts.map +0 -1
  121. package/dist/cli/commands/windows/focus.d.ts.map +0 -1
  122. package/dist/cli/commands/windows/list.d.ts.map +0 -1
  123. package/dist/cli/commands/windows/map.d.ts.map +0 -1
  124. package/dist/cli/commands/windows/read.d.ts.map +0 -1
  125. package/dist/cli/commands/windows/search.d.ts.map +0 -1
  126. package/dist/cli/commands/windows/show.d.ts.map +0 -1
  127. package/dist/cli/commands/windows/watch.d.ts.map +0 -1
  128. package/dist/lib/active-sessions.d.ts.map +0 -1
  129. package/dist/lib/agent-adapters.d.ts.map +0 -1
  130. package/dist/lib/agent-sessions.d.ts.map +0 -1
  131. package/dist/lib/agent-trace.d.ts.map +0 -1
  132. package/dist/lib/analytics.d.ts.map +0 -1
  133. package/dist/lib/annotations-convex.d.ts.map +0 -1
  134. package/dist/lib/annotations.d.ts.map +0 -1
  135. package/dist/lib/auto/discover.d.ts.map +0 -1
  136. package/dist/lib/auto/ideate.d.ts.map +0 -1
  137. package/dist/lib/auto/spawn.d.ts.map +0 -1
  138. package/dist/lib/auto/workspace.d.ts.map +0 -1
  139. package/dist/lib/backlog.d.ts.map +0 -1
  140. package/dist/lib/backlog.test.d.ts +0 -1
  141. package/dist/lib/backlog.test.js +0 -162
  142. package/dist/lib/config-loader.d.ts.map +0 -1
  143. package/dist/lib/config-sync/adapters/claude.d.ts.map +0 -1
  144. package/dist/lib/config-sync/adapters/codex.d.ts.map +0 -1
  145. package/dist/lib/config-sync/adapters/copilot.d.ts.map +0 -1
  146. package/dist/lib/config-sync/adapters/gemini.d.ts.map +0 -1
  147. package/dist/lib/config-sync/adapters/index.d.ts.map +0 -1
  148. package/dist/lib/config-sync/adapters/opencode.d.ts.map +0 -1
  149. package/dist/lib/config-sync/index.d.ts.map +0 -1
  150. package/dist/lib/config-sync/types.d.ts.map +0 -1
  151. package/dist/lib/config-sync/writer.d.ts.map +0 -1
  152. package/dist/lib/content-sync/index.d.ts.map +0 -1
  153. package/dist/lib/content-sync/types.d.ts.map +0 -1
  154. package/dist/lib/contracts.d.ts.map +0 -1
  155. package/dist/lib/convex.d.ts.map +0 -1
  156. package/dist/lib/device.d.ts.map +0 -1
  157. package/dist/lib/digest/index.d.ts.map +0 -1
  158. package/dist/lib/docs/lint.d.ts.map +0 -1
  159. package/dist/lib/docs/lint.test.d.ts +0 -1
  160. package/dist/lib/docs/lint.test.js +0 -120
  161. package/dist/lib/docs/sync.d.ts.map +0 -1
  162. package/dist/lib/doctor/index.d.ts.map +0 -1
  163. package/dist/lib/doctor/repos.d.ts.map +0 -1
  164. package/dist/lib/doctor/templates.d.ts.map +0 -1
  165. package/dist/lib/errors.d.ts.map +0 -1
  166. package/dist/lib/events.d.ts.map +0 -1
  167. package/dist/lib/heartbeat.d.ts.map +0 -1
  168. package/dist/lib/heartbeat.test.d.ts +0 -1
  169. package/dist/lib/heartbeat.test.js +0 -124
  170. package/dist/lib/hooks/adapters/claude.d.ts.map +0 -1
  171. package/dist/lib/hooks/adapters/codex.d.ts.map +0 -1
  172. package/dist/lib/hooks/adapters/copilot.d.ts.map +0 -1
  173. package/dist/lib/hooks/context.d.ts.map +0 -1
  174. package/dist/lib/hooks/index.d.ts.map +0 -1
  175. package/dist/lib/hooks/registry.d.ts.map +0 -1
  176. package/dist/lib/hooks/runner.d.ts.map +0 -1
  177. package/dist/lib/hooks/types.d.ts.map +0 -1
  178. package/dist/lib/index.test.d.ts +0 -1
  179. package/dist/lib/index.test.js +0 -334
  180. package/dist/lib/managed-session.d.ts.map +0 -1
  181. package/dist/lib/math.d.ts.map +0 -1
  182. package/dist/lib/math.test.d.ts +0 -1
  183. package/dist/lib/math.test.js +0 -238
  184. package/dist/lib/ngrok.d.ts.map +0 -1
  185. package/dist/lib/nvim/discovery.d.ts.map +0 -1
  186. package/dist/lib/nvim/discovery.test.d.ts +0 -1
  187. package/dist/lib/nvim/discovery.test.js +0 -131
  188. package/dist/lib/nvim/index.d.ts.map +0 -1
  189. package/dist/lib/nvim/remote.d.ts.map +0 -1
  190. package/dist/lib/nvim/remote.test.d.ts +0 -1
  191. package/dist/lib/nvim/remote.test.js +0 -18
  192. package/dist/lib/panes/broker.d.ts.map +0 -1
  193. package/dist/lib/panes/index.d.ts.map +0 -1
  194. package/dist/lib/panes/server.d.ts.map +0 -1
  195. package/dist/lib/preview/detect.d.ts.map +0 -1
  196. package/dist/lib/preview/index.d.ts.map +0 -1
  197. package/dist/lib/preview/manager.d.ts.map +0 -1
  198. package/dist/lib/preview/schema.d.ts.map +0 -1
  199. package/dist/lib/preview/sprite.d.ts.map +0 -1
  200. package/dist/lib/preview/watcher.d.ts.map +0 -1
  201. package/dist/lib/process/index.d.ts.map +0 -1
  202. package/dist/lib/process/snapshot.d.ts.map +0 -1
  203. package/dist/lib/process/snapshot.test.d.ts +0 -1
  204. package/dist/lib/process/snapshot.test.js +0 -127
  205. package/dist/lib/project-identity.d.ts.map +0 -1
  206. package/dist/lib/provider-auth.d.ts.map +0 -1
  207. package/dist/lib/references.d.ts.map +0 -1
  208. package/dist/lib/report.d.ts.map +0 -1
  209. package/dist/lib/resources.d.ts.map +0 -1
  210. package/dist/lib/resources.test.d.ts +0 -1
  211. package/dist/lib/resources.test.js +0 -94
  212. package/dist/lib/runner.d.ts.map +0 -1
  213. package/dist/lib/runner.test.d.ts +0 -1
  214. package/dist/lib/runner.test.js +0 -234
  215. package/dist/lib/session-artifacts.d.ts.map +0 -1
  216. package/dist/lib/session-manager.d.ts.map +0 -1
  217. package/dist/lib/session-manager.test.d.ts +0 -1
  218. package/dist/lib/session-manager.test.js +0 -310
  219. package/dist/lib/session-result.d.ts.map +0 -1
  220. package/dist/lib/session-state.d.ts.map +0 -1
  221. package/dist/lib/slack-workspace.d.ts.map +0 -1
  222. package/dist/lib/tmux/bridge.d.ts.map +0 -1
  223. package/dist/lib/tmux/context.d.ts.map +0 -1
  224. package/dist/lib/tmux/context.test.d.ts +0 -1
  225. package/dist/lib/tmux/context.test.js +0 -215
  226. package/dist/lib/tmux/index.d.ts.map +0 -1
  227. package/dist/lib/tmux/map.d.ts.map +0 -1
  228. package/dist/lib/tmux/map.test.d.ts +0 -1
  229. package/dist/lib/tmux/map.test.js +0 -80
  230. package/dist/lib/tmux/panes.d.ts.map +0 -1
  231. package/dist/lib/tmux/redaction.d.ts.map +0 -1
  232. package/dist/lib/tmux/redaction.test.d.ts +0 -1
  233. package/dist/lib/tmux/redaction.test.js +0 -183
  234. package/dist/lib/triage-llm.d.ts.map +0 -1
  235. package/dist/lib/triage-tracker.d.ts.map +0 -1
  236. package/dist/lib/triage.d.ts.map +0 -1
  237. package/dist/lib/types.d.ts.map +0 -1
  238. package/dist/lib/windows/index.d.ts.map +0 -1
  239. package/dist/lib/windows/inventory.d.ts.map +0 -1
  240. package/dist/lib/windows/inventory.test.d.ts +0 -1
  241. package/dist/lib/windows/inventory.test.js +0 -292
  242. package/dist/lib/windows/types.d.ts.map +0 -1
  243. package/dist/lib.d.ts.map +0 -1
  244. package/dist/web/app/@overlay/default.d.ts +0 -1
  245. package/dist/web/app/@overlay/default.js +0 -3
  246. package/dist/web/app/about/page.d.ts +0 -1
  247. package/dist/web/app/about/page.js +0 -6
  248. package/dist/web/app/layout.d.ts +0 -7
  249. package/dist/web/app/layout.js +0 -19
  250. package/dist/web/app/page.d.ts +0 -1
  251. package/dist/web/app/page.js +0 -38
  252. package/dist/web/app/settings/page.d.ts +0 -1
  253. package/dist/web/app/settings/page.js +0 -6
  254. package/dist/web/app/shortcuts/page.d.ts +0 -1
  255. package/dist/web/app/shortcuts/page.js +0 -6
  256. package/dist/web/atoms/sidebar.d.ts +0 -16
  257. package/dist/web/atoms/sidebar.js +0 -58
  258. package/dist/web/atoms/state.d.ts +0 -24
  259. package/dist/web/atoms/state.js +0 -43
  260. package/dist/web/components/command-palette.d.ts +0 -6
  261. package/dist/web/components/command-palette.js +0 -297
  262. package/dist/web/components/main-view.d.ts +0 -1
  263. package/dist/web/components/main-view.js +0 -93
  264. package/dist/web/components/overlay/page-overlay.d.ts +0 -16
  265. package/dist/web/components/overlay/page-overlay.js +0 -84
  266. package/dist/web/components/pane-view.d.ts +0 -5
  267. package/dist/web/components/pane-view.js +0 -168
  268. package/dist/web/components/project-files-view.d.ts +0 -6
  269. package/dist/web/components/project-files-view.js +0 -205
  270. package/dist/web/components/project-planning-view.d.ts +0 -6
  271. package/dist/web/components/project-planning-view.js +0 -146
  272. package/dist/web/components/session-view.d.ts +0 -6
  273. package/dist/web/components/session-view.js +0 -211
  274. package/dist/web/components/sessions-list-view.d.ts +0 -1
  275. package/dist/web/components/sessions-list-view.js +0 -118
  276. package/dist/web/components/sidebar/index.d.ts +0 -9
  277. package/dist/web/components/sidebar/index.js +0 -29
  278. package/dist/web/components/sidebar/kbd.d.ts +0 -17
  279. package/dist/web/components/sidebar/kbd.js +0 -47
  280. package/dist/web/components/sidebar/nav-group.d.ts +0 -22
  281. package/dist/web/components/sidebar/nav-group.js +0 -43
  282. package/dist/web/components/sidebar/nav-item.d.ts +0 -17
  283. package/dist/web/components/sidebar/nav-item.js +0 -38
  284. package/dist/web/components/sidebar/sidebar-header.d.ts +0 -9
  285. package/dist/web/components/sidebar/sidebar-header.js +0 -18
  286. package/dist/web/components/sidebar/sidebar-nav.d.ts +0 -7
  287. package/dist/web/components/sidebar/sidebar-nav.js +0 -505
  288. package/dist/web/components/sidebar/sidebar-search.d.ts +0 -7
  289. package/dist/web/components/sidebar/sidebar-search.js +0 -18
  290. package/dist/web/components/sidebar/sidebar-settings.d.ts +0 -4
  291. package/dist/web/components/sidebar/sidebar-settings.js +0 -28
  292. package/dist/web/components/sidebar/sidebar-transition.d.ts +0 -12
  293. package/dist/web/components/sidebar/sidebar-transition.js +0 -58
  294. package/dist/web/components/status-bar.d.ts +0 -1
  295. package/dist/web/components/status-bar.js +0 -53
  296. package/dist/web/components/terminal.d.ts +0 -4
  297. package/dist/web/components/terminal.js +0 -324
  298. package/dist/web/components/toast.d.ts +0 -7
  299. package/dist/web/components/toast.js +0 -72
  300. package/dist/web/hooks/use-keybindings.d.ts +0 -30
  301. package/dist/web/hooks/use-keybindings.js +0 -322
  302. package/dist/web/hooks/use-state.d.ts +0 -11
  303. package/dist/web/hooks/use-state.js +0 -84
  304. package/dist/web/lib/api.d.ts +0 -179
  305. package/dist/web/lib/api.js +0 -79
  306. package/dist/web/lib/paths.d.ts +0 -2
  307. package/dist/web/lib/paths.js +0 -26
  308. package/dist/web/lib/utils.d.ts +0 -2
  309. package/dist/web/lib/utils.js +0 -5
  310. package/dist/web/lib/ws.d.ts +0 -18
  311. package/dist/web/lib/ws.js +0 -138
  312. package/dist/web/next.config.d.ts +0 -3
  313. package/dist/web/next.config.js +0 -9
  314. package/scripts/generate-manifest.ts +0 -44
  315. package/src/cli/base-command.ts +0 -233
  316. package/src/cli/commands/__tests__/annotations.test.ts +0 -704
  317. package/src/cli/commands/__tests__/bridge.test.ts +0 -101
  318. package/src/cli/commands/__tests__/daemon.test.ts +0 -79
  319. package/src/cli/commands/agent/list.ts +0 -75
  320. package/src/cli/commands/annotation/ack.ts +0 -37
  321. package/src/cli/commands/annotation/create.ts +0 -67
  322. package/src/cli/commands/annotation/events.ts +0 -63
  323. package/src/cli/commands/annotation/export.ts +0 -67
  324. package/src/cli/commands/annotation/import.ts +0 -98
  325. package/src/cli/commands/annotation/ingest.ts +0 -112
  326. package/src/cli/commands/annotation/list.ts +0 -57
  327. package/src/cli/commands/annotation/reply.ts +0 -46
  328. package/src/cli/commands/annotation/resolve.ts +0 -37
  329. package/src/cli/commands/auto/index.ts +0 -755
  330. package/src/cli/commands/backlog/add.ts +0 -74
  331. package/src/cli/commands/backlog/claim.ts +0 -53
  332. package/src/cli/commands/backlog/complete.ts +0 -51
  333. package/src/cli/commands/backlog/list.ts +0 -107
  334. package/src/cli/commands/backlog/pick.ts +0 -50
  335. package/src/cli/commands/backlog/sync.ts +0 -131
  336. package/src/cli/commands/bootstrap.ts +0 -205
  337. package/src/cli/commands/bridge.ts +0 -233
  338. package/src/cli/commands/context/inject.ts +0 -103
  339. package/src/cli/commands/context/list.ts +0 -112
  340. package/src/cli/commands/context/publish.ts +0 -83
  341. package/src/cli/commands/context/read.ts +0 -85
  342. package/src/cli/commands/daemon.ts +0 -1809
  343. package/src/cli/commands/digest/index.ts +0 -245
  344. package/src/cli/commands/docs/lint.ts +0 -93
  345. package/src/cli/commands/docs/sync.ts +0 -90
  346. package/src/cli/commands/doctor.ts +0 -267
  347. package/src/cli/commands/find/index.ts +0 -313
  348. package/src/cli/commands/history/index.ts +0 -269
  349. package/src/cli/commands/hooks/guard.ts +0 -71
  350. package/src/cli/commands/hooks/list.ts +0 -139
  351. package/src/cli/commands/hooks/lock.ts +0 -47
  352. package/src/cli/commands/hooks/status.ts +0 -56
  353. package/src/cli/commands/hooks/test.ts +0 -190
  354. package/src/cli/commands/hooks/unlock.ts +0 -56
  355. package/src/cli/commands/list.e2e.test.ts +0 -58
  356. package/src/cli/commands/list.ts +0 -96
  357. package/src/cli/commands/login.ts +0 -236
  358. package/src/cli/commands/logout.ts +0 -45
  359. package/src/cli/commands/panes/broker.ts +0 -68
  360. package/src/cli/commands/panes/pipe-sink.ts +0 -101
  361. package/src/cli/commands/panes/snapshot.ts +0 -156
  362. package/src/cli/commands/plan.e2e.test.ts +0 -90
  363. package/src/cli/commands/plan.ts +0 -68
  364. package/src/cli/commands/preview/index.ts +0 -282
  365. package/src/cli/commands/preview/list.ts +0 -116
  366. package/src/cli/commands/preview/status.ts +0 -137
  367. package/src/cli/commands/preview/stop.ts +0 -165
  368. package/src/cli/commands/project/add.ts +0 -110
  369. package/src/cli/commands/project/list.ts +0 -136
  370. package/src/cli/commands/project/remove.ts +0 -60
  371. package/src/cli/commands/push.ts +0 -115
  372. package/src/cli/commands/reference/add.ts +0 -266
  373. package/src/cli/commands/reference/delete.ts +0 -67
  374. package/src/cli/commands/reference/extract.ts +0 -389
  375. package/src/cli/commands/reference/list.ts +0 -117
  376. package/src/cli/commands/reference/normalize.ts +0 -90
  377. package/src/cli/commands/reference/open.ts +0 -92
  378. package/src/cli/commands/reference/save.ts +0 -103
  379. package/src/cli/commands/reference/search.ts +0 -85
  380. package/src/cli/commands/reference/show.ts +0 -174
  381. package/src/cli/commands/reference/update-index.ts +0 -103
  382. package/src/cli/commands/reference/update.ts +0 -136
  383. package/src/cli/commands/report/blocked.ts +0 -165
  384. package/src/cli/commands/report/complete.ts +0 -179
  385. package/src/cli/commands/report/progress.ts +0 -142
  386. package/src/cli/commands/report/start.ts +0 -140
  387. package/src/cli/commands/resource/acquire.ts +0 -116
  388. package/src/cli/commands/resource/list.ts +0 -77
  389. package/src/cli/commands/resource/release.ts +0 -64
  390. package/src/cli/commands/resource/wait.ts +0 -93
  391. package/src/cli/commands/review.ts +0 -105
  392. package/src/cli/commands/session/attach.ts +0 -200
  393. package/src/cli/commands/session/await.ts +0 -83
  394. package/src/cli/commands/session/complete.ts +0 -100
  395. package/src/cli/commands/session/create.ts +0 -92
  396. package/src/cli/commands/session/heartbeat.ts +0 -63
  397. package/src/cli/commands/session/list.ts +0 -281
  398. package/src/cli/commands/session/mark-done.ts +0 -132
  399. package/src/cli/commands/session/mine.ts +0 -189
  400. package/src/cli/commands/session/replay.ts +0 -659
  401. package/src/cli/commands/session/run.ts +0 -44
  402. package/src/cli/commands/session/show.ts +0 -177
  403. package/src/cli/commands/session/start.ts +0 -580
  404. package/src/cli/commands/session/state/cleanup.ts +0 -61
  405. package/src/cli/commands/session/state/end.ts +0 -47
  406. package/src/cli/commands/session/state/get.ts +0 -65
  407. package/src/cli/commands/session/state/init.ts +0 -50
  408. package/src/cli/commands/session/state/list.ts +0 -68
  409. package/src/cli/commands/session/state/update.ts +0 -108
  410. package/src/cli/commands/session/stop.ts +0 -134
  411. package/src/cli/commands/session/view.ts +0 -186
  412. package/src/cli/commands/start.ts +0 -256
  413. package/src/cli/commands/state/dump.ts +0 -449
  414. package/src/cli/commands/status.ts +0 -244
  415. package/src/cli/commands/sync.ts +0 -174
  416. package/src/cli/commands/trace/export.ts +0 -255
  417. package/src/cli/commands/triage/claim.ts +0 -203
  418. package/src/cli/commands/triage/list.ts +0 -137
  419. package/src/cli/commands/triage/next.ts +0 -73
  420. package/src/cli/commands/triage/pull.ts +0 -97
  421. package/src/cli/commands/triage/stats.ts +0 -82
  422. package/src/cli/commands/tunnel/list.ts +0 -113
  423. package/src/cli/commands/tunnel/start.ts +0 -122
  424. package/src/cli/commands/tunnel/stop.ts +0 -108
  425. package/src/cli/commands/tunnel/url.ts +0 -82
  426. package/src/cli/commands/web/start.ts +0 -125
  427. package/src/cli/commands/windows/context.ts +0 -439
  428. package/src/cli/commands/windows/focus.ts +0 -130
  429. package/src/cli/commands/windows/list.ts +0 -213
  430. package/src/cli/commands/windows/map.ts +0 -223
  431. package/src/cli/commands/windows/read.ts +0 -279
  432. package/src/cli/commands/windows/search.ts +0 -219
  433. package/src/cli/commands/windows/show.ts +0 -188
  434. package/src/cli/commands/windows/watch.ts +0 -262
  435. package/src/lib/__tests__/annotations-convex.test.ts +0 -104
  436. package/src/lib/active-sessions.ts +0 -1486
  437. package/src/lib/agent-adapters.ts +0 -412
  438. package/src/lib/agent-sessions.ts +0 -671
  439. package/src/lib/agent-trace.test.ts +0 -296
  440. package/src/lib/agent-trace.ts +0 -513
  441. package/src/lib/analytics.ts +0 -178
  442. package/src/lib/annotations-convex.ts +0 -296
  443. package/src/lib/annotations.test.ts +0 -274
  444. package/src/lib/annotations.ts +0 -836
  445. package/src/lib/auto/discover.ts +0 -545
  446. package/src/lib/auto/ideate.ts +0 -412
  447. package/src/lib/auto/spawn.ts +0 -549
  448. package/src/lib/auto/workspace.ts +0 -282
  449. package/src/lib/backlog.test.ts +0 -194
  450. package/src/lib/backlog.ts +0 -428
  451. package/src/lib/config-loader.ts +0 -391
  452. package/src/lib/config-sync/adapters/claude.ts +0 -91
  453. package/src/lib/config-sync/adapters/codex.ts +0 -135
  454. package/src/lib/config-sync/adapters/copilot.ts +0 -98
  455. package/src/lib/config-sync/adapters/gemini.ts +0 -86
  456. package/src/lib/config-sync/adapters/index.ts +0 -39
  457. package/src/lib/config-sync/adapters/opencode.ts +0 -94
  458. package/src/lib/config-sync/index.ts +0 -399
  459. package/src/lib/config-sync/types.ts +0 -92
  460. package/src/lib/config-sync/writer.ts +0 -188
  461. package/src/lib/content-sync/index.ts +0 -882
  462. package/src/lib/content-sync/types.ts +0 -104
  463. package/src/lib/contracts.test.ts +0 -186
  464. package/src/lib/contracts.ts +0 -195
  465. package/src/lib/convex.ts +0 -54
  466. package/src/lib/device.ts +0 -41
  467. package/src/lib/digest/index.ts +0 -529
  468. package/src/lib/docs/lint.test.ts +0 -135
  469. package/src/lib/docs/lint.ts +0 -310
  470. package/src/lib/docs/sync.ts +0 -184
  471. package/src/lib/doctor/index.ts +0 -647
  472. package/src/lib/doctor/repos.ts +0 -381
  473. package/src/lib/doctor/templates.ts +0 -191
  474. package/src/lib/errors.ts +0 -111
  475. package/src/lib/events.ts +0 -479
  476. package/src/lib/heartbeat.test.ts +0 -164
  477. package/src/lib/heartbeat.ts +0 -326
  478. package/src/lib/hooks/adapters/claude.ts +0 -115
  479. package/src/lib/hooks/adapters/codex.ts +0 -92
  480. package/src/lib/hooks/adapters/copilot.ts +0 -141
  481. package/src/lib/hooks/context.ts +0 -174
  482. package/src/lib/hooks/index.ts +0 -39
  483. package/src/lib/hooks/registry.ts +0 -101
  484. package/src/lib/hooks/runner.ts +0 -208
  485. package/src/lib/hooks/types.ts +0 -89
  486. package/src/lib/index.test.ts +0 -426
  487. package/src/lib/managed-session.ts +0 -117
  488. package/src/lib/math.test.ts +0 -299
  489. package/src/lib/math.ts +0 -120
  490. package/src/lib/ngrok.ts +0 -441
  491. package/src/lib/nvim/discovery.test.ts +0 -157
  492. package/src/lib/nvim/discovery.ts +0 -181
  493. package/src/lib/nvim/index.ts +0 -28
  494. package/src/lib/nvim/remote.test.ts +0 -21
  495. package/src/lib/nvim/remote.ts +0 -184
  496. package/src/lib/panes/README.md +0 -20
  497. package/src/lib/panes/broker.ts +0 -261
  498. package/src/lib/panes/index.ts +0 -1
  499. package/src/lib/panes/server.ts +0 -379
  500. package/src/lib/preview/detect.ts +0 -184
  501. package/src/lib/preview/index.ts +0 -1
  502. package/src/lib/process/index.ts +0 -16
  503. package/src/lib/process/snapshot.test.ts +0 -188
  504. package/src/lib/process/snapshot.ts +0 -257
  505. package/src/lib/provider-auth.ts +0 -258
  506. package/src/lib/references.ts +0 -481
  507. package/src/lib/report.ts +0 -973
  508. package/src/lib/resources.test.ts +0 -132
  509. package/src/lib/resources.ts +0 -429
  510. package/src/lib/runner.test.ts +0 -288
  511. package/src/lib/runner.ts +0 -1223
  512. package/src/lib/session-artifacts.test.ts +0 -107
  513. package/src/lib/session-artifacts.ts +0 -193
  514. package/src/lib/session-manager.test.ts +0 -402
  515. package/src/lib/session-manager.ts +0 -150
  516. package/src/lib/session-result.test.ts +0 -98
  517. package/src/lib/session-result.ts +0 -262
  518. package/src/lib/session-state.ts +0 -470
  519. package/src/lib/slack-workspace.ts +0 -25
  520. package/src/lib/tmux/bridge.ts +0 -439
  521. package/src/lib/tmux/context.test.ts +0 -242
  522. package/src/lib/tmux/context.ts +0 -380
  523. package/src/lib/tmux/index.ts +0 -46
  524. package/src/lib/tmux/map.test.ts +0 -99
  525. package/src/lib/tmux/map.ts +0 -252
  526. package/src/lib/tmux/panes.ts +0 -170
  527. package/src/lib/tmux/redaction.test.ts +0 -231
  528. package/src/lib/tmux/redaction.ts +0 -201
  529. package/src/lib/triage-llm.ts +0 -312
  530. package/src/lib/triage-tracker.ts +0 -400
  531. package/src/lib/triage.ts +0 -655
  532. package/src/lib/types.ts +0 -61
  533. package/src/lib/windows/index.ts +0 -2
  534. package/src/lib/windows/inventory.test.ts +0 -370
  535. package/src/lib/windows/inventory.ts +0 -352
  536. package/src/lib/windows/types.ts +0 -46
  537. package/src/lib.ts +0 -260
@@ -1,704 +0,0 @@
1
- import { existsSync, mkdirSync, rmSync } from "node:fs";
2
- import { tmpdir } from "node:os";
3
- import { join } from "node:path";
4
- import { afterEach, beforeEach, describe, expect, it } from "vitest";
5
- import {
6
- type AfsAnnotation,
7
- AnnotationStore,
8
- type EventEnvelope,
9
- } from "../../../lib/annotations.js";
10
-
11
- const TEST_DIR = join(tmpdir(), `abbie-annotations-test-${process.pid}`);
12
- const PREVIEW_ID = "preview-test-001";
13
-
14
- describe("AnnotationStore – AFS interoperability", () => {
15
- let store: AnnotationStore;
16
-
17
- beforeEach(() => {
18
- if (existsSync(TEST_DIR)) {
19
- rmSync(TEST_DIR, { recursive: true });
20
- }
21
- mkdirSync(TEST_DIR, { recursive: true });
22
- store = new AnnotationStore(TEST_DIR);
23
- });
24
-
25
- afterEach(() => {
26
- if (existsSync(TEST_DIR)) {
27
- rmSync(TEST_DIR, { recursive: true });
28
- }
29
- });
30
-
31
- // ==========================================================================
32
- // AFS → internal → AFS roundtrip (lossless for core/recommended fields)
33
- // ==========================================================================
34
-
35
- describe("AFS roundtrip", () => {
36
- it("roundtrips core fields losslessly", () => {
37
- const original: AfsAnnotation = {
38
- id: "ann_roundtrip_1",
39
- comment: "Button clipped on mobile",
40
- elementPath: "body > main > .hero > button.cta",
41
- timestamp: 1_705_694_400_000,
42
- x: 45.5,
43
- y: 480,
44
- element: "button",
45
- url: "http://localhost:3000/landing",
46
- intent: "fix",
47
- severity: "blocking",
48
- status: "pending",
49
- boundingBox: { x: 40, y: 470, width: 120, height: 44 },
50
- reactComponents: "HeroButton",
51
- cssClasses: "cta primary",
52
- computedStyles: "font-size:16px",
53
- accessibility: "role=button",
54
- nearbyText: "Get started",
55
- selectedText: "Start",
56
- thread: [
57
- { id: "thr_1", role: "human", content: "Make it 48px", timestamp: 1_705_694_401_000 },
58
- { id: "thr_2", role: "agent", content: "Fixed to 48px", timestamp: 1_705_694_402_000 },
59
- ],
60
- };
61
-
62
- store.createFromAfs({ previewId: PREVIEW_ID, annotation: original });
63
- const exported = store.exportAfs(PREVIEW_ID, original.id);
64
- expect(exported).not.toBeNull();
65
-
66
- // Core fields
67
- expect(exported!.id).toBe(original.id);
68
- expect(exported!.comment).toBe(original.comment);
69
- expect(exported!.elementPath).toBe(original.elementPath);
70
- expect(exported!.timestamp).toBe(original.timestamp);
71
- expect(exported!.x).toBe(original.x);
72
- expect(exported!.y).toBe(original.y);
73
- expect(exported!.element).toBe(original.element);
74
- expect(exported!.url).toBe(original.url);
75
- expect(exported!.status).toBe(original.status);
76
-
77
- // Intent/severity roundtrip through mapping
78
- expect(exported!.intent).toBe("fix"); // bug → fix
79
- expect(exported!.severity).toBe("blocking"); // critical → blocking
80
-
81
- // Recommended fields preserved via metadata.afs
82
- expect(exported!.boundingBox).toEqual(original.boundingBox);
83
- expect(exported!.reactComponents).toBe(original.reactComponents);
84
- expect(exported!.cssClasses).toBe(original.cssClasses);
85
- expect(exported!.computedStyles).toBe(original.computedStyles);
86
- expect(exported!.accessibility).toBe(original.accessibility);
87
- expect(exported!.nearbyText).toBe(original.nearbyText);
88
- expect(exported!.selectedText).toBe(original.selectedText);
89
-
90
- // Thread roundtrip
91
- expect(exported!.thread).toHaveLength(2);
92
- expect(exported!.thread![0].id).toBe("thr_1");
93
- expect(exported!.thread![0].role).toBe("human");
94
- expect(exported!.thread![0].content).toBe("Make it 48px");
95
- expect(exported!.thread![1].role).toBe("agent");
96
- });
97
-
98
- it("roundtrips batch import then export", () => {
99
- const batch: AfsAnnotation[] = [
100
- {
101
- id: "ann_batch_1",
102
- comment: "First",
103
- elementPath: "body",
104
- timestamp: 1000,
105
- x: 10,
106
- y: 20,
107
- element: "div",
108
- intent: "change",
109
- severity: "suggestion",
110
- },
111
- {
112
- id: "ann_batch_2",
113
- comment: "Second",
114
- elementPath: "body > main",
115
- timestamp: 2000,
116
- x: 30,
117
- y: 40,
118
- element: "main",
119
- intent: "question",
120
- severity: "important",
121
- },
122
- ];
123
-
124
- const imported = store.importAfsBatch({ previewId: PREVIEW_ID, annotations: batch });
125
- expect(imported).toHaveLength(2);
126
- expect(imported[0].id).toBe("ann_batch_1");
127
- expect(imported[1].id).toBe("ann_batch_2");
128
-
129
- const exported = store.exportAfsBatch(PREVIEW_ID);
130
- expect(exported).toHaveLength(2);
131
- expect(exported[0].id).toBe("ann_batch_1");
132
- expect(exported[0].comment).toBe("First");
133
- expect(exported[1].id).toBe("ann_batch_2");
134
- expect(exported[1].comment).toBe("Second");
135
- });
136
-
137
- it("preserves status across roundtrip", () => {
138
- const afs: AfsAnnotation = {
139
- id: "ann_status",
140
- comment: "Status test",
141
- elementPath: "body",
142
- timestamp: 1000,
143
- x: 0,
144
- y: 0,
145
- element: "div",
146
- status: "acknowledged",
147
- };
148
-
149
- store.createFromAfs({ previewId: PREVIEW_ID, annotation: afs });
150
- const exported = store.exportAfs(PREVIEW_ID, "ann_status");
151
- expect(exported!.status).toBe("acknowledged");
152
- });
153
- });
154
-
155
- // ==========================================================================
156
- // Event ordering / replay
157
- // ==========================================================================
158
-
159
- describe("event ordering and replay", () => {
160
- it("records events in monotonically increasing sequence", () => {
161
- const a = store.create({ previewId: PREVIEW_ID, body: "Test annotation" });
162
- store.acknowledge(PREVIEW_ID, a.id);
163
- store.reply(PREVIEW_ID, a.id, "claude", "Looking into it");
164
- store.resolve(PREVIEW_ID, a.id);
165
-
166
- const events = store.events(PREVIEW_ID);
167
- expect(events).toHaveLength(4);
168
-
169
- // Sequence must be strictly increasing
170
- for (let i = 1; i < events.length; i++) {
171
- expect(events[i].seq).toBeGreaterThan(events[i - 1].seq);
172
- }
173
-
174
- // Types in expected order
175
- expect(events.map((e) => e.type)).toEqual([
176
- "annotation.created",
177
- "status.changed",
178
- "thread.message",
179
- "status.changed",
180
- ]);
181
- });
182
-
183
- it("records delete events", () => {
184
- const a = store.create({ previewId: PREVIEW_ID, body: "To be deleted" });
185
- const deleted = store.delete(PREVIEW_ID, a.id);
186
-
187
- expect(deleted).not.toBeNull();
188
- expect(deleted!.id).toBe(a.id);
189
-
190
- const events = store.events(PREVIEW_ID);
191
- expect(events).toHaveLength(2);
192
- expect(events[1].type).toBe("annotation.deleted");
193
- expect(events[1].data.body).toBe("To be deleted");
194
- });
195
-
196
- it("replays AFS import events with correct types", () => {
197
- const afs: AfsAnnotation = {
198
- id: "ann_import_evt",
199
- comment: "Imported annotation",
200
- elementPath: "body",
201
- timestamp: 1000,
202
- x: 0,
203
- y: 0,
204
- element: "div",
205
- };
206
-
207
- store.createFromAfs({ previewId: PREVIEW_ID, annotation: afs });
208
-
209
- // Update via upsert
210
- store.createFromAfs({
211
- previewId: PREVIEW_ID,
212
- annotation: { ...afs, comment: "Updated annotation", status: "acknowledged" },
213
- });
214
-
215
- const events = store.events(PREVIEW_ID);
216
- expect(events).toHaveLength(2);
217
- expect(events[0].type).toBe("annotation.created");
218
- expect(events[0].data.source).toBe("afs");
219
- expect(events[1].type).toBe("annotation.updated");
220
- expect(events[1].data.source).toBe("afs");
221
- });
222
-
223
- it("maintains correct event seq across multiple annotations", () => {
224
- store.create({ previewId: PREVIEW_ID, body: "First" });
225
- store.create({ previewId: PREVIEW_ID, body: "Second" });
226
- store.create({ previewId: PREVIEW_ID, body: "Third" });
227
-
228
- const events = store.events(PREVIEW_ID);
229
- expect(events).toHaveLength(3);
230
- expect(events.map((e) => e.seq)).toEqual([1, 2, 3]);
231
- });
232
- });
233
-
234
- // ==========================================================================
235
- // Event envelopes
236
- // ==========================================================================
237
-
238
- describe("event envelopes", () => {
239
- it("wraps events with preview context", () => {
240
- store.create({ previewId: PREVIEW_ID, body: "Test" });
241
-
242
- const envelopes = store.exportEvents(PREVIEW_ID);
243
- expect(envelopes).toHaveLength(1);
244
- expect(envelopes[0].version).toBe("1.0");
245
- expect(envelopes[0].previewId).toBe(PREVIEW_ID);
246
- expect(envelopes[0].event.type).toBe("annotation.created");
247
- });
248
-
249
- it("includes linkedSessionId in envelope", () => {
250
- const a = store.create({ previewId: PREVIEW_ID, body: "Linked" });
251
- store.linkSession(PREVIEW_ID, a.id, "sess_abc");
252
-
253
- const envelopes = store.exportEvents(PREVIEW_ID);
254
- expect(envelopes[0].sessionId).toBe("sess_abc");
255
- });
256
-
257
- it("allows sessionId override", () => {
258
- store.create({ previewId: PREVIEW_ID, body: "Override" });
259
-
260
- const envelopes = store.exportEvents(PREVIEW_ID, {
261
- sessionId: "sess_override",
262
- });
263
- expect(envelopes[0].sessionId).toBe("sess_override");
264
- });
265
-
266
- it("produces valid EventEnvelope shape", () => {
267
- const a = store.create({ previewId: PREVIEW_ID, body: "Shape test" });
268
- store.acknowledge(PREVIEW_ID, a.id);
269
-
270
- const envelopes: EventEnvelope[] = store.exportEvents(PREVIEW_ID);
271
-
272
- for (const env of envelopes) {
273
- expect(env).toHaveProperty("version", "1.0");
274
- expect(env).toHaveProperty("previewId", PREVIEW_ID);
275
- expect(env.event).toHaveProperty("type");
276
- expect(env.event).toHaveProperty("annotationId");
277
- expect(env.event).toHaveProperty("seq");
278
- expect(env.event).toHaveProperty("timestamp");
279
- expect(env.event).toHaveProperty("data");
280
- }
281
- });
282
- });
283
-
284
- // ==========================================================================
285
- // Preview linkage integration
286
- // ==========================================================================
287
-
288
- describe("preview linkage", () => {
289
- it("annotations are scoped to preview IDs", () => {
290
- store.create({ previewId: "preview-A", body: "In A" });
291
- store.create({ previewId: "preview-B", body: "In B" });
292
-
293
- expect(store.list("preview-A")).toHaveLength(1);
294
- expect(store.list("preview-B")).toHaveLength(1);
295
- expect(store.list("preview-A")[0].body).toBe("In A");
296
- expect(store.list("preview-B")[0].body).toBe("In B");
297
- });
298
-
299
- it("events are scoped to preview IDs", () => {
300
- store.create({ previewId: "preview-A", body: "Event in A" });
301
- store.create({ previewId: "preview-B", body: "Event in B" });
302
-
303
- expect(store.events("preview-A")).toHaveLength(1);
304
- expect(store.events("preview-B")).toHaveLength(1);
305
- });
306
-
307
- it("links annotations to sessions and includes in AFS export", () => {
308
- const a = store.create({
309
- previewId: PREVIEW_ID,
310
- body: "Needs agent fix",
311
- intent: "blocker",
312
- });
313
- store.linkSession(PREVIEW_ID, a.id, "abbie-20260220-fix-xyz");
314
-
315
- const linked = store.get(PREVIEW_ID, a.id);
316
- expect(linked!.linkedSessionId).toBe("abbie-20260220-fix-xyz");
317
-
318
- // Session linkage appears in event envelopes
319
- const envelopes = store.exportEvents(PREVIEW_ID);
320
- expect(envelopes[0].sessionId).toBe("abbie-20260220-fix-xyz");
321
- });
322
-
323
- it("supports full lifecycle: import → transition → thread → export", () => {
324
- const afs: AfsAnnotation = {
325
- id: "ann_lifecycle",
326
- comment: "Button broken on mobile",
327
- elementPath: "body > .hero > button",
328
- timestamp: 1_705_694_400_000,
329
- x: 50,
330
- y: 300,
331
- element: "button",
332
- url: "/landing",
333
- intent: "fix",
334
- severity: "blocking",
335
- };
336
-
337
- // Import
338
- store.createFromAfs({ previewId: PREVIEW_ID, annotation: afs });
339
-
340
- // Link to session
341
- store.linkSession(PREVIEW_ID, afs.id, "sess_fix_123");
342
-
343
- // Acknowledge
344
- store.acknowledge(PREVIEW_ID, afs.id);
345
-
346
- // Thread conversation
347
- store.reply(PREVIEW_ID, afs.id, "agent", "Fixing button height");
348
- store.reply(PREVIEW_ID, afs.id, "human", "Looks good now");
349
-
350
- // Resolve
351
- store.resolve(PREVIEW_ID, afs.id);
352
-
353
- // Verify final state
354
- const final = store.get(PREVIEW_ID, afs.id);
355
- expect(final!.status).toBe("resolved");
356
- expect(final!.linkedSessionId).toBe("sess_fix_123");
357
- expect(final!.thread).toHaveLength(2);
358
-
359
- // Verify events capture full lifecycle
360
- const events = store.events(PREVIEW_ID);
361
- expect(events.map((e) => e.type)).toEqual([
362
- "annotation.created",
363
- "status.changed", // → acknowledged
364
- "thread.message", // agent reply
365
- "thread.message", // human reply
366
- "status.changed", // → resolved
367
- ]);
368
-
369
- // Export back to AFS
370
- const exported = store.exportAfs(PREVIEW_ID, afs.id);
371
- expect(exported!.comment).toBe(afs.comment);
372
- expect(exported!.status).toBe("resolved");
373
- expect(exported!.thread).toHaveLength(2);
374
-
375
- // Event envelopes include session
376
- const envelopes = store.exportEvents(PREVIEW_ID);
377
- expect(envelopes.every((e) => e.previewId === PREVIEW_ID)).toBe(true);
378
- expect(envelopes.every((e) => e.sessionId === "sess_fix_123")).toBe(true);
379
- });
380
- });
381
-
382
- // ==========================================================================
383
- // Status transitions
384
- // ==========================================================================
385
-
386
- describe("status transitions", () => {
387
- it("pending → acknowledged → resolved", () => {
388
- const a = store.create({ previewId: PREVIEW_ID, body: "Test" });
389
- expect(a.status).toBe("pending");
390
-
391
- const acked = store.acknowledge(PREVIEW_ID, a.id);
392
- expect(acked!.status).toBe("acknowledged");
393
-
394
- const resolved = store.resolve(PREVIEW_ID, a.id);
395
- expect(resolved!.status).toBe("resolved");
396
- });
397
-
398
- it("pending → acknowledged → dismissed", () => {
399
- const a = store.create({ previewId: PREVIEW_ID, body: "Test" });
400
- store.acknowledge(PREVIEW_ID, a.id);
401
-
402
- const dismissed = store.dismiss(PREVIEW_ID, a.id);
403
- expect(dismissed!.status).toBe("dismissed");
404
- });
405
-
406
- it("preserves thread continuity across transitions", () => {
407
- const a = store.create({ previewId: PREVIEW_ID, body: "Thread test" });
408
- store.reply(PREVIEW_ID, a.id, "human", "Before ack");
409
- store.acknowledge(PREVIEW_ID, a.id);
410
- store.reply(PREVIEW_ID, a.id, "agent", "After ack");
411
- store.resolve(PREVIEW_ID, a.id);
412
-
413
- const final = store.get(PREVIEW_ID, a.id);
414
- expect(final!.thread).toHaveLength(2);
415
- expect(final!.thread[0].body).toBe("Before ack");
416
- expect(final!.thread[1].body).toBe("After ack");
417
- expect(final!.status).toBe("resolved");
418
- });
419
- });
420
-
421
- // ==========================================================================
422
- // AFS event ingestion pipeline
423
- // ==========================================================================
424
-
425
- describe("AFS event ingestion", () => {
426
- it("ingests annotation.created events", () => {
427
- const events = [
428
- {
429
- type: "annotation.created" as const,
430
- annotationId: "ann_ingest_1",
431
- timestamp: 1000,
432
- data: {
433
- annotation: {
434
- id: "ann_ingest_1",
435
- comment: "Button broken",
436
- elementPath: "body > button",
437
- timestamp: 1000,
438
- x: 10,
439
- y: 20,
440
- element: "button",
441
- intent: "fix" as const,
442
- severity: "blocking" as const,
443
- },
444
- },
445
- },
446
- ];
447
-
448
- const result = store.ingestAfsEvents({ previewId: PREVIEW_ID, events });
449
- expect(result.ingested).toBe(1);
450
- expect(result.annotations).toHaveLength(1);
451
- expect(result.annotations[0].id).toBe("ann_ingest_1");
452
- expect(result.annotations[0].severity).toBe("critical");
453
- expect(result.annotations[0].intent).toBe("bug");
454
- });
455
-
456
- it("ingests annotation.updated events as upserts", () => {
457
- const events = [
458
- {
459
- type: "annotation.created" as const,
460
- annotationId: "ann_up_1",
461
- timestamp: 1000,
462
- data: {
463
- annotation: {
464
- id: "ann_up_1",
465
- comment: "Initial",
466
- elementPath: "body",
467
- timestamp: 1000,
468
- x: 0,
469
- y: 0,
470
- element: "div",
471
- },
472
- },
473
- },
474
- {
475
- type: "annotation.updated" as const,
476
- annotationId: "ann_up_1",
477
- timestamp: 2000,
478
- data: {
479
- annotation: {
480
- id: "ann_up_1",
481
- comment: "Updated text",
482
- elementPath: "body > main",
483
- timestamp: 2000,
484
- x: 5,
485
- y: 10,
486
- element: "main",
487
- status: "acknowledged" as const,
488
- },
489
- },
490
- },
491
- ];
492
-
493
- const result = store.ingestAfsEvents({ previewId: PREVIEW_ID, events });
494
- expect(result.ingested).toBe(2);
495
- expect(result.annotations).toHaveLength(1);
496
- expect(result.annotations[0].body).toBe("Updated text");
497
- expect(result.annotations[0].status).toBe("acknowledged");
498
- });
499
-
500
- it("ingests annotation.resolved events", () => {
501
- // Create first
502
- store.create({ previewId: PREVIEW_ID, body: "To resolve" });
503
- const annotations = store.list(PREVIEW_ID);
504
- const id = annotations[0].id;
505
-
506
- const events = [
507
- {
508
- type: "annotation.resolved" as const,
509
- annotationId: id,
510
- timestamp: 3000,
511
- data: { resolvedBy: "agent" as const },
512
- },
513
- ];
514
-
515
- const result = store.ingestAfsEvents({ previewId: PREVIEW_ID, events });
516
- expect(result.ingested).toBe(1);
517
- const resolved = store.get(PREVIEW_ID, id);
518
- expect(resolved!.status).toBe("resolved");
519
- expect((resolved!.metadata?.afs as Record<string, unknown>)?.resolvedBy).toBe("agent");
520
- });
521
-
522
- it("ingests annotation.deleted events", () => {
523
- const a = store.create({ previewId: PREVIEW_ID, body: "To delete" });
524
- const events = [
525
- {
526
- type: "annotation.deleted" as const,
527
- annotationId: a.id,
528
- timestamp: 4000,
529
- data: {},
530
- },
531
- ];
532
-
533
- const result = store.ingestAfsEvents({ previewId: PREVIEW_ID, events });
534
- expect(result.ingested).toBe(1);
535
- expect(store.list(PREVIEW_ID)).toHaveLength(0);
536
- });
537
-
538
- it("ingests thread.message events", () => {
539
- const a = store.create({ previewId: PREVIEW_ID, body: "Thread target" });
540
- const events = [
541
- {
542
- type: "thread.message" as const,
543
- annotationId: a.id,
544
- timestamp: 5000,
545
- data: {
546
- message: {
547
- id: "msg_1",
548
- role: "agent" as const,
549
- content: "Working on it",
550
- timestamp: 5000,
551
- },
552
- },
553
- },
554
- ];
555
-
556
- const result = store.ingestAfsEvents({ previewId: PREVIEW_ID, events });
557
- expect(result.ingested).toBe(1);
558
- const updated = store.get(PREVIEW_ID, a.id);
559
- expect(updated!.thread).toHaveLength(1);
560
- expect(updated!.thread[0].body).toBe("Working on it");
561
- });
562
-
563
- it("processes mixed event stream in order", () => {
564
- const events = [
565
- {
566
- type: "annotation.created" as const,
567
- annotationId: "ann_mix_1",
568
- timestamp: 1000,
569
- data: {
570
- annotation: {
571
- id: "ann_mix_1",
572
- comment: "Bug report",
573
- elementPath: "body",
574
- timestamp: 1000,
575
- x: 0,
576
- y: 0,
577
- element: "div",
578
- severity: "blocking" as const,
579
- },
580
- },
581
- },
582
- {
583
- type: "thread.message" as const,
584
- annotationId: "ann_mix_1",
585
- timestamp: 2000,
586
- data: {
587
- message: {
588
- id: "msg_1",
589
- role: "agent" as const,
590
- content: "Investigating",
591
- timestamp: 2000,
592
- },
593
- },
594
- },
595
- {
596
- type: "annotation.resolved" as const,
597
- annotationId: "ann_mix_1",
598
- timestamp: 3000,
599
- data: { resolvedBy: "agent" as const },
600
- },
601
- ];
602
-
603
- const result = store.ingestAfsEvents({ previewId: PREVIEW_ID, events });
604
- expect(result.ingested).toBe(3);
605
-
606
- const final = store.get(PREVIEW_ID, "ann_mix_1");
607
- expect(final!.status).toBe("resolved");
608
- expect(final!.thread).toHaveLength(1);
609
-
610
- // Internal events should reflect the full lifecycle
611
- const internalEvents = store.events(PREVIEW_ID);
612
- expect(internalEvents.length).toBeGreaterThanOrEqual(3);
613
- });
614
-
615
- it("skips events with missing data gracefully", () => {
616
- const events = [
617
- {
618
- type: "annotation.created" as const,
619
- annotationId: "ann_skip",
620
- timestamp: 1000,
621
- data: {}, // Missing annotation
622
- },
623
- {
624
- type: "thread.message" as const,
625
- annotationId: "nonexistent",
626
- timestamp: 2000,
627
- data: {}, // Missing message
628
- },
629
- ];
630
-
631
- const result = store.ingestAfsEvents({ previewId: PREVIEW_ID, events });
632
- expect(result.ingested).toBe(0);
633
- expect(result.annotations).toHaveLength(0);
634
- });
635
- });
636
-
637
- // ==========================================================================
638
- // Session routing
639
- // ==========================================================================
640
-
641
- describe("session routing", () => {
642
- it("getActionable returns blocking/critical unresolved annotations", () => {
643
- store.create({ previewId: PREVIEW_ID, body: "Info note", severity: "info" });
644
- store.create({ previewId: PREVIEW_ID, body: "Critical bug", severity: "critical" });
645
- store.create({ previewId: PREVIEW_ID, body: "Error issue", severity: "error" });
646
- store.create({ previewId: PREVIEW_ID, body: "Blocker", intent: "blocker" });
647
-
648
- const actionable = store.getActionable(PREVIEW_ID);
649
- expect(actionable).toHaveLength(3);
650
- expect(actionable.map((a) => a.body).sort()).toEqual(
651
- ["Blocker", "Critical bug", "Error issue"].sort()
652
- );
653
- });
654
-
655
- it("getActionable excludes resolved and dismissed", () => {
656
- const a1 = store.create({ previewId: PREVIEW_ID, body: "Resolved", severity: "critical" });
657
- store.create({ previewId: PREVIEW_ID, body: "Still open", severity: "critical" });
658
- const a3 = store.create({ previewId: PREVIEW_ID, body: "Dismissed", severity: "error" });
659
-
660
- store.resolve(PREVIEW_ID, a1.id);
661
- store.dismiss(PREVIEW_ID, a3.id);
662
-
663
- const actionable = store.getActionable(PREVIEW_ID);
664
- expect(actionable).toHaveLength(1);
665
- expect(actionable[0].body).toBe("Still open");
666
- });
667
-
668
- it("routeBlockingToSession links unlinked blocking annotations", () => {
669
- store.create({ previewId: PREVIEW_ID, body: "Critical 1", severity: "critical" });
670
- store.create({ previewId: PREVIEW_ID, body: "Critical 2", severity: "critical" });
671
- store.create({ previewId: PREVIEW_ID, body: "Info (skip)", severity: "info" });
672
-
673
- const routed = store.routeBlockingToSession(PREVIEW_ID, "sess_fix_001");
674
- expect(routed).toHaveLength(2);
675
- expect(routed.every((a) => a.linkedSessionId === "sess_fix_001")).toBe(true);
676
- });
677
-
678
- it("routeBlockingToSession skips already-linked annotations", () => {
679
- const a1 = store.create({
680
- previewId: PREVIEW_ID,
681
- body: "Already linked",
682
- severity: "critical",
683
- });
684
- store.linkSession(PREVIEW_ID, a1.id, "sess_existing");
685
- store.create({ previewId: PREVIEW_ID, body: "Unlinked", severity: "critical" });
686
-
687
- const routed = store.routeBlockingToSession(PREVIEW_ID, "sess_new");
688
- expect(routed).toHaveLength(1);
689
- expect(routed[0].body).toBe("Unlinked");
690
-
691
- // Original link unchanged
692
- const original = store.get(PREVIEW_ID, a1.id);
693
- expect(original!.linkedSessionId).toBe("sess_existing");
694
- });
695
-
696
- it("routeBlockingToSession returns empty when no actionable annotations", () => {
697
- store.create({ previewId: PREVIEW_ID, body: "Info", severity: "info" });
698
- store.create({ previewId: PREVIEW_ID, body: "Warning", severity: "warning" });
699
-
700
- const routed = store.routeBlockingToSession(PREVIEW_ID, "sess_empty");
701
- expect(routed).toHaveLength(0);
702
- });
703
- });
704
- });