@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.
- package/dist/cli/commands/login.js +26 -0
- package/dist/cli/commands/start.js +2 -1
- package/oclif.manifest.json +1 -1
- package/package.json +9 -5
- package/dist/cli/base-command.d.ts.map +0 -1
- package/dist/cli/commands/agent/list.d.ts.map +0 -1
- package/dist/cli/commands/annotation/ack.d.ts.map +0 -1
- package/dist/cli/commands/annotation/create.d.ts.map +0 -1
- package/dist/cli/commands/annotation/events.d.ts.map +0 -1
- package/dist/cli/commands/annotation/export.d.ts.map +0 -1
- package/dist/cli/commands/annotation/import.d.ts.map +0 -1
- package/dist/cli/commands/annotation/ingest.d.ts.map +0 -1
- package/dist/cli/commands/annotation/list.d.ts.map +0 -1
- package/dist/cli/commands/annotation/reply.d.ts.map +0 -1
- package/dist/cli/commands/annotation/resolve.d.ts.map +0 -1
- package/dist/cli/commands/auto/index.d.ts.map +0 -1
- package/dist/cli/commands/backlog/add.d.ts.map +0 -1
- package/dist/cli/commands/backlog/claim.d.ts.map +0 -1
- package/dist/cli/commands/backlog/complete.d.ts.map +0 -1
- package/dist/cli/commands/backlog/list.d.ts.map +0 -1
- package/dist/cli/commands/backlog/pick.d.ts.map +0 -1
- package/dist/cli/commands/backlog/sync.d.ts.map +0 -1
- package/dist/cli/commands/bootstrap.d.ts.map +0 -1
- package/dist/cli/commands/bridge.d.ts.map +0 -1
- package/dist/cli/commands/context/inject.d.ts.map +0 -1
- package/dist/cli/commands/context/list.d.ts.map +0 -1
- package/dist/cli/commands/context/publish.d.ts.map +0 -1
- package/dist/cli/commands/context/read.d.ts.map +0 -1
- package/dist/cli/commands/daemon.d.ts.map +0 -1
- package/dist/cli/commands/digest/index.d.ts.map +0 -1
- package/dist/cli/commands/docs/lint.d.ts.map +0 -1
- package/dist/cli/commands/docs/sync.d.ts.map +0 -1
- package/dist/cli/commands/doctor.d.ts.map +0 -1
- package/dist/cli/commands/find/index.d.ts.map +0 -1
- package/dist/cli/commands/gc.d.ts.map +0 -1
- package/dist/cli/commands/history/index.d.ts.map +0 -1
- package/dist/cli/commands/hooks/guard.d.ts.map +0 -1
- package/dist/cli/commands/hooks/list.d.ts.map +0 -1
- package/dist/cli/commands/hooks/lock.d.ts.map +0 -1
- package/dist/cli/commands/hooks/status.d.ts.map +0 -1
- package/dist/cli/commands/hooks/test.d.ts.map +0 -1
- package/dist/cli/commands/hooks/unlock.d.ts.map +0 -1
- package/dist/cli/commands/index.d.ts.map +0 -1
- package/dist/cli/commands/list.d.ts.map +0 -1
- package/dist/cli/commands/list.e2e.test.d.ts +0 -1
- package/dist/cli/commands/list.e2e.test.js +0 -47
- package/dist/cli/commands/login.d.ts.map +0 -1
- package/dist/cli/commands/logout.d.ts.map +0 -1
- package/dist/cli/commands/panes/broker.d.ts.map +0 -1
- package/dist/cli/commands/panes/pipe-sink.d.ts.map +0 -1
- package/dist/cli/commands/panes/snapshot.d.ts.map +0 -1
- package/dist/cli/commands/plan.d.ts.map +0 -1
- package/dist/cli/commands/plan.e2e.test.d.ts +0 -1
- package/dist/cli/commands/plan.e2e.test.js +0 -74
- package/dist/cli/commands/preview/index.d.ts.map +0 -1
- package/dist/cli/commands/preview/init.d.ts.map +0 -1
- package/dist/cli/commands/preview/list.d.ts.map +0 -1
- package/dist/cli/commands/preview/status.d.ts.map +0 -1
- package/dist/cli/commands/preview/stop.d.ts.map +0 -1
- package/dist/cli/commands/preview/sync.d.ts.map +0 -1
- package/dist/cli/commands/preview/watch.d.ts.map +0 -1
- package/dist/cli/commands/project/add.d.ts.map +0 -1
- package/dist/cli/commands/project/list.d.ts.map +0 -1
- package/dist/cli/commands/project/remove.d.ts.map +0 -1
- package/dist/cli/commands/push.d.ts.map +0 -1
- package/dist/cli/commands/reference/add.d.ts.map +0 -1
- package/dist/cli/commands/reference/delete.d.ts.map +0 -1
- package/dist/cli/commands/reference/extract.d.ts.map +0 -1
- package/dist/cli/commands/reference/list.d.ts.map +0 -1
- package/dist/cli/commands/reference/normalize.d.ts.map +0 -1
- package/dist/cli/commands/reference/open.d.ts.map +0 -1
- package/dist/cli/commands/reference/save.d.ts.map +0 -1
- package/dist/cli/commands/reference/search.d.ts.map +0 -1
- package/dist/cli/commands/reference/show.d.ts.map +0 -1
- package/dist/cli/commands/reference/update-index.d.ts.map +0 -1
- package/dist/cli/commands/reference/update.d.ts.map +0 -1
- package/dist/cli/commands/report/blocked.d.ts.map +0 -1
- package/dist/cli/commands/report/complete.d.ts.map +0 -1
- package/dist/cli/commands/report/progress.d.ts.map +0 -1
- package/dist/cli/commands/report/start.d.ts.map +0 -1
- package/dist/cli/commands/resource/acquire.d.ts.map +0 -1
- package/dist/cli/commands/resource/list.d.ts.map +0 -1
- package/dist/cli/commands/resource/release.d.ts.map +0 -1
- package/dist/cli/commands/resource/wait.d.ts.map +0 -1
- package/dist/cli/commands/review.d.ts.map +0 -1
- package/dist/cli/commands/session/attach.d.ts.map +0 -1
- package/dist/cli/commands/session/await.d.ts.map +0 -1
- package/dist/cli/commands/session/complete.d.ts.map +0 -1
- package/dist/cli/commands/session/create.d.ts.map +0 -1
- package/dist/cli/commands/session/heartbeat.d.ts.map +0 -1
- package/dist/cli/commands/session/list.d.ts.map +0 -1
- package/dist/cli/commands/session/mark-done.d.ts.map +0 -1
- package/dist/cli/commands/session/mine.d.ts.map +0 -1
- package/dist/cli/commands/session/replay.d.ts.map +0 -1
- package/dist/cli/commands/session/run.d.ts.map +0 -1
- package/dist/cli/commands/session/show.d.ts.map +0 -1
- package/dist/cli/commands/session/start.d.ts.map +0 -1
- package/dist/cli/commands/session/state/cleanup.d.ts.map +0 -1
- package/dist/cli/commands/session/state/end.d.ts.map +0 -1
- package/dist/cli/commands/session/state/get.d.ts.map +0 -1
- package/dist/cli/commands/session/state/init.d.ts.map +0 -1
- package/dist/cli/commands/session/state/list.d.ts.map +0 -1
- package/dist/cli/commands/session/state/update.d.ts.map +0 -1
- package/dist/cli/commands/session/stop.d.ts.map +0 -1
- package/dist/cli/commands/session/view.d.ts.map +0 -1
- package/dist/cli/commands/start.d.ts.map +0 -1
- package/dist/cli/commands/state/dump.d.ts.map +0 -1
- package/dist/cli/commands/status.d.ts.map +0 -1
- package/dist/cli/commands/sync.d.ts.map +0 -1
- package/dist/cli/commands/trace/export.d.ts.map +0 -1
- package/dist/cli/commands/triage/claim.d.ts.map +0 -1
- package/dist/cli/commands/triage/list.d.ts.map +0 -1
- package/dist/cli/commands/triage/next.d.ts.map +0 -1
- package/dist/cli/commands/triage/pull.d.ts.map +0 -1
- package/dist/cli/commands/triage/stats.d.ts.map +0 -1
- package/dist/cli/commands/tunnel/list.d.ts.map +0 -1
- package/dist/cli/commands/tunnel/start.d.ts.map +0 -1
- package/dist/cli/commands/tunnel/stop.d.ts.map +0 -1
- package/dist/cli/commands/tunnel/url.d.ts.map +0 -1
- package/dist/cli/commands/web/start.d.ts.map +0 -1
- package/dist/cli/commands/windows/context.d.ts.map +0 -1
- package/dist/cli/commands/windows/focus.d.ts.map +0 -1
- package/dist/cli/commands/windows/list.d.ts.map +0 -1
- package/dist/cli/commands/windows/map.d.ts.map +0 -1
- package/dist/cli/commands/windows/read.d.ts.map +0 -1
- package/dist/cli/commands/windows/search.d.ts.map +0 -1
- package/dist/cli/commands/windows/show.d.ts.map +0 -1
- package/dist/cli/commands/windows/watch.d.ts.map +0 -1
- package/dist/lib/active-sessions.d.ts.map +0 -1
- package/dist/lib/agent-adapters.d.ts.map +0 -1
- package/dist/lib/agent-sessions.d.ts.map +0 -1
- package/dist/lib/agent-trace.d.ts.map +0 -1
- package/dist/lib/analytics.d.ts.map +0 -1
- package/dist/lib/annotations-convex.d.ts.map +0 -1
- package/dist/lib/annotations.d.ts.map +0 -1
- package/dist/lib/auto/discover.d.ts.map +0 -1
- package/dist/lib/auto/ideate.d.ts.map +0 -1
- package/dist/lib/auto/spawn.d.ts.map +0 -1
- package/dist/lib/auto/workspace.d.ts.map +0 -1
- package/dist/lib/backlog.d.ts.map +0 -1
- package/dist/lib/backlog.test.d.ts +0 -1
- package/dist/lib/backlog.test.js +0 -162
- package/dist/lib/config-loader.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/claude.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/codex.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/copilot.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/gemini.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/index.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/opencode.d.ts.map +0 -1
- package/dist/lib/config-sync/index.d.ts.map +0 -1
- package/dist/lib/config-sync/types.d.ts.map +0 -1
- package/dist/lib/config-sync/writer.d.ts.map +0 -1
- package/dist/lib/content-sync/index.d.ts.map +0 -1
- package/dist/lib/content-sync/types.d.ts.map +0 -1
- package/dist/lib/contracts.d.ts.map +0 -1
- package/dist/lib/convex.d.ts.map +0 -1
- package/dist/lib/device.d.ts.map +0 -1
- package/dist/lib/digest/index.d.ts.map +0 -1
- package/dist/lib/docs/lint.d.ts.map +0 -1
- package/dist/lib/docs/lint.test.d.ts +0 -1
- package/dist/lib/docs/lint.test.js +0 -120
- package/dist/lib/docs/sync.d.ts.map +0 -1
- package/dist/lib/doctor/index.d.ts.map +0 -1
- package/dist/lib/doctor/repos.d.ts.map +0 -1
- package/dist/lib/doctor/templates.d.ts.map +0 -1
- package/dist/lib/errors.d.ts.map +0 -1
- package/dist/lib/events.d.ts.map +0 -1
- package/dist/lib/heartbeat.d.ts.map +0 -1
- package/dist/lib/heartbeat.test.d.ts +0 -1
- package/dist/lib/heartbeat.test.js +0 -124
- package/dist/lib/hooks/adapters/claude.d.ts.map +0 -1
- package/dist/lib/hooks/adapters/codex.d.ts.map +0 -1
- package/dist/lib/hooks/adapters/copilot.d.ts.map +0 -1
- package/dist/lib/hooks/context.d.ts.map +0 -1
- package/dist/lib/hooks/index.d.ts.map +0 -1
- package/dist/lib/hooks/registry.d.ts.map +0 -1
- package/dist/lib/hooks/runner.d.ts.map +0 -1
- package/dist/lib/hooks/types.d.ts.map +0 -1
- package/dist/lib/index.test.d.ts +0 -1
- package/dist/lib/index.test.js +0 -334
- package/dist/lib/managed-session.d.ts.map +0 -1
- package/dist/lib/math.d.ts.map +0 -1
- package/dist/lib/math.test.d.ts +0 -1
- package/dist/lib/math.test.js +0 -238
- package/dist/lib/ngrok.d.ts.map +0 -1
- package/dist/lib/nvim/discovery.d.ts.map +0 -1
- package/dist/lib/nvim/discovery.test.d.ts +0 -1
- package/dist/lib/nvim/discovery.test.js +0 -131
- package/dist/lib/nvim/index.d.ts.map +0 -1
- package/dist/lib/nvim/remote.d.ts.map +0 -1
- package/dist/lib/nvim/remote.test.d.ts +0 -1
- package/dist/lib/nvim/remote.test.js +0 -18
- package/dist/lib/panes/broker.d.ts.map +0 -1
- package/dist/lib/panes/index.d.ts.map +0 -1
- package/dist/lib/panes/server.d.ts.map +0 -1
- package/dist/lib/preview/detect.d.ts.map +0 -1
- package/dist/lib/preview/index.d.ts.map +0 -1
- package/dist/lib/preview/manager.d.ts.map +0 -1
- package/dist/lib/preview/schema.d.ts.map +0 -1
- package/dist/lib/preview/sprite.d.ts.map +0 -1
- package/dist/lib/preview/watcher.d.ts.map +0 -1
- package/dist/lib/process/index.d.ts.map +0 -1
- package/dist/lib/process/snapshot.d.ts.map +0 -1
- package/dist/lib/process/snapshot.test.d.ts +0 -1
- package/dist/lib/process/snapshot.test.js +0 -127
- package/dist/lib/project-identity.d.ts.map +0 -1
- package/dist/lib/provider-auth.d.ts.map +0 -1
- package/dist/lib/references.d.ts.map +0 -1
- package/dist/lib/report.d.ts.map +0 -1
- package/dist/lib/resources.d.ts.map +0 -1
- package/dist/lib/resources.test.d.ts +0 -1
- package/dist/lib/resources.test.js +0 -94
- package/dist/lib/runner.d.ts.map +0 -1
- package/dist/lib/runner.test.d.ts +0 -1
- package/dist/lib/runner.test.js +0 -234
- package/dist/lib/session-artifacts.d.ts.map +0 -1
- package/dist/lib/session-manager.d.ts.map +0 -1
- package/dist/lib/session-manager.test.d.ts +0 -1
- package/dist/lib/session-manager.test.js +0 -310
- package/dist/lib/session-result.d.ts.map +0 -1
- package/dist/lib/session-state.d.ts.map +0 -1
- package/dist/lib/slack-workspace.d.ts.map +0 -1
- package/dist/lib/tmux/bridge.d.ts.map +0 -1
- package/dist/lib/tmux/context.d.ts.map +0 -1
- package/dist/lib/tmux/context.test.d.ts +0 -1
- package/dist/lib/tmux/context.test.js +0 -215
- package/dist/lib/tmux/index.d.ts.map +0 -1
- package/dist/lib/tmux/map.d.ts.map +0 -1
- package/dist/lib/tmux/map.test.d.ts +0 -1
- package/dist/lib/tmux/map.test.js +0 -80
- package/dist/lib/tmux/panes.d.ts.map +0 -1
- package/dist/lib/tmux/redaction.d.ts.map +0 -1
- package/dist/lib/tmux/redaction.test.d.ts +0 -1
- package/dist/lib/tmux/redaction.test.js +0 -183
- package/dist/lib/triage-llm.d.ts.map +0 -1
- package/dist/lib/triage-tracker.d.ts.map +0 -1
- package/dist/lib/triage.d.ts.map +0 -1
- package/dist/lib/types.d.ts.map +0 -1
- package/dist/lib/windows/index.d.ts.map +0 -1
- package/dist/lib/windows/inventory.d.ts.map +0 -1
- package/dist/lib/windows/inventory.test.d.ts +0 -1
- package/dist/lib/windows/inventory.test.js +0 -292
- package/dist/lib/windows/types.d.ts.map +0 -1
- package/dist/lib.d.ts.map +0 -1
- package/dist/web/app/@overlay/default.d.ts +0 -1
- package/dist/web/app/@overlay/default.js +0 -3
- package/dist/web/app/about/page.d.ts +0 -1
- package/dist/web/app/about/page.js +0 -6
- package/dist/web/app/layout.d.ts +0 -7
- package/dist/web/app/layout.js +0 -19
- package/dist/web/app/page.d.ts +0 -1
- package/dist/web/app/page.js +0 -38
- package/dist/web/app/settings/page.d.ts +0 -1
- package/dist/web/app/settings/page.js +0 -6
- package/dist/web/app/shortcuts/page.d.ts +0 -1
- package/dist/web/app/shortcuts/page.js +0 -6
- package/dist/web/atoms/sidebar.d.ts +0 -16
- package/dist/web/atoms/sidebar.js +0 -58
- package/dist/web/atoms/state.d.ts +0 -24
- package/dist/web/atoms/state.js +0 -43
- package/dist/web/components/command-palette.d.ts +0 -6
- package/dist/web/components/command-palette.js +0 -297
- package/dist/web/components/main-view.d.ts +0 -1
- package/dist/web/components/main-view.js +0 -93
- package/dist/web/components/overlay/page-overlay.d.ts +0 -16
- package/dist/web/components/overlay/page-overlay.js +0 -84
- package/dist/web/components/pane-view.d.ts +0 -5
- package/dist/web/components/pane-view.js +0 -168
- package/dist/web/components/project-files-view.d.ts +0 -6
- package/dist/web/components/project-files-view.js +0 -205
- package/dist/web/components/project-planning-view.d.ts +0 -6
- package/dist/web/components/project-planning-view.js +0 -146
- package/dist/web/components/session-view.d.ts +0 -6
- package/dist/web/components/session-view.js +0 -211
- package/dist/web/components/sessions-list-view.d.ts +0 -1
- package/dist/web/components/sessions-list-view.js +0 -118
- package/dist/web/components/sidebar/index.d.ts +0 -9
- package/dist/web/components/sidebar/index.js +0 -29
- package/dist/web/components/sidebar/kbd.d.ts +0 -17
- package/dist/web/components/sidebar/kbd.js +0 -47
- package/dist/web/components/sidebar/nav-group.d.ts +0 -22
- package/dist/web/components/sidebar/nav-group.js +0 -43
- package/dist/web/components/sidebar/nav-item.d.ts +0 -17
- package/dist/web/components/sidebar/nav-item.js +0 -38
- package/dist/web/components/sidebar/sidebar-header.d.ts +0 -9
- package/dist/web/components/sidebar/sidebar-header.js +0 -18
- package/dist/web/components/sidebar/sidebar-nav.d.ts +0 -7
- package/dist/web/components/sidebar/sidebar-nav.js +0 -505
- package/dist/web/components/sidebar/sidebar-search.d.ts +0 -7
- package/dist/web/components/sidebar/sidebar-search.js +0 -18
- package/dist/web/components/sidebar/sidebar-settings.d.ts +0 -4
- package/dist/web/components/sidebar/sidebar-settings.js +0 -28
- package/dist/web/components/sidebar/sidebar-transition.d.ts +0 -12
- package/dist/web/components/sidebar/sidebar-transition.js +0 -58
- package/dist/web/components/status-bar.d.ts +0 -1
- package/dist/web/components/status-bar.js +0 -53
- package/dist/web/components/terminal.d.ts +0 -4
- package/dist/web/components/terminal.js +0 -324
- package/dist/web/components/toast.d.ts +0 -7
- package/dist/web/components/toast.js +0 -72
- package/dist/web/hooks/use-keybindings.d.ts +0 -30
- package/dist/web/hooks/use-keybindings.js +0 -322
- package/dist/web/hooks/use-state.d.ts +0 -11
- package/dist/web/hooks/use-state.js +0 -84
- package/dist/web/lib/api.d.ts +0 -179
- package/dist/web/lib/api.js +0 -79
- package/dist/web/lib/paths.d.ts +0 -2
- package/dist/web/lib/paths.js +0 -26
- package/dist/web/lib/utils.d.ts +0 -2
- package/dist/web/lib/utils.js +0 -5
- package/dist/web/lib/ws.d.ts +0 -18
- package/dist/web/lib/ws.js +0 -138
- package/dist/web/next.config.d.ts +0 -3
- package/dist/web/next.config.js +0 -9
- package/scripts/generate-manifest.ts +0 -44
- package/src/cli/base-command.ts +0 -233
- package/src/cli/commands/__tests__/annotations.test.ts +0 -704
- package/src/cli/commands/__tests__/bridge.test.ts +0 -101
- package/src/cli/commands/__tests__/daemon.test.ts +0 -79
- package/src/cli/commands/agent/list.ts +0 -75
- package/src/cli/commands/annotation/ack.ts +0 -37
- package/src/cli/commands/annotation/create.ts +0 -67
- package/src/cli/commands/annotation/events.ts +0 -63
- package/src/cli/commands/annotation/export.ts +0 -67
- package/src/cli/commands/annotation/import.ts +0 -98
- package/src/cli/commands/annotation/ingest.ts +0 -112
- package/src/cli/commands/annotation/list.ts +0 -57
- package/src/cli/commands/annotation/reply.ts +0 -46
- package/src/cli/commands/annotation/resolve.ts +0 -37
- package/src/cli/commands/auto/index.ts +0 -755
- package/src/cli/commands/backlog/add.ts +0 -74
- package/src/cli/commands/backlog/claim.ts +0 -53
- package/src/cli/commands/backlog/complete.ts +0 -51
- package/src/cli/commands/backlog/list.ts +0 -107
- package/src/cli/commands/backlog/pick.ts +0 -50
- package/src/cli/commands/backlog/sync.ts +0 -131
- package/src/cli/commands/bootstrap.ts +0 -205
- package/src/cli/commands/bridge.ts +0 -233
- package/src/cli/commands/context/inject.ts +0 -103
- package/src/cli/commands/context/list.ts +0 -112
- package/src/cli/commands/context/publish.ts +0 -83
- package/src/cli/commands/context/read.ts +0 -85
- package/src/cli/commands/daemon.ts +0 -1809
- package/src/cli/commands/digest/index.ts +0 -245
- package/src/cli/commands/docs/lint.ts +0 -93
- package/src/cli/commands/docs/sync.ts +0 -90
- package/src/cli/commands/doctor.ts +0 -267
- package/src/cli/commands/find/index.ts +0 -313
- package/src/cli/commands/history/index.ts +0 -269
- package/src/cli/commands/hooks/guard.ts +0 -71
- package/src/cli/commands/hooks/list.ts +0 -139
- package/src/cli/commands/hooks/lock.ts +0 -47
- package/src/cli/commands/hooks/status.ts +0 -56
- package/src/cli/commands/hooks/test.ts +0 -190
- package/src/cli/commands/hooks/unlock.ts +0 -56
- package/src/cli/commands/list.e2e.test.ts +0 -58
- package/src/cli/commands/list.ts +0 -96
- package/src/cli/commands/login.ts +0 -236
- package/src/cli/commands/logout.ts +0 -45
- package/src/cli/commands/panes/broker.ts +0 -68
- package/src/cli/commands/panes/pipe-sink.ts +0 -101
- package/src/cli/commands/panes/snapshot.ts +0 -156
- package/src/cli/commands/plan.e2e.test.ts +0 -90
- package/src/cli/commands/plan.ts +0 -68
- package/src/cli/commands/preview/index.ts +0 -282
- package/src/cli/commands/preview/list.ts +0 -116
- package/src/cli/commands/preview/status.ts +0 -137
- package/src/cli/commands/preview/stop.ts +0 -165
- package/src/cli/commands/project/add.ts +0 -110
- package/src/cli/commands/project/list.ts +0 -136
- package/src/cli/commands/project/remove.ts +0 -60
- package/src/cli/commands/push.ts +0 -115
- package/src/cli/commands/reference/add.ts +0 -266
- package/src/cli/commands/reference/delete.ts +0 -67
- package/src/cli/commands/reference/extract.ts +0 -389
- package/src/cli/commands/reference/list.ts +0 -117
- package/src/cli/commands/reference/normalize.ts +0 -90
- package/src/cli/commands/reference/open.ts +0 -92
- package/src/cli/commands/reference/save.ts +0 -103
- package/src/cli/commands/reference/search.ts +0 -85
- package/src/cli/commands/reference/show.ts +0 -174
- package/src/cli/commands/reference/update-index.ts +0 -103
- package/src/cli/commands/reference/update.ts +0 -136
- package/src/cli/commands/report/blocked.ts +0 -165
- package/src/cli/commands/report/complete.ts +0 -179
- package/src/cli/commands/report/progress.ts +0 -142
- package/src/cli/commands/report/start.ts +0 -140
- package/src/cli/commands/resource/acquire.ts +0 -116
- package/src/cli/commands/resource/list.ts +0 -77
- package/src/cli/commands/resource/release.ts +0 -64
- package/src/cli/commands/resource/wait.ts +0 -93
- package/src/cli/commands/review.ts +0 -105
- package/src/cli/commands/session/attach.ts +0 -200
- package/src/cli/commands/session/await.ts +0 -83
- package/src/cli/commands/session/complete.ts +0 -100
- package/src/cli/commands/session/create.ts +0 -92
- package/src/cli/commands/session/heartbeat.ts +0 -63
- package/src/cli/commands/session/list.ts +0 -281
- package/src/cli/commands/session/mark-done.ts +0 -132
- package/src/cli/commands/session/mine.ts +0 -189
- package/src/cli/commands/session/replay.ts +0 -659
- package/src/cli/commands/session/run.ts +0 -44
- package/src/cli/commands/session/show.ts +0 -177
- package/src/cli/commands/session/start.ts +0 -580
- package/src/cli/commands/session/state/cleanup.ts +0 -61
- package/src/cli/commands/session/state/end.ts +0 -47
- package/src/cli/commands/session/state/get.ts +0 -65
- package/src/cli/commands/session/state/init.ts +0 -50
- package/src/cli/commands/session/state/list.ts +0 -68
- package/src/cli/commands/session/state/update.ts +0 -108
- package/src/cli/commands/session/stop.ts +0 -134
- package/src/cli/commands/session/view.ts +0 -186
- package/src/cli/commands/start.ts +0 -256
- package/src/cli/commands/state/dump.ts +0 -449
- package/src/cli/commands/status.ts +0 -244
- package/src/cli/commands/sync.ts +0 -174
- package/src/cli/commands/trace/export.ts +0 -255
- package/src/cli/commands/triage/claim.ts +0 -203
- package/src/cli/commands/triage/list.ts +0 -137
- package/src/cli/commands/triage/next.ts +0 -73
- package/src/cli/commands/triage/pull.ts +0 -97
- package/src/cli/commands/triage/stats.ts +0 -82
- package/src/cli/commands/tunnel/list.ts +0 -113
- package/src/cli/commands/tunnel/start.ts +0 -122
- package/src/cli/commands/tunnel/stop.ts +0 -108
- package/src/cli/commands/tunnel/url.ts +0 -82
- package/src/cli/commands/web/start.ts +0 -125
- package/src/cli/commands/windows/context.ts +0 -439
- package/src/cli/commands/windows/focus.ts +0 -130
- package/src/cli/commands/windows/list.ts +0 -213
- package/src/cli/commands/windows/map.ts +0 -223
- package/src/cli/commands/windows/read.ts +0 -279
- package/src/cli/commands/windows/search.ts +0 -219
- package/src/cli/commands/windows/show.ts +0 -188
- package/src/cli/commands/windows/watch.ts +0 -262
- package/src/lib/__tests__/annotations-convex.test.ts +0 -104
- package/src/lib/active-sessions.ts +0 -1486
- package/src/lib/agent-adapters.ts +0 -412
- package/src/lib/agent-sessions.ts +0 -671
- package/src/lib/agent-trace.test.ts +0 -296
- package/src/lib/agent-trace.ts +0 -513
- package/src/lib/analytics.ts +0 -178
- package/src/lib/annotations-convex.ts +0 -296
- package/src/lib/annotations.test.ts +0 -274
- package/src/lib/annotations.ts +0 -836
- package/src/lib/auto/discover.ts +0 -545
- package/src/lib/auto/ideate.ts +0 -412
- package/src/lib/auto/spawn.ts +0 -549
- package/src/lib/auto/workspace.ts +0 -282
- package/src/lib/backlog.test.ts +0 -194
- package/src/lib/backlog.ts +0 -428
- package/src/lib/config-loader.ts +0 -391
- package/src/lib/config-sync/adapters/claude.ts +0 -91
- package/src/lib/config-sync/adapters/codex.ts +0 -135
- package/src/lib/config-sync/adapters/copilot.ts +0 -98
- package/src/lib/config-sync/adapters/gemini.ts +0 -86
- package/src/lib/config-sync/adapters/index.ts +0 -39
- package/src/lib/config-sync/adapters/opencode.ts +0 -94
- package/src/lib/config-sync/index.ts +0 -399
- package/src/lib/config-sync/types.ts +0 -92
- package/src/lib/config-sync/writer.ts +0 -188
- package/src/lib/content-sync/index.ts +0 -882
- package/src/lib/content-sync/types.ts +0 -104
- package/src/lib/contracts.test.ts +0 -186
- package/src/lib/contracts.ts +0 -195
- package/src/lib/convex.ts +0 -54
- package/src/lib/device.ts +0 -41
- package/src/lib/digest/index.ts +0 -529
- package/src/lib/docs/lint.test.ts +0 -135
- package/src/lib/docs/lint.ts +0 -310
- package/src/lib/docs/sync.ts +0 -184
- package/src/lib/doctor/index.ts +0 -647
- package/src/lib/doctor/repos.ts +0 -381
- package/src/lib/doctor/templates.ts +0 -191
- package/src/lib/errors.ts +0 -111
- package/src/lib/events.ts +0 -479
- package/src/lib/heartbeat.test.ts +0 -164
- package/src/lib/heartbeat.ts +0 -326
- package/src/lib/hooks/adapters/claude.ts +0 -115
- package/src/lib/hooks/adapters/codex.ts +0 -92
- package/src/lib/hooks/adapters/copilot.ts +0 -141
- package/src/lib/hooks/context.ts +0 -174
- package/src/lib/hooks/index.ts +0 -39
- package/src/lib/hooks/registry.ts +0 -101
- package/src/lib/hooks/runner.ts +0 -208
- package/src/lib/hooks/types.ts +0 -89
- package/src/lib/index.test.ts +0 -426
- package/src/lib/managed-session.ts +0 -117
- package/src/lib/math.test.ts +0 -299
- package/src/lib/math.ts +0 -120
- package/src/lib/ngrok.ts +0 -441
- package/src/lib/nvim/discovery.test.ts +0 -157
- package/src/lib/nvim/discovery.ts +0 -181
- package/src/lib/nvim/index.ts +0 -28
- package/src/lib/nvim/remote.test.ts +0 -21
- package/src/lib/nvim/remote.ts +0 -184
- package/src/lib/panes/README.md +0 -20
- package/src/lib/panes/broker.ts +0 -261
- package/src/lib/panes/index.ts +0 -1
- package/src/lib/panes/server.ts +0 -379
- package/src/lib/preview/detect.ts +0 -184
- package/src/lib/preview/index.ts +0 -1
- package/src/lib/process/index.ts +0 -16
- package/src/lib/process/snapshot.test.ts +0 -188
- package/src/lib/process/snapshot.ts +0 -257
- package/src/lib/provider-auth.ts +0 -258
- package/src/lib/references.ts +0 -481
- package/src/lib/report.ts +0 -973
- package/src/lib/resources.test.ts +0 -132
- package/src/lib/resources.ts +0 -429
- package/src/lib/runner.test.ts +0 -288
- package/src/lib/runner.ts +0 -1223
- package/src/lib/session-artifacts.test.ts +0 -107
- package/src/lib/session-artifacts.ts +0 -193
- package/src/lib/session-manager.test.ts +0 -402
- package/src/lib/session-manager.ts +0 -150
- package/src/lib/session-result.test.ts +0 -98
- package/src/lib/session-result.ts +0 -262
- package/src/lib/session-state.ts +0 -470
- package/src/lib/slack-workspace.ts +0 -25
- package/src/lib/tmux/bridge.ts +0 -439
- package/src/lib/tmux/context.test.ts +0 -242
- package/src/lib/tmux/context.ts +0 -380
- package/src/lib/tmux/index.ts +0 -46
- package/src/lib/tmux/map.test.ts +0 -99
- package/src/lib/tmux/map.ts +0 -252
- package/src/lib/tmux/panes.ts +0 -170
- package/src/lib/tmux/redaction.test.ts +0 -231
- package/src/lib/tmux/redaction.ts +0 -201
- package/src/lib/triage-llm.ts +0 -312
- package/src/lib/triage-tracker.ts +0 -400
- package/src/lib/triage.ts +0 -655
- package/src/lib/types.ts +0 -61
- package/src/lib/windows/index.ts +0 -2
- package/src/lib/windows/inventory.test.ts +0 -370
- package/src/lib/windows/inventory.ts +0 -352
- package/src/lib/windows/types.ts +0 -46
- 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
|
-
}
|