@shepai/cli 1.156.0 → 1.157.0
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/README.md +253 -142
- package/apis/json-schema/Language.yaml +13 -0
- package/apis/json-schema/UserProfile.yaml +3 -0
- package/dist/packages/core/src/application/use-cases/agents/approve-agent-run.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/agents/approve-agent-run.use-case.js +5 -0
- package/dist/packages/core/src/application/use-cases/agents/reject-agent-run.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/agents/reject-agent-run.use-case.js +7 -0
- package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.js +11 -1
- package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.js +3 -0
- package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.js +5 -0
- package/dist/packages/core/src/domain/generated/output.d.ts +14 -0
- package/dist/packages/core/src/domain/generated/output.d.ts.map +1 -1
- package/dist/packages/core/src/domain/generated/output.js +11 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts +1 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.js +4 -2
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.d.ts +14 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.d.ts.map +1 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.js +19 -0
- package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.js +3 -2
- package/dist/packages/core/src/infrastructure/services/git/pr-branding.d.ts +1 -1
- package/dist/packages/core/src/infrastructure/services/git/pr-branding.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/git/pr-branding.js +1 -1
- package/dist/packages/core/src/infrastructure/services/tool-installer/tool-installer.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/tool-installer/tool-installer.service.js +3 -1
- package/dist/packages/core/src/infrastructure/services/tool-installer/tools/claude-code.json +3 -4
- package/dist/src/presentation/cli/commands/_serve.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/_serve.command.js +5 -3
- package/dist/src/presentation/cli/commands/agent/approve.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/approve.command.js +9 -4
- package/dist/src/presentation/cli/commands/agent/delete.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/delete.command.js +9 -5
- package/dist/src/presentation/cli/commands/agent/index.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/index.js +3 -1
- package/dist/src/presentation/cli/commands/agent/logs.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/logs.command.js +7 -5
- package/dist/src/presentation/cli/commands/agent/ls.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/ls.command.js +12 -10
- package/dist/src/presentation/cli/commands/agent/reject.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/reject.command.js +10 -5
- package/dist/src/presentation/cli/commands/agent/resolve-run.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/resolve-run.js +7 -2
- package/dist/src/presentation/cli/commands/agent/show.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/show.command.js +8 -6
- package/dist/src/presentation/cli/commands/agent/stop.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/agent/stop.command.js +9 -4
- package/dist/src/presentation/cli/commands/daemon/start-daemon.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/daemon/start-daemon.js +10 -8
- package/dist/src/presentation/cli/commands/daemon/stop-daemon.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/daemon/stop-daemon.js +5 -3
- package/dist/src/presentation/cli/commands/feat/adopt.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/adopt.command.js +14 -12
- package/dist/src/presentation/cli/commands/feat/approve.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/approve.command.js +8 -6
- package/dist/src/presentation/cli/commands/feat/archive.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/archive.command.js +10 -8
- package/dist/src/presentation/cli/commands/feat/del.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/del.command.js +17 -15
- package/dist/src/presentation/cli/commands/feat/index.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/index.js +2 -1
- package/dist/src/presentation/cli/commands/feat/logs.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/logs.command.js +8 -6
- package/dist/src/presentation/cli/commands/feat/ls.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/ls.command.js +14 -12
- package/dist/src/presentation/cli/commands/feat/new.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/new.command.js +43 -37
- package/dist/src/presentation/cli/commands/feat/reject.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/reject.command.js +11 -9
- package/dist/src/presentation/cli/commands/feat/resolve-waiting-feature.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/resolve-waiting-feature.js +12 -5
- package/dist/src/presentation/cli/commands/feat/resume.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/resume.command.js +8 -6
- package/dist/src/presentation/cli/commands/feat/review.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/review.command.js +17 -15
- package/dist/src/presentation/cli/commands/feat/show.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/show.command.js +89 -45
- package/dist/src/presentation/cli/commands/feat/start.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/start.command.js +12 -10
- package/dist/src/presentation/cli/commands/feat/unarchive.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/unarchive.command.js +8 -6
- package/dist/src/presentation/cli/commands/ide-open.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/ide-open.command.js +10 -5
- package/dist/src/presentation/cli/commands/install.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/install.command.js +29 -21
- package/dist/src/presentation/cli/commands/log-viewer.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/log-viewer.js +6 -3
- package/dist/src/presentation/cli/commands/repo/add.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/repo/add.command.js +12 -10
- package/dist/src/presentation/cli/commands/repo/index.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/repo/index.js +3 -1
- package/dist/src/presentation/cli/commands/repo/ls.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/repo/ls.command.js +11 -9
- package/dist/src/presentation/cli/commands/repo/resolve-repository.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/repo/resolve-repository.js +7 -2
- package/dist/src/presentation/cli/commands/repo/show.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/repo/show.command.js +21 -10
- package/dist/src/presentation/cli/commands/restart.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/restart.command.js +6 -4
- package/dist/src/presentation/cli/commands/run.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/run.command.js +21 -17
- package/dist/src/presentation/cli/commands/session/index.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/session/index.js +3 -1
- package/dist/src/presentation/cli/commands/session/ls.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/session/ls.command.js +11 -9
- package/dist/src/presentation/cli/commands/session/show.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/session/show.command.js +26 -18
- package/dist/src/presentation/cli/commands/settings/agent.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/settings/agent.command.js +12 -8
- package/dist/src/presentation/cli/commands/settings/ide.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/settings/ide.command.js +13 -7
- package/dist/src/presentation/cli/commands/settings/index.d.ts +1 -0
- package/dist/src/presentation/cli/commands/settings/index.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/settings/index.js +7 -3
- package/dist/src/presentation/cli/commands/settings/init.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/settings/init.command.js +8 -7
- package/dist/src/presentation/cli/commands/settings/language.command.d.ts +14 -0
- package/dist/src/presentation/cli/commands/settings/language.command.d.ts.map +1 -0
- package/dist/src/presentation/cli/commands/settings/language.command.js +79 -0
- package/dist/src/presentation/cli/commands/settings/model.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/settings/model.command.js +7 -6
- package/dist/src/presentation/cli/commands/settings/show.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/settings/show.command.js +4 -3
- package/dist/src/presentation/cli/commands/settings/workflow.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/settings/workflow.command.js +20 -18
- package/dist/src/presentation/cli/commands/start.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/start.command.js +5 -3
- package/dist/src/presentation/cli/commands/status.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/status.command.js +32 -24
- package/dist/src/presentation/cli/commands/stop.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/stop.command.js +4 -2
- package/dist/src/presentation/cli/commands/tools.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/tools.command.js +8 -4
- package/dist/src/presentation/cli/commands/ui.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/ui.command.js +12 -10
- package/dist/src/presentation/cli/commands/upgrade.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/upgrade.command.js +18 -13
- package/dist/src/presentation/cli/commands/version.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/version.command.js +5 -3
- package/dist/src/presentation/cli/i18n.d.ts +41 -0
- package/dist/src/presentation/cli/i18n.d.ts.map +1 -0
- package/dist/src/presentation/cli/i18n.js +100 -0
- package/dist/src/presentation/cli/index.js +13 -1
- package/dist/src/presentation/cli/ui/install-messages.d.ts.map +1 -1
- package/dist/src/presentation/cli/ui/install-messages.js +16 -6
- package/dist/src/presentation/tui/i18n.d.ts +24 -0
- package/dist/src/presentation/tui/i18n.d.ts.map +1 -0
- package/dist/src/presentation/tui/i18n.js +48 -0
- package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts +13 -31
- package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts.map +1 -1
- package/dist/src/presentation/tui/prompts/agent-select.prompt.js +17 -15
- package/dist/src/presentation/tui/prompts/auth-method.prompt.d.ts +7 -11
- package/dist/src/presentation/tui/prompts/auth-method.prompt.d.ts.map +1 -1
- package/dist/src/presentation/tui/prompts/auth-method.prompt.js +7 -5
- package/dist/src/presentation/tui/prompts/ide-select.prompt.d.ts.map +1 -1
- package/dist/src/presentation/tui/prompts/ide-select.prompt.js +2 -1
- package/dist/src/presentation/tui/prompts/prd-review-summary.prompt.d.ts.map +1 -1
- package/dist/src/presentation/tui/prompts/prd-review-summary.prompt.js +8 -6
- package/dist/src/presentation/tui/wizards/agent-config.wizard.d.ts.map +1 -1
- package/dist/src/presentation/tui/wizards/agent-config.wizard.js +2 -1
- package/dist/src/presentation/tui/wizards/github-import.wizard.d.ts.map +1 -1
- package/dist/src/presentation/tui/wizards/github-import.wizard.js +15 -11
- package/dist/src/presentation/tui/wizards/merge-review.wizard.d.ts.map +1 -1
- package/dist/src/presentation/tui/wizards/merge-review.wizard.js +10 -8
- package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.d.ts.map +1 -1
- package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.js +10 -7
- package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.d.ts +0 -41
- package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.d.ts.map +1 -1
- package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.js +15 -15
- package/dist/src/presentation/tui/wizards/plan-review.wizard.d.ts.map +1 -1
- package/dist/src/presentation/tui/wizards/plan-review.wizard.js +10 -8
- package/dist/src/presentation/tui/wizards/prd-review.wizard.d.ts.map +1 -1
- package/dist/src/presentation/tui/wizards/prd-review.wizard.js +3 -2
- package/dist/src/presentation/web/app/(dashboard)/get-graph-data.d.ts.map +1 -1
- package/dist/src/presentation/web/app/(dashboard)/get-graph-data.js +4 -2
- package/dist/src/presentation/web/app/actions/create-feature.d.ts.map +1 -1
- package/dist/src/presentation/web/app/actions/create-feature.js +3 -0
- package/dist/src/presentation/web/app/layout.d.ts.map +1 -1
- package/dist/src/presentation/web/app/layout.js +5 -2
- package/dist/src/presentation/web/components/assistant-ui/thread.d.ts.map +1 -1
- package/dist/src/presentation/web/components/assistant-ui/thread.js +13 -10
- package/dist/src/presentation/web/components/common/add-repository-button/add-repository-button.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/add-repository-button/add-repository-button.js +3 -1
- package/dist/src/presentation/web/components/common/attachment-chip/attachment-chip.js +1 -1
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.js +5 -2
- package/dist/src/presentation/web/components/common/ci-status-badge/ci-status-badge.js +3 -3
- package/dist/src/presentation/web/components/common/control-center-drawer/adopt-branch-drawer.js +4 -4
- package/dist/src/presentation/web/components/common/control-center-drawer/feature-drawer-client.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/control-center-drawer/feature-drawer-client.js +7 -1
- package/dist/src/presentation/web/components/common/control-center-drawer/repository-drawer-client.js +1 -1
- package/dist/src/presentation/web/components/common/delete-feature-dialog/delete-feature-dialog.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/delete-feature-dialog/delete-feature-dialog.js +3 -1
- package/dist/src/presentation/web/components/common/deployment-status-badge/deployment-status-badge.js +2 -2
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.js +6 -2
- package/dist/src/presentation/web/components/common/empty-state/empty-state.stories.js +2 -2
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.js +34 -22
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/activity-tab.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/activity-tab.js +11 -7
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/activity-tab.stories.js +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/branch-sync-status.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/branch-sync-status.js +3 -1
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/feature-drawer-tabs.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/feature-drawer-tabs.js +4 -2
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/feature-drawer-tabs.stories.js +2 -2
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/log-tab.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/log-tab.js +5 -3
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/overview-tab.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer-tabs/overview-tab.js +9 -5
- package/dist/src/presentation/web/components/common/feature-list-item/feature-list-item.js +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts +2 -2
- package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.js +22 -22
- package/dist/src/presentation/web/components/common/feature-node/feature-node.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-node.js +49 -36
- package/dist/src/presentation/web/components/common/feature-node/feature-sessions-dropdown.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-sessions-dropdown.js +7 -3
- package/dist/src/presentation/web/components/common/feature-status-badges/feature-status-badges.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-status-badges/feature-status-badges.js +4 -2
- package/dist/src/presentation/web/components/common/feature-status-config.d.ts +2 -1
- package/dist/src/presentation/web/components/common/feature-status-config.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-status-config.js +6 -6
- package/dist/src/presentation/web/components/common/feature-status-group/feature-status-group.js +1 -1
- package/dist/src/presentation/web/components/common/floating-action-button/floating-action-button.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/floating-action-button/floating-action-button.js +4 -2
- package/dist/src/presentation/web/components/common/github-import-dialog/github-repo-browser.js +1 -1
- package/dist/src/presentation/web/components/common/merge-review/diff-view.js +2 -2
- package/dist/src/presentation/web/components/common/merge-review/merge-review.js +2 -2
- package/dist/src/presentation/web/components/common/merge-review/merge-review.stories.js +1 -1
- package/dist/src/presentation/web/components/common/prd-questionnaire/prd-questionnaire.js +3 -3
- package/dist/src/presentation/web/components/common/reject-feedback-dialog/reject-feedback-dialog.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/reject-feedback-dialog/reject-feedback-dialog.js +6 -4
- package/dist/src/presentation/web/components/common/repository-node/repository-drawer.stories.js +3 -3
- package/dist/src/presentation/web/components/common/repository-node/repository-node-config.d.ts +1 -1
- package/dist/src/presentation/web/components/common/repository-node/repository-node-config.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/repository-node/repository-node.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/repository-node/repository-node.js +18 -11
- package/dist/src/presentation/web/components/common/repository-node/repository-node.stories.js +12 -12
- package/dist/src/presentation/web/components/common/server-log-viewer/server-log-viewer.js +1 -1
- package/dist/src/presentation/web/components/common/task-progress-view/task-progress-view.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/task-progress-view/task-progress-view.js +7 -4
- package/dist/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.js +2 -2
- package/dist/src/presentation/web/components/common/version-badge/version-badge.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/version-badge/version-badge.js +3 -1
- package/dist/src/presentation/web/components/features/chat/ChatComposer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/chat/ChatComposer.js +3 -1
- package/dist/src/presentation/web/components/features/chat/ChatMessageBubble.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/chat/ChatMessageBubble.js +7 -5
- package/dist/src/presentation/web/components/features/chat/ChatMessageList.js +1 -1
- package/dist/src/presentation/web/components/features/chat/ChatSheet.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/chat/ChatSheet.js +5 -3
- package/dist/src/presentation/web/components/features/chat/ChatTab.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/chat/ChatTab.js +5 -3
- package/dist/src/presentation/web/components/features/control-center/control-center-empty-state.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/control-center/control-center-empty-state.js +15 -11
- package/dist/src/presentation/web/components/features/control-center/control-center-inner.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/control-center/control-center-inner.js +14 -6
- package/dist/src/presentation/web/components/features/control-center/control-center.stories.js +1 -1
- package/dist/src/presentation/web/components/features/control-center/use-control-center-state.js +2 -2
- package/dist/src/presentation/web/components/features/control-center/welcome-agent-setup.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/control-center/welcome-agent-setup.js +8 -6
- package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.js +3 -1
- package/dist/src/presentation/web/components/features/features-canvas/features-canvas.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/features-canvas/features-canvas.js +4 -2
- package/dist/src/presentation/web/components/features/features-canvas/features-canvas.stories.js +6 -6
- package/dist/src/presentation/web/components/features/settings/AgentModelPicker/index.js +2 -2
- package/dist/src/presentation/web/components/features/settings/ModelPicker/index.js +2 -2
- package/dist/src/presentation/web/components/features/settings/agent-settings-section.js +1 -1
- package/dist/src/presentation/web/components/features/settings/language-settings-section.d.ts +5 -0
- package/dist/src/presentation/web/components/features/settings/language-settings-section.d.ts.map +1 -0
- package/dist/src/presentation/web/components/features/settings/language-settings-section.js +54 -0
- package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.d.ts +18 -0
- package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.d.ts.map +1 -0
- package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.js +36 -0
- package/dist/src/presentation/web/components/features/settings/settings-page-client.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/settings/settings-page-client.js +100 -88
- package/dist/src/presentation/web/components/features/settings/timeout-slider.js +1 -1
- package/dist/src/presentation/web/components/features/skills/category-filter.js +1 -1
- package/dist/src/presentation/web/components/features/skills/skills-page-client.js +1 -1
- package/dist/src/presentation/web/components/features/tools/tool-card.js +1 -1
- package/dist/src/presentation/web/components/features/tools/tool-detail-drawer.js +2 -2
- package/dist/src/presentation/web/components/features/version/version-page-client.js +1 -1
- package/dist/src/presentation/web/components/layouts/app-shell/app-shell.d.ts.map +1 -1
- package/dist/src/presentation/web/components/layouts/app-shell/app-shell.js +5 -1
- package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.d.ts.map +1 -1
- package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.js +13 -7
- package/dist/src/presentation/web/components/providers/i18n-provider.d.ts +17 -0
- package/dist/src/presentation/web/components/providers/i18n-provider.d.ts.map +1 -0
- package/dist/src/presentation/web/components/providers/i18n-provider.js +36 -0
- package/dist/src/presentation/web/components/ui/alert-dialog.js +1 -1
- package/dist/src/presentation/web/components/ui/alert.js +1 -1
- package/dist/src/presentation/web/components/ui/checkbox-group.js +1 -1
- package/dist/src/presentation/web/components/ui/command.js +1 -1
- package/dist/src/presentation/web/components/ui/dialog.d.ts.map +1 -1
- package/dist/src/presentation/web/components/ui/dialog.js +2 -2
- package/dist/src/presentation/web/components/ui/dialog.stories.js +1 -1
- package/dist/src/presentation/web/components/ui/drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/ui/drawer.js +2 -8
- package/dist/src/presentation/web/components/ui/dropdown-menu.js +6 -6
- package/dist/src/presentation/web/components/ui/scroll-area.js +1 -1
- package/dist/src/presentation/web/components/ui/select.js +1 -1
- package/dist/src/presentation/web/components/ui/sheet.js +3 -3
- package/dist/src/presentation/web/components/ui/sidebar.d.ts.map +1 -1
- package/dist/src/presentation/web/components/ui/sidebar.js +15 -15
- package/dist/src/presentation/web/components/ui/switch.js +1 -1
- package/dist/src/presentation/web/hooks/use-graph-state.d.ts.map +1 -1
- package/dist/src/presentation/web/hooks/use-graph-state.js +7 -4
- package/dist/src/presentation/web/hooks/use-sound-action.stories.js +1 -1
- package/dist/src/presentation/web/lib/i18n.d.ts +15 -0
- package/dist/src/presentation/web/lib/i18n.d.ts.map +1 -0
- package/dist/src/presentation/web/lib/i18n.js +64 -0
- package/dist/src/presentation/web/lib/language.d.ts +23 -0
- package/dist/src/presentation/web/lib/language.d.ts.map +1 -0
- package/dist/src/presentation/web/lib/language.js +37 -0
- package/dist/src/presentation/web/lib/layout-with-dagre.d.ts +2 -0
- package/dist/src/presentation/web/lib/layout-with-dagre.d.ts.map +1 -1
- package/dist/src/presentation/web/lib/layout-with-dagre.js +4 -0
- package/dist/src/presentation/web/lib/rtl-fonts.d.ts +19 -0
- package/dist/src/presentation/web/lib/rtl-fonts.d.ts.map +1 -0
- package/dist/src/presentation/web/lib/rtl-fonts.js +51 -0
- package/dist/translations/ar/cli.json +613 -0
- package/dist/translations/ar/common.json +55 -0
- package/dist/translations/ar/tui.json +130 -0
- package/dist/translations/ar/web.json +594 -0
- package/dist/translations/de/cli.json +613 -0
- package/dist/translations/de/common.json +55 -0
- package/dist/translations/de/tui.json +109 -0
- package/dist/translations/de/web.json +580 -0
- package/dist/translations/en/cli.json +613 -0
- package/dist/translations/en/common.json +55 -0
- package/dist/translations/en/tui.json +130 -0
- package/dist/translations/en/web.json +594 -0
- package/dist/translations/es/cli.json +613 -0
- package/dist/translations/es/common.json +55 -0
- package/dist/translations/es/tui.json +130 -0
- package/dist/translations/es/web.json +594 -0
- package/dist/translations/fr/cli.json +613 -0
- package/dist/translations/fr/common.json +55 -0
- package/dist/translations/fr/tui.json +130 -0
- package/dist/translations/fr/web.json +594 -0
- package/dist/translations/he/cli.json +613 -0
- package/dist/translations/he/common.json +55 -0
- package/dist/translations/he/tui.json +130 -0
- package/dist/translations/he/web.json +594 -0
- package/dist/translations/pt/cli.json +613 -0
- package/dist/translations/pt/common.json +55 -0
- package/dist/translations/pt/tui.json +130 -0
- package/dist/translations/pt/web.json +594 -0
- package/dist/translations/ru/cli.json +613 -0
- package/dist/translations/ru/common.json +55 -0
- package/dist/translations/ru/tui.json +130 -0
- package/dist/translations/ru/web.json +594 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +5 -3
- package/web/.next/BUILD_ID +1 -1
- package/web/.next/build-manifest.json +2 -2
- package/web/.next/fallback-build-manifest.json +2 -2
- package/web/.next/prerender-manifest.json +3 -3
- package/web/.next/required-server-files.js +6 -6
- package/web/.next/required-server-files.json +6 -6
- package/web/.next/server/app/(dashboard)/@drawer/adopt/page/server-reference-manifest.json +28 -28
- package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js +3 -3
- package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/adopt/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/chat/page/server-reference-manifest.json +26 -26
- package/web/.next/server/app/(dashboard)/@drawer/chat/page.js +3 -3
- package/web/.next/server/app/(dashboard)/@drawer/chat/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/chat/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/create/page/server-reference-manifest.json +29 -29
- package/web/.next/server/app/(dashboard)/@drawer/create/page.js +3 -3
- package/web/.next/server/app/(dashboard)/@drawer/create/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/create/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page/server-reference-manifest.json +36 -36
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js +4 -4
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page/server-reference-manifest.json +36 -36
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js +4 -4
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +26 -26
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js +3 -3
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page/server-reference-manifest.json +26 -26
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js +3 -3
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/chat/page/server-reference-manifest.json +26 -26
- package/web/.next/server/app/(dashboard)/chat/page.js +3 -3
- package/web/.next/server/app/(dashboard)/chat/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/chat/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/create/page/server-reference-manifest.json +29 -29
- package/web/.next/server/app/(dashboard)/create/page.js +3 -3
- package/web/.next/server/app/(dashboard)/create/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/create/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page/server-reference-manifest.json +36 -36
- package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js +4 -4
- package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/feature/[featureId]/page/server-reference-manifest.json +36 -36
- package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js +4 -4
- package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/feature/[featureId]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/page/server-reference-manifest.json +26 -26
- package/web/.next/server/app/(dashboard)/page.js +3 -3
- package/web/.next/server/app/(dashboard)/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +26 -26
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js +3 -3
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page/server-reference-manifest.json +26 -26
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js +3 -3
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/_global-error.html +2 -2
- package/web/.next/server/app/_global-error.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/web/.next/server/app/_not-found/page/server-reference-manifest.json +5 -5
- package/web/.next/server/app/_not-found/page.js +2 -2
- package/web/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/api/attachments/preview/route.js.nft.json +1 -1
- package/web/.next/server/app/api/evidence/route.js.nft.json +1 -1
- package/web/.next/server/app/api/graph-data/route.js.nft.json +1 -1
- package/web/.next/server/app/api/interactive/chat/[featureId]/messages/route.js.nft.json +1 -1
- package/web/.next/server/app/settings/page/server-reference-manifest.json +8 -8
- package/web/.next/server/app/settings/page.js +2 -2
- package/web/.next/server/app/settings/page.js.nft.json +1 -1
- package/web/.next/server/app/settings/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/skills/page/server-reference-manifest.json +10 -10
- package/web/.next/server/app/skills/page.js +3 -4
- package/web/.next/server/app/skills/page.js.nft.json +1 -1
- package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/tools/page/server-reference-manifest.json +10 -10
- package/web/.next/server/app/tools/page.js +3 -4
- package/web/.next/server/app/tools/page.js.nft.json +1 -1
- package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/version/page/server-reference-manifest.json +5 -5
- package/web/.next/server/app/version/page.js +2 -2
- package/web/.next/server/app/version/page.js.nft.json +1 -1
- package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
- package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_370c43b1.js +1 -1
- package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_370c43b1.js.map +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__a402b567._.js +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__a402b567._.js.map +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__b4102cc7._.js +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__b4102cc7._.js.map +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__beda892a._.js +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__beda892a._.js.map +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js.map +1 -1
- package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js +1 -1
- package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js.map +1 -1
- package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js +3 -3
- package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__209c9597._.js +4 -0
- package/web/.next/server/chunks/ssr/{[root-of-the-server]__88f7e8e6._.js.map → [root-of-the-server]__209c9597._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__27301e38._.js +4 -0
- package/web/.next/server/chunks/ssr/{[root-of-the-server]__17ed7ed1._.js.map → [root-of-the-server]__27301e38._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__357d99f9._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__56b70465._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__56b70465._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__6fecf886._.js +4 -0
- package/web/.next/server/chunks/ssr/{[root-of-the-server]__42bf1807._.js.map → [root-of-the-server]__6fecf886._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__8b0aac03._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__8d27866c._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__8d27866c._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__9f3504c7._.js +4 -0
- package/web/.next/server/chunks/ssr/{[root-of-the-server]__f80bfc75._.js.map → [root-of-the-server]__9f3504c7._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__bd6ed91a._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__bd6ed91a._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__c30f1f82._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__c30f1f82._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__dffa13c5._.js +3 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__dffa13c5._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__e91ffd5e._.js +2 -2
- package/web/.next/server/chunks/ssr/[root-of-the-server]__e91ffd5e._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__f8dd4422._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__f8dd4422._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_05c23ad9._.js +1 -1
- package/web/.next/server/chunks/ssr/_05c23ad9._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_0dc06d07._.js +3 -0
- package/web/.next/server/chunks/ssr/_0dc06d07._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_16eb4fec._.js +1 -1
- package/web/.next/server/chunks/ssr/_16eb4fec._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_3a0b989f._.js +2 -2
- package/web/.next/server/chunks/ssr/_3a0b989f._.js.map +1 -1
- package/web/.next/server/chunks/ssr/{_67104d9e._.js → _3bcda5d7._.js} +2 -2
- package/web/.next/server/chunks/ssr/{_67104d9e._.js.map → _3bcda5d7._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/_5119a3df._.js +3 -0
- package/web/.next/server/chunks/ssr/_5119a3df._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_56b9d60f._.js +1 -1
- package/web/.next/server/chunks/ssr/_56b9d60f._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_5f69c13f._.js +1 -1
- package/web/.next/server/chunks/ssr/_5f69c13f._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_7c5b97c6._.js +1 -1
- package/web/.next/server/chunks/ssr/_7c5b97c6._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_82c57f10._.js +1 -1
- package/web/.next/server/chunks/ssr/_82c57f10._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_8b57edb8._.js +1 -1
- package/web/.next/server/chunks/ssr/_8b57edb8._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_8d733ce4._.js +1 -1
- package/web/.next/server/chunks/ssr/_8d733ce4._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_9495d50b._.js +1 -1
- package/web/.next/server/chunks/ssr/_9495d50b._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_9f6b4b4a._.js +3 -0
- package/web/.next/server/chunks/ssr/{_08dc06df._.js.map → _9f6b4b4a._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/_a0e3f7e4._.js +1 -1
- package/web/.next/server/chunks/ssr/_a0e3f7e4._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_ac4a3873._.js +1 -1
- package/web/.next/server/chunks/ssr/_ac4a3873._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_b3bcbae5._.js +4 -0
- package/web/.next/server/chunks/ssr/_b3bcbae5._.js.map +1 -0
- package/web/.next/server/chunks/ssr/{_507a8382._.js → _b9ba2473._.js} +2 -2
- package/web/.next/server/chunks/ssr/_b9ba2473._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_bcaea66b._.js +3 -0
- package/web/.next/server/chunks/ssr/_bcaea66b._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_bcfa8457._.js +9 -0
- package/web/.next/server/chunks/ssr/_bcfa8457._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_ca0aa7f0._.js +1 -1
- package/web/.next/server/chunks/ssr/_ca0aa7f0._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_cb5a021e._.js +1 -1
- package/web/.next/server/chunks/ssr/_cb5a021e._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_cfbd1d7e._.js +1 -1
- package/web/.next/server/chunks/ssr/_cfbd1d7e._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_d86175ae._.js +1 -1
- package/web/.next/server/chunks/ssr/_d86175ae._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_d8bedf13._.js +1 -1
- package/web/.next/server/chunks/ssr/_d8bedf13._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_d90b0a06._.js +3 -0
- package/web/.next/server/chunks/ssr/_d90b0a06._.js.map +1 -0
- package/web/.next/server/chunks/ssr/{_b354e40a._.js → _ddbf84e9._.js} +2 -2
- package/web/.next/server/chunks/ssr/{_b354e40a._.js.map → _ddbf84e9._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/_fa7efce3._.js +2 -2
- package/web/.next/server/chunks/ssr/_fa7efce3._.js.map +1 -1
- package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js +1 -1
- package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js.map +1 -1
- package/web/.next/server/chunks/ssr/node_modules__pnpm_8ec2c790._.js +1 -1
- package/web/.next/server/chunks/ssr/node_modules__pnpm_8ec2c790._.js.map +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_baaca5d5._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_ca99d62d._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_ca99d62d._.js.map +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_895e5bfa._.js +3 -0
- package/web/.next/server/chunks/ssr/src_presentation_web_components_895e5bfa._.js.map +1 -0
- package/web/.next/server/chunks/ssr/src_presentation_web_components_a5e6c910._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_a5e6c910._.js.map +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js.map +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_features_tools_tools-page-client_tsx_3d0aa70c._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_features_tools_tools-page-client_tsx_3d0aa70c._.js.map +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_db9fa0c2._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_db9fa0c2._.js.map +1 -1
- package/web/.next/server/chunks/ssr/translations_23dd5e7e._.js +3 -0
- package/web/.next/server/chunks/ssr/translations_23dd5e7e._.js.map +1 -0
- package/web/.next/server/pages/500.html +2 -2
- package/web/.next/server/server-reference-manifest.js +1 -1
- package/web/.next/server/server-reference-manifest.json +45 -45
- package/web/.next/static/chunks/{3e1e0f9bde3530d2.js → 08ff9ace090d2691.js} +1 -1
- package/web/.next/static/chunks/{b4cde06eff374c59.js → 0a79dfbb8486b66e.js} +2 -2
- package/web/.next/static/chunks/19591a6c619a8d84.js +7 -0
- package/web/.next/static/chunks/1c541c77fae77297.js +1 -0
- package/web/.next/static/chunks/2273b81cd7c7d2af.css +1 -0
- package/web/.next/static/chunks/{688971d5bad5dc7c.js → 3deefc76ea55047c.js} +1 -1
- package/web/.next/static/chunks/42484808c3fdd6f1.js +1 -0
- package/web/.next/static/chunks/443f46d9ffb173d9.js +5 -0
- package/web/.next/static/chunks/{11091b676d1b3bd4.js → 47477ed4c5871747.js} +1 -1
- package/web/.next/static/chunks/4864ff06a738d58b.js +1 -0
- package/web/.next/static/chunks/{5064470ab185e453.js → 6a12dec4a63ed342.js} +2 -2
- package/web/.next/static/chunks/{22c459f1877b1e4f.js → 74db65fa7bfb80bd.js} +1 -1
- package/web/.next/static/chunks/9061f08ab7e537a8.js +1 -0
- package/web/.next/static/chunks/91c1a0ccc964c832.js +2 -0
- package/web/.next/static/chunks/{37156b1c0646309f.js → b820b3d89776f2ae.js} +1 -1
- package/web/.next/static/chunks/c142797526c0a85c.js +1 -0
- package/web/.next/static/chunks/{baa593a4681fc66e.js → c66b8a09a10d8855.js} +1 -1
- package/web/.next/static/chunks/{f98f811478ff3d9e.js → c9ead31f0a1c2de1.js} +1 -1
- package/web/.next/static/chunks/cf55aeccca2297f0.js +1 -0
- package/web/.next/static/chunks/d2cbeefbc8967b16.js +1 -0
- package/web/.next/static/chunks/d5366257d6b9f855.js +1 -0
- package/web/.next/static/chunks/{5ae60a052ab5f437.js → d6e702c209c413ce.js} +2 -2
- package/web/.next/static/chunks/f8e198917b279786.js +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0b150ddf._.js +0 -3
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0b150ddf._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__17ed7ed1._.js +0 -4
- package/web/.next/server/chunks/ssr/[root-of-the-server]__28d0d265._.js +0 -4
- package/web/.next/server/chunks/ssr/[root-of-the-server]__28d0d265._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__42bf1807._.js +0 -4
- package/web/.next/server/chunks/ssr/[root-of-the-server]__88f7e8e6._.js +0 -4
- package/web/.next/server/chunks/ssr/[root-of-the-server]__f80bfc75._.js +0 -4
- package/web/.next/server/chunks/ssr/_08dc06df._.js +0 -3
- package/web/.next/server/chunks/ssr/_140901ed._.js +0 -4
- package/web/.next/server/chunks/ssr/_140901ed._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_4b432739._.js +0 -3
- package/web/.next/server/chunks/ssr/_4b432739._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_507a8382._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_8219712a._.js +0 -3
- package/web/.next/server/chunks/ssr/_8219712a._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_d4b20e29._.js +0 -3
- package/web/.next/server/chunks/ssr/_d4b20e29._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_e9a73a63._.js +0 -9
- package/web/.next/server/chunks/ssr/_e9a73a63._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_324a47da._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_324a47da._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_cdc632e3.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_cdc632e3.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_39ca0924.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_39ca0924.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_357e3eb0._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_components_357e3eb0._.js.map +0 -1
- package/web/.next/static/chunks/0104ee32c0b12767.js +0 -7
- package/web/.next/static/chunks/1555e75b3393cfe1.js +0 -1
- package/web/.next/static/chunks/4b2c4a5c35ebb70d.js +0 -1
- package/web/.next/static/chunks/697bbb4ddfc7aed8.js +0 -1
- package/web/.next/static/chunks/8590bd2e69b24b9e.css +0 -1
- package/web/.next/static/chunks/88a729f218d9628b.js +0 -5
- package/web/.next/static/chunks/88ffe4a8760a3559.js +0 -1
- package/web/.next/static/chunks/8ba1c07ef18b15a9.js +0 -1
- package/web/.next/static/chunks/92629ccb27a1bdb9.js +0 -2
- package/web/.next/static/chunks/ae30b66927c676ff.js +0 -1
- package/web/.next/static/chunks/cd54b758f58061d0.js +0 -1
- package/web/.next/static/chunks/f5c527d3f8699035.js +0 -1
- /package/web/.next/static/{N3SkMLMrYUFai4W2zwMGS → t8-30La5Z2OhsRJq4XLko}/_buildManifest.js +0 -0
- /package/web/.next/static/{N3SkMLMrYUFai4W2zwMGS → t8-30La5Z2OhsRJq4XLko}/_clientMiddlewareManifest.json +0 -0
- /package/web/.next/static/{N3SkMLMrYUFai4W2zwMGS → t8-30La5Z2OhsRJq4XLko}/_ssgManifest.js +0 -0
|
@@ -17,18 +17,20 @@ import { container } from '../../../../../packages/core/src/infrastructure/di/co
|
|
|
17
17
|
import { ShowFeatureUseCase } from '../../../../../packages/core/src/application/use-cases/features/show-feature.use-case.js';
|
|
18
18
|
import { messages } from '../../ui/index.js';
|
|
19
19
|
import { viewLog } from '../log-viewer.js';
|
|
20
|
+
import { getCliI18n } from '../../i18n.js';
|
|
20
21
|
export function createLogsCommand() {
|
|
22
|
+
const t = getCliI18n().t;
|
|
21
23
|
return new Command('logs')
|
|
22
|
-
.description('
|
|
23
|
-
.argument('<id>',
|
|
24
|
-
.option('-f, --follow',
|
|
25
|
-
.option('-n, --lines <count>', '
|
|
24
|
+
.description(t('cli:commands.feat.logs.description'))
|
|
25
|
+
.argument('<id>', t('cli:commands.feat.logs.idArgument'))
|
|
26
|
+
.option('-f, --follow', t('cli:commands.feat.logs.followOption'))
|
|
27
|
+
.option('-n, --lines <count>', t('cli:commands.feat.logs.linesOption'), '0')
|
|
26
28
|
.action(async (id, opts) => {
|
|
27
29
|
try {
|
|
28
30
|
const useCase = container.resolve(ShowFeatureUseCase);
|
|
29
31
|
const feature = await useCase.execute(id);
|
|
30
32
|
if (!feature.agentRunId) {
|
|
31
|
-
messages.error(
|
|
33
|
+
messages.error(t('cli:commands.feat.logs.noAgentRun', { name: feature.name }));
|
|
32
34
|
process.exitCode = 1;
|
|
33
35
|
return;
|
|
34
36
|
}
|
|
@@ -45,7 +47,7 @@ export function createLogsCommand() {
|
|
|
45
47
|
}
|
|
46
48
|
catch (error) {
|
|
47
49
|
const err = error instanceof Error ? error : new Error(String(error));
|
|
48
|
-
messages.error('
|
|
50
|
+
messages.error(t('cli:commands.feat.logs.failedToRead'), err);
|
|
49
51
|
process.exitCode = 1;
|
|
50
52
|
}
|
|
51
53
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ls.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/ls.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAGH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"ls.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/ls.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAGH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AA0J/F,8EAA8E;AAC9E,wBAAgB,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,MAAM,CAOhD;AAiBD,UAAU,KAAK;IACb,OAAO,EAAE,OAAO,CAAC;IACjB,GAAG,EAAE,QAAQ,GAAG,IAAI,CAAC;IACrB,MAAM,EAAE,WAAW,EAAE,CAAC;CACvB;AAED,UAAU,QAAQ;IAChB,KAAK,EAAE,KAAK,CAAC;IACb,QAAQ,EAAE,QAAQ,EAAE,CAAC;CACtB;AAED,UAAU,SAAS;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,QAAQ,EAAE,CAAC;CACnB;AAED,UAAU,OAAO;IACf,KAAK,EAAE,KAAK,CAAC;IACb,YAAY,EAAE,OAAO,EAAE,CAAC;IACxB,MAAM,EAAE,OAAO,CAAC;CACjB;AAED;;;;GAIG;AACH,wBAAgB,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAgCtD;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,SAAS,EAAE,CA8B9E;AAED,kEAAkE;AAClE,wBAAgB,WAAW,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,YAAY,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,CAWjF;AAED,sEAAsE;AACtE,wBAAgB,eAAe,CAAC,YAAY,EAAE,OAAO,EAAE,EAAE,MAAM,EAAE,OAAO,GAAG,MAAM,CAOhF;AAQD,yDAAyD;AACzD,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,CAazE;AAeD,wBAAgB,eAAe,IAAI,OAAO,CAoFzC"}
|
|
@@ -15,6 +15,7 @@ import { Command } from 'commander';
|
|
|
15
15
|
import { container } from '../../../../../packages/core/src/infrastructure/di/container.js';
|
|
16
16
|
import { ListFeaturesUseCase } from '../../../../../packages/core/src/application/use-cases/features/list-features.use-case.js';
|
|
17
17
|
import { colors, symbols, messages, fmt } from '../../ui/index.js';
|
|
18
|
+
import { getCliI18n } from '../../i18n.js';
|
|
18
19
|
/** Map graph node names to human-readable phase labels (active). */
|
|
19
20
|
const NODE_TO_PHASE = {
|
|
20
21
|
analyze: 'Analyzing',
|
|
@@ -292,11 +293,12 @@ function countFeatures(groups) {
|
|
|
292
293
|
return count;
|
|
293
294
|
}
|
|
294
295
|
export function createLsCommand() {
|
|
296
|
+
const t = getCliI18n().t;
|
|
295
297
|
return new Command('ls')
|
|
296
|
-
.description('
|
|
297
|
-
.option('-r, --repo <path>', '
|
|
298
|
-
.option('--include-deleted', '
|
|
299
|
-
.option('--show-archived', '
|
|
298
|
+
.description(t('cli:commands.feat.ls.description'))
|
|
299
|
+
.option('-r, --repo <path>', t('cli:commands.feat.ls.repoOption'))
|
|
300
|
+
.option('--include-deleted', t('cli:commands.feat.ls.includeDeletedOption'))
|
|
301
|
+
.option('--show-archived', t('cli:commands.feat.ls.showArchivedOption'))
|
|
300
302
|
.action(async (options) => {
|
|
301
303
|
try {
|
|
302
304
|
const useCase = container.resolve(ListFeaturesUseCase);
|
|
@@ -324,20 +326,20 @@ export function createLsCommand() {
|
|
|
324
326
|
const total = countFeatures(groups);
|
|
325
327
|
if (total === 0) {
|
|
326
328
|
messages.newline();
|
|
327
|
-
messages.info('
|
|
329
|
+
messages.info(t('cli:commands.feat.ls.noFeatures'));
|
|
328
330
|
messages.newline();
|
|
329
331
|
return;
|
|
330
332
|
}
|
|
331
333
|
const lines = [];
|
|
332
334
|
lines.push('');
|
|
333
|
-
lines.push(` ${fmt.heading(
|
|
335
|
+
lines.push(` ${fmt.heading(t('cli:commands.feat.ls.featuresHeading', { count: String(total) }))}`);
|
|
334
336
|
lines.push('');
|
|
335
337
|
// Column headers
|
|
336
|
-
const h1 = colors.muted('
|
|
337
|
-
const h2 = colors.muted('
|
|
338
|
-
const h3 = colors.muted('
|
|
339
|
-
const h4 = colors.muted('
|
|
340
|
-
const h5 = colors.muted('
|
|
338
|
+
const h1 = colors.muted(t('cli:commands.feat.ls.nameHeader').padEnd(FIRST_COL_WIDTH));
|
|
339
|
+
const h2 = colors.muted(t('cli:commands.feat.ls.statusHeader').padEnd(STATUS_WIDTH));
|
|
340
|
+
const h3 = colors.muted(t('cli:commands.feat.ls.gatesHeader').padEnd(GATES_WIDTH));
|
|
341
|
+
const h4 = colors.muted(t('cli:commands.feat.ls.elapsedHeader').padEnd(ELAPSED_WIDTH));
|
|
342
|
+
const h5 = colors.muted(t('cli:commands.feat.ls.doneHeader'));
|
|
341
343
|
lines.push(` ${h1} ${h2} ${h3} ${h4} ${h5}`);
|
|
342
344
|
for (const group of groups) {
|
|
343
345
|
lines.push('');
|
|
@@ -353,7 +355,7 @@ export function createLsCommand() {
|
|
|
353
355
|
}
|
|
354
356
|
catch (error) {
|
|
355
357
|
const err = error instanceof Error ? error : new Error(String(error));
|
|
356
|
-
messages.error('
|
|
358
|
+
messages.error(t('cli:commands.feat.ls.failedToList'), err);
|
|
357
359
|
process.exitCode = 1;
|
|
358
360
|
}
|
|
359
361
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"new.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/new.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"new.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/new.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AA8DpC;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,OAAO,CA8J1C"}
|
|
@@ -17,6 +17,7 @@ import { container } from '../../../../../packages/core/src/infrastructure/di/co
|
|
|
17
17
|
import { CreateFeatureUseCase } from '../../../../../packages/core/src/application/use-cases/features/create/create-feature.use-case.js';
|
|
18
18
|
import { SdlcLifecycle } from '../../../../../packages/core/src/domain/generated/output.js';
|
|
19
19
|
import { colors, messages, spinner } from '../../ui/index.js';
|
|
20
|
+
import { getCliI18n } from '../../i18n.js';
|
|
20
21
|
import { getShepHomeDir } from '../../../../../packages/core/src/infrastructure/services/filesystem/shep-directory.service.js';
|
|
21
22
|
import { getSettings, hasSettings } from '../../../../../packages/core/src/infrastructure/services/settings.service.js';
|
|
22
23
|
import { CheckOnboardingStatusUseCase } from '../../../../../packages/core/src/application/use-cases/settings/check-onboarding-status.use-case.js';
|
|
@@ -43,22 +44,23 @@ function getWorkflowDefaults() {
|
|
|
43
44
|
* Create the feat new command
|
|
44
45
|
*/
|
|
45
46
|
export function createNewCommand() {
|
|
47
|
+
const t = getCliI18n().t;
|
|
46
48
|
return new Command('new')
|
|
47
|
-
.description('
|
|
48
|
-
.argument('<description>', '
|
|
49
|
-
.option('-r, --repo <path>',
|
|
50
|
-
.option('--push', '
|
|
51
|
-
.option('--pr',
|
|
52
|
-
.option('--no-pr', '
|
|
53
|
-
.option('--allow-prd', '
|
|
54
|
-
.option('--allow-plan', '
|
|
55
|
-
.option('--allow-merge', '
|
|
56
|
-
.option('--allow-all',
|
|
57
|
-
.option('--parent <fid>',
|
|
58
|
-
.option('--pending', '
|
|
59
|
-
.option('--fast', '
|
|
60
|
-
.option('--model <model>', '
|
|
61
|
-
.option('--attach <path>', '
|
|
49
|
+
.description(t('cli:commands.feat.new.description'))
|
|
50
|
+
.argument('<description>', t('cli:commands.feat.new.descriptionArgument'))
|
|
51
|
+
.option('-r, --repo <path>', t('cli:commands.feat.new.repoOption'))
|
|
52
|
+
.option('--push', t('cli:commands.feat.new.pushOption'))
|
|
53
|
+
.option('--pr', t('cli:commands.feat.new.prOption'))
|
|
54
|
+
.option('--no-pr', t('cli:commands.feat.new.noPrOption'))
|
|
55
|
+
.option('--allow-prd', t('cli:commands.feat.new.allowPrdOption'))
|
|
56
|
+
.option('--allow-plan', t('cli:commands.feat.new.allowPlanOption'))
|
|
57
|
+
.option('--allow-merge', t('cli:commands.feat.new.allowMergeOption'))
|
|
58
|
+
.option('--allow-all', t('cli:commands.feat.new.allowAllOption'))
|
|
59
|
+
.option('--parent <fid>', t('cli:commands.feat.new.parentOption'))
|
|
60
|
+
.option('--pending', t('cli:commands.feat.new.pendingOption'))
|
|
61
|
+
.option('--fast', t('cli:commands.feat.new.fastOption'))
|
|
62
|
+
.option('--model <model>', t('cli:commands.feat.new.modelOption'))
|
|
63
|
+
.option('--attach <path>', t('cli:commands.feat.new.attachOption'), collect, [])
|
|
62
64
|
.action(async (description, options) => {
|
|
63
65
|
try {
|
|
64
66
|
// First-run onboarding gate — only for interactive terminals
|
|
@@ -88,7 +90,7 @@ export function createNewCommand() {
|
|
|
88
90
|
const featureRepo = container.resolve('IFeatureRepository');
|
|
89
91
|
const parentFeature = await featureRepo.findByIdPrefix(options.parent);
|
|
90
92
|
if (!parentFeature) {
|
|
91
|
-
messages.error(
|
|
93
|
+
messages.error(t('cli:commands.feat.new.parentNotFound', { id: options.parent }));
|
|
92
94
|
process.exitCode = 1;
|
|
93
95
|
return;
|
|
94
96
|
}
|
|
@@ -100,14 +102,14 @@ export function createNewCommand() {
|
|
|
100
102
|
for (const raw of options.attach) {
|
|
101
103
|
const resolved = resolve(raw);
|
|
102
104
|
if (!existsSync(resolved)) {
|
|
103
|
-
messages.error(
|
|
105
|
+
messages.error(t('cli:commands.feat.new.attachmentNotFound', { path: resolved }));
|
|
104
106
|
process.exitCode = 1;
|
|
105
107
|
return;
|
|
106
108
|
}
|
|
107
109
|
attachmentPaths.push(resolved);
|
|
108
110
|
}
|
|
109
111
|
}
|
|
110
|
-
const result = await spinner('
|
|
112
|
+
const result = await spinner(t('cli:commands.feat.new.spinnerText'), () => useCase.execute({
|
|
111
113
|
userInput: description,
|
|
112
114
|
repositoryPath: repoPath,
|
|
113
115
|
approvalGates,
|
|
@@ -127,30 +129,34 @@ export function createNewCommand() {
|
|
|
127
129
|
if (warning) {
|
|
128
130
|
messages.warning(warning);
|
|
129
131
|
}
|
|
130
|
-
messages.success('
|
|
132
|
+
messages.success(t('cli:commands.feat.new.featureCreated'));
|
|
131
133
|
if (feature.lifecycle === SdlcLifecycle.Blocked) {
|
|
132
|
-
messages.info(
|
|
134
|
+
messages.info(t('cli:commands.feat.new.blockedInfo'));
|
|
133
135
|
}
|
|
134
136
|
if (feature.lifecycle === SdlcLifecycle.Pending) {
|
|
135
|
-
messages.info(
|
|
137
|
+
messages.info(t('cli:commands.feat.new.pendingInfo', {
|
|
138
|
+
command: colors.accent(`shep feat start ${feature.id.slice(0, 8)}`),
|
|
139
|
+
}));
|
|
136
140
|
}
|
|
137
|
-
console.log(` ${colors.muted('
|
|
138
|
-
console.log(` ${colors.muted('
|
|
139
|
-
console.log(` ${colors.muted('
|
|
140
|
-
console.log(` ${colors.muted('
|
|
141
|
-
console.log(` ${colors.muted('
|
|
141
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.idLabel'))} ${colors.accent(feature.id)}`);
|
|
142
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.nameLabel'))} ${feature.name}`);
|
|
143
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.branchLabel'))} ${colors.accent(feature.branch)}`);
|
|
144
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.statusLabel'))} ${feature.lifecycle}`);
|
|
145
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.worktreeLabel'))} ${worktreePath}`);
|
|
142
146
|
if (feature.specPath) {
|
|
143
|
-
console.log(` ${colors.muted('
|
|
147
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.specLabel'))} ${feature.specPath}`);
|
|
144
148
|
}
|
|
145
149
|
if (feature.agentRunId) {
|
|
146
150
|
const agentStatus = feature.lifecycle === SdlcLifecycle.Pending
|
|
147
|
-
? colors.muted('
|
|
148
|
-
: colors.success('
|
|
149
|
-
console.log(` ${colors.muted('
|
|
151
|
+
? colors.muted(t('cli:commands.feat.new.pendingStatus'))
|
|
152
|
+
: colors.success(t('cli:commands.feat.new.spawnedStatus'));
|
|
153
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.agentLabel'))} ${agentStatus} (run ${feature.agentRunId.slice(0, 8)})`);
|
|
150
154
|
}
|
|
151
155
|
if (push || openPr) {
|
|
152
|
-
const pushHint = openPr
|
|
153
|
-
|
|
156
|
+
const pushHint = openPr
|
|
157
|
+
? t('cli:commands.feat.new.pushPr')
|
|
158
|
+
: t('cli:commands.feat.new.pushOnly');
|
|
159
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.pushLabel'))} ${pushHint}`);
|
|
154
160
|
}
|
|
155
161
|
const approved = [
|
|
156
162
|
approvalGates.allowPrd && 'PRD',
|
|
@@ -158,16 +164,16 @@ export function createNewCommand() {
|
|
|
158
164
|
approvalGates.allowMerge && 'Merge',
|
|
159
165
|
].filter(Boolean);
|
|
160
166
|
const hint = approved.length === 3
|
|
161
|
-
? '
|
|
167
|
+
? t('cli:commands.feat.new.fullyAutonomous')
|
|
162
168
|
: approved.length === 0
|
|
163
|
-
? '
|
|
164
|
-
:
|
|
165
|
-
console.log(` ${colors.muted('
|
|
169
|
+
? t('cli:commands.feat.new.pauseAfterEvery')
|
|
170
|
+
: t('cli:commands.feat.new.autoApprove', { approved: approved.join(', ') });
|
|
171
|
+
console.log(` ${colors.muted(t('cli:commands.feat.new.reviewLabel'))} ${hint}`);
|
|
166
172
|
messages.newline();
|
|
167
173
|
}
|
|
168
174
|
catch (error) {
|
|
169
175
|
const err = error instanceof Error ? error : new Error(String(error));
|
|
170
|
-
messages.error('
|
|
176
|
+
messages.error(t('cli:commands.feat.new.failedToCreate'), err);
|
|
171
177
|
process.exitCode = 1;
|
|
172
178
|
}
|
|
173
179
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reject.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/reject.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"reject.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/reject.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AASpC,wBAAgB,mBAAmB,IAAI,OAAO,CA+C7C"}
|
|
@@ -12,11 +12,13 @@ import { container } from '../../../../../packages/core/src/infrastructure/di/co
|
|
|
12
12
|
import { RejectAgentRunUseCase } from '../../../../../packages/core/src/application/use-cases/agents/reject-agent-run.use-case.js';
|
|
13
13
|
import { resolveWaitingFeature } from './resolve-waiting-feature.js';
|
|
14
14
|
import { colors, messages } from '../../ui/index.js';
|
|
15
|
+
import { getCliI18n } from '../../i18n.js';
|
|
15
16
|
export function createRejectCommand() {
|
|
17
|
+
const t = getCliI18n().t;
|
|
16
18
|
return new Command('reject')
|
|
17
|
-
.description('
|
|
18
|
-
.argument('[id]',
|
|
19
|
-
.requiredOption('--reason <text>',
|
|
19
|
+
.description(t('cli:commands.feat.reject.description'))
|
|
20
|
+
.argument('[id]', t('cli:commands.feat.reject.idArgument'))
|
|
21
|
+
.requiredOption('--reason <text>', t('cli:commands.feat.reject.reasonOption'))
|
|
20
22
|
.action(async (featureId, options) => {
|
|
21
23
|
try {
|
|
22
24
|
const featureRepo = container.resolve('IFeatureRepository');
|
|
@@ -34,18 +36,18 @@ export function createRejectCommand() {
|
|
|
34
36
|
throw new Error(result.reason);
|
|
35
37
|
}
|
|
36
38
|
messages.newline();
|
|
37
|
-
messages.warning(
|
|
38
|
-
console.log(` ${colors.muted('
|
|
39
|
-
console.log(` ${colors.muted('
|
|
39
|
+
messages.warning(t('cli:commands.feat.reject.rejectedWarning', { name: feature.name }));
|
|
40
|
+
console.log(` ${colors.muted(t('cli:commands.feat.reject.reasonLabel'))} ${options.reason}`);
|
|
41
|
+
console.log(` ${colors.muted(t('cli:commands.feat.reject.iterationLabel'))} ${result.iteration}`);
|
|
40
42
|
if (result.iterationWarning) {
|
|
41
|
-
messages.warning('
|
|
43
|
+
messages.warning(t('cli:commands.feat.reject.iterationWarning'));
|
|
42
44
|
}
|
|
43
|
-
console.log(` ${colors.muted('
|
|
45
|
+
console.log(` ${colors.muted(t('cli:commands.feat.reject.agentLabel'))} ${t('cli:commands.feat.reject.agentRerunning')}`);
|
|
44
46
|
messages.newline();
|
|
45
47
|
}
|
|
46
48
|
catch (error) {
|
|
47
49
|
const err = error instanceof Error ? error : new Error(String(error));
|
|
48
|
-
messages.error('
|
|
50
|
+
messages.error(t('cli:commands.feat.reject.failedToReject'), err);
|
|
49
51
|
process.exitCode = 1;
|
|
50
52
|
}
|
|
51
53
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resolve-waiting-feature.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/resolve-waiting-feature.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAEtE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yEAAyE,CAAC;AAClH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qEAAqE,CAAC;
|
|
1
|
+
{"version":3,"file":"resolve-waiting-feature.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/resolve-waiting-feature.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAEtE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yEAAyE,CAAC;AAClH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qEAAqE,CAAC;AAG/G,MAAM,WAAW,4BAA4B;IAC3C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,kBAAkB,CAAC;IAChC,OAAO,EAAE,mBAAmB,CAAC;CAC9B;AAED,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,OAAO,CAAC;IACjB,GAAG,EAAE,QAAQ,CAAC;CACf;AAED;;;;;;;GAOG;AACH,wBAAsB,qBAAqB,CACzC,OAAO,EAAE,4BAA4B,GACpC,OAAO,CAAC,sBAAsB,CAAC,CAOjC"}
|
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
* feature that is currently waiting for human approval.
|
|
7
7
|
*/
|
|
8
8
|
import { AgentRunStatus } from '../../../../../packages/core/src/domain/generated/output.js';
|
|
9
|
+
import { getCliI18n } from '../../i18n.js';
|
|
9
10
|
/**
|
|
10
11
|
* Resolve the target feature waiting for approval.
|
|
11
12
|
*
|
|
@@ -22,16 +23,20 @@ export async function resolveWaitingFeature(options) {
|
|
|
22
23
|
return resolveAuto(repoPath, featureRepo, runRepo);
|
|
23
24
|
}
|
|
24
25
|
async function resolveExplicit(featureId, featureRepo, runRepo) {
|
|
26
|
+
const t = getCliI18n().t;
|
|
25
27
|
const feature = (await featureRepo.findById(featureId)) ?? (await featureRepo.findByIdPrefix(featureId));
|
|
26
28
|
if (!feature) {
|
|
27
|
-
throw new Error(
|
|
29
|
+
throw new Error(t('cli:commands.feat.resolveWaiting.featureNotFound', { id: featureId }));
|
|
28
30
|
}
|
|
29
31
|
if (!feature.agentRunId) {
|
|
30
|
-
throw new Error(
|
|
32
|
+
throw new Error(t('cli:commands.feat.resolveWaiting.noAgentRun', { name: feature.name }));
|
|
31
33
|
}
|
|
32
34
|
const run = await runRepo.findById(feature.agentRunId);
|
|
33
35
|
if (!run || run.status !== AgentRunStatus.waitingApproval) {
|
|
34
|
-
throw new Error(
|
|
36
|
+
throw new Error(t('cli:commands.feat.resolveWaiting.notWaitingForApproval', {
|
|
37
|
+
name: feature.name,
|
|
38
|
+
status: run?.status ?? 'unknown',
|
|
39
|
+
}));
|
|
35
40
|
}
|
|
36
41
|
return { feature, run };
|
|
37
42
|
}
|
|
@@ -47,11 +52,13 @@ async function resolveAuto(repoPath, featureRepo, runRepo) {
|
|
|
47
52
|
}
|
|
48
53
|
}
|
|
49
54
|
if (waiting.length === 0) {
|
|
50
|
-
|
|
55
|
+
const t = getCliI18n().t;
|
|
56
|
+
throw new Error(t('cli:commands.feat.resolveWaiting.noFeaturesWaiting'));
|
|
51
57
|
}
|
|
52
58
|
if (waiting.length > 1) {
|
|
59
|
+
const t = getCliI18n().t;
|
|
53
60
|
const names = waiting.map((w) => ` - ${w.feature.name} (${w.feature.id.slice(0, 8)})`);
|
|
54
|
-
throw new Error(
|
|
61
|
+
throw new Error(`${t('cli:commands.feat.resolveWaiting.multipleFeaturesWaiting')}\n${names.join('\n')}`);
|
|
55
62
|
}
|
|
56
63
|
return waiting[0];
|
|
57
64
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resume.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/resume.command.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"resume.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/resume.command.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,wBAAgB,mBAAmB,IAAI,OAAO,CAyB7C"}
|
|
@@ -10,23 +10,25 @@ import { Command } from 'commander';
|
|
|
10
10
|
import { container } from '../../../../../packages/core/src/infrastructure/di/container.js';
|
|
11
11
|
import { ResumeFeatureUseCase } from '../../../../../packages/core/src/application/use-cases/features/resume-feature.use-case.js';
|
|
12
12
|
import { colors, messages } from '../../ui/index.js';
|
|
13
|
+
import { getCliI18n } from '../../i18n.js';
|
|
13
14
|
export function createResumeCommand() {
|
|
15
|
+
const t = getCliI18n().t;
|
|
14
16
|
return new Command('resume')
|
|
15
|
-
.description('
|
|
16
|
-
.argument('<id>',
|
|
17
|
+
.description(t('cli:commands.feat.resume.description'))
|
|
18
|
+
.argument('<id>', t('cli:commands.feat.resume.idArgument'))
|
|
17
19
|
.action(async (id) => {
|
|
18
20
|
try {
|
|
19
21
|
const useCase = container.resolve(ResumeFeatureUseCase);
|
|
20
22
|
const { feature, newRun } = await useCase.execute(id);
|
|
21
23
|
messages.newline();
|
|
22
|
-
messages.success('
|
|
23
|
-
console.log(` ${colors.muted('
|
|
24
|
-
console.log(` ${colors.muted('
|
|
24
|
+
messages.success(t('cli:commands.feat.resume.agentResumed'));
|
|
25
|
+
console.log(` ${colors.muted(t('cli:commands.feat.resume.featureLabel'))} ${feature.name}`);
|
|
26
|
+
console.log(` ${colors.muted(t('cli:commands.feat.resume.runIdLabel'))} ${colors.accent(newRun.id.substring(0, 8))}`);
|
|
25
27
|
messages.newline();
|
|
26
28
|
}
|
|
27
29
|
catch (error) {
|
|
28
30
|
const err = error instanceof Error ? error : new Error(String(error));
|
|
29
|
-
messages.error('
|
|
31
|
+
messages.error(t('cli:commands.feat.resume.failedToResume'), err);
|
|
30
32
|
process.exitCode = 1;
|
|
31
33
|
}
|
|
32
34
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"review.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/review.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"review.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/review.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAkEpC,wBAAgB,mBAAmB,IAAI,OAAO,CA4F7C"}
|
|
@@ -18,6 +18,7 @@ import { prdReviewWizard } from '../../../tui/wizards/prd-review.wizard.js';
|
|
|
18
18
|
import { planReviewWizard } from '../../../tui/wizards/plan-review.wizard.js';
|
|
19
19
|
import { mergeReviewWizard } from '../../../tui/wizards/merge-review.wizard.js';
|
|
20
20
|
import { colors, messages } from '../../ui/index.js';
|
|
21
|
+
import { getCliI18n } from '../../i18n.js';
|
|
21
22
|
function parsePhase(runResult) {
|
|
22
23
|
return runResult?.startsWith('node:') ? runResult.slice(5) : 'unknown';
|
|
23
24
|
}
|
|
@@ -53,9 +54,10 @@ function phaseNextStep(phase) {
|
|
|
53
54
|
}
|
|
54
55
|
}
|
|
55
56
|
export function createReviewCommand() {
|
|
57
|
+
const t = getCliI18n().t;
|
|
56
58
|
return new Command('review')
|
|
57
|
-
.description('
|
|
58
|
-
.argument('[id]',
|
|
59
|
+
.description(t('cli:commands.feat.review.description'))
|
|
60
|
+
.argument('[id]', t('cli:commands.feat.review.idArgument'))
|
|
59
61
|
.action(async (featureId) => {
|
|
60
62
|
try {
|
|
61
63
|
const featureRepo = container.resolve('IFeatureRepository');
|
|
@@ -69,9 +71,9 @@ export function createReviewCommand() {
|
|
|
69
71
|
});
|
|
70
72
|
const phase = parsePhase(run.result);
|
|
71
73
|
messages.newline();
|
|
72
|
-
messages.info(
|
|
73
|
-
console.log(` ${colors.muted('
|
|
74
|
-
console.log(` ${colors.muted('
|
|
74
|
+
messages.info(t('cli:commands.feat.review.reviewing', { name: colors.accent(feature.name) }));
|
|
75
|
+
console.log(` ${colors.muted(t('cli:commands.feat.review.phaseLabel'))} ${colors.warning(phase)}`);
|
|
76
|
+
console.log(` ${colors.muted(t('cli:commands.feat.review.branchLabel'))} ${colors.accent(feature.branch)}`);
|
|
75
77
|
messages.newline();
|
|
76
78
|
const wizardResult = await runPhaseWizard(phase, feature.id, repoPath);
|
|
77
79
|
if (wizardResult.action === 'approve') {
|
|
@@ -82,14 +84,14 @@ export function createReviewCommand() {
|
|
|
82
84
|
const approveResult = await approveUseCase.execute(run.id, payload);
|
|
83
85
|
if (approveResult.approved) {
|
|
84
86
|
messages.newline();
|
|
85
|
-
messages.success(
|
|
87
|
+
messages.success(t('cli:commands.feat.review.approvedSuccess', { name: feature.name }));
|
|
86
88
|
if (wizardResult.changedSelections && wizardResult.changedSelections.length > 0) {
|
|
87
|
-
console.log(` ${colors.muted('
|
|
89
|
+
console.log(` ${colors.muted(t('cli:commands.feat.review.changesLabel'))} ${t('cli:commands.feat.review.changesUpdated', { count: wizardResult.changedSelections.length })}`);
|
|
88
90
|
}
|
|
89
91
|
if (wizardResult.feedback) {
|
|
90
|
-
console.log(` ${colors.muted('
|
|
92
|
+
console.log(` ${colors.muted(t('cli:commands.feat.review.commentLabel'))} ${wizardResult.feedback}`);
|
|
91
93
|
}
|
|
92
|
-
console.log(` ${colors.muted('
|
|
94
|
+
console.log(` ${colors.muted(t('cli:commands.feat.review.agentLabel'))} ${t('cli:commands.feat.review.proceedingTo', { phase: phaseNextStep(phase) })}`);
|
|
93
95
|
messages.newline();
|
|
94
96
|
}
|
|
95
97
|
else {
|
|
@@ -101,13 +103,13 @@ export function createReviewCommand() {
|
|
|
101
103
|
const rejectResult = await rejectUseCase.execute(run.id, wizardResult.feedback);
|
|
102
104
|
if (rejectResult.rejected) {
|
|
103
105
|
messages.newline();
|
|
104
|
-
messages.warning(
|
|
105
|
-
console.log(` ${colors.muted('
|
|
106
|
-
console.log(` ${colors.muted('
|
|
106
|
+
messages.warning(t('cli:commands.feat.review.rejectedWarning', { name: feature.name }));
|
|
107
|
+
console.log(` ${colors.muted(t('cli:commands.feat.review.feedbackLabel'))} ${wizardResult.feedback}`);
|
|
108
|
+
console.log(` ${colors.muted(t('cli:commands.feat.review.iterationLabel'))} ${rejectResult.iteration}`);
|
|
107
109
|
if (rejectResult.iterationWarning) {
|
|
108
|
-
messages.warning('
|
|
110
|
+
messages.warning(t('cli:commands.feat.review.iterationWarning'));
|
|
109
111
|
}
|
|
110
|
-
console.log(` ${colors.muted('
|
|
112
|
+
console.log(` ${colors.muted(t('cli:commands.feat.review.agentLabel'))} ${t('cli:commands.feat.review.agentRerunning', { phase })}`);
|
|
111
113
|
messages.newline();
|
|
112
114
|
}
|
|
113
115
|
else {
|
|
@@ -117,7 +119,7 @@ export function createReviewCommand() {
|
|
|
117
119
|
}
|
|
118
120
|
catch (error) {
|
|
119
121
|
const err = error instanceof Error ? error : new Error(String(error));
|
|
120
|
-
messages.error('
|
|
122
|
+
messages.error(t('cli:commands.feat.review.failedToReview'), err);
|
|
121
123
|
process.exitCode = 1;
|
|
122
124
|
}
|
|
123
125
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"show.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/show.command.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,OAAO,KAAK,EAEV,QAAQ,EACR,WAAW,EACX,sBAAsB,EACvB,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"show.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/show.command.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,OAAO,KAAK,EAEV,QAAQ,EACR,WAAW,EACX,sBAAsB,EACvB,MAAM,8BAA8B,CAAC;AA2OtC;;;GAGG;AACH,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,WAAW,EAAE,EACtB,UAAU,EAAE,QAAQ,GAAG,IAAI,EAC3B,UAAU,GAAE,sBAAsB,EAAO,GACxC,MAAM,EAAE,CAkJV;AAED,wBAAgB,iBAAiB,IAAI,OAAO,CAgO3C"}
|