@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,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;