@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,211 +0,0 @@
1
- 'use client';
2
- import { useState } from 'react';
3
- import { useAtom } from 'jotai';
4
- import { Tooltip } from '@base-ui-components/react/tooltip';
5
- import { Robot, Folder, Clock, Hash, Stop, CircleNotch, CheckCircle, XCircle, Terminal, GitBranch, Circle, Copy, ArrowSquareOut, SidebarSimple, } from '@phosphor-icons/react';
6
- import { cn } from '@/lib/utils';
7
- import { api } from '@/lib/api';
8
- import { sidebarCollapsedAtom } from '@/atoms/state';
9
- import { formatDisplayPath } from '@/lib/paths';
10
- // Agent color mapping
11
- const AGENT_COLORS = {
12
- claude: { bg: 'bg-agent-claude/15', text: 'text-agent-claude', icon: '🐙' },
13
- codex: { bg: 'bg-agent-codex/15', text: 'text-agent-codex', icon: '🦉' },
14
- copilot: { bg: 'bg-agent-copilot/15', text: 'text-agent-copilot', icon: '🐕' },
15
- gemini: { bg: 'bg-agent-gemini/15', text: 'text-agent-gemini', icon: '🦊' },
16
- };
17
- function StatusIndicator({ status }) {
18
- const config = {
19
- running: { color: 'bg-success', label: 'Running', animate: true },
20
- completed: { color: 'bg-success', label: 'Completed', animate: false },
21
- failed: { color: 'bg-destructive', label: 'Failed', animate: false },
22
- stopped: { color: 'bg-foreground-quaternary', label: 'Stopped', animate: false },
23
- }[status];
24
- return (<div className="flex items-center gap-2">
25
- <span className={cn('h-2 w-2 rounded-full', config.color, config.animate && 'animate-pulse')}/>
26
- <span className="text-xs font-medium text-foreground-secondary">{config.label}</span>
27
- </div>);
28
- }
29
- function InfoCard({ children, className }) {
30
- return (<div className={cn('rounded-xl border border-border/60 bg-card/50 p-4', className)}>
31
- {children}
32
- </div>);
33
- }
34
- function DetailItem({ icon, label, value, mono = false, copyable = false }) {
35
- const [copied, setCopied] = useState(false);
36
- const handleCopy = async () => {
37
- await navigator.clipboard.writeText(value);
38
- setCopied(true);
39
- setTimeout(() => setCopied(false), 1500);
40
- };
41
- return (<div className="flex items-start gap-3 py-2.5 first:pt-0 last:pb-0">
42
- <div className="mt-0.5 flex h-5 w-5 items-center justify-center text-foreground-tertiary">
43
- {icon}
44
- </div>
45
- <div className="min-w-0 flex-1">
46
- <div className="text-[10px] font-medium uppercase tracking-wider text-foreground-quaternary">
47
- {label}
48
- </div>
49
- <div className="mt-1 flex items-center gap-2">
50
- <span className={cn('text-sm text-foreground', mono && 'font-mono text-xs')}>
51
- {value}
52
- </span>
53
- {copyable && (<button onClick={handleCopy} className={cn('flex h-5 w-5 items-center justify-center rounded text-foreground-quaternary', 'outline-none transition-colors duration-150 hover:duration-0', 'hover:bg-background-tertiary hover:text-foreground-secondary', copied && 'text-success')}>
54
- {copied ? <CheckCircle className="h-3 w-3" weight="fill"/> : <Copy className="h-3 w-3"/>}
55
- </button>)}
56
- </div>
57
- </div>
58
- </div>);
59
- }
60
- export function SessionView({ session }) {
61
- const [stopping, setStopping] = useState(false);
62
- const [sidebarCollapsed, setSidebarCollapsed] = useAtom(sidebarCollapsedAtom);
63
- const handleStop = async (force = false) => {
64
- setStopping(true);
65
- try {
66
- await api.stopSession(session.session_id, force);
67
- }
68
- catch (e) {
69
- console.error('Failed to stop session:', e);
70
- }
71
- finally {
72
- setStopping(false);
73
- }
74
- };
75
- const startedAt = new Date(session.started_at);
76
- const formattedDate = startedAt.toLocaleDateString('en-US', {
77
- weekday: 'short',
78
- month: 'short',
79
- day: 'numeric',
80
- hour: 'numeric',
81
- minute: '2-digit',
82
- });
83
- const duration = Date.now() - startedAt.getTime();
84
- const durationStr = duration < 60000
85
- ? `${Math.floor(duration / 1000)}s`
86
- : duration < 3600000
87
- ? `${Math.floor(duration / 60000)}m`
88
- : `${Math.floor(duration / 3600000)}h ${Math.floor((duration % 3600000) / 60000)}m`;
89
- const agentConfig = AGENT_COLORS[session.agent] || AGENT_COLORS.copilot;
90
- return (<div className="relative flex h-full flex-col bg-background">
91
- {/* Header with toggle */}
92
- <div className="flex h-12 shrink-0 items-center px-4">
93
- <Tooltip.Provider delay={300} closeDelay={0}>
94
- <Tooltip.Root>
95
- <Tooltip.Trigger render={<button onClick={() => setSidebarCollapsed(!sidebarCollapsed)} className={cn('flex h-7 w-7 items-center justify-center rounded-full', 'outline-none', 'bg-background-tertiary text-foreground-secondary', 'hover:bg-background-elevated hover:text-foreground')}>
96
- <SidebarSimple className="h-3.5 w-3.5"/>
97
- </button>}/>
98
- <Tooltip.Portal>
99
- <Tooltip.Positioner side="bottom" sideOffset={6}>
100
- <Tooltip.Popup className={cn('z-50 rounded-md px-2 py-1', 'bg-background-secondary border border-border', 'text-xs text-foreground-secondary', 'shadow-lg', 'origin-[var(--transform-origin)]', 'transition-[transform,opacity] duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', 'data-[instant]:duration-0', 'data-[starting-style]:scale-[0.96] data-[starting-style]:opacity-0', 'data-[ending-style]:scale-[0.96] data-[ending-style]:opacity-0')}>
101
- {sidebarCollapsed ? 'Show sidebar' : 'Hide sidebar'}
102
- </Tooltip.Popup>
103
- </Tooltip.Positioner>
104
- </Tooltip.Portal>
105
- </Tooltip.Root>
106
- </Tooltip.Provider>
107
- </div>
108
-
109
- {/* Floating header */}
110
- <div className="absolute left-4 right-4 top-14 z-20">
111
- <div className={cn('flex h-11 items-center justify-between rounded-xl px-3', 'border border-border/60 bg-card/90 shadow-lg backdrop-blur-md')}>
112
- {/* Left: Session info */}
113
- <div className="flex items-center gap-2.5">
114
- <div className={cn('flex h-6 w-6 items-center justify-center rounded-md text-sm', agentConfig.bg)}>
115
- {agentConfig.icon}
116
- </div>
117
- <div className="flex items-center gap-2">
118
- <span className="text-sm font-medium text-foreground">{session.project}</span>
119
- <span className="text-xs text-foreground-quaternary">·</span>
120
- <span className={cn('text-xs font-medium', agentConfig.text)}>{session.agent}</span>
121
- </div>
122
- </div>
123
-
124
- {/* Right: Status + actions */}
125
- <div className="flex items-center gap-3">
126
- <StatusIndicator status={session.status}/>
127
- {session.status === 'running' && (<>
128
- <div className="h-4 w-px bg-border/60"/>
129
- <button onClick={() => handleStop()} disabled={stopping} className={cn('flex items-center gap-1.5 rounded-lg px-2 py-1 text-xs font-medium', 'bg-destructive/15 text-destructive', 'outline-none transition-colors duration-150 hover:duration-0 hover:bg-destructive/25')}>
130
- {stopping ? (<CircleNotch className="h-3 w-3 animate-spin"/>) : (<Stop className="h-3 w-3" weight="fill"/>)}
131
- {stopping ? 'Stopping...' : 'Stop'}
132
- </button>
133
- </>)}
134
- </div>
135
- </div>
136
- </div>
137
-
138
- {/* Content */}
139
- <div className="h-full overflow-auto px-4 pb-4 pt-16">
140
- <div className="mx-auto max-w-2xl space-y-4">
141
- {/* Goal card - prominent */}
142
- <InfoCard className="bg-card">
143
- <div className="flex items-start gap-3">
144
- <div className="mt-1 flex h-8 w-8 items-center justify-center rounded-lg bg-primary/10">
145
- <Robot className="h-4 w-4 text-primary"/>
146
- </div>
147
- <div className="flex-1">
148
- <div className="text-[10px] font-medium uppercase tracking-wider text-foreground-quaternary">
149
- Goal
150
- </div>
151
- <p className="mt-2 text-sm leading-relaxed text-foreground">
152
- {session.goal}
153
- </p>
154
- </div>
155
- </div>
156
- </InfoCard>
157
-
158
- {/* Session details */}
159
- <InfoCard>
160
- <div className="divide-y divide-border/40">
161
- <DetailItem icon={<Hash className="h-4 w-4"/>} label="Session ID" value={session.session_id} mono copyable/>
162
- <DetailItem icon={<Folder className="h-4 w-4"/>} label="Working Directory" value={formatDisplayPath(session.cwd)} mono/>
163
- <DetailItem icon={<Clock className="h-4 w-4"/>} label="Started" value={`${formattedDate} (${durationStr} ago)`}/>
164
- {session.issue && (<DetailItem icon={<GitBranch className="h-4 w-4"/>} label="Linear Issue" value={session.issue} copyable/>)}
165
- {session.trace_id && (<DetailItem icon={<Hash className="h-4 w-4"/>} label="Trace ID" value={session.trace_id} mono copyable/>)}
166
- </div>
167
- </InfoCard>
168
-
169
- {/* Exit status (if completed/failed) */}
170
- {session.exit_code !== undefined && (<InfoCard className={cn(session.exit_code === 0 ? 'border-success/30 bg-success/5' : 'border-destructive/30 bg-destructive/5')}>
171
- <div className="flex items-center gap-3">
172
- {session.exit_code === 0 ? (<CheckCircle className="h-5 w-5 text-success" weight="fill"/>) : (<XCircle className="h-5 w-5 text-destructive" weight="fill"/>)}
173
- <div>
174
- <div className="text-sm font-medium text-foreground">
175
- {session.exit_code === 0 ? 'Completed successfully' : 'Exited with error'}
176
- </div>
177
- <div className="text-xs text-foreground-secondary">
178
- Exit code: <code className="font-mono">{session.exit_code}</code>
179
- </div>
180
- </div>
181
- </div>
182
- </InfoCard>)}
183
-
184
- {/* Quick actions */}
185
- <div className="flex items-center gap-2 pt-2">
186
- <button className={cn('flex items-center gap-1.5 rounded-lg px-3 py-1.5 text-xs font-medium', 'bg-background-tertiary text-foreground-secondary', 'outline-none transition-colors duration-150 hover:duration-0', 'hover:bg-background-elevated hover:text-foreground')}>
187
- <Terminal className="h-3.5 w-3.5"/>
188
- View Output
189
- </button>
190
- <button className={cn('flex items-center gap-1.5 rounded-lg px-3 py-1.5 text-xs font-medium', 'bg-background-tertiary text-foreground-secondary', 'outline-none transition-colors duration-150 hover:duration-0', 'hover:bg-background-elevated hover:text-foreground')}>
191
- <ArrowSquareOut className="h-3.5 w-3.5"/>
192
- Open in VS Code
193
- </button>
194
- </div>
195
- </div>
196
- </div>
197
-
198
- {/* Status bar */}
199
- <div className="absolute bottom-0 left-0 right-0 flex h-7 items-center justify-between border-t border-border/40 bg-background/90 px-4 text-[10px] backdrop-blur-sm">
200
- <div className="flex items-center gap-3 text-foreground-quaternary">
201
- <span>PID: <code className="font-mono">{session.pid}</code></span>
202
- </div>
203
- <div className="flex items-center gap-2 text-foreground-quaternary">
204
- {session.status === 'running' && (<span className="flex items-center gap-1.5">
205
- <Circle className="h-1.5 w-1.5 animate-pulse text-success" weight="fill"/>
206
- Active
207
- </span>)}
208
- </div>
209
- </div>
210
- </div>);
211
- }
@@ -1 +0,0 @@
1
- export declare function SessionsListView(): any;
@@ -1,118 +0,0 @@
1
- 'use client';
2
- import { useMemo, useState } from 'react';
3
- import { useAtom, useAtomValue, useSetAtom } from 'jotai';
4
- import { Tooltip } from '@base-ui-components/react/tooltip';
5
- import { Circle, MagnifyingGlass, SidebarSimple, } from '@phosphor-icons/react';
6
- import { cn } from '@/lib/utils';
7
- import { formatDisplayPath } from '@/lib/paths';
8
- import { projectsAtom, selectedProjectAtom, selectedSessionIdAtom, sessionsAtom, sidebarCollapsedAtom, } from '@/atoms/state';
9
- function formatTime(iso) {
10
- const date = new Date(iso);
11
- return date.toLocaleTimeString('en-US', {
12
- hour: 'numeric',
13
- minute: '2-digit',
14
- });
15
- }
16
- export function SessionsListView() {
17
- const sessions = useAtomValue(sessionsAtom);
18
- const projects = useAtomValue(projectsAtom);
19
- const setSelectedSessionId = useSetAtom(selectedSessionIdAtom);
20
- const setSelectedProject = useSetAtom(selectedProjectAtom);
21
- const [sidebarCollapsed, setSidebarCollapsed] = useAtom(sidebarCollapsedAtom);
22
- const [query, setQuery] = useState('');
23
- const filtered = useMemo(() => {
24
- const q = query.trim().toLowerCase();
25
- const items = [...sessions].sort((a, b) => b.started_at.localeCompare(a.started_at));
26
- if (!q)
27
- return items;
28
- return items.filter((s) => {
29
- return (s.project.toLowerCase().includes(q) ||
30
- s.goal.toLowerCase().includes(q) ||
31
- s.agent.toLowerCase().includes(q) ||
32
- (s.issue ?? '').toLowerCase().includes(q));
33
- });
34
- }, [sessions, query]);
35
- return (<div className="flex h-full flex-col bg-background-secondary">
36
- {/* Header */}
37
- <div className="grid h-12 shrink-0 grid-cols-[1fr_auto_1fr] items-center px-4">
38
- <Tooltip.Provider delay={300} closeDelay={0}>
39
- <div className="flex items-center justify-start gap-1.5">
40
- <Tooltip.Root>
41
- <Tooltip.Trigger render={<button onClick={() => setSidebarCollapsed(!sidebarCollapsed)} className={cn('flex h-7 w-7 items-center justify-center rounded-full', 'outline-none', 'bg-background-tertiary text-foreground-secondary', 'hover:bg-background-elevated hover:text-foreground')}>
42
- <SidebarSimple className="h-3.5 w-3.5"/>
43
- </button>}/>
44
- <Tooltip.Portal>
45
- <Tooltip.Positioner side="bottom" sideOffset={6}>
46
- <Tooltip.Popup className={cn('z-50 rounded-md px-2 py-1', 'bg-background-secondary border border-border', 'text-xs text-foreground-secondary', 'shadow-lg', 'origin-[var(--transform-origin)]', 'transition-[transform,opacity] duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', 'data-[instant]:duration-0', 'data-[starting-style]:scale-[0.96] data-[starting-style]:opacity-0', 'data-[ending-style]:scale-[0.96] data-[ending-style]:opacity-0')}>
47
- {sidebarCollapsed ? 'Show sidebar' : 'Hide sidebar'}
48
- </Tooltip.Popup>
49
- </Tooltip.Positioner>
50
- </Tooltip.Portal>
51
- </Tooltip.Root>
52
- </div>
53
- </Tooltip.Provider>
54
-
55
- <span className="text-sm font-medium text-foreground">Sessions</span>
56
- <div />
57
- </div>
58
-
59
- {/* Search */}
60
- <div className="px-4 pb-3">
61
- <div className={cn('flex items-center gap-2 rounded-full px-3 py-2', 'bg-background-tertiary text-foreground-secondary', 'border border-border/60')}>
62
- <MagnifyingGlass className="h-4 w-4 text-foreground-tertiary"/>
63
- <input value={query} onChange={(e) => setQuery(e.target.value)} placeholder="Search sessions…" className={cn('w-full bg-transparent text-sm text-foreground outline-none', 'placeholder:text-foreground-quaternary')}/>
64
- </div>
65
- </div>
66
-
67
- {/* List */}
68
- <div className="flex-1 overflow-y-auto px-3 pb-4">
69
- {filtered.length === 0 ? (<div className="px-4 py-10 text-center text-sm text-foreground-tertiary">
70
- No sessions found.
71
- </div>) : (<div className="space-y-1">
72
- {filtered.map((session) => {
73
- const emoji = projects.projects[session.project]?.emoji ?? projects.defaultEmoji;
74
- const running = session.status === 'running';
75
- const cwd = formatDisplayPath(session.cwd);
76
- return (<button key={session.session_id} onClick={() => {
77
- setSelectedProject(null);
78
- setSelectedSessionId(session.session_id);
79
- }} className={cn('w-full rounded-2xl px-4 py-3 text-left', 'outline-none', 'bg-background-tertiary/40 hover:bg-background-tertiary', 'transition-colors duration-150 hover:duration-0')}>
80
- <div className="flex items-center gap-3">
81
- <div className="flex h-9 w-9 items-center justify-center rounded-xl bg-background-secondary text-lg">
82
- {emoji}
83
- </div>
84
-
85
- <div className="min-w-0 flex-1">
86
- <div className="truncate text-sm font-medium text-foreground">
87
- {session.goal || session.project}
88
- </div>
89
-
90
- <div className="mt-1 flex items-center justify-between gap-3">
91
- <div className="min-w-0 truncate text-xs text-foreground-tertiary">
92
- {cwd}
93
- </div>
94
- <div className="shrink-0 text-xs text-foreground-tertiary">
95
- {formatTime(session.started_at)}
96
- </div>
97
- </div>
98
-
99
- <div className="mt-1 flex items-center justify-between gap-3">
100
- <div className="truncate text-[11px] text-foreground-quaternary">
101
- {session.project} · {session.agent}
102
- {session.issue ? ` · ${session.issue}` : ''}
103
- </div>
104
- <div className="shrink-0 flex items-center gap-1.5">
105
- <Circle weight="fill" className={cn('h-2 w-2', running ? 'text-success' : 'text-foreground-quaternary')}/>
106
- <span className="text-[11px] text-foreground-quaternary">
107
- {running ? 'Running' : session.status}
108
- </span>
109
- </div>
110
- </div>
111
- </div>
112
- </div>
113
- </button>);
114
- })}
115
- </div>)}
116
- </div>
117
- </div>);
118
- }
@@ -1,9 +0,0 @@
1
- /**
2
- * Main sidebar component combining:
3
- * - Linear-style accordion navigation (projects expand to show sessions)
4
- * - Vercel-style drill-down for settings (blur + slide transitions)
5
- * - When collapsed, completely unmounts (toggle lives in main header)
6
- *
7
- * All list interactions are instant (0ms) for responsive feel.
8
- */
9
- export declare function Sidebar(): any;
@@ -1,29 +0,0 @@
1
- 'use client';
2
- import { useRef } from 'react';
3
- import { useAtomValue } from 'jotai';
4
- import { Tooltip } from '@base-ui-components/react/tooltip';
5
- import { cn } from '@/lib/utils';
6
- import { sidebarCollapsedAtom } from '@/atoms/state';
7
- import { SidebarTransition } from './sidebar-transition';
8
- const SIDEBAR_WIDTH = 260;
9
- /**
10
- * Main sidebar component combining:
11
- * - Linear-style accordion navigation (projects expand to show sessions)
12
- * - Vercel-style drill-down for settings (blur + slide transitions)
13
- * - When collapsed, completely unmounts (toggle lives in main header)
14
- *
15
- * All list interactions are instant (0ms) for responsive feel.
16
- */
17
- export function Sidebar() {
18
- const collapsed = useAtomValue(sidebarCollapsedAtom);
19
- const sidebarRef = useRef(null);
20
- // Don't render sidebar at all when collapsed
21
- if (collapsed) {
22
- return null;
23
- }
24
- return (<Tooltip.Provider delay={300} closeDelay={0}>
25
- <aside ref={sidebarRef} style={{ width: SIDEBAR_WIDTH }} className={cn('relative flex h-full shrink-0 flex-col border-r border-border bg-background')}>
26
- <SidebarTransition />
27
- </aside>
28
- </Tooltip.Provider>);
29
- }
@@ -1,17 +0,0 @@
1
- interface KbdProps {
2
- children: React.ReactNode;
3
- className?: string;
4
- }
5
- /**
6
- * Keyboard shortcut display component.
7
- * Renders keyboard shortcuts in Linear's style: "G then S"
8
- * Always uppercase like Linear.
9
- */
10
- export declare function Kbd({ children, className }: KbdProps): any;
11
- /**
12
- * Compound keyboard shortcut (e.g., "G then S")
13
- */
14
- export declare function KbdSequence({ keys }: {
15
- keys: string[];
16
- }): any;
17
- export {};
@@ -1,47 +0,0 @@
1
- 'use client';
2
- import { cn } from '@/lib/utils';
3
- /**
4
- * Keyboard shortcut display component.
5
- * Renders keyboard shortcuts in Linear's style: "G then S"
6
- * Always uppercase like Linear.
7
- */
8
- export function Kbd({ children, className }) {
9
- // Normalize key display: uppercase, and common aliases
10
- const normalizeKey = (key) => {
11
- if (typeof key !== 'string')
12
- return key;
13
- const aliases = {
14
- escape: 'Esc',
15
- esc: 'Esc',
16
- enter: 'Enter',
17
- return: 'Enter',
18
- space: 'Space',
19
- tab: 'Tab',
20
- backspace: 'Backspace',
21
- delete: 'Del',
22
- arrowup: '↑',
23
- arrowdown: '↓',
24
- arrowleft: '←',
25
- arrowright: '→',
26
- };
27
- const lower = key.toLowerCase();
28
- if (aliases[lower])
29
- return aliases[lower];
30
- // Single chars uppercase, multi-char capitalize first
31
- return key.length === 1 ? key.toUpperCase() : key;
32
- };
33
- return (<kbd className={cn('inline-flex items-center gap-1 rounded-sm px-1.5 py-0.5', 'bg-background-elevated border border-border/60', 'font-mono text-[10px] text-foreground-tertiary', className)}>
34
- {normalizeKey(children)}
35
- </kbd>);
36
- }
37
- /**
38
- * Compound keyboard shortcut (e.g., "G then S")
39
- */
40
- export function KbdSequence({ keys }) {
41
- return (<span className="inline-flex items-center gap-1">
42
- {keys.map((key, i) => (<span key={i} className="inline-flex items-center gap-1">
43
- <Kbd>{key}</Kbd>
44
- {i < keys.length - 1 && (<span className="text-[10px] text-foreground-quaternary">then</span>)}
45
- </span>))}
46
- </span>);
47
- }
@@ -1,22 +0,0 @@
1
- import { Collapsible } from '@base-ui-components/react/collapsible';
2
- interface NavGroupProps {
3
- label: string;
4
- leading?: React.ReactNode;
5
- icon?: React.ReactNode;
6
- expanded: boolean;
7
- onExpandedChange: (expanded: boolean) => void;
8
- triggerProps?: Omit<React.ComponentPropsWithoutRef<typeof Collapsible.Trigger>, 'className' | 'children'>;
9
- dragging?: boolean;
10
- actions?: React.ReactNode;
11
- actionsVisible?: boolean;
12
- children: React.ReactNode;
13
- className?: string;
14
- }
15
- /**
16
- * Collapsible navigation group (Linear accordion pattern).
17
- * Uses Base UI Collapsible for accessibility.
18
- *
19
- * Expansion is instant (list-item UX).
20
- */
21
- export declare function NavGroup({ label, leading, icon, expanded, onExpandedChange, triggerProps, dragging, actions, actionsVisible, children, className, }: NavGroupProps): any;
22
- export {};
@@ -1,43 +0,0 @@
1
- 'use client';
2
- import { Collapsible } from '@base-ui-components/react/collapsible';
3
- import { ChevronDownIcon } from '@heroicons/react/24/outline';
4
- import { cn } from '@/lib/utils';
5
- /**
6
- * Collapsible navigation group (Linear accordion pattern).
7
- * Uses Base UI Collapsible for accessibility.
8
- *
9
- * Expansion is instant (list-item UX).
10
- */
11
- export function NavGroup({ label, leading, icon, expanded, onExpandedChange, triggerProps, dragging, actions, actionsVisible, children, className, }) {
12
- const headerActive = expanded || actionsVisible;
13
- const contentOpacity = dragging ? 'opacity-70' : 'opacity-100';
14
- return (<Collapsible.Root open={expanded} onOpenChange={onExpandedChange} className={className}>
15
- <div className={cn('group flex items-center', headerActive ? 'text-foreground' : 'text-foreground-secondary', 'hover:text-foreground')}>
16
- <Collapsible.Trigger {...triggerProps} className={cn('flex h-7 flex-1 items-center gap-1.5 py-0 pl-2 pr-2 text-left text-sm', 'cursor-grab select-none outline-none transition-none active:cursor-grabbing', dragging && 'cursor-grabbing')}>
17
- {leading && (<span className={cn('shrink-0 transition-opacity duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', dragging ? 'opacity-0' : 'opacity-100')} aria-hidden={dragging ? true : undefined}>
18
- {leading}
19
- </span>)}
20
-
21
- {/* Fixed-width icon container for stable positioning */}
22
- <span className={cn('flex w-5 shrink-0 items-center text-base leading-none', 'transition-opacity duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', contentOpacity)}>
23
- {icon}
24
- </span>
25
- <div className={cn('min-w-0 flex items-center gap-1', 'transition-opacity duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', contentOpacity)}>
26
- <span className="truncate font-medium">{label}</span>
27
- <ChevronDownIcon className={cn('h-3.5 w-3.5 text-foreground-tertiary', 'transition-opacity duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', !expanded && '-rotate-90', dragging ? 'opacity-0' : 'opacity-100')}/>
28
- </div>
29
-
30
- <span className="flex-1"/>
31
- </Collapsible.Trigger>
32
-
33
- {actions && (<div className={cn('shrink-0 pr-2', 'transition-opacity duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', dragging ? 'pointer-events-none opacity-0' : 'opacity-100')}>
34
- {actions}
35
- </div>)}
36
- </div>
37
- <Collapsible.Panel data-collapsible-panel data-state={expanded ? 'open' : 'closed'} className={cn('grid overflow-hidden', 'transition-[grid-template-rows,opacity] duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', dragging ? 'grid-rows-[0fr] opacity-0' : 'grid-rows-[1fr] opacity-100')}>
38
- <div className="overflow-hidden">
39
- <div className="py-1 pl-6 pr-2">{children}</div>
40
- </div>
41
- </Collapsible.Panel>
42
- </Collapsible.Root>);
43
- }
@@ -1,17 +0,0 @@
1
- import * as React from 'react';
2
- interface NavItemProps {
3
- label: string;
4
- icon?: React.ReactNode;
5
- shortcut?: string[];
6
- selected?: boolean;
7
- active?: boolean;
8
- onClick?: () => void;
9
- className?: string;
10
- children?: React.ReactNode;
11
- }
12
- /**
13
- * Single navigation item with optional keyboard shortcut in tooltip.
14
- * Uses Base UI Tooltip for proper positioning and accessibility.
15
- */
16
- export declare function NavItem({ label, icon, shortcut, selected, active, onClick, className, children, }: NavItemProps): any;
17
- export {};
@@ -1,38 +0,0 @@
1
- 'use client';
2
- import * as React from 'react';
3
- import { Tooltip } from '@base-ui-components/react/tooltip';
4
- import { cn } from '@/lib/utils';
5
- /**
6
- * Single navigation item with optional keyboard shortcut in tooltip.
7
- * Uses Base UI Tooltip for proper positioning and accessibility.
8
- */
9
- export function NavItem({ label, icon, shortcut, selected, active, onClick, className, children, }) {
10
- const button = (<button onClick={onClick} data-selected={selected || undefined} data-active={active || undefined} className={cn('flex h-7 w-full items-center gap-2 rounded-[8px] py-0 pl-3 pr-2 text-left text-sm', 'cursor-pointer outline-none transition-none', selected
11
- ? 'bg-background-secondary text-foreground'
12
- : 'text-foreground-secondary hover:bg-background-secondary hover:text-foreground', active && !selected && 'text-foreground', className)}>
13
- {/* Fixed-width icon container for stable positioning */}
14
- <span className="flex w-5 shrink-0 items-center text-base leading-none">
15
- {icon}
16
- </span>
17
- <span className="flex-1 truncate">{label}</span>
18
- {children}
19
- </button>);
20
- if (!shortcut) {
21
- return button;
22
- }
23
- return (<Tooltip.Root>
24
- <Tooltip.Trigger render={button}/>
25
- <Tooltip.Portal>
26
- <Tooltip.Positioner side="right" sideOffset={8}>
27
- <Tooltip.Popup className={cn('z-50 flex items-center gap-1.5 rounded-md px-2 py-1', 'bg-background-secondary border border-border', 'text-xs text-foreground-secondary', 'shadow-lg', 'origin-[var(--transform-origin)]', 'transition-[transform,opacity] duration-100', '[transition-timing-function:cubic-bezier(0.32,0.72,0,1)]', 'data-[instant]:duration-0', 'data-[starting-style]:scale-[0.96] data-[starting-style]:opacity-0', 'data-[ending-style]:scale-[0.96] data-[ending-style]:opacity-0')}>
28
- {shortcut.map((key, i) => (<React.Fragment key={i}>
29
- {i > 0 && <span className="text-foreground-tertiary">then</span>}
30
- <kbd className="inline-flex h-5 min-w-5 items-center justify-center rounded bg-background-tertiary px-1 font-mono text-[11px] font-medium text-foreground">
31
- {key}
32
- </kbd>
33
- </React.Fragment>))}
34
- </Tooltip.Popup>
35
- </Tooltip.Positioner>
36
- </Tooltip.Portal>
37
- </Tooltip.Root>);
38
- }
@@ -1,9 +0,0 @@
1
- interface SidebarHeaderProps {
2
- title: string;
3
- }
4
- /**
5
- * Sidebar header with back button for drilled sub-views.
6
- * Always renders - parent AnimatePresence handles exit animation.
7
- */
8
- export declare function SidebarHeader({ title }: SidebarHeaderProps): any;
9
- export {};
@@ -1,18 +0,0 @@
1
- 'use client';
2
- import { useSetAtom } from 'jotai';
3
- import { ChevronLeftIcon } from '@heroicons/react/24/outline';
4
- import { popViewAtom } from '@/atoms/sidebar';
5
- import { cn } from '@/lib/utils';
6
- /**
7
- * Sidebar header with back button for drilled sub-views.
8
- * Always renders - parent AnimatePresence handles exit animation.
9
- */
10
- export function SidebarHeader({ title }) {
11
- const popView = useSetAtom(popViewAtom);
12
- return (<div className="flex h-12 items-center px-2">
13
- <button onClick={() => popView()} className={cn('flex items-center gap-1.5 rounded-full px-3 py-1.5 text-xs font-medium', 'outline-none transition-colors duration-150 hover:duration-0', 'bg-background-secondary text-foreground-secondary', 'hover:bg-background-tertiary hover:text-foreground')}>
14
- <ChevronLeftIcon className="h-3.5 w-3.5"/>
15
- <span>{title}</span>
16
- </button>
17
- </div>);
18
- }
@@ -1,7 +0,0 @@
1
- /**
2
- * Main navigation - project list (tmux windows) with expandable sections.
3
- */
4
- export declare function SidebarNav({ className, onScrolledChange, }: {
5
- className?: string;
6
- onScrolledChange?: (scrolled: boolean) => void;
7
- }): any;