@creativeintelligence/abbie 0.1.4 → 0.1.6

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 (538) hide show
  1. package/dist/cli/commands/login.js +26 -0
  2. package/dist/cli/commands/start.js +2 -1
  3. package/oclif.manifest.json +1 -1
  4. package/package.json +9 -5
  5. package/dist/cli/base-command.d.ts.map +0 -1
  6. package/dist/cli/commands/agent/list.d.ts.map +0 -1
  7. package/dist/cli/commands/annotation/ack.d.ts.map +0 -1
  8. package/dist/cli/commands/annotation/create.d.ts.map +0 -1
  9. package/dist/cli/commands/annotation/events.d.ts.map +0 -1
  10. package/dist/cli/commands/annotation/export.d.ts.map +0 -1
  11. package/dist/cli/commands/annotation/import.d.ts.map +0 -1
  12. package/dist/cli/commands/annotation/ingest.d.ts.map +0 -1
  13. package/dist/cli/commands/annotation/list.d.ts.map +0 -1
  14. package/dist/cli/commands/annotation/reply.d.ts.map +0 -1
  15. package/dist/cli/commands/annotation/resolve.d.ts.map +0 -1
  16. package/dist/cli/commands/auto/index.d.ts.map +0 -1
  17. package/dist/cli/commands/backlog/add.d.ts.map +0 -1
  18. package/dist/cli/commands/backlog/claim.d.ts.map +0 -1
  19. package/dist/cli/commands/backlog/complete.d.ts.map +0 -1
  20. package/dist/cli/commands/backlog/list.d.ts.map +0 -1
  21. package/dist/cli/commands/backlog/pick.d.ts.map +0 -1
  22. package/dist/cli/commands/backlog/sync.d.ts.map +0 -1
  23. package/dist/cli/commands/bootstrap.d.ts.map +0 -1
  24. package/dist/cli/commands/bridge.d.ts.map +0 -1
  25. package/dist/cli/commands/context/inject.d.ts.map +0 -1
  26. package/dist/cli/commands/context/list.d.ts.map +0 -1
  27. package/dist/cli/commands/context/publish.d.ts.map +0 -1
  28. package/dist/cli/commands/context/read.d.ts.map +0 -1
  29. package/dist/cli/commands/daemon.d.ts.map +0 -1
  30. package/dist/cli/commands/digest/index.d.ts.map +0 -1
  31. package/dist/cli/commands/docs/lint.d.ts.map +0 -1
  32. package/dist/cli/commands/docs/sync.d.ts.map +0 -1
  33. package/dist/cli/commands/doctor.d.ts.map +0 -1
  34. package/dist/cli/commands/find/index.d.ts.map +0 -1
  35. package/dist/cli/commands/gc.d.ts.map +0 -1
  36. package/dist/cli/commands/history/index.d.ts.map +0 -1
  37. package/dist/cli/commands/hooks/guard.d.ts.map +0 -1
  38. package/dist/cli/commands/hooks/list.d.ts.map +0 -1
  39. package/dist/cli/commands/hooks/lock.d.ts.map +0 -1
  40. package/dist/cli/commands/hooks/status.d.ts.map +0 -1
  41. package/dist/cli/commands/hooks/test.d.ts.map +0 -1
  42. package/dist/cli/commands/hooks/unlock.d.ts.map +0 -1
  43. package/dist/cli/commands/index.d.ts.map +0 -1
  44. package/dist/cli/commands/list.d.ts.map +0 -1
  45. package/dist/cli/commands/list.e2e.test.d.ts +0 -1
  46. package/dist/cli/commands/list.e2e.test.js +0 -47
  47. package/dist/cli/commands/login.d.ts.map +0 -1
  48. package/dist/cli/commands/logout.d.ts.map +0 -1
  49. package/dist/cli/commands/panes/broker.d.ts.map +0 -1
  50. package/dist/cli/commands/panes/pipe-sink.d.ts.map +0 -1
  51. package/dist/cli/commands/panes/snapshot.d.ts.map +0 -1
  52. package/dist/cli/commands/plan.d.ts.map +0 -1
  53. package/dist/cli/commands/plan.e2e.test.d.ts +0 -1
  54. package/dist/cli/commands/plan.e2e.test.js +0 -74
  55. package/dist/cli/commands/preview/index.d.ts.map +0 -1
  56. package/dist/cli/commands/preview/init.d.ts.map +0 -1
  57. package/dist/cli/commands/preview/list.d.ts.map +0 -1
  58. package/dist/cli/commands/preview/status.d.ts.map +0 -1
  59. package/dist/cli/commands/preview/stop.d.ts.map +0 -1
  60. package/dist/cli/commands/preview/sync.d.ts.map +0 -1
  61. package/dist/cli/commands/preview/watch.d.ts.map +0 -1
  62. package/dist/cli/commands/project/add.d.ts.map +0 -1
  63. package/dist/cli/commands/project/list.d.ts.map +0 -1
  64. package/dist/cli/commands/project/remove.d.ts.map +0 -1
  65. package/dist/cli/commands/push.d.ts.map +0 -1
  66. package/dist/cli/commands/reference/add.d.ts.map +0 -1
  67. package/dist/cli/commands/reference/delete.d.ts.map +0 -1
  68. package/dist/cli/commands/reference/extract.d.ts.map +0 -1
  69. package/dist/cli/commands/reference/list.d.ts.map +0 -1
  70. package/dist/cli/commands/reference/normalize.d.ts.map +0 -1
  71. package/dist/cli/commands/reference/open.d.ts.map +0 -1
  72. package/dist/cli/commands/reference/save.d.ts.map +0 -1
  73. package/dist/cli/commands/reference/search.d.ts.map +0 -1
  74. package/dist/cli/commands/reference/show.d.ts.map +0 -1
  75. package/dist/cli/commands/reference/update-index.d.ts.map +0 -1
  76. package/dist/cli/commands/reference/update.d.ts.map +0 -1
  77. package/dist/cli/commands/report/blocked.d.ts.map +0 -1
  78. package/dist/cli/commands/report/complete.d.ts.map +0 -1
  79. package/dist/cli/commands/report/progress.d.ts.map +0 -1
  80. package/dist/cli/commands/report/start.d.ts.map +0 -1
  81. package/dist/cli/commands/resource/acquire.d.ts.map +0 -1
  82. package/dist/cli/commands/resource/list.d.ts.map +0 -1
  83. package/dist/cli/commands/resource/release.d.ts.map +0 -1
  84. package/dist/cli/commands/resource/wait.d.ts.map +0 -1
  85. package/dist/cli/commands/review.d.ts.map +0 -1
  86. package/dist/cli/commands/session/attach.d.ts.map +0 -1
  87. package/dist/cli/commands/session/await.d.ts.map +0 -1
  88. package/dist/cli/commands/session/complete.d.ts.map +0 -1
  89. package/dist/cli/commands/session/create.d.ts.map +0 -1
  90. package/dist/cli/commands/session/heartbeat.d.ts.map +0 -1
  91. package/dist/cli/commands/session/list.d.ts.map +0 -1
  92. package/dist/cli/commands/session/mark-done.d.ts.map +0 -1
  93. package/dist/cli/commands/session/mine.d.ts.map +0 -1
  94. package/dist/cli/commands/session/replay.d.ts.map +0 -1
  95. package/dist/cli/commands/session/run.d.ts.map +0 -1
  96. package/dist/cli/commands/session/show.d.ts.map +0 -1
  97. package/dist/cli/commands/session/start.d.ts.map +0 -1
  98. package/dist/cli/commands/session/state/cleanup.d.ts.map +0 -1
  99. package/dist/cli/commands/session/state/end.d.ts.map +0 -1
  100. package/dist/cli/commands/session/state/get.d.ts.map +0 -1
  101. package/dist/cli/commands/session/state/init.d.ts.map +0 -1
  102. package/dist/cli/commands/session/state/list.d.ts.map +0 -1
  103. package/dist/cli/commands/session/state/update.d.ts.map +0 -1
  104. package/dist/cli/commands/session/stop.d.ts.map +0 -1
  105. package/dist/cli/commands/session/view.d.ts.map +0 -1
  106. package/dist/cli/commands/start.d.ts.map +0 -1
  107. package/dist/cli/commands/state/dump.d.ts.map +0 -1
  108. package/dist/cli/commands/status.d.ts.map +0 -1
  109. package/dist/cli/commands/sync.d.ts.map +0 -1
  110. package/dist/cli/commands/trace/export.d.ts.map +0 -1
  111. package/dist/cli/commands/triage/claim.d.ts.map +0 -1
  112. package/dist/cli/commands/triage/list.d.ts.map +0 -1
  113. package/dist/cli/commands/triage/next.d.ts.map +0 -1
  114. package/dist/cli/commands/triage/pull.d.ts.map +0 -1
  115. package/dist/cli/commands/triage/stats.d.ts.map +0 -1
  116. package/dist/cli/commands/tunnel/list.d.ts.map +0 -1
  117. package/dist/cli/commands/tunnel/start.d.ts.map +0 -1
  118. package/dist/cli/commands/tunnel/stop.d.ts.map +0 -1
  119. package/dist/cli/commands/tunnel/url.d.ts.map +0 -1
  120. package/dist/cli/commands/web/start.d.ts.map +0 -1
  121. package/dist/cli/commands/windows/context.d.ts.map +0 -1
  122. package/dist/cli/commands/windows/focus.d.ts.map +0 -1
  123. package/dist/cli/commands/windows/list.d.ts.map +0 -1
  124. package/dist/cli/commands/windows/map.d.ts.map +0 -1
  125. package/dist/cli/commands/windows/read.d.ts.map +0 -1
  126. package/dist/cli/commands/windows/search.d.ts.map +0 -1
  127. package/dist/cli/commands/windows/show.d.ts.map +0 -1
  128. package/dist/cli/commands/windows/watch.d.ts.map +0 -1
  129. package/dist/lib/active-sessions.d.ts.map +0 -1
  130. package/dist/lib/agent-adapters.d.ts.map +0 -1
  131. package/dist/lib/agent-sessions.d.ts.map +0 -1
  132. package/dist/lib/agent-trace.d.ts.map +0 -1
  133. package/dist/lib/analytics.d.ts.map +0 -1
  134. package/dist/lib/annotations-convex.d.ts.map +0 -1
  135. package/dist/lib/annotations.d.ts.map +0 -1
  136. package/dist/lib/auto/discover.d.ts.map +0 -1
  137. package/dist/lib/auto/ideate.d.ts.map +0 -1
  138. package/dist/lib/auto/spawn.d.ts.map +0 -1
  139. package/dist/lib/auto/workspace.d.ts.map +0 -1
  140. package/dist/lib/backlog.d.ts.map +0 -1
  141. package/dist/lib/backlog.test.d.ts +0 -1
  142. package/dist/lib/backlog.test.js +0 -162
  143. package/dist/lib/config-loader.d.ts.map +0 -1
  144. package/dist/lib/config-sync/adapters/claude.d.ts.map +0 -1
  145. package/dist/lib/config-sync/adapters/codex.d.ts.map +0 -1
  146. package/dist/lib/config-sync/adapters/copilot.d.ts.map +0 -1
  147. package/dist/lib/config-sync/adapters/gemini.d.ts.map +0 -1
  148. package/dist/lib/config-sync/adapters/index.d.ts.map +0 -1
  149. package/dist/lib/config-sync/adapters/opencode.d.ts.map +0 -1
  150. package/dist/lib/config-sync/index.d.ts.map +0 -1
  151. package/dist/lib/config-sync/types.d.ts.map +0 -1
  152. package/dist/lib/config-sync/writer.d.ts.map +0 -1
  153. package/dist/lib/content-sync/index.d.ts.map +0 -1
  154. package/dist/lib/content-sync/types.d.ts.map +0 -1
  155. package/dist/lib/contracts.d.ts.map +0 -1
  156. package/dist/lib/convex.d.ts.map +0 -1
  157. package/dist/lib/device.d.ts.map +0 -1
  158. package/dist/lib/digest/index.d.ts.map +0 -1
  159. package/dist/lib/docs/lint.d.ts.map +0 -1
  160. package/dist/lib/docs/lint.test.d.ts +0 -1
  161. package/dist/lib/docs/lint.test.js +0 -120
  162. package/dist/lib/docs/sync.d.ts.map +0 -1
  163. package/dist/lib/doctor/index.d.ts.map +0 -1
  164. package/dist/lib/doctor/repos.d.ts.map +0 -1
  165. package/dist/lib/doctor/templates.d.ts.map +0 -1
  166. package/dist/lib/errors.d.ts.map +0 -1
  167. package/dist/lib/events.d.ts.map +0 -1
  168. package/dist/lib/heartbeat.d.ts.map +0 -1
  169. package/dist/lib/heartbeat.test.d.ts +0 -1
  170. package/dist/lib/heartbeat.test.js +0 -124
  171. package/dist/lib/hooks/adapters/claude.d.ts.map +0 -1
  172. package/dist/lib/hooks/adapters/codex.d.ts.map +0 -1
  173. package/dist/lib/hooks/adapters/copilot.d.ts.map +0 -1
  174. package/dist/lib/hooks/context.d.ts.map +0 -1
  175. package/dist/lib/hooks/index.d.ts.map +0 -1
  176. package/dist/lib/hooks/registry.d.ts.map +0 -1
  177. package/dist/lib/hooks/runner.d.ts.map +0 -1
  178. package/dist/lib/hooks/types.d.ts.map +0 -1
  179. package/dist/lib/index.test.d.ts +0 -1
  180. package/dist/lib/index.test.js +0 -334
  181. package/dist/lib/managed-session.d.ts.map +0 -1
  182. package/dist/lib/math.d.ts.map +0 -1
  183. package/dist/lib/math.test.d.ts +0 -1
  184. package/dist/lib/math.test.js +0 -238
  185. package/dist/lib/ngrok.d.ts.map +0 -1
  186. package/dist/lib/nvim/discovery.d.ts.map +0 -1
  187. package/dist/lib/nvim/discovery.test.d.ts +0 -1
  188. package/dist/lib/nvim/discovery.test.js +0 -131
  189. package/dist/lib/nvim/index.d.ts.map +0 -1
  190. package/dist/lib/nvim/remote.d.ts.map +0 -1
  191. package/dist/lib/nvim/remote.test.d.ts +0 -1
  192. package/dist/lib/nvim/remote.test.js +0 -18
  193. package/dist/lib/panes/broker.d.ts.map +0 -1
  194. package/dist/lib/panes/index.d.ts.map +0 -1
  195. package/dist/lib/panes/server.d.ts.map +0 -1
  196. package/dist/lib/preview/detect.d.ts.map +0 -1
  197. package/dist/lib/preview/index.d.ts.map +0 -1
  198. package/dist/lib/preview/manager.d.ts.map +0 -1
  199. package/dist/lib/preview/schema.d.ts.map +0 -1
  200. package/dist/lib/preview/sprite.d.ts.map +0 -1
  201. package/dist/lib/preview/watcher.d.ts.map +0 -1
  202. package/dist/lib/process/index.d.ts.map +0 -1
  203. package/dist/lib/process/snapshot.d.ts.map +0 -1
  204. package/dist/lib/process/snapshot.test.d.ts +0 -1
  205. package/dist/lib/process/snapshot.test.js +0 -127
  206. package/dist/lib/project-identity.d.ts.map +0 -1
  207. package/dist/lib/provider-auth.d.ts.map +0 -1
  208. package/dist/lib/references.d.ts.map +0 -1
  209. package/dist/lib/report.d.ts.map +0 -1
  210. package/dist/lib/resources.d.ts.map +0 -1
  211. package/dist/lib/resources.test.d.ts +0 -1
  212. package/dist/lib/resources.test.js +0 -94
  213. package/dist/lib/runner.d.ts.map +0 -1
  214. package/dist/lib/runner.test.d.ts +0 -1
  215. package/dist/lib/runner.test.js +0 -234
  216. package/dist/lib/session-artifacts.d.ts.map +0 -1
  217. package/dist/lib/session-manager.d.ts.map +0 -1
  218. package/dist/lib/session-manager.test.d.ts +0 -1
  219. package/dist/lib/session-manager.test.js +0 -310
  220. package/dist/lib/session-result.d.ts.map +0 -1
  221. package/dist/lib/session-state.d.ts.map +0 -1
  222. package/dist/lib/slack-workspace.d.ts.map +0 -1
  223. package/dist/lib/tmux/bridge.d.ts.map +0 -1
  224. package/dist/lib/tmux/context.d.ts.map +0 -1
  225. package/dist/lib/tmux/context.test.d.ts +0 -1
  226. package/dist/lib/tmux/context.test.js +0 -215
  227. package/dist/lib/tmux/index.d.ts.map +0 -1
  228. package/dist/lib/tmux/map.d.ts.map +0 -1
  229. package/dist/lib/tmux/map.test.d.ts +0 -1
  230. package/dist/lib/tmux/map.test.js +0 -80
  231. package/dist/lib/tmux/panes.d.ts.map +0 -1
  232. package/dist/lib/tmux/redaction.d.ts.map +0 -1
  233. package/dist/lib/tmux/redaction.test.d.ts +0 -1
  234. package/dist/lib/tmux/redaction.test.js +0 -183
  235. package/dist/lib/triage-llm.d.ts.map +0 -1
  236. package/dist/lib/triage-tracker.d.ts.map +0 -1
  237. package/dist/lib/triage.d.ts.map +0 -1
  238. package/dist/lib/types.d.ts.map +0 -1
  239. package/dist/lib/windows/index.d.ts.map +0 -1
  240. package/dist/lib/windows/inventory.d.ts.map +0 -1
  241. package/dist/lib/windows/inventory.test.d.ts +0 -1
  242. package/dist/lib/windows/inventory.test.js +0 -292
  243. package/dist/lib/windows/types.d.ts.map +0 -1
  244. package/dist/lib.d.ts.map +0 -1
  245. package/dist/web/app/@overlay/default.d.ts +0 -1
  246. package/dist/web/app/@overlay/default.js +0 -3
  247. package/dist/web/app/about/page.d.ts +0 -1
  248. package/dist/web/app/about/page.js +0 -6
  249. package/dist/web/app/layout.d.ts +0 -7
  250. package/dist/web/app/layout.js +0 -19
  251. package/dist/web/app/page.d.ts +0 -1
  252. package/dist/web/app/page.js +0 -38
  253. package/dist/web/app/settings/page.d.ts +0 -1
  254. package/dist/web/app/settings/page.js +0 -6
  255. package/dist/web/app/shortcuts/page.d.ts +0 -1
  256. package/dist/web/app/shortcuts/page.js +0 -6
  257. package/dist/web/atoms/sidebar.d.ts +0 -16
  258. package/dist/web/atoms/sidebar.js +0 -58
  259. package/dist/web/atoms/state.d.ts +0 -24
  260. package/dist/web/atoms/state.js +0 -43
  261. package/dist/web/components/command-palette.d.ts +0 -6
  262. package/dist/web/components/command-palette.js +0 -297
  263. package/dist/web/components/main-view.d.ts +0 -1
  264. package/dist/web/components/main-view.js +0 -93
  265. package/dist/web/components/overlay/page-overlay.d.ts +0 -16
  266. package/dist/web/components/overlay/page-overlay.js +0 -84
  267. package/dist/web/components/pane-view.d.ts +0 -5
  268. package/dist/web/components/pane-view.js +0 -168
  269. package/dist/web/components/project-files-view.d.ts +0 -6
  270. package/dist/web/components/project-files-view.js +0 -205
  271. package/dist/web/components/project-planning-view.d.ts +0 -6
  272. package/dist/web/components/project-planning-view.js +0 -146
  273. package/dist/web/components/session-view.d.ts +0 -6
  274. package/dist/web/components/session-view.js +0 -211
  275. package/dist/web/components/sessions-list-view.d.ts +0 -1
  276. package/dist/web/components/sessions-list-view.js +0 -118
  277. package/dist/web/components/sidebar/index.d.ts +0 -9
  278. package/dist/web/components/sidebar/index.js +0 -29
  279. package/dist/web/components/sidebar/kbd.d.ts +0 -17
  280. package/dist/web/components/sidebar/kbd.js +0 -47
  281. package/dist/web/components/sidebar/nav-group.d.ts +0 -22
  282. package/dist/web/components/sidebar/nav-group.js +0 -43
  283. package/dist/web/components/sidebar/nav-item.d.ts +0 -17
  284. package/dist/web/components/sidebar/nav-item.js +0 -38
  285. package/dist/web/components/sidebar/sidebar-header.d.ts +0 -9
  286. package/dist/web/components/sidebar/sidebar-header.js +0 -18
  287. package/dist/web/components/sidebar/sidebar-nav.d.ts +0 -7
  288. package/dist/web/components/sidebar/sidebar-nav.js +0 -505
  289. package/dist/web/components/sidebar/sidebar-search.d.ts +0 -7
  290. package/dist/web/components/sidebar/sidebar-search.js +0 -18
  291. package/dist/web/components/sidebar/sidebar-settings.d.ts +0 -4
  292. package/dist/web/components/sidebar/sidebar-settings.js +0 -28
  293. package/dist/web/components/sidebar/sidebar-transition.d.ts +0 -12
  294. package/dist/web/components/sidebar/sidebar-transition.js +0 -58
  295. package/dist/web/components/status-bar.d.ts +0 -1
  296. package/dist/web/components/status-bar.js +0 -53
  297. package/dist/web/components/terminal.d.ts +0 -4
  298. package/dist/web/components/terminal.js +0 -324
  299. package/dist/web/components/toast.d.ts +0 -7
  300. package/dist/web/components/toast.js +0 -72
  301. package/dist/web/hooks/use-keybindings.d.ts +0 -30
  302. package/dist/web/hooks/use-keybindings.js +0 -322
  303. package/dist/web/hooks/use-state.d.ts +0 -11
  304. package/dist/web/hooks/use-state.js +0 -84
  305. package/dist/web/lib/api.d.ts +0 -179
  306. package/dist/web/lib/api.js +0 -79
  307. package/dist/web/lib/paths.d.ts +0 -2
  308. package/dist/web/lib/paths.js +0 -26
  309. package/dist/web/lib/utils.d.ts +0 -2
  310. package/dist/web/lib/utils.js +0 -5
  311. package/dist/web/lib/ws.d.ts +0 -18
  312. package/dist/web/lib/ws.js +0 -138
  313. package/dist/web/next.config.d.ts +0 -3
  314. package/dist/web/next.config.js +0 -9
  315. package/scripts/generate-manifest.ts +0 -44
  316. package/src/cli/base-command.ts +0 -233
  317. package/src/cli/commands/__tests__/annotations.test.ts +0 -704
  318. package/src/cli/commands/__tests__/bridge.test.ts +0 -101
  319. package/src/cli/commands/__tests__/daemon.test.ts +0 -79
  320. package/src/cli/commands/agent/list.ts +0 -75
  321. package/src/cli/commands/annotation/ack.ts +0 -37
  322. package/src/cli/commands/annotation/create.ts +0 -67
  323. package/src/cli/commands/annotation/events.ts +0 -63
  324. package/src/cli/commands/annotation/export.ts +0 -67
  325. package/src/cli/commands/annotation/import.ts +0 -98
  326. package/src/cli/commands/annotation/ingest.ts +0 -112
  327. package/src/cli/commands/annotation/list.ts +0 -57
  328. package/src/cli/commands/annotation/reply.ts +0 -46
  329. package/src/cli/commands/annotation/resolve.ts +0 -37
  330. package/src/cli/commands/auto/index.ts +0 -755
  331. package/src/cli/commands/backlog/add.ts +0 -74
  332. package/src/cli/commands/backlog/claim.ts +0 -53
  333. package/src/cli/commands/backlog/complete.ts +0 -51
  334. package/src/cli/commands/backlog/list.ts +0 -107
  335. package/src/cli/commands/backlog/pick.ts +0 -50
  336. package/src/cli/commands/backlog/sync.ts +0 -131
  337. package/src/cli/commands/bootstrap.ts +0 -205
  338. package/src/cli/commands/bridge.ts +0 -233
  339. package/src/cli/commands/context/inject.ts +0 -103
  340. package/src/cli/commands/context/list.ts +0 -112
  341. package/src/cli/commands/context/publish.ts +0 -83
  342. package/src/cli/commands/context/read.ts +0 -85
  343. package/src/cli/commands/daemon.ts +0 -1809
  344. package/src/cli/commands/digest/index.ts +0 -245
  345. package/src/cli/commands/docs/lint.ts +0 -93
  346. package/src/cli/commands/docs/sync.ts +0 -90
  347. package/src/cli/commands/doctor.ts +0 -267
  348. package/src/cli/commands/find/index.ts +0 -313
  349. package/src/cli/commands/history/index.ts +0 -269
  350. package/src/cli/commands/hooks/guard.ts +0 -71
  351. package/src/cli/commands/hooks/list.ts +0 -139
  352. package/src/cli/commands/hooks/lock.ts +0 -47
  353. package/src/cli/commands/hooks/status.ts +0 -56
  354. package/src/cli/commands/hooks/test.ts +0 -190
  355. package/src/cli/commands/hooks/unlock.ts +0 -56
  356. package/src/cli/commands/list.e2e.test.ts +0 -58
  357. package/src/cli/commands/list.ts +0 -96
  358. package/src/cli/commands/login.ts +0 -236
  359. package/src/cli/commands/logout.ts +0 -45
  360. package/src/cli/commands/panes/broker.ts +0 -68
  361. package/src/cli/commands/panes/pipe-sink.ts +0 -101
  362. package/src/cli/commands/panes/snapshot.ts +0 -156
  363. package/src/cli/commands/plan.e2e.test.ts +0 -90
  364. package/src/cli/commands/plan.ts +0 -68
  365. package/src/cli/commands/preview/index.ts +0 -282
  366. package/src/cli/commands/preview/list.ts +0 -116
  367. package/src/cli/commands/preview/status.ts +0 -137
  368. package/src/cli/commands/preview/stop.ts +0 -165
  369. package/src/cli/commands/project/add.ts +0 -110
  370. package/src/cli/commands/project/list.ts +0 -136
  371. package/src/cli/commands/project/remove.ts +0 -60
  372. package/src/cli/commands/push.ts +0 -115
  373. package/src/cli/commands/reference/add.ts +0 -266
  374. package/src/cli/commands/reference/delete.ts +0 -67
  375. package/src/cli/commands/reference/extract.ts +0 -389
  376. package/src/cli/commands/reference/list.ts +0 -117
  377. package/src/cli/commands/reference/normalize.ts +0 -90
  378. package/src/cli/commands/reference/open.ts +0 -92
  379. package/src/cli/commands/reference/save.ts +0 -103
  380. package/src/cli/commands/reference/search.ts +0 -85
  381. package/src/cli/commands/reference/show.ts +0 -174
  382. package/src/cli/commands/reference/update-index.ts +0 -103
  383. package/src/cli/commands/reference/update.ts +0 -136
  384. package/src/cli/commands/report/blocked.ts +0 -165
  385. package/src/cli/commands/report/complete.ts +0 -179
  386. package/src/cli/commands/report/progress.ts +0 -142
  387. package/src/cli/commands/report/start.ts +0 -140
  388. package/src/cli/commands/resource/acquire.ts +0 -116
  389. package/src/cli/commands/resource/list.ts +0 -77
  390. package/src/cli/commands/resource/release.ts +0 -64
  391. package/src/cli/commands/resource/wait.ts +0 -93
  392. package/src/cli/commands/review.ts +0 -105
  393. package/src/cli/commands/session/attach.ts +0 -200
  394. package/src/cli/commands/session/await.ts +0 -83
  395. package/src/cli/commands/session/complete.ts +0 -100
  396. package/src/cli/commands/session/create.ts +0 -92
  397. package/src/cli/commands/session/heartbeat.ts +0 -63
  398. package/src/cli/commands/session/list.ts +0 -281
  399. package/src/cli/commands/session/mark-done.ts +0 -132
  400. package/src/cli/commands/session/mine.ts +0 -189
  401. package/src/cli/commands/session/replay.ts +0 -659
  402. package/src/cli/commands/session/run.ts +0 -44
  403. package/src/cli/commands/session/show.ts +0 -177
  404. package/src/cli/commands/session/start.ts +0 -580
  405. package/src/cli/commands/session/state/cleanup.ts +0 -61
  406. package/src/cli/commands/session/state/end.ts +0 -47
  407. package/src/cli/commands/session/state/get.ts +0 -65
  408. package/src/cli/commands/session/state/init.ts +0 -50
  409. package/src/cli/commands/session/state/list.ts +0 -68
  410. package/src/cli/commands/session/state/update.ts +0 -108
  411. package/src/cli/commands/session/stop.ts +0 -134
  412. package/src/cli/commands/session/view.ts +0 -186
  413. package/src/cli/commands/start.ts +0 -256
  414. package/src/cli/commands/state/dump.ts +0 -449
  415. package/src/cli/commands/status.ts +0 -244
  416. package/src/cli/commands/sync.ts +0 -174
  417. package/src/cli/commands/trace/export.ts +0 -255
  418. package/src/cli/commands/triage/claim.ts +0 -203
  419. package/src/cli/commands/triage/list.ts +0 -137
  420. package/src/cli/commands/triage/next.ts +0 -73
  421. package/src/cli/commands/triage/pull.ts +0 -97
  422. package/src/cli/commands/triage/stats.ts +0 -82
  423. package/src/cli/commands/tunnel/list.ts +0 -113
  424. package/src/cli/commands/tunnel/start.ts +0 -122
  425. package/src/cli/commands/tunnel/stop.ts +0 -108
  426. package/src/cli/commands/tunnel/url.ts +0 -82
  427. package/src/cli/commands/web/start.ts +0 -125
  428. package/src/cli/commands/windows/context.ts +0 -439
  429. package/src/cli/commands/windows/focus.ts +0 -130
  430. package/src/cli/commands/windows/list.ts +0 -213
  431. package/src/cli/commands/windows/map.ts +0 -223
  432. package/src/cli/commands/windows/read.ts +0 -279
  433. package/src/cli/commands/windows/search.ts +0 -219
  434. package/src/cli/commands/windows/show.ts +0 -188
  435. package/src/cli/commands/windows/watch.ts +0 -262
  436. package/src/lib/__tests__/annotations-convex.test.ts +0 -104
  437. package/src/lib/active-sessions.ts +0 -1486
  438. package/src/lib/agent-adapters.ts +0 -412
  439. package/src/lib/agent-sessions.ts +0 -671
  440. package/src/lib/agent-trace.test.ts +0 -296
  441. package/src/lib/agent-trace.ts +0 -513
  442. package/src/lib/analytics.ts +0 -178
  443. package/src/lib/annotations-convex.ts +0 -296
  444. package/src/lib/annotations.test.ts +0 -274
  445. package/src/lib/annotations.ts +0 -836
  446. package/src/lib/auto/discover.ts +0 -545
  447. package/src/lib/auto/ideate.ts +0 -412
  448. package/src/lib/auto/spawn.ts +0 -549
  449. package/src/lib/auto/workspace.ts +0 -282
  450. package/src/lib/backlog.test.ts +0 -194
  451. package/src/lib/backlog.ts +0 -428
  452. package/src/lib/config-loader.ts +0 -391
  453. package/src/lib/config-sync/adapters/claude.ts +0 -91
  454. package/src/lib/config-sync/adapters/codex.ts +0 -135
  455. package/src/lib/config-sync/adapters/copilot.ts +0 -98
  456. package/src/lib/config-sync/adapters/gemini.ts +0 -86
  457. package/src/lib/config-sync/adapters/index.ts +0 -39
  458. package/src/lib/config-sync/adapters/opencode.ts +0 -94
  459. package/src/lib/config-sync/index.ts +0 -399
  460. package/src/lib/config-sync/types.ts +0 -92
  461. package/src/lib/config-sync/writer.ts +0 -188
  462. package/src/lib/content-sync/index.ts +0 -882
  463. package/src/lib/content-sync/types.ts +0 -104
  464. package/src/lib/contracts.test.ts +0 -186
  465. package/src/lib/contracts.ts +0 -195
  466. package/src/lib/convex.ts +0 -54
  467. package/src/lib/device.ts +0 -41
  468. package/src/lib/digest/index.ts +0 -529
  469. package/src/lib/docs/lint.test.ts +0 -135
  470. package/src/lib/docs/lint.ts +0 -310
  471. package/src/lib/docs/sync.ts +0 -184
  472. package/src/lib/doctor/index.ts +0 -647
  473. package/src/lib/doctor/repos.ts +0 -381
  474. package/src/lib/doctor/templates.ts +0 -191
  475. package/src/lib/errors.ts +0 -111
  476. package/src/lib/events.ts +0 -479
  477. package/src/lib/heartbeat.test.ts +0 -164
  478. package/src/lib/heartbeat.ts +0 -326
  479. package/src/lib/hooks/adapters/claude.ts +0 -115
  480. package/src/lib/hooks/adapters/codex.ts +0 -92
  481. package/src/lib/hooks/adapters/copilot.ts +0 -141
  482. package/src/lib/hooks/context.ts +0 -174
  483. package/src/lib/hooks/index.ts +0 -39
  484. package/src/lib/hooks/registry.ts +0 -101
  485. package/src/lib/hooks/runner.ts +0 -208
  486. package/src/lib/hooks/types.ts +0 -89
  487. package/src/lib/index.test.ts +0 -426
  488. package/src/lib/managed-session.ts +0 -117
  489. package/src/lib/math.test.ts +0 -299
  490. package/src/lib/math.ts +0 -120
  491. package/src/lib/ngrok.ts +0 -441
  492. package/src/lib/nvim/discovery.test.ts +0 -157
  493. package/src/lib/nvim/discovery.ts +0 -181
  494. package/src/lib/nvim/index.ts +0 -28
  495. package/src/lib/nvim/remote.test.ts +0 -21
  496. package/src/lib/nvim/remote.ts +0 -184
  497. package/src/lib/panes/README.md +0 -20
  498. package/src/lib/panes/broker.ts +0 -261
  499. package/src/lib/panes/index.ts +0 -1
  500. package/src/lib/panes/server.ts +0 -379
  501. package/src/lib/preview/detect.ts +0 -184
  502. package/src/lib/preview/index.ts +0 -1
  503. package/src/lib/process/index.ts +0 -16
  504. package/src/lib/process/snapshot.test.ts +0 -188
  505. package/src/lib/process/snapshot.ts +0 -257
  506. package/src/lib/provider-auth.ts +0 -258
  507. package/src/lib/references.ts +0 -481
  508. package/src/lib/report.ts +0 -973
  509. package/src/lib/resources.test.ts +0 -132
  510. package/src/lib/resources.ts +0 -429
  511. package/src/lib/runner.test.ts +0 -288
  512. package/src/lib/runner.ts +0 -1223
  513. package/src/lib/session-artifacts.test.ts +0 -107
  514. package/src/lib/session-artifacts.ts +0 -193
  515. package/src/lib/session-manager.test.ts +0 -402
  516. package/src/lib/session-manager.ts +0 -150
  517. package/src/lib/session-result.test.ts +0 -98
  518. package/src/lib/session-result.ts +0 -262
  519. package/src/lib/session-state.ts +0 -470
  520. package/src/lib/slack-workspace.ts +0 -25
  521. package/src/lib/tmux/bridge.ts +0 -439
  522. package/src/lib/tmux/context.test.ts +0 -242
  523. package/src/lib/tmux/context.ts +0 -380
  524. package/src/lib/tmux/index.ts +0 -46
  525. package/src/lib/tmux/map.test.ts +0 -99
  526. package/src/lib/tmux/map.ts +0 -252
  527. package/src/lib/tmux/panes.ts +0 -170
  528. package/src/lib/tmux/redaction.test.ts +0 -231
  529. package/src/lib/tmux/redaction.ts +0 -201
  530. package/src/lib/triage-llm.ts +0 -312
  531. package/src/lib/triage-tracker.ts +0 -400
  532. package/src/lib/triage.ts +0 -655
  533. package/src/lib/types.ts +0 -61
  534. package/src/lib/windows/index.ts +0 -2
  535. package/src/lib/windows/inventory.test.ts +0 -370
  536. package/src/lib/windows/inventory.ts +0 -352
  537. package/src/lib/windows/types.ts +0 -46
  538. 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
- });