@shepai/cli 1.155.0-pr485.4c45fca → 1.155.0-pr486.e53674d

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (537) hide show
  1. package/apis/json-schema/UserProfile.yaml +0 -3
  2. package/dist/packages/core/src/domain/generated/output.d.ts +0 -14
  3. package/dist/packages/core/src/domain/generated/output.d.ts.map +1 -1
  4. package/dist/packages/core/src/domain/generated/output.js +0 -11
  5. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts +0 -1
  6. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts.map +1 -1
  7. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.js +2 -4
  8. package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.d.ts.map +1 -1
  9. package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.js +2 -3
  10. package/dist/packages/core/src/infrastructure/services/tool-installer/tool-installer.service.d.ts.map +1 -1
  11. package/dist/packages/core/src/infrastructure/services/tool-installer/tool-installer.service.js +1 -3
  12. package/dist/packages/core/src/infrastructure/services/tool-installer/tools/claude-code.json +4 -3
  13. package/dist/src/presentation/cli/commands/_serve.command.d.ts.map +1 -1
  14. package/dist/src/presentation/cli/commands/_serve.command.js +3 -5
  15. package/dist/src/presentation/cli/commands/agent/approve.command.d.ts.map +1 -1
  16. package/dist/src/presentation/cli/commands/agent/approve.command.js +4 -9
  17. package/dist/src/presentation/cli/commands/agent/delete.command.d.ts.map +1 -1
  18. package/dist/src/presentation/cli/commands/agent/delete.command.js +5 -9
  19. package/dist/src/presentation/cli/commands/agent/index.d.ts.map +1 -1
  20. package/dist/src/presentation/cli/commands/agent/index.js +1 -3
  21. package/dist/src/presentation/cli/commands/agent/logs.command.d.ts.map +1 -1
  22. package/dist/src/presentation/cli/commands/agent/logs.command.js +5 -7
  23. package/dist/src/presentation/cli/commands/agent/ls.command.d.ts.map +1 -1
  24. package/dist/src/presentation/cli/commands/agent/ls.command.js +10 -12
  25. package/dist/src/presentation/cli/commands/agent/reject.command.d.ts.map +1 -1
  26. package/dist/src/presentation/cli/commands/agent/reject.command.js +5 -10
  27. package/dist/src/presentation/cli/commands/agent/resolve-run.d.ts.map +1 -1
  28. package/dist/src/presentation/cli/commands/agent/resolve-run.js +2 -7
  29. package/dist/src/presentation/cli/commands/agent/show.command.d.ts.map +1 -1
  30. package/dist/src/presentation/cli/commands/agent/show.command.js +6 -8
  31. package/dist/src/presentation/cli/commands/agent/stop.command.d.ts.map +1 -1
  32. package/dist/src/presentation/cli/commands/agent/stop.command.js +4 -9
  33. package/dist/src/presentation/cli/commands/daemon/start-daemon.d.ts.map +1 -1
  34. package/dist/src/presentation/cli/commands/daemon/start-daemon.js +8 -10
  35. package/dist/src/presentation/cli/commands/daemon/stop-daemon.d.ts.map +1 -1
  36. package/dist/src/presentation/cli/commands/daemon/stop-daemon.js +3 -5
  37. package/dist/src/presentation/cli/commands/feat/adopt.command.d.ts.map +1 -1
  38. package/dist/src/presentation/cli/commands/feat/adopt.command.js +12 -14
  39. package/dist/src/presentation/cli/commands/feat/approve.command.d.ts.map +1 -1
  40. package/dist/src/presentation/cli/commands/feat/approve.command.js +6 -8
  41. package/dist/src/presentation/cli/commands/feat/archive.command.d.ts.map +1 -1
  42. package/dist/src/presentation/cli/commands/feat/archive.command.js +8 -10
  43. package/dist/src/presentation/cli/commands/feat/del.command.d.ts.map +1 -1
  44. package/dist/src/presentation/cli/commands/feat/del.command.js +15 -17
  45. package/dist/src/presentation/cli/commands/feat/index.d.ts.map +1 -1
  46. package/dist/src/presentation/cli/commands/feat/index.js +1 -2
  47. package/dist/src/presentation/cli/commands/feat/logs.command.d.ts.map +1 -1
  48. package/dist/src/presentation/cli/commands/feat/logs.command.js +6 -8
  49. package/dist/src/presentation/cli/commands/feat/ls.command.d.ts.map +1 -1
  50. package/dist/src/presentation/cli/commands/feat/ls.command.js +12 -14
  51. package/dist/src/presentation/cli/commands/feat/new.command.d.ts.map +1 -1
  52. package/dist/src/presentation/cli/commands/feat/new.command.js +37 -43
  53. package/dist/src/presentation/cli/commands/feat/reject.command.d.ts.map +1 -1
  54. package/dist/src/presentation/cli/commands/feat/reject.command.js +9 -11
  55. package/dist/src/presentation/cli/commands/feat/resolve-waiting-feature.d.ts.map +1 -1
  56. package/dist/src/presentation/cli/commands/feat/resolve-waiting-feature.js +5 -12
  57. package/dist/src/presentation/cli/commands/feat/resume.command.d.ts.map +1 -1
  58. package/dist/src/presentation/cli/commands/feat/resume.command.js +6 -8
  59. package/dist/src/presentation/cli/commands/feat/review.command.d.ts.map +1 -1
  60. package/dist/src/presentation/cli/commands/feat/review.command.js +15 -17
  61. package/dist/src/presentation/cli/commands/feat/show.command.d.ts.map +1 -1
  62. package/dist/src/presentation/cli/commands/feat/show.command.js +45 -89
  63. package/dist/src/presentation/cli/commands/feat/start.command.d.ts.map +1 -1
  64. package/dist/src/presentation/cli/commands/feat/start.command.js +10 -12
  65. package/dist/src/presentation/cli/commands/feat/unarchive.command.d.ts.map +1 -1
  66. package/dist/src/presentation/cli/commands/feat/unarchive.command.js +6 -8
  67. package/dist/src/presentation/cli/commands/ide-open.command.d.ts.map +1 -1
  68. package/dist/src/presentation/cli/commands/ide-open.command.js +5 -10
  69. package/dist/src/presentation/cli/commands/install.command.d.ts.map +1 -1
  70. package/dist/src/presentation/cli/commands/install.command.js +21 -29
  71. package/dist/src/presentation/cli/commands/log-viewer.d.ts.map +1 -1
  72. package/dist/src/presentation/cli/commands/log-viewer.js +3 -6
  73. package/dist/src/presentation/cli/commands/repo/add.command.d.ts.map +1 -1
  74. package/dist/src/presentation/cli/commands/repo/add.command.js +10 -12
  75. package/dist/src/presentation/cli/commands/repo/index.d.ts.map +1 -1
  76. package/dist/src/presentation/cli/commands/repo/index.js +1 -3
  77. package/dist/src/presentation/cli/commands/repo/ls.command.d.ts.map +1 -1
  78. package/dist/src/presentation/cli/commands/repo/ls.command.js +9 -11
  79. package/dist/src/presentation/cli/commands/repo/resolve-repository.d.ts.map +1 -1
  80. package/dist/src/presentation/cli/commands/repo/resolve-repository.js +2 -7
  81. package/dist/src/presentation/cli/commands/repo/show.command.d.ts.map +1 -1
  82. package/dist/src/presentation/cli/commands/repo/show.command.js +10 -21
  83. package/dist/src/presentation/cli/commands/restart.command.d.ts.map +1 -1
  84. package/dist/src/presentation/cli/commands/restart.command.js +4 -6
  85. package/dist/src/presentation/cli/commands/run.command.d.ts.map +1 -1
  86. package/dist/src/presentation/cli/commands/run.command.js +17 -21
  87. package/dist/src/presentation/cli/commands/session/index.d.ts.map +1 -1
  88. package/dist/src/presentation/cli/commands/session/index.js +1 -3
  89. package/dist/src/presentation/cli/commands/session/ls.command.d.ts.map +1 -1
  90. package/dist/src/presentation/cli/commands/session/ls.command.js +9 -11
  91. package/dist/src/presentation/cli/commands/session/show.command.d.ts.map +1 -1
  92. package/dist/src/presentation/cli/commands/session/show.command.js +18 -26
  93. package/dist/src/presentation/cli/commands/settings/agent.command.d.ts.map +1 -1
  94. package/dist/src/presentation/cli/commands/settings/agent.command.js +8 -12
  95. package/dist/src/presentation/cli/commands/settings/ide.command.d.ts.map +1 -1
  96. package/dist/src/presentation/cli/commands/settings/ide.command.js +7 -13
  97. package/dist/src/presentation/cli/commands/settings/index.d.ts +0 -1
  98. package/dist/src/presentation/cli/commands/settings/index.d.ts.map +1 -1
  99. package/dist/src/presentation/cli/commands/settings/index.js +3 -7
  100. package/dist/src/presentation/cli/commands/settings/init.command.d.ts.map +1 -1
  101. package/dist/src/presentation/cli/commands/settings/init.command.js +7 -8
  102. package/dist/src/presentation/cli/commands/settings/model.command.d.ts.map +1 -1
  103. package/dist/src/presentation/cli/commands/settings/model.command.js +6 -7
  104. package/dist/src/presentation/cli/commands/settings/show.command.d.ts.map +1 -1
  105. package/dist/src/presentation/cli/commands/settings/show.command.js +3 -4
  106. package/dist/src/presentation/cli/commands/settings/workflow.command.d.ts.map +1 -1
  107. package/dist/src/presentation/cli/commands/settings/workflow.command.js +18 -20
  108. package/dist/src/presentation/cli/commands/start.command.d.ts.map +1 -1
  109. package/dist/src/presentation/cli/commands/start.command.js +3 -5
  110. package/dist/src/presentation/cli/commands/status.command.d.ts.map +1 -1
  111. package/dist/src/presentation/cli/commands/status.command.js +24 -32
  112. package/dist/src/presentation/cli/commands/stop.command.d.ts.map +1 -1
  113. package/dist/src/presentation/cli/commands/stop.command.js +2 -4
  114. package/dist/src/presentation/cli/commands/tools.command.d.ts.map +1 -1
  115. package/dist/src/presentation/cli/commands/tools.command.js +4 -8
  116. package/dist/src/presentation/cli/commands/ui.command.d.ts.map +1 -1
  117. package/dist/src/presentation/cli/commands/ui.command.js +10 -12
  118. package/dist/src/presentation/cli/commands/upgrade.command.d.ts.map +1 -1
  119. package/dist/src/presentation/cli/commands/upgrade.command.js +13 -18
  120. package/dist/src/presentation/cli/commands/version.command.d.ts.map +1 -1
  121. package/dist/src/presentation/cli/commands/version.command.js +3 -5
  122. package/dist/src/presentation/cli/index.js +1 -13
  123. package/dist/src/presentation/cli/ui/install-messages.d.ts.map +1 -1
  124. package/dist/src/presentation/cli/ui/install-messages.js +6 -16
  125. package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts +31 -13
  126. package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts.map +1 -1
  127. package/dist/src/presentation/tui/prompts/agent-select.prompt.js +15 -17
  128. package/dist/src/presentation/tui/prompts/auth-method.prompt.d.ts +11 -7
  129. package/dist/src/presentation/tui/prompts/auth-method.prompt.d.ts.map +1 -1
  130. package/dist/src/presentation/tui/prompts/auth-method.prompt.js +5 -7
  131. package/dist/src/presentation/tui/prompts/ide-select.prompt.d.ts.map +1 -1
  132. package/dist/src/presentation/tui/prompts/ide-select.prompt.js +1 -2
  133. package/dist/src/presentation/tui/prompts/prd-review-summary.prompt.d.ts.map +1 -1
  134. package/dist/src/presentation/tui/prompts/prd-review-summary.prompt.js +6 -8
  135. package/dist/src/presentation/tui/wizards/agent-config.wizard.d.ts.map +1 -1
  136. package/dist/src/presentation/tui/wizards/agent-config.wizard.js +1 -2
  137. package/dist/src/presentation/tui/wizards/github-import.wizard.d.ts.map +1 -1
  138. package/dist/src/presentation/tui/wizards/github-import.wizard.js +11 -15
  139. package/dist/src/presentation/tui/wizards/merge-review.wizard.d.ts.map +1 -1
  140. package/dist/src/presentation/tui/wizards/merge-review.wizard.js +8 -10
  141. package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.d.ts.map +1 -1
  142. package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.js +7 -10
  143. package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.d.ts +41 -0
  144. package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.d.ts.map +1 -1
  145. package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.js +15 -15
  146. package/dist/src/presentation/tui/wizards/plan-review.wizard.d.ts.map +1 -1
  147. package/dist/src/presentation/tui/wizards/plan-review.wizard.js +8 -10
  148. package/dist/src/presentation/tui/wizards/prd-review.wizard.d.ts.map +1 -1
  149. package/dist/src/presentation/tui/wizards/prd-review.wizard.js +2 -3
  150. package/dist/src/presentation/web/app/layout.d.ts.map +1 -1
  151. package/dist/src/presentation/web/app/layout.js +2 -5
  152. package/dist/src/presentation/web/components/assistant-ui/thread.js +5 -5
  153. package/dist/src/presentation/web/components/common/attachment-chip/attachment-chip.js +1 -1
  154. package/dist/src/presentation/web/components/common/base-drawer/base-drawer.js +1 -1
  155. package/dist/src/presentation/web/components/common/ci-status-badge/ci-status-badge.js +3 -3
  156. package/dist/src/presentation/web/components/common/control-center-drawer/adopt-branch-drawer.js +4 -4
  157. package/dist/src/presentation/web/components/common/control-center-drawer/repository-drawer-client.js +1 -1
  158. package/dist/src/presentation/web/components/common/delete-feature-dialog/delete-feature-dialog.d.ts.map +1 -1
  159. package/dist/src/presentation/web/components/common/delete-feature-dialog/delete-feature-dialog.js +1 -3
  160. package/dist/src/presentation/web/components/common/deployment-status-badge/deployment-status-badge.js +2 -2
  161. package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.js +2 -2
  162. package/dist/src/presentation/web/components/common/empty-state/empty-state.stories.js +2 -2
  163. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.js +2 -2
  164. package/dist/src/presentation/web/components/common/feature-drawer-tabs/activity-tab.js +4 -4
  165. package/dist/src/presentation/web/components/common/feature-drawer-tabs/branch-sync-status.js +1 -1
  166. package/dist/src/presentation/web/components/common/feature-drawer-tabs/feature-drawer-tabs.js +1 -1
  167. package/dist/src/presentation/web/components/common/feature-drawer-tabs/log-tab.js +1 -1
  168. package/dist/src/presentation/web/components/common/feature-drawer-tabs/overview-tab.js +1 -1
  169. package/dist/src/presentation/web/components/common/feature-list-item/feature-list-item.js +1 -1
  170. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts +2 -2
  171. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts.map +1 -1
  172. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.js +22 -22
  173. package/dist/src/presentation/web/components/common/feature-node/feature-node.js +4 -4
  174. package/dist/src/presentation/web/components/common/feature-node/feature-sessions-dropdown.js +1 -1
  175. package/dist/src/presentation/web/components/common/feature-status-group/feature-status-group.js +1 -1
  176. package/dist/src/presentation/web/components/common/github-import-dialog/github-repo-browser.js +1 -1
  177. package/dist/src/presentation/web/components/common/merge-review/diff-view.js +2 -2
  178. package/dist/src/presentation/web/components/common/merge-review/merge-review.js +2 -2
  179. package/dist/src/presentation/web/components/common/prd-questionnaire/prd-questionnaire.js +3 -3
  180. package/dist/src/presentation/web/components/common/reject-feedback-dialog/reject-feedback-dialog.d.ts.map +1 -1
  181. package/dist/src/presentation/web/components/common/reject-feedback-dialog/reject-feedback-dialog.js +4 -6
  182. package/dist/src/presentation/web/components/common/repository-node/repository-node.js +3 -3
  183. package/dist/src/presentation/web/components/common/server-log-viewer/server-log-viewer.js +1 -1
  184. package/dist/src/presentation/web/components/common/task-progress-view/task-progress-view.js +2 -2
  185. package/dist/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.js +2 -2
  186. package/dist/src/presentation/web/components/common/version-badge/version-badge.js +1 -1
  187. package/dist/src/presentation/web/components/features/chat/ChatMessageBubble.js +4 -4
  188. package/dist/src/presentation/web/components/features/chat/ChatMessageList.js +1 -1
  189. package/dist/src/presentation/web/components/features/chat/ChatTab.js +1 -1
  190. package/dist/src/presentation/web/components/features/control-center/control-center-empty-state.d.ts.map +1 -1
  191. package/dist/src/presentation/web/components/features/control-center/control-center-empty-state.js +11 -15
  192. package/dist/src/presentation/web/components/features/control-center/welcome-agent-setup.d.ts.map +1 -1
  193. package/dist/src/presentation/web/components/features/control-center/welcome-agent-setup.js +6 -8
  194. package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.d.ts.map +1 -1
  195. package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.js +1 -3
  196. package/dist/src/presentation/web/components/features/features-canvas/features-canvas.d.ts.map +1 -1
  197. package/dist/src/presentation/web/components/features/features-canvas/features-canvas.js +2 -4
  198. package/dist/src/presentation/web/components/features/settings/AgentModelPicker/index.js +2 -2
  199. package/dist/src/presentation/web/components/features/settings/ModelPicker/index.js +2 -2
  200. package/dist/src/presentation/web/components/features/settings/agent-settings-section.js +1 -1
  201. package/dist/src/presentation/web/components/features/settings/settings-page-client.d.ts.map +1 -1
  202. package/dist/src/presentation/web/components/features/settings/settings-page-client.js +77 -89
  203. package/dist/src/presentation/web/components/features/settings/timeout-slider.js +1 -1
  204. package/dist/src/presentation/web/components/features/skills/category-filter.js +1 -1
  205. package/dist/src/presentation/web/components/features/skills/skills-page-client.js +1 -1
  206. package/dist/src/presentation/web/components/features/tools/tool-card.js +1 -1
  207. package/dist/src/presentation/web/components/features/tools/tool-detail-drawer.js +2 -2
  208. package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.d.ts.map +1 -1
  209. package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.js +4 -10
  210. package/dist/src/presentation/web/components/ui/alert-dialog.js +1 -1
  211. package/dist/src/presentation/web/components/ui/alert.js +1 -1
  212. package/dist/src/presentation/web/components/ui/checkbox-group.js +1 -1
  213. package/dist/src/presentation/web/components/ui/command.js +1 -1
  214. package/dist/src/presentation/web/components/ui/dialog.d.ts.map +1 -1
  215. package/dist/src/presentation/web/components/ui/dialog.js +2 -2
  216. package/dist/src/presentation/web/components/ui/dialog.stories.js +1 -1
  217. package/dist/src/presentation/web/components/ui/drawer.js +1 -1
  218. package/dist/src/presentation/web/components/ui/dropdown-menu.js +6 -6
  219. package/dist/src/presentation/web/components/ui/scroll-area.js +1 -1
  220. package/dist/src/presentation/web/components/ui/select.js +1 -1
  221. package/dist/src/presentation/web/components/ui/sheet.js +1 -1
  222. package/dist/src/presentation/web/components/ui/sidebar.js +6 -6
  223. package/dist/src/presentation/web/hooks/use-sound-action.stories.js +1 -1
  224. package/dist/tsconfig.build.tsbuildinfo +1 -1
  225. package/package.json +2 -4
  226. package/web/.next/BUILD_ID +1 -1
  227. package/web/.next/build-manifest.json +2 -2
  228. package/web/.next/fallback-build-manifest.json +2 -2
  229. package/web/.next/prerender-manifest.json +3 -3
  230. package/web/.next/required-server-files.js +1 -1
  231. package/web/.next/required-server-files.json +1 -1
  232. package/web/.next/server/app/(dashboard)/@drawer/adopt/page/server-reference-manifest.json +28 -28
  233. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js +3 -3
  234. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js.nft.json +1 -1
  235. package/web/.next/server/app/(dashboard)/@drawer/adopt/page_client-reference-manifest.js +1 -1
  236. package/web/.next/server/app/(dashboard)/@drawer/chat/page/server-reference-manifest.json +26 -26
  237. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js +3 -3
  238. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js.nft.json +1 -1
  239. package/web/.next/server/app/(dashboard)/@drawer/chat/page_client-reference-manifest.js +1 -1
  240. package/web/.next/server/app/(dashboard)/@drawer/create/page/server-reference-manifest.json +29 -29
  241. package/web/.next/server/app/(dashboard)/@drawer/create/page.js +3 -3
  242. package/web/.next/server/app/(dashboard)/@drawer/create/page.js.nft.json +1 -1
  243. package/web/.next/server/app/(dashboard)/@drawer/create/page_client-reference-manifest.js +1 -1
  244. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page/server-reference-manifest.json +36 -36
  245. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js +4 -4
  246. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  247. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  248. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page/server-reference-manifest.json +36 -36
  249. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js +4 -4
  250. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js.nft.json +1 -1
  251. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page_client-reference-manifest.js +1 -1
  252. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +26 -26
  253. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js +3 -3
  254. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  255. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  256. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page/server-reference-manifest.json +26 -26
  257. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js +3 -3
  258. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js.nft.json +1 -1
  259. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  260. package/web/.next/server/app/(dashboard)/chat/page/server-reference-manifest.json +26 -26
  261. package/web/.next/server/app/(dashboard)/chat/page.js +3 -3
  262. package/web/.next/server/app/(dashboard)/chat/page.js.nft.json +1 -1
  263. package/web/.next/server/app/(dashboard)/chat/page_client-reference-manifest.js +1 -1
  264. package/web/.next/server/app/(dashboard)/create/page/server-reference-manifest.json +29 -29
  265. package/web/.next/server/app/(dashboard)/create/page.js +3 -3
  266. package/web/.next/server/app/(dashboard)/create/page.js.nft.json +1 -1
  267. package/web/.next/server/app/(dashboard)/create/page_client-reference-manifest.js +1 -1
  268. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page/server-reference-manifest.json +36 -36
  269. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js +4 -4
  270. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  271. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  272. package/web/.next/server/app/(dashboard)/feature/[featureId]/page/server-reference-manifest.json +36 -36
  273. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js +4 -4
  274. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js.nft.json +1 -1
  275. package/web/.next/server/app/(dashboard)/feature/[featureId]/page_client-reference-manifest.js +1 -1
  276. package/web/.next/server/app/(dashboard)/page/server-reference-manifest.json +26 -26
  277. package/web/.next/server/app/(dashboard)/page.js +3 -3
  278. package/web/.next/server/app/(dashboard)/page.js.nft.json +1 -1
  279. package/web/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
  280. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +26 -26
  281. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js +3 -3
  282. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  283. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  284. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page/server-reference-manifest.json +26 -26
  285. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js +3 -3
  286. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js.nft.json +1 -1
  287. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  288. package/web/.next/server/app/_global-error.html +2 -2
  289. package/web/.next/server/app/_global-error.rsc +1 -1
  290. package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  291. package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  292. package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  293. package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  294. package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  295. package/web/.next/server/app/_not-found/page/server-reference-manifest.json +5 -5
  296. package/web/.next/server/app/_not-found/page.js +2 -2
  297. package/web/.next/server/app/_not-found/page.js.nft.json +1 -1
  298. package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  299. package/web/.next/server/app/api/attachments/preview/route.js.nft.json +1 -1
  300. package/web/.next/server/app/api/evidence/route.js.nft.json +1 -1
  301. package/web/.next/server/app/api/graph-data/route.js.nft.json +1 -1
  302. package/web/.next/server/app/api/interactive/chat/[featureId]/messages/route.js.nft.json +1 -1
  303. package/web/.next/server/app/settings/page/server-reference-manifest.json +8 -8
  304. package/web/.next/server/app/settings/page.js +2 -2
  305. package/web/.next/server/app/settings/page.js.nft.json +1 -1
  306. package/web/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  307. package/web/.next/server/app/skills/page/server-reference-manifest.json +10 -10
  308. package/web/.next/server/app/skills/page.js +4 -3
  309. package/web/.next/server/app/skills/page.js.nft.json +1 -1
  310. package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
  311. package/web/.next/server/app/tools/page/server-reference-manifest.json +10 -10
  312. package/web/.next/server/app/tools/page.js +4 -3
  313. package/web/.next/server/app/tools/page.js.nft.json +1 -1
  314. package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
  315. package/web/.next/server/app/version/page/server-reference-manifest.json +5 -5
  316. package/web/.next/server/app/version/page.js +2 -2
  317. package/web/.next/server/app/version/page.js.nft.json +1 -1
  318. package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
  319. package/web/.next/server/chunks/[root-of-the-server]__a402b567._.js +1 -1
  320. package/web/.next/server/chunks/[root-of-the-server]__beda892a._.js +1 -1
  321. package/web/.next/server/chunks/[root-of-the-server]__beda892a._.js.map +1 -1
  322. package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js +1 -1
  323. package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js.map +1 -1
  324. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js +1 -1
  325. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js.map +1 -1
  326. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js +2 -2
  327. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js.map +1 -1
  328. package/web/.next/server/chunks/ssr/[root-of-the-server]__0b150ddf._.js +3 -0
  329. package/web/.next/server/chunks/ssr/[root-of-the-server]__0b150ddf._.js.map +1 -0
  330. package/web/.next/server/chunks/ssr/{[root-of-the-server]__27301e38._.js → [root-of-the-server]__17ed7ed1._.js} +2 -2
  331. package/web/.next/server/chunks/ssr/{[root-of-the-server]__27301e38._.js.map → [root-of-the-server]__17ed7ed1._.js.map} +1 -1
  332. package/web/.next/server/chunks/ssr/{[root-of-the-server]__8d27866c._.js → [root-of-the-server]__28d0d265._.js} +3 -3
  333. package/web/.next/server/chunks/ssr/[root-of-the-server]__28d0d265._.js.map +1 -0
  334. package/web/.next/server/chunks/ssr/[root-of-the-server]__357d99f9._.js +1 -1
  335. package/web/.next/server/chunks/ssr/{[root-of-the-server]__6fecf886._.js → [root-of-the-server]__42bf1807._.js} +2 -2
  336. package/web/.next/server/chunks/ssr/{[root-of-the-server]__6fecf886._.js.map → [root-of-the-server]__42bf1807._.js.map} +1 -1
  337. package/web/.next/server/chunks/ssr/[root-of-the-server]__56b70465._.js +1 -1
  338. package/web/.next/server/chunks/ssr/[root-of-the-server]__56b70465._.js.map +1 -1
  339. package/web/.next/server/chunks/ssr/[root-of-the-server]__5edfc56b._.js +1 -1
  340. package/web/.next/server/chunks/ssr/{[root-of-the-server]__209c9597._.js → [root-of-the-server]__88f7e8e6._.js} +2 -2
  341. package/web/.next/server/chunks/ssr/{[root-of-the-server]__209c9597._.js.map → [root-of-the-server]__88f7e8e6._.js.map} +1 -1
  342. package/web/.next/server/chunks/ssr/[root-of-the-server]__8b0aac03._.js +1 -1
  343. package/web/.next/server/chunks/ssr/[root-of-the-server]__c30f1f82._.js +1 -1
  344. package/web/.next/server/chunks/ssr/[root-of-the-server]__c30f1f82._.js.map +1 -1
  345. package/web/.next/server/chunks/ssr/[root-of-the-server]__e91ffd5e._.js +2 -2
  346. package/web/.next/server/chunks/ssr/[root-of-the-server]__e91ffd5e._.js.map +1 -1
  347. package/web/.next/server/chunks/ssr/{[root-of-the-server]__9f3504c7._.js → [root-of-the-server]__f80bfc75._.js} +2 -2
  348. package/web/.next/server/chunks/ssr/{[root-of-the-server]__9f3504c7._.js.map → [root-of-the-server]__f80bfc75._.js.map} +1 -1
  349. package/web/.next/server/chunks/ssr/{[root-of-the-server]__25ee8d4c._.js → [root-of-the-server]__f8dd4422._.js} +2 -2
  350. package/web/.next/server/chunks/ssr/[root-of-the-server]__f8dd4422._.js.map +1 -0
  351. package/web/.next/server/chunks/ssr/_05c23ad9._.js +1 -1
  352. package/web/.next/server/chunks/ssr/_05c23ad9._.js.map +1 -1
  353. package/web/.next/server/chunks/ssr/_16eb4fec._.js +1 -1
  354. package/web/.next/server/chunks/ssr/_16eb4fec._.js.map +1 -1
  355. package/web/.next/server/chunks/ssr/_3a0b989f._.js +2 -2
  356. package/web/.next/server/chunks/ssr/_3a0b989f._.js.map +1 -1
  357. package/web/.next/server/chunks/ssr/_41633e32._.js +3 -0
  358. package/web/.next/server/chunks/ssr/{_28e7429c._.js.map → _41633e32._.js.map} +1 -1
  359. package/web/.next/server/chunks/ssr/_4b432739._.js +3 -0
  360. package/web/.next/server/chunks/ssr/_4b432739._.js.map +1 -0
  361. package/web/.next/server/chunks/ssr/{_b9ba2473._.js → _507a8382._.js} +2 -2
  362. package/web/.next/server/chunks/ssr/_507a8382._.js.map +1 -0
  363. package/web/.next/server/chunks/ssr/_56b9d60f._.js +1 -1
  364. package/web/.next/server/chunks/ssr/_56b9d60f._.js.map +1 -1
  365. package/web/.next/server/chunks/ssr/{_7773b2dc._.js → _59d0f988._.js} +2 -2
  366. package/web/.next/server/chunks/ssr/{_7773b2dc._.js.map → _59d0f988._.js.map} +1 -1
  367. package/web/.next/server/chunks/ssr/_5f69c13f._.js +1 -1
  368. package/web/.next/server/chunks/ssr/_5f69c13f._.js.map +1 -1
  369. package/web/.next/server/chunks/ssr/{_3bcda5d7._.js → _67104d9e._.js} +2 -2
  370. package/web/.next/server/chunks/ssr/{_3bcda5d7._.js.map → _67104d9e._.js.map} +1 -1
  371. package/web/.next/server/chunks/ssr/_7c5b97c6._.js +1 -1
  372. package/web/.next/server/chunks/ssr/_7c5b97c6._.js.map +1 -1
  373. package/web/.next/server/chunks/ssr/_813095ef._.js +4 -0
  374. package/web/.next/server/chunks/ssr/_813095ef._.js.map +1 -0
  375. package/web/.next/server/chunks/ssr/_8219712a._.js +3 -0
  376. package/web/.next/server/chunks/ssr/_8219712a._.js.map +1 -0
  377. package/web/.next/server/chunks/ssr/_82c57f10._.js +1 -1
  378. package/web/.next/server/chunks/ssr/_82c57f10._.js.map +1 -1
  379. package/web/.next/server/chunks/ssr/_8b57edb8._.js +1 -1
  380. package/web/.next/server/chunks/ssr/_8b57edb8._.js.map +1 -1
  381. package/web/.next/server/chunks/ssr/_9495d50b._.js +1 -1
  382. package/web/.next/server/chunks/ssr/_9495d50b._.js.map +1 -1
  383. package/web/.next/server/chunks/ssr/_a0e3f7e4._.js +1 -1
  384. package/web/.next/server/chunks/ssr/_a0e3f7e4._.js.map +1 -1
  385. package/web/.next/server/chunks/ssr/_ac4a3873._.js +1 -1
  386. package/web/.next/server/chunks/ssr/_ac4a3873._.js.map +1 -1
  387. package/web/.next/server/chunks/ssr/_ca0aa7f0._.js +1 -1
  388. package/web/.next/server/chunks/ssr/_ca0aa7f0._.js.map +1 -1
  389. package/web/.next/server/chunks/ssr/_cb5a021e._.js +1 -1
  390. package/web/.next/server/chunks/ssr/_cb5a021e._.js.map +1 -1
  391. package/web/.next/server/chunks/ssr/_cfbd1d7e._.js +1 -1
  392. package/web/.next/server/chunks/ssr/_cfbd1d7e._.js.map +1 -1
  393. package/web/.next/server/chunks/ssr/_d4b20e29._.js +1 -1
  394. package/web/.next/server/chunks/ssr/_d4b20e29._.js.map +1 -1
  395. package/web/.next/server/chunks/ssr/_d86175ae._.js +1 -1
  396. package/web/.next/server/chunks/ssr/_d86175ae._.js.map +1 -1
  397. package/web/.next/server/chunks/ssr/_d8bedf13._.js +1 -1
  398. package/web/.next/server/chunks/ssr/_d8bedf13._.js.map +1 -1
  399. package/web/.next/server/chunks/ssr/_e9a73a63._.js +9 -0
  400. package/web/.next/server/chunks/ssr/_e9a73a63._.js.map +1 -0
  401. package/web/.next/server/chunks/ssr/_fa7efce3._.js +2 -2
  402. package/web/.next/server/chunks/ssr/_fa7efce3._.js.map +1 -1
  403. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js +1 -1
  404. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js.map +1 -1
  405. package/web/.next/server/chunks/ssr/src_presentation_web_324a47da._.js +1 -1
  406. package/web/.next/server/chunks/ssr/src_presentation_web_324a47da._.js.map +1 -1
  407. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_cdc632e3.js +3 -0
  408. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_cdc632e3.js.map +1 -0
  409. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_39ca0924.js +3 -0
  410. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_39ca0924.js.map +1 -0
  411. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_baaca5d5._.js +1 -1
  412. package/web/.next/server/chunks/ssr/src_presentation_web_components_357e3eb0._.js +3 -0
  413. package/web/.next/server/chunks/ssr/src_presentation_web_components_357e3eb0._.js.map +1 -0
  414. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js +1 -1
  415. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js.map +1 -1
  416. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_tools_tools-page-client_tsx_3d0aa70c._.js +1 -1
  417. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_tools_tools-page-client_tsx_3d0aa70c._.js.map +1 -1
  418. package/web/.next/server/chunks/ssr/src_presentation_web_db9fa0c2._.js.map +1 -1
  419. package/web/.next/server/pages/500.html +2 -2
  420. package/web/.next/server/server-reference-manifest.js +1 -1
  421. package/web/.next/server/server-reference-manifest.json +45 -45
  422. package/web/.next/static/chunks/{47477ed4c5871747.js → 11091b676d1b3bd4.js} +1 -1
  423. package/web/.next/static/chunks/125b250c28113507.js +1 -0
  424. package/web/.next/static/chunks/{74db65fa7bfb80bd.js → 22c459f1877b1e4f.js} +1 -1
  425. package/web/.next/static/chunks/2817c3b9d560aaeb.js +1 -0
  426. package/web/.next/static/chunks/{24d5e151f7de6b4c.js → 42e9d0c76e624005.js} +1 -1
  427. package/web/.next/static/chunks/{e4e358c4f67366fd.js → 4b2c4a5c35ebb70d.js} +1 -1
  428. package/web/.next/static/chunks/{d6e702c209c413ce.js → 5ae60a052ab5f437.js} +2 -2
  429. package/web/.next/static/chunks/{3deefc76ea55047c.js → 688971d5bad5dc7c.js} +1 -1
  430. package/web/.next/static/chunks/{1c07a9270515f2e3.js → 6e6cd6218f76e404.js} +2 -2
  431. package/web/.next/static/chunks/7a1a68bdc20f0428.js +1 -0
  432. package/web/.next/static/chunks/8590bd2e69b24b9e.css +1 -0
  433. package/web/.next/static/chunks/{536afd754a63da39.js → 902c670cb337840c.js} +1 -1
  434. package/web/.next/static/chunks/{4978be67c4e6498f.js → a676d236e8214de3.js} +3 -3
  435. package/web/.next/static/chunks/a7c1cddd7d406fb8.js +7 -0
  436. package/web/.next/static/chunks/b3be394b3cc24151.js +1 -0
  437. package/web/.next/static/chunks/b4080e40597d7f8e.js +1 -0
  438. package/web/.next/static/chunks/{bfdb66301af07da1.js → b4cde06eff374c59.js} +2 -2
  439. package/web/.next/static/chunks/cd54b758f58061d0.js +1 -0
  440. package/web/.next/static/chunks/da980f1c277bafcb.js +2 -0
  441. package/web/.next/static/chunks/{b674bc11b321a5ee.js → ea823175bb410162.js} +1 -1
  442. package/apis/json-schema/Language.yaml +0 -13
  443. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.d.ts +0 -14
  444. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.d.ts.map +0 -1
  445. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.js +0 -19
  446. package/dist/src/presentation/cli/commands/settings/language.command.d.ts +0 -14
  447. package/dist/src/presentation/cli/commands/settings/language.command.d.ts.map +0 -1
  448. package/dist/src/presentation/cli/commands/settings/language.command.js +0 -79
  449. package/dist/src/presentation/cli/i18n.d.ts +0 -41
  450. package/dist/src/presentation/cli/i18n.d.ts.map +0 -1
  451. package/dist/src/presentation/cli/i18n.js +0 -100
  452. package/dist/src/presentation/tui/i18n.d.ts +0 -24
  453. package/dist/src/presentation/tui/i18n.d.ts.map +0 -1
  454. package/dist/src/presentation/tui/i18n.js +0 -48
  455. package/dist/src/presentation/web/components/features/settings/language-settings-section.d.ts +0 -5
  456. package/dist/src/presentation/web/components/features/settings/language-settings-section.d.ts.map +0 -1
  457. package/dist/src/presentation/web/components/features/settings/language-settings-section.js +0 -54
  458. package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.d.ts +0 -18
  459. package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.d.ts.map +0 -1
  460. package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.js +0 -36
  461. package/dist/src/presentation/web/components/providers/i18n-provider.d.ts +0 -17
  462. package/dist/src/presentation/web/components/providers/i18n-provider.d.ts.map +0 -1
  463. package/dist/src/presentation/web/components/providers/i18n-provider.js +0 -36
  464. package/dist/src/presentation/web/lib/i18n.d.ts +0 -15
  465. package/dist/src/presentation/web/lib/i18n.d.ts.map +0 -1
  466. package/dist/src/presentation/web/lib/i18n.js +0 -46
  467. package/dist/src/presentation/web/lib/language.d.ts +0 -23
  468. package/dist/src/presentation/web/lib/language.d.ts.map +0 -1
  469. package/dist/src/presentation/web/lib/language.js +0 -37
  470. package/dist/src/presentation/web/lib/rtl-fonts.d.ts +0 -19
  471. package/dist/src/presentation/web/lib/rtl-fonts.d.ts.map +0 -1
  472. package/dist/src/presentation/web/lib/rtl-fonts.js +0 -51
  473. package/dist/translations/ar/cli.json +0 -613
  474. package/dist/translations/ar/common.json +0 -55
  475. package/dist/translations/ar/tui.json +0 -130
  476. package/dist/translations/ar/web.json +0 -320
  477. package/dist/translations/de/cli.json +0 -613
  478. package/dist/translations/de/common.json +0 -55
  479. package/dist/translations/de/tui.json +0 -109
  480. package/dist/translations/de/web.json +0 -306
  481. package/dist/translations/en/cli.json +0 -613
  482. package/dist/translations/en/common.json +0 -55
  483. package/dist/translations/en/tui.json +0 -130
  484. package/dist/translations/en/web.json +0 -320
  485. package/dist/translations/es/cli.json +0 -613
  486. package/dist/translations/es/common.json +0 -55
  487. package/dist/translations/es/tui.json +0 -130
  488. package/dist/translations/es/web.json +0 -320
  489. package/dist/translations/fr/cli.json +0 -613
  490. package/dist/translations/fr/common.json +0 -55
  491. package/dist/translations/fr/tui.json +0 -130
  492. package/dist/translations/fr/web.json +0 -320
  493. package/dist/translations/he/cli.json +0 -613
  494. package/dist/translations/he/common.json +0 -55
  495. package/dist/translations/he/tui.json +0 -130
  496. package/dist/translations/he/web.json +0 -320
  497. package/dist/translations/pt/cli.json +0 -613
  498. package/dist/translations/pt/common.json +0 -55
  499. package/dist/translations/pt/tui.json +0 -130
  500. package/dist/translations/pt/web.json +0 -320
  501. package/dist/translations/ru/cli.json +0 -613
  502. package/dist/translations/ru/common.json +0 -55
  503. package/dist/translations/ru/tui.json +0 -130
  504. package/dist/translations/ru/web.json +0 -320
  505. package/web/.next/server/chunks/ssr/[root-of-the-server]__25ee8d4c._.js.map +0 -1
  506. package/web/.next/server/chunks/ssr/[root-of-the-server]__8d27866c._.js.map +0 -1
  507. package/web/.next/server/chunks/ssr/[root-of-the-server]__bd6ed91a._.js +0 -4
  508. package/web/.next/server/chunks/ssr/[root-of-the-server]__bd6ed91a._.js.map +0 -1
  509. package/web/.next/server/chunks/ssr/[root-of-the-server]__dffa13c5._.js +0 -3
  510. package/web/.next/server/chunks/ssr/[root-of-the-server]__dffa13c5._.js.map +0 -1
  511. package/web/.next/server/chunks/ssr/_0cd9ca53._.js +0 -3
  512. package/web/.next/server/chunks/ssr/_0cd9ca53._.js.map +0 -1
  513. package/web/.next/server/chunks/ssr/_28e7429c._.js +0 -3
  514. package/web/.next/server/chunks/ssr/_470e90f4._.js +0 -9
  515. package/web/.next/server/chunks/ssr/_470e90f4._.js.map +0 -1
  516. package/web/.next/server/chunks/ssr/_5bfcc8de._.js +0 -4
  517. package/web/.next/server/chunks/ssr/_5bfcc8de._.js.map +0 -1
  518. package/web/.next/server/chunks/ssr/_b9ba2473._.js.map +0 -1
  519. package/web/.next/server/chunks/ssr/_d90b0a06._.js +0 -3
  520. package/web/.next/server/chunks/ssr/_d90b0a06._.js.map +0 -1
  521. package/web/.next/server/chunks/ssr/node_modules__pnpm_55cf6695._.js +0 -3
  522. package/web/.next/server/chunks/ssr/node_modules__pnpm_55cf6695._.js.map +0 -1
  523. package/web/.next/server/chunks/ssr/src_presentation_web_components_895e5bfa._.js +0 -3
  524. package/web/.next/server/chunks/ssr/src_presentation_web_components_895e5bfa._.js.map +0 -1
  525. package/web/.next/static/chunks/05c9ed792a1d9056.js +0 -1
  526. package/web/.next/static/chunks/2aada437f51df3e6.js +0 -1
  527. package/web/.next/static/chunks/2eeee9bcbf660a4b.js +0 -1
  528. package/web/.next/static/chunks/4a399ee2a9942a1b.js +0 -1
  529. package/web/.next/static/chunks/70390bd89521bc19.js +0 -1
  530. package/web/.next/static/chunks/8fd082719935d5e6.js +0 -1
  531. package/web/.next/static/chunks/91927044df8e28bb.js +0 -7
  532. package/web/.next/static/chunks/b1b5b0bf84caabd4.js +0 -1
  533. package/web/.next/static/chunks/b68b16b4c3528979.js +0 -2
  534. package/web/.next/static/chunks/d58e68d03d055a9b.css +0 -1
  535. /package/web/.next/static/{Uqo91vsr2HsZrCKrZOYMZ → _5yY0q7bqEA7bwlEo729P}/_buildManifest.js +0 -0
  536. /package/web/.next/static/{Uqo91vsr2HsZrCKrZOYMZ → _5yY0q7bqEA7bwlEo729P}/_clientMiddlewareManifest.json +0 -0
  537. /package/web/.next/static/{Uqo91vsr2HsZrCKrZOYMZ → _5yY0q7bqEA7bwlEo729P}/_ssgManifest.js +0 -0
@@ -5,22 +5,20 @@
5
5
  * Shows approve/reject action with optional comment.
6
6
  */
7
7
  import { select, input } from '@inquirer/prompts';
8
- import { getTuiI18n } from '../i18n.js';
9
8
  import { shepTheme } from '../themes/shep.theme.js';
10
9
  export async function mergeReviewWizard() {
11
- const t = getTuiI18n().t;
12
10
  const action = await select({
13
- message: t('tui:wizards.mergeReview.message'),
11
+ message: 'Review the merge. What would you like to do?',
14
12
  choices: [
15
13
  {
16
- name: t('tui:wizards.mergeReview.approveAndMerge'),
14
+ name: 'Approve and merge',
17
15
  value: 'approve',
18
- description: t('tui:wizards.mergeReview.approveDescription'),
16
+ description: 'Accept the changes and merge the branch',
19
17
  },
20
18
  {
21
- name: t('tui:wizards.mergeReview.reject'),
19
+ name: 'Reject',
22
20
  value: 'reject',
23
- description: t('tui:wizards.mergeReview.rejectDescription'),
21
+ description: 'Provide feedback — implementation will iterate',
24
22
  },
25
23
  ],
26
24
  theme: shepTheme,
@@ -28,14 +26,14 @@ export async function mergeReviewWizard() {
28
26
  let feedback;
29
27
  if (action === 'reject') {
30
28
  feedback = await input({
31
- message: t('tui:wizards.mergeReview.rejectFeedback'),
29
+ message: 'What needs to change before merging?',
32
30
  theme: shepTheme,
33
- validate: (value) => value.trim().length > 0 || t('tui:wizards.mergeReview.feedbackRequired'),
31
+ validate: (value) => value.trim().length > 0 || 'Feedback is required for rejection',
34
32
  });
35
33
  }
36
34
  else {
37
35
  feedback = await input({
38
- message: t('tui:wizards.mergeReview.approveComment'),
36
+ message: 'Any comments? (optional, press Enter to skip)',
39
37
  theme: shepTheme,
40
38
  });
41
39
  if (feedback?.trim().length === 0)
@@ -1 +1 @@
1
- {"version":3,"file":"onboarding.wizard.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/tui/wizards/onboarding/onboarding.wizard.ts"],"names":[],"mappings":"AACA;;;;;;GAMG;AAUH,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AAuBzD;;;;;;;;;GASG;AACH,wBAAsB,gBAAgB,CACpC,SAAS,GAAE,MAAM,OAAO,CAAC,iBAAiB,CAAgB,EAC1D,OAAO,GAAE,MAAM,OAAO,CAAC,MAAM,CAAc,EAC3C,YAAY,GAAE,MAAM,OAAO,CAAC,sBAAsB,CAA2B,GAC5E,OAAO,CAAC,IAAI,CAAC,CAoCf"}
1
+ {"version":3,"file":"onboarding.wizard.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/tui/wizards/onboarding/onboarding.wizard.ts"],"names":[],"mappings":"AACA;;;;;;GAMG;AASH,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AAmBzD;;;;;;;;;GASG;AACH,wBAAsB,gBAAgB,CACpC,SAAS,GAAE,MAAM,OAAO,CAAC,iBAAiB,CAAgB,EAC1D,OAAO,GAAE,MAAM,OAAO,CAAC,MAAM,CAAc,EAC3C,YAAY,GAAE,MAAM,OAAO,CAAC,sBAAsB,CAA2B,GAC5E,OAAO,CAAC,IAAI,CAAC,CAoCf"}
@@ -10,7 +10,6 @@ import pc from 'picocolors';
10
10
  import { container } from '../../../../../packages/core/src/infrastructure/di/container.js';
11
11
  import { CompleteOnboardingUseCase } from '../../../../../packages/core/src/application/use-cases/settings/complete-onboarding.use-case.js';
12
12
  import { resetSettings, initializeSettings } from '../../../../../packages/core/src/infrastructure/services/settings.service.js';
13
- import { getTuiI18n } from '../../i18n.js';
14
13
  import { runAgentStep } from './steps/agent.step.js';
15
14
  import { runIdeStep } from './steps/ide.step.js';
16
15
  import { runWorkflowDefaultsStep } from './steps/workflow-defaults.step.js';
@@ -18,16 +17,14 @@ import { runWorkflowDefaultsStep } from './steps/workflow-defaults.step.js';
18
17
  * Display the welcome banner before the first wizard step.
19
18
  */
20
19
  function showWelcomeBanner() {
21
- const t = getTuiI18n().t;
22
20
  console.log();
23
- console.log(pc.cyan(pc.bold(` ${t('tui:wizards.onboarding.welcomeTitle')}`)));
24
- console.log(pc.dim(` ${t('tui:wizards.onboarding.welcomeSubtitle')}`));
21
+ console.log(pc.cyan(pc.bold(' Welcome to Shep AI CLI')));
22
+ console.log(pc.dim(" Let's set up your environment in 3 quick steps."));
25
23
  console.log();
26
- console.log(pc.yellow(` \u26a0 ${t('tui:wizards.onboarding.prerequisiteWarning')}`) +
27
- pc.bold(t('tui:wizards.onboarding.prerequisiteLabel')) +
28
- pc.dim(` ${t('tui:wizards.onboarding.prerequisiteDescription')}`));
29
- console.log(pc.dim(` ${t('tui:wizards.onboarding.installFrom')}`) +
30
- pc.underline(t('tui:wizards.onboarding.installUrl')));
24
+ console.log(pc.yellow(' Prerequisite: ') +
25
+ pc.bold('GitHub CLI (gh)') +
26
+ pc.dim(' is required for full CI/CD self-healing capabilities.'));
27
+ console.log(pc.dim(' Install it from: ') + pc.underline('https://cli.github.com/'));
31
28
  console.log();
32
29
  }
33
30
  /**
@@ -60,7 +57,7 @@ export async function onboardingWizard(agentStep = runAgentStep, ideStep = runId
60
57
  resetSettings();
61
58
  initializeSettings(updatedSettings);
62
59
  console.log();
63
- console.log(pc.green(` \u2713 ${getTuiI18n().t('tui:wizards.onboarding.setupComplete')}`));
60
+ console.log(pc.green(" Setup complete! You're ready to use Shep."));
64
61
  console.log();
65
62
  }
66
63
  catch (error) {
@@ -51,6 +51,47 @@ export declare function buildWorkflowDefaultsConfig(initial?: Partial<WorkflowDe
51
51
  checked: boolean;
52
52
  })[];
53
53
  };
54
+ /** Static config with all defaults unchecked (used by onboarding). */
55
+ export declare const workflowDefaultsConfig: {
56
+ message: string;
57
+ instructions: string;
58
+ theme: {
59
+ readonly prefix: {
60
+ readonly idle: string;
61
+ readonly done: string;
62
+ };
63
+ readonly style: {
64
+ readonly highlight: import("picocolors/types.js").Formatter;
65
+ readonly answer: import("picocolors/types.js").Formatter;
66
+ };
67
+ };
68
+ choices: ({
69
+ name: string;
70
+ value: "allowPrd";
71
+ description: string;
72
+ checked: boolean;
73
+ } | {
74
+ name: string;
75
+ value: "allowPlan";
76
+ description: string;
77
+ checked: boolean;
78
+ } | {
79
+ name: string;
80
+ value: "allowMerge";
81
+ description: string;
82
+ checked: boolean;
83
+ } | {
84
+ name: string;
85
+ value: "pushOnImplementationComplete";
86
+ description: string;
87
+ checked: boolean;
88
+ } | {
89
+ name: string;
90
+ value: "openPrOnImplementationComplete";
91
+ description: string;
92
+ checked: boolean;
93
+ })[];
94
+ };
54
95
  /**
55
96
  * Runs the workflow defaults step.
56
97
  * Accepts optional initial values to pre-check choices (for reconfiguration).
@@ -1 +1 @@
1
- {"version":3,"file":"workflow-defaults.step.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AAE1D,oCAAoC;AACpC,MAAM,MAAM,kBAAkB,GAC1B,UAAU,GACV,WAAW,GACX,YAAY,GACZ,8BAA8B,GAC9B,gCAAgC,CAAC;AAErC;;;GAGG;AACH,wBAAgB,2BAA2B,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,sBAAsB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAuCpF;AAED;;;;GAIG;AACH,wBAAsB,uBAAuB,CAC3C,OAAO,CAAC,EAAE,OAAO,CAAC,sBAAsB,CAAC,GACxC,OAAO,CAAC,sBAAsB,CAAC,CAYjC"}
1
+ {"version":3,"file":"workflow-defaults.step.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AAE1D,oCAAoC;AACpC,MAAM,MAAM,kBAAkB,GAC1B,UAAU,GACV,WAAW,GACX,YAAY,GACZ,8BAA8B,GAC9B,gCAAgC,CAAC;AAErC;;;GAGG;AACH,wBAAgB,2BAA2B,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,sBAAsB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAsCpF;AAED,sEAAsE;AACtE,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAgC,CAAC;AAEpE;;;;GAIG;AACH,wBAAsB,uBAAuB,CAC3C,OAAO,CAAC,EAAE,OAAO,CAAC,sBAAsB,CAAC,GACxC,OAAO,CAAC,sBAAsB,CAAC,CAYjC"}
@@ -5,59 +5,59 @@
5
5
  * that will apply to all new features.
6
6
  */
7
7
  import { checkbox } from '@inquirer/prompts';
8
- import { getTuiI18n } from '../../../i18n.js';
9
8
  import { shepTheme } from '../../../themes/shep.theme.js';
10
9
  /**
11
10
  * Build checkbox configuration for workflow defaults.
12
11
  * Accepts optional initial values to pre-check choices (for reconfiguration).
13
12
  */
14
13
  export function buildWorkflowDefaultsConfig(initial) {
15
- const t = getTuiI18n().t;
16
14
  return {
17
- message: t('tui:wizards.workflowDefaults.message'),
18
- instructions: t('tui:wizards.workflowDefaults.instructions'),
15
+ message: 'Select workflow defaults for new features',
16
+ instructions: '(Space to toggle, Enter to confirm)',
19
17
  theme: shepTheme,
20
18
  choices: [
21
19
  {
22
- name: t('tui:wizards.workflowDefaults.allowPrd'),
20
+ name: 'Allow PRD',
23
21
  value: 'allowPrd',
24
- description: t('tui:wizards.workflowDefaults.allowPrdDescription'),
22
+ description: 'Auto-approve requirements phase',
25
23
  checked: initial?.allowPrd ?? false,
26
24
  },
27
25
  {
28
- name: t('tui:wizards.workflowDefaults.allowPlan'),
26
+ name: 'Allow Plan',
29
27
  value: 'allowPlan',
30
- description: t('tui:wizards.workflowDefaults.allowPlanDescription'),
28
+ description: 'Auto-approve planning phase',
31
29
  checked: initial?.allowPlan ?? false,
32
30
  },
33
31
  {
34
- name: t('tui:wizards.workflowDefaults.allowMerge'),
32
+ name: 'Allow Merge',
35
33
  value: 'allowMerge',
36
- description: t('tui:wizards.workflowDefaults.allowMergeDescription'),
34
+ description: 'Auto-approve and auto-merge after implementation',
37
35
  checked: initial?.allowMerge ?? false,
38
36
  },
39
37
  {
40
- name: t('tui:wizards.workflowDefaults.pushOnFinish'),
38
+ name: 'Push on finish',
41
39
  value: 'pushOnImplementationComplete',
42
- description: t('tui:wizards.workflowDefaults.pushOnFinishDescription'),
40
+ description: 'Push branch to remote when implementation completes',
43
41
  checked: initial?.pushOnImplementationComplete ?? false,
44
42
  },
45
43
  {
46
- name: t('tui:wizards.workflowDefaults.createPr'),
44
+ name: 'Create PR',
47
45
  value: 'openPrOnImplementationComplete',
48
- description: t('tui:wizards.workflowDefaults.createPrDescription'),
46
+ description: 'Open pull request when implementation completes',
49
47
  checked: initial?.openPrOnImplementationComplete ?? false,
50
48
  },
51
49
  ],
52
50
  };
53
51
  }
52
+ /** Static config with all defaults unchecked (used by onboarding). */
53
+ export const workflowDefaultsConfig = buildWorkflowDefaultsConfig();
54
54
  /**
55
55
  * Runs the workflow defaults step.
56
56
  * Accepts optional initial values to pre-check choices (for reconfiguration).
57
57
  * Returns an object with all 5 boolean flags.
58
58
  */
59
59
  export async function runWorkflowDefaultsStep(initial) {
60
- const config = buildWorkflowDefaultsConfig(initial);
60
+ const config = initial ? buildWorkflowDefaultsConfig(initial) : workflowDefaultsConfig;
61
61
  const selected = await checkbox(config);
62
62
  const selectedSet = new Set(selected);
63
63
  return {
@@ -1 +1 @@
1
- {"version":3,"file":"plan-review.wizard.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/tui/wizards/plan-review.wizard.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAMH,MAAM,MAAM,gBAAgB,GAAG,SAAS,GAAG,QAAQ,CAAC;AAEpD,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,gBAAgB,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAsB,gBAAgB,IAAI,OAAO,CAAC,sBAAsB,CAAC,CAmCxE"}
1
+ {"version":3,"file":"plan-review.wizard.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/tui/wizards/plan-review.wizard.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,MAAM,MAAM,gBAAgB,GAAG,SAAS,GAAG,QAAQ,CAAC;AAEpD,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,gBAAgB,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAsB,gBAAgB,IAAI,OAAO,CAAC,sBAAsB,CAAC,CAkCxE"}
@@ -5,22 +5,20 @@
5
5
  * Shows approve/reject action with optional comment.
6
6
  */
7
7
  import { select, input } from '@inquirer/prompts';
8
- import { getTuiI18n } from '../i18n.js';
9
8
  import { shepTheme } from '../themes/shep.theme.js';
10
9
  export async function planReviewWizard() {
11
- const t = getTuiI18n().t;
12
10
  const action = await select({
13
- message: t('tui:wizards.planReview.message'),
11
+ message: 'Review the implementation plan. What would you like to do?',
14
12
  choices: [
15
13
  {
16
- name: t('tui:wizards.planReview.approveAndContinue'),
14
+ name: 'Approve and continue',
17
15
  value: 'approve',
18
- description: t('tui:wizards.planReview.approveDescription'),
16
+ description: 'Accept the plan and proceed to implementation',
19
17
  },
20
18
  {
21
- name: t('tui:wizards.planReview.rejectAndIterate'),
19
+ name: 'Reject and iterate',
22
20
  value: 'reject',
23
- description: t('tui:wizards.planReview.rejectDescription'),
21
+ description: 'Provide feedback and re-run planning',
24
22
  },
25
23
  ],
26
24
  theme: shepTheme,
@@ -28,14 +26,14 @@ export async function planReviewWizard() {
28
26
  let feedback;
29
27
  if (action === 'reject') {
30
28
  feedback = await input({
31
- message: t('tui:wizards.planReview.rejectFeedback'),
29
+ message: 'What needs to change in the plan?',
32
30
  theme: shepTheme,
33
- validate: (value) => value.trim().length > 0 || t('tui:wizards.planReview.feedbackRequired'),
31
+ validate: (value) => value.trim().length > 0 || 'Feedback is required for rejection',
34
32
  });
35
33
  }
36
34
  else {
37
35
  feedback = await input({
38
- message: t('tui:wizards.planReview.approveComment'),
36
+ message: 'Any comments? (optional, press Enter to skip)',
39
37
  theme: shepTheme,
40
38
  });
41
39
  if (feedback?.trim().length === 0)
@@ -1 +1 @@
1
- {"version":3,"file":"prd-review.wizard.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/tui/wizards/prd-review.wizard.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAIH,OAAO,EAEL,KAAK,YAAY,EAClB,MAAM,yCAAyC,CAAC;AACjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2DAA2D,CAAC;AAC9F,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AAI5E,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,YAAY,CAAC;IACrB,iBAAiB,EAAE,uBAAuB,EAAE,CAAC;IAC7C,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;;;;;;;GAQG;AACH,wBAAsB,eAAe,CAAC,SAAS,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,qBAAqB,CAAC,CA+B/F"}
1
+ {"version":3,"file":"prd-review.wizard.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/tui/wizards/prd-review.wizard.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAIH,OAAO,EAEL,KAAK,YAAY,EAClB,MAAM,yCAAyC,CAAC;AACjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2DAA2D,CAAC;AAC9F,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AAG5E,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,YAAY,CAAC;IACrB,iBAAiB,EAAE,uBAAuB,EAAE,CAAC;IAC7C,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;;;;;;;GAQG;AACH,wBAAsB,eAAe,CAAC,SAAS,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,qBAAqB,CAAC,CA8B/F"}
@@ -8,7 +8,6 @@
8
8
  import { select, input } from '@inquirer/prompts';
9
9
  import { createQuestionSelectConfig } from '../prompts/prd-review-question.prompt.js';
10
10
  import { createReviewActionConfig, } from '../prompts/prd-review-summary.prompt.js';
11
- import { getTuiI18n } from '../i18n.js';
12
11
  import { shepTheme } from '../themes/shep.theme.js';
13
12
  /**
14
13
  * Runs the interactive PRD review wizard.
@@ -36,9 +35,9 @@ export async function prdReviewWizard(questions) {
36
35
  let feedback;
37
36
  if (action === 'reject') {
38
37
  feedback = await input({
39
- message: getTuiI18n().t('tui:prompts.prdReview.feedbackPrompt'),
38
+ message: 'What needs to change? (feedback for re-iteration)',
40
39
  theme: shepTheme,
41
- validate: (value) => value.trim().length > 0 || getTuiI18n().t('tui:prompts.prdReview.feedbackRequired'),
40
+ validate: (value) => value.trim().length > 0 || 'Feedback is required for rejection',
42
41
  });
43
42
  }
44
43
  return { action, changedSelections, feedback };
@@ -1 +1 @@
1
- {"version":3,"file":"layout.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/app/layout.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAErC,OAAO,6BAA6B,CAAC;AACrC,OAAO,2CAA2C,CAAC;AACnD,OAAO,eAAe,CAAC;AASvB,sFAAsF;AACtF,eAAO,MAAM,OAAO,kBAAkB,CAAC;AAEvC,eAAO,MAAM,QAAQ,EAAE,QAkBtB,CAAC;AAEF,wBAA8B,UAAU,CAAC,EACvC,QAAQ,GACT,EAAE,QAAQ,CAAC;IACV,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,CAAC,oDA2BD"}
1
+ {"version":3,"file":"layout.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/app/layout.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAErC,OAAO,6BAA6B,CAAC;AACrC,OAAO,2CAA2C,CAAC;AACnD,OAAO,eAAe,CAAC;AAOvB,sFAAsF;AACtF,eAAO,MAAM,OAAO,kBAAkB,CAAC;AAEvC,eAAO,MAAM,QAAQ,EAAE,QAkBtB,CAAC;AAEF,wBAA8B,UAAU,CAAC,EACvC,QAAQ,GACT,EAAE,QAAQ,CAAC;IACV,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,CAAC,oDAwBD"}
@@ -8,8 +8,6 @@ import { Toaster } from '../components/ui/sonner.js';
8
8
  import { getFeatureFlags } from '../lib/feature-flags.js';
9
9
  import { FeatureFlagsProvider } from '../hooks/feature-flags-context.js';
10
10
  import { QueryProvider } from '../components/providers/query-provider.js';
11
- import { I18nProvider } from '../components/providers/i18n-provider.js';
12
- import { getLanguagePreference } from '../lib/language.js';
13
11
  /** Force dynamic rendering for all pages since they depend on client-side context. */
14
12
  export const dynamic = 'force-dynamic';
15
13
  export const metadata = {
@@ -33,8 +31,7 @@ export const metadata = {
33
31
  export default async function RootLayout({ children, }) {
34
32
  const cookieStore = await cookies();
35
33
  const sidebarOpen = cookieStore.get('shep-sidebar-open')?.value === 'true';
36
- const { language, dir } = getLanguagePreference();
37
- return (_jsxs("html", { lang: language, dir: dir, suppressHydrationWarning: true, children: [_jsx("head", { children: _jsx("script", { dangerouslySetInnerHTML: {
34
+ return (_jsxs("html", { lang: "en", suppressHydrationWarning: true, children: [_jsx("head", { children: _jsx("script", { dangerouslySetInnerHTML: {
38
35
  __html: `(function(){try{var d=document.documentElement,t=localStorage.getItem('shep-theme'),s=window.matchMedia('(prefers-color-scheme: dark)').matches;if(t==='dark'||(t==='system'&&s)||(!t&&s)){d.classList.add('dark')}}catch(e){}})();`,
39
- } }) }), _jsxs("body", { className: "min-h-screen antialiased", children: [_jsx(I18nProvider, { initialLanguage: language, children: _jsx(QueryProvider, { children: _jsx(FeatureFlagsProvider, { flags: getFeatureFlags(), children: _jsx(AppShell, { sidebarOpen: sidebarOpen, children: children }) }) }) }), _jsx(Toaster, { position: "bottom-center" })] })] }));
36
+ } }) }), _jsxs("body", { className: "min-h-screen antialiased", children: [_jsx(QueryProvider, { children: _jsx(FeatureFlagsProvider, { flags: getFeatureFlags(), children: _jsx(AppShell, { sidebarOpen: sidebarOpen, children: children }) }) }), _jsx(Toaster, { position: "bottom-center" })] })] }));
40
37
  }
@@ -23,17 +23,17 @@ const markdownComponents = {
23
23
  }
24
24
  return _jsx(CollapsibleCode, { language: lang, children: children });
25
25
  },
26
- ul: ({ children }) => _jsx("ul", { className: "mb-2 list-disc ps-4 last:mb-0", children: children }),
27
- ol: ({ children }) => _jsx("ol", { className: "mb-2 list-decimal ps-4 last:mb-0", children: children }),
26
+ ul: ({ children }) => _jsx("ul", { className: "mb-2 list-disc pl-4 last:mb-0", children: children }),
27
+ ol: ({ children }) => _jsx("ol", { className: "mb-2 list-decimal pl-4 last:mb-0", children: children }),
28
28
  li: ({ children }) => _jsx("li", { className: "mb-0.5", children: children }),
29
29
  h1: ({ children }) => _jsx("h1", { className: "mb-1 text-base font-bold", children: children }),
30
30
  h2: ({ children }) => _jsx("h2", { className: "mb-1 text-sm font-bold", children: children }),
31
31
  h3: ({ children }) => _jsx("h3", { className: "mb-1 text-sm font-semibold", children: children }),
32
32
  a: ({ children, href }) => (_jsx("a", { href: href, className: "text-blue-500 underline", target: "_blank", rel: "noopener noreferrer", children: children })),
33
- blockquote: ({ children }) => (_jsx("blockquote", { className: "border-muted-foreground/30 my-1 border-s-2 ps-3 italic opacity-80", children: children })),
33
+ blockquote: ({ children }) => (_jsx("blockquote", { className: "border-muted-foreground/30 my-1 border-l-2 pl-3 italic opacity-80", children: children })),
34
34
  table: ({ children }) => (_jsx("div", { className: "my-2 overflow-x-auto", children: _jsx("table", { className: "min-w-full border-collapse text-xs", children: children }) })),
35
35
  thead: ({ children }) => _jsx("thead", { className: "bg-muted/50 border-b", children: children }),
36
- th: ({ children }) => _jsx("th", { className: "px-2 py-1 text-start font-semibold", children: children }),
36
+ th: ({ children }) => _jsx("th", { className: "px-2 py-1 text-left font-semibold", children: children }),
37
37
  td: ({ children }) => _jsx("td", { className: "border-muted border-t px-2 py-1", children: children }),
38
38
  tr: ({ children }) => _jsx("tr", { children: children }),
39
39
  hr: () => _jsx("hr", { className: "border-border/40 my-3 border-t" }),
@@ -94,7 +94,7 @@ function HtmlPreviewBlock({ code, language }) {
94
94
  : 'text-muted-foreground hover:text-foreground'), children: "Preview" }), _jsx("button", { type: "button", onClick: () => {
95
95
  setFullscreenCode(!showPreview);
96
96
  setMaximized(true);
97
- }, className: "text-muted-foreground hover:text-foreground ms-1 rounded p-0.5 transition-colors", title: "Open fullscreen", children: _jsx(Maximize2, { className: "h-3 w-3" }) })] })] }), _jsx("div", { style: { height: 'min(55vh, 450px)' }, children: showPreview ? (_jsx("iframe", { srcDoc: code, sandbox: "allow-scripts", className: "h-full w-full border-0 bg-white", title: "HTML Preview" })) : (_jsx("pre", { className: "h-full overflow-auto p-3 font-mono text-xs leading-relaxed", children: _jsx("code", { children: code }) })) })] }), maximized && typeof document !== 'undefined'
97
+ }, className: "text-muted-foreground hover:text-foreground ml-1 rounded p-0.5 transition-colors", title: "Open fullscreen", children: _jsx(Maximize2, { className: "h-3 w-3" }) })] })] }), _jsx("div", { style: { height: 'min(55vh, 450px)' }, children: showPreview ? (_jsx("iframe", { srcDoc: code, sandbox: "allow-scripts", className: "h-full w-full border-0 bg-white", title: "HTML Preview" })) : (_jsx("pre", { className: "h-full overflow-auto p-3 font-mono text-xs leading-relaxed", children: _jsx("code", { children: code }) })) })] }), maximized && typeof document !== 'undefined'
98
98
  ? createPortal(_jsx("div", { className: "fixed inset-0 z-[9999] flex items-center justify-center bg-black/70 backdrop-blur-sm", onClick: () => setMaximized(false), children: _jsxs("div", { className: "bg-background relative flex h-[95vh] w-[95vw] flex-col overflow-hidden rounded-xl border shadow-2xl", onClick: (e) => e.stopPropagation(), children: [_jsxs("div", { className: "bg-muted/80 flex h-12 shrink-0 items-center justify-between border-b px-5", children: [_jsxs("div", { className: "bg-muted flex items-center gap-0.5 rounded-lg p-1", children: [_jsx("button", { type: "button", onClick: () => setFullscreenCode(false), className: cn('rounded-md px-4 py-1.5 text-sm font-medium transition-all', !fullscreenCode
99
99
  ? 'bg-background text-foreground shadow-sm'
100
100
  : 'text-muted-foreground hover:text-foreground'), children: "Preview" }), _jsx("button", { type: "button", onClick: () => setFullscreenCode(true), className: cn('rounded-md px-4 py-1.5 text-sm font-medium transition-all', fullscreenCode
@@ -33,5 +33,5 @@ export function AttachmentChip({ name, size, mimeType, path, onRemove, loading =
33
33
  const thumbnail = (_jsxs("button", { type: "button", className: "relative block cursor-pointer rounded-md", children: [_jsx("img", { src: previewUrl(path, mimeType), alt: name, title: name, className: "h-12 w-12 rounded-md border object-cover transition-opacity hover:opacity-80" }), notes ? (_jsx("span", { className: "ring-background absolute -right-1 -bottom-1 flex h-4 w-4 items-center justify-center rounded-full bg-amber-500 text-white shadow-sm ring-2", children: _jsx(StickyNoteIcon, { className: "h-2.5 w-2.5" }) })) : null] }));
34
34
  return (_jsx(TooltipProvider, { delayDuration: 200, children: _jsxs(Dialog, { children: [_jsxs(Tooltip, { children: [_jsxs("div", { className: "group relative", children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx(DialogTrigger, { asChild: true, children: thumbnail }) }), !disabled && (_jsx("button", { type: "button", onClick: onRemove, className: "absolute -top-1.5 -right-1.5 hidden h-5 w-5 cursor-pointer items-center justify-center rounded-full bg-black/70 text-white group-hover:flex", "aria-label": `Remove ${name}`, children: _jsx(X, { className: "h-3 w-3" }) }))] }), notes ? (_jsx(TooltipContent, { side: "bottom", className: "max-w-[220px] border border-amber-200 bg-amber-50 text-amber-950 dark:border-amber-800 dark:bg-amber-950 dark:text-amber-100", children: _jsx("p", { className: "line-clamp-3 text-xs leading-snug", children: notes }) })) : null] }), _jsxs(DialogContent, { className: "max-w-3xl gap-0 overflow-hidden border-0 p-0 [&>button:last-child]:!cursor-pointer [&>button:last-child]:!rounded-full [&>button:last-child]:!bg-black/70 [&>button:last-child]:!p-1.5 [&>button:last-child]:!text-white [&>button:last-child]:!opacity-100 [&>button:last-child]:!shadow-lg [&>button:last-child]:!backdrop-blur-md [&>button:last-child]:hover:!bg-black/90", children: [_jsx(VisuallyHidden.Root, { children: _jsxs(DialogTitle, { children: ["Preview: ", name] }) }), _jsx("div", { className: "relative bg-black/90", children: _jsx("img", { src: previewUrl(path, mimeType), alt: name, className: "h-auto max-h-[70vh] w-full object-contain" }) }), _jsxs("div", { className: "bg-background flex flex-col gap-2 px-4 py-3", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsxs("div", { className: "flex min-w-0 flex-1 flex-col", children: [_jsx("span", { className: "truncate text-sm font-medium", children: name }), _jsx("span", { className: "text-muted-foreground text-xs", children: formatFileSize(size) })] }), _jsx("a", { href: previewUrl(path, mimeType), download: name, className: "text-muted-foreground hover:text-foreground shrink-0 cursor-pointer rounded p-1.5 transition-colors", "aria-label": `Download ${name}`, children: _jsx(DownloadIcon, { className: "h-4 w-4" }) })] }), onNotesChange ? (_jsx(Textarea, { placeholder: "Add notes about this image\u2026", value: notes ?? '', onChange: (e) => onNotesChange(e.target.value), rows: 2, className: "resize-none text-sm", "aria-label": "Image notes" })) : notes ? (_jsx("p", { className: "text-muted-foreground text-sm", children: notes })) : null] })] })] }) }));
35
35
  }
36
- return (_jsxs("div", { className: "group relative flex items-center gap-2 rounded-full border py-1 ps-2 pe-3", children: [_jsx("div", { className: cn('flex h-6 w-6 shrink-0 items-center justify-center rounded-full', iconColorClass), children: _jsx(Icon, { className: "h-3 w-3" }) }), _jsx("span", { className: "max-w-[120px] truncate text-sm", children: name }), _jsx("span", { className: "text-muted-foreground text-xs", children: formatFileSize(size) }), !disabled && (_jsx("button", { type: "button", onClick: onRemove, className: "absolute -top-1.5 -right-1.5 hidden h-5 w-5 cursor-pointer items-center justify-center rounded-full bg-black/70 text-white group-hover:flex", "aria-label": `Remove ${name}`, children: _jsx(X, { className: "h-3 w-3" }) }))] }));
36
+ return (_jsxs("div", { className: "group relative flex items-center gap-2 rounded-full border py-1 pr-3 pl-2", children: [_jsx("div", { className: cn('flex h-6 w-6 shrink-0 items-center justify-center rounded-full', iconColorClass), children: _jsx(Icon, { className: "h-3 w-3" }) }), _jsx("span", { className: "max-w-[120px] truncate text-sm", children: name }), _jsx("span", { className: "text-muted-foreground text-xs", children: formatFileSize(size) }), !disabled && (_jsx("button", { type: "button", onClick: onRemove, className: "absolute -top-1.5 -right-1.5 hidden h-5 w-5 cursor-pointer items-center justify-center rounded-full bg-black/70 text-white group-hover:flex", "aria-label": `Remove ${name}`, children: _jsx(X, { className: "h-3 w-3" }) }))] }));
37
37
  }
@@ -55,7 +55,7 @@ export function BaseDrawer({ open, onClose, modal = false, dismissOnOutsideClick
55
55
  return (_jsxs(Drawer, { direction: "right", modal: modal, handleOnly: true, open: open, onOpenChange: (isOpen) => {
56
56
  if (!isOpen)
57
57
  onClose();
58
- }, children: [modal ? _jsx(DrawerOverlay, {}) : null, _jsxs(DrawerContent, { ref: contentRef, direction: "right", showCloseButton: false, className: cn(drawerVariants({ size }), 'bg-white/85 backdrop-blur-xl dark:bg-neutral-800/85', className), "data-testid": testId, onInteractOutside: modal ? undefined : (e) => e.preventDefault(), children: [_jsx(DrawerTitle, { asChild: true, children: _jsx("span", { className: "sr-only", children: title }) }), _jsx(DrawerDescription, { asChild: true, children: _jsx("span", { className: "sr-only", children: title }) }), _jsxs("button", { type: "button", "aria-label": "Close", onClick: onClose, className: "ring-offset-background focus:ring-ring absolute end-4 top-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden", "data-testid": testId ? `${testId}-close-button` : undefined, children: [_jsx(XIcon, { className: "size-4" }), _jsx("span", { className: "sr-only", children: "Close" })] }), header ? _jsx(DrawerHeader, { className: "shrink-0", children: header }) : null, header ? _jsx(Separator, {}) : null, featureFlags.envDeploy && deployTarget ? _jsx(DeployBar, { deployTarget: deployTarget }) : null, _jsx("div", { className: "flex min-h-0 flex-1 flex-col overflow-hidden", children: children }), footer ? _jsx(DrawerFooter, { className: "shrink-0", children: footer }) : null] })] }));
58
+ }, children: [modal ? _jsx(DrawerOverlay, {}) : null, _jsxs(DrawerContent, { ref: contentRef, direction: "right", showCloseButton: false, className: cn(drawerVariants({ size }), 'bg-white/85 backdrop-blur-xl dark:bg-neutral-800/85', className), "data-testid": testId, onInteractOutside: modal ? undefined : (e) => e.preventDefault(), children: [_jsx(DrawerTitle, { asChild: true, children: _jsx("span", { className: "sr-only", children: title }) }), _jsx(DrawerDescription, { asChild: true, children: _jsx("span", { className: "sr-only", children: title }) }), _jsxs("button", { type: "button", "aria-label": "Close", onClick: onClose, className: "ring-offset-background focus:ring-ring absolute top-4 right-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden", "data-testid": testId ? `${testId}-close-button` : undefined, children: [_jsx(XIcon, { className: "size-4" }), _jsx("span", { className: "sr-only", children: "Close" })] }), header ? _jsx(DrawerHeader, { className: "shrink-0", children: header }) : null, header ? _jsx(Separator, {}) : null, featureFlags.envDeploy && deployTarget ? _jsx(DeployBar, { deployTarget: deployTarget }) : null, _jsx("div", { className: "flex min-h-0 flex-1 flex-col overflow-hidden", children: children }), footer ? _jsx(DrawerFooter, { className: "shrink-0", children: footer }) : null] })] }));
59
59
  }
60
60
  function DeployBar({ deployTarget }) {
61
61
  const deployAction = useDeployAction(deployTarget);
@@ -5,10 +5,10 @@ import { Badge } from '../../ui/badge.js';
5
5
  export function CiStatusBadge({ status }) {
6
6
  switch (status) {
7
7
  case CiStatus.Success:
8
- return (_jsxs(Badge, { className: "border-transparent bg-green-50 text-green-700 hover:bg-green-50", children: [_jsx(CheckCircle2, { className: "me-1 h-3.5 w-3.5" }), "Passing"] }));
8
+ return (_jsxs(Badge, { className: "border-transparent bg-green-50 text-green-700 hover:bg-green-50", children: [_jsx(CheckCircle2, { className: "mr-1 h-3.5 w-3.5" }), "Passing"] }));
9
9
  case CiStatus.Pending:
10
- return (_jsxs(Badge, { className: "border-transparent bg-yellow-50 text-yellow-700 hover:bg-yellow-50", children: [_jsx(Loader2, { className: "me-1 h-3.5 w-3.5 animate-spin" }), "Pending"] }));
10
+ return (_jsxs(Badge, { className: "border-transparent bg-yellow-50 text-yellow-700 hover:bg-yellow-50", children: [_jsx(Loader2, { className: "mr-1 h-3.5 w-3.5 animate-spin" }), "Pending"] }));
11
11
  case CiStatus.Failure:
12
- return (_jsxs(Badge, { className: "border-transparent bg-red-50 text-red-700 hover:bg-red-50", children: [_jsx(XCircle, { className: "me-1 h-3.5 w-3.5" }), "Failing"] }));
12
+ return (_jsxs(Badge, { className: "border-transparent bg-red-50 text-red-700 hover:bg-red-50", children: [_jsx(XCircle, { className: "mr-1 h-3.5 w-3.5" }), "Failing"] }));
13
13
  }
14
14
  }
@@ -91,15 +91,15 @@ export function AdoptBranchDrawer({ open, onClose, onSubmit, isSubmitting = fals
91
91
  }, [repoOpen]);
92
92
  const isDisabled = !branchName.trim() || !selectedRepositoryPath || isSubmitting;
93
93
  const header = (_jsxs("div", { children: [_jsxs(DrawerTitle, { className: "flex items-center gap-2", children: [_jsx(GitBranch, { className: "h-4 w-4" }), "Adopt Branch"] }), _jsx(DrawerDescription, { className: "text-muted-foreground text-sm", children: "Import an existing git branch into Shep's feature tracking" })] }));
94
- return (_jsx(BaseDrawer, { open: open, onClose: handleClose, size: "sm", modal: false, header: header, "data-testid": "adopt-branch-drawer", children: _jsxs("form", { onSubmit: handleSubmit, className: "flex flex-1 flex-col", children: [_jsx("div", { className: "flex-1 overflow-y-auto p-4", children: _jsxs("div", { className: "flex flex-col gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: "Repository" }), _jsxs(Popover, { open: repoOpen, onOpenChange: setRepoOpen, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs("button", { type: "button", role: "combobox", "aria-expanded": repoOpen, "aria-label": "Repository", disabled: isSubmitting, "data-testid": "adopt-repo-combobox", className: cn('border-input bg-background ring-offset-background focus:ring-ring flex h-9 w-full items-center justify-between rounded-md border px-3 py-2 text-sm focus:ring-2 focus:ring-offset-2 focus:outline-none disabled:cursor-not-allowed disabled:opacity-50', !selectedRepo && 'text-muted-foreground'), children: [_jsx("span", { className: "truncate", children: selectedRepo ? selectedRepo.name : 'Select repository...' }), _jsx(ChevronsUpDown, { className: "ms-2 h-4 w-4 shrink-0 opacity-50" })] }) }), _jsx(PopoverContent, { className: "w-80 p-0", align: "start", "data-testid": "adopt-repo-combobox-content", children: _jsxs("div", { className: "flex flex-col", children: [_jsx("div", { className: "border-b p-2", children: _jsx(Input, { ref: repoInputRef, placeholder: "Search repositories...", value: repoQuery, onChange: (e) => setRepoQuery(e.target.value), className: "h-8 border-0 p-0 text-sm shadow-none focus-visible:ring-0", "data-testid": "adopt-repo-search" }) }), _jsx("div", { className: "max-h-48 overflow-y-auto py-1", role: "listbox", "aria-label": "Repositories", children: filteredRepos.length === 0 ? (_jsx("p", { className: "text-muted-foreground px-3 py-2 text-sm", children: "No repositories found." })) : (filteredRepos.map((r) => (_jsxs("button", { type: "button", role: "option", "aria-selected": selectedRepositoryPath === r.path, onClick: () => handleRepoSelect(r.path), className: cn('hover:bg-accent hover:text-accent-foreground flex w-full items-center gap-2 px-3 py-2 text-sm', selectedRepositoryPath === r.path && 'bg-accent/50'), "data-testid": `adopt-repo-option-${r.id}`, children: [_jsx(CheckIcon, { className: cn('h-4 w-4 shrink-0', selectedRepositoryPath !== r.path && 'invisible') }), _jsxs("span", { className: "flex flex-col items-start truncate", children: [_jsx("span", { className: "truncate", children: r.name }), _jsx("span", { className: "text-muted-foreground truncate text-xs", children: r.path })] })] }, r.id)))) })] }) })] }), _jsx("p", { className: "text-muted-foreground text-xs", children: "Select the repository that contains the branch you want to adopt." })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { htmlFor: "branch-name", children: "Branch name" }), _jsxs(Popover, { open: comboboxOpen, onOpenChange: setComboboxOpen, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs(Button, { variant: "outline", role: "combobox", "aria-expanded": comboboxOpen, disabled: isSubmitting || !hasRepo, className: "w-full justify-between font-normal", "data-testid": "adopt-branch-input", children: [_jsx("span", { className: "truncate", children: !hasRepo
94
+ return (_jsx(BaseDrawer, { open: open, onClose: handleClose, size: "sm", modal: false, header: header, "data-testid": "adopt-branch-drawer", children: _jsxs("form", { onSubmit: handleSubmit, className: "flex flex-1 flex-col", children: [_jsx("div", { className: "flex-1 overflow-y-auto p-4", children: _jsxs("div", { className: "flex flex-col gap-4", children: [_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { children: "Repository" }), _jsxs(Popover, { open: repoOpen, onOpenChange: setRepoOpen, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs("button", { type: "button", role: "combobox", "aria-expanded": repoOpen, "aria-label": "Repository", disabled: isSubmitting, "data-testid": "adopt-repo-combobox", className: cn('border-input bg-background ring-offset-background focus:ring-ring flex h-9 w-full items-center justify-between rounded-md border px-3 py-2 text-sm focus:ring-2 focus:ring-offset-2 focus:outline-none disabled:cursor-not-allowed disabled:opacity-50', !selectedRepo && 'text-muted-foreground'), children: [_jsx("span", { className: "truncate", children: selectedRepo ? selectedRepo.name : 'Select repository...' }), _jsx(ChevronsUpDown, { className: "ml-2 h-4 w-4 shrink-0 opacity-50" })] }) }), _jsx(PopoverContent, { className: "w-80 p-0", align: "start", "data-testid": "adopt-repo-combobox-content", children: _jsxs("div", { className: "flex flex-col", children: [_jsx("div", { className: "border-b p-2", children: _jsx(Input, { ref: repoInputRef, placeholder: "Search repositories...", value: repoQuery, onChange: (e) => setRepoQuery(e.target.value), className: "h-8 border-0 p-0 text-sm shadow-none focus-visible:ring-0", "data-testid": "adopt-repo-search" }) }), _jsx("div", { className: "max-h-48 overflow-y-auto py-1", role: "listbox", "aria-label": "Repositories", children: filteredRepos.length === 0 ? (_jsx("p", { className: "text-muted-foreground px-3 py-2 text-sm", children: "No repositories found." })) : (filteredRepos.map((r) => (_jsxs("button", { type: "button", role: "option", "aria-selected": selectedRepositoryPath === r.path, onClick: () => handleRepoSelect(r.path), className: cn('hover:bg-accent hover:text-accent-foreground flex w-full items-center gap-2 px-3 py-2 text-sm', selectedRepositoryPath === r.path && 'bg-accent/50'), "data-testid": `adopt-repo-option-${r.id}`, children: [_jsx(CheckIcon, { className: cn('h-4 w-4 shrink-0', selectedRepositoryPath !== r.path && 'invisible') }), _jsxs("span", { className: "flex flex-col items-start truncate", children: [_jsx("span", { className: "truncate", children: r.name }), _jsx("span", { className: "text-muted-foreground truncate text-xs", children: r.path })] })] }, r.id)))) })] }) })] }), _jsx("p", { className: "text-muted-foreground text-xs", children: "Select the repository that contains the branch you want to adopt." })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(Label, { htmlFor: "branch-name", children: "Branch name" }), _jsxs(Popover, { open: comboboxOpen, onOpenChange: setComboboxOpen, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs(Button, { variant: "outline", role: "combobox", "aria-expanded": comboboxOpen, disabled: isSubmitting || !hasRepo, className: "w-full justify-between font-normal", "data-testid": "adopt-branch-input", children: [_jsx("span", { className: "truncate", children: !hasRepo
95
95
  ? 'Select a repository first...'
96
96
  : branchesLoading
97
97
  ? 'Loading branches...'
98
- : branchName || 'Select a branch...' }), _jsx(ChevronsUpDown, { className: "ms-2 h-4 w-4 shrink-0 opacity-50" })] }) }), _jsx(PopoverContent, { className: "w-[var(--radix-popover-trigger-width)] p-0", align: "start", children: _jsxs(Command, { children: [_jsx(CommandInput, { ref: inputRef, placeholder: "Search branches...", value: inputValue, onChange: handleInputChange, onKeyDown: handleInputKeyDown, "data-testid": "adopt-branch-search" }), _jsxs(CommandList, { children: [!branchesLoading && filteredBranches.length === 0 && (_jsx(CommandEmpty, { children: branches.length === 0
98
+ : branchName || 'Select a branch...' }), _jsx(ChevronsUpDown, { className: "ml-2 h-4 w-4 shrink-0 opacity-50" })] }) }), _jsx(PopoverContent, { className: "w-[var(--radix-popover-trigger-width)] p-0", align: "start", children: _jsxs(Command, { children: [_jsx(CommandInput, { ref: inputRef, placeholder: "Search branches...", value: inputValue, onChange: handleInputChange, onKeyDown: handleInputKeyDown, "data-testid": "adopt-branch-search" }), _jsxs(CommandList, { children: [!branchesLoading && filteredBranches.length === 0 && (_jsx(CommandEmpty, { children: branches.length === 0
99
99
  ? 'No branches found.'
100
100
  : inputValue
101
101
  ? 'No match — press Enter to use this value.'
102
- : 'No branches available.' })), branchesLoading ? (_jsx(CommandEmpty, { children: _jsx(Loader2, { className: "mx-auto h-4 w-4 animate-spin" }) })) : null, filteredBranches.length > 0 && (_jsx(CommandGroup, { children: filteredBranches.map((branch) => (_jsxs(CommandItem, { selected: branch === branchName, onClick: () => handleSelect(branch), children: [_jsx(Check, { className: cn('me-2 h-4 w-4', branch === branchName ? 'opacity-100' : 'opacity-0') }), _jsx(GitBranch, { className: "me-2 h-3 w-3 opacity-50" }), branch] }, branch))) }))] })] }) })] }), _jsx("p", { className: "text-muted-foreground text-xs", children: hasRepo
102
+ : 'No branches available.' })), branchesLoading ? (_jsx(CommandEmpty, { children: _jsx(Loader2, { className: "mx-auto h-4 w-4 animate-spin" }) })) : null, filteredBranches.length > 0 && (_jsx(CommandGroup, { children: filteredBranches.map((branch) => (_jsxs(CommandItem, { selected: branch === branchName, onClick: () => handleSelect(branch), children: [_jsx(Check, { className: cn('mr-2 h-4 w-4', branch === branchName ? 'opacity-100' : 'opacity-0') }), _jsx(GitBranch, { className: "mr-2 h-3 w-3 opacity-50" }), branch] }, branch))) }))] })] }) })] }), _jsx("p", { className: "text-muted-foreground text-xs", children: hasRepo
103
103
  ? 'Select a branch from the dropdown or type to search. Local and remote branches are shown.'
104
- : 'Please select a repository above to see available branches.' })] }), error ? (_jsx("p", { className: "text-destructive text-sm", "data-testid": "adopt-branch-error", children: error })) : null] }) }), _jsx("div", { className: "border-t p-4", children: _jsxs("div", { className: "flex gap-2", children: [_jsx(Button, { type: "button", variant: "outline", onClick: handleClose, disabled: isSubmitting, className: "flex-1", children: "Cancel" }), _jsx(Button, { type: "submit", disabled: isDisabled, className: "flex-1", "data-testid": "adopt-branch-submit", children: isSubmitting ? (_jsxs(_Fragment, { children: [_jsx(Loader2, { className: "me-2 h-4 w-4 animate-spin" }), "Adopting..."] })) : ('Adopt Branch') })] }) })] }) }));
104
+ : 'Please select a repository above to see available branches.' })] }), error ? (_jsx("p", { className: "text-destructive text-sm", "data-testid": "adopt-branch-error", children: error })) : null] }) }), _jsx("div", { className: "border-t p-4", children: _jsxs("div", { className: "flex gap-2", children: [_jsx(Button, { type: "button", variant: "outline", onClick: handleClose, disabled: isSubmitting, className: "flex-1", children: "Cancel" }), _jsx(Button, { type: "submit", disabled: isDisabled, className: "flex-1", "data-testid": "adopt-branch-submit", children: isSubmitting ? (_jsxs(_Fragment, { children: [_jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), "Adopting..."] })) : ('Adopt Branch') })] }) })] }) }));
105
105
  }
@@ -33,5 +33,5 @@ export function RepositoryDrawerClient({ data, initialTab }) {
33
33
  const isDeployActive = deployAction.status === 'Booting' || deployAction.status === 'Ready';
34
34
  // Session ID for repo chat — deterministic per repo
35
35
  const repoSessionId = data.id ? `repo-${data.id}` : `repo-${data.name}`;
36
- return (_jsx(BaseDrawer, { open: isOpen, onClose: onClose, size: "lg", modal: false, "data-testid": "repository-drawer", children: _jsxs(Tabs, { value: activeTab, onValueChange: setActiveTab, className: "flex min-h-0 flex-1 flex-col", children: [_jsxs("div", { className: "shrink-0 px-4 pt-4 pb-3", "data-testid": "repository-drawer-header", children: [_jsxs("div", { className: "flex items-baseline gap-4 pe-6", children: [_jsx("h2", { className: "text-foreground min-w-0 shrink truncate text-base font-semibold tracking-tight", children: data.name }), _jsxs(TabsList, { className: "h-auto shrink-0 gap-0.5 rounded-none border-0 bg-transparent p-0", children: [_jsx(TabsTrigger, { value: "overview", className: "text-muted-foreground hover:text-foreground data-[state=active]:text-foreground data-[state=active]:border-primary h-auto rounded-none border-b-2 border-transparent bg-transparent px-2 py-0.5 text-[12px] font-medium shadow-none transition-colors data-[state=active]:bg-transparent data-[state=active]:shadow-none", children: "Overview" }), _jsx(TabsTrigger, { value: "chat", className: "text-muted-foreground hover:text-foreground data-[state=active]:text-foreground data-[state=active]:border-primary h-auto rounded-none border-b-2 border-transparent bg-transparent px-2 py-0.5 text-[12px] font-medium shadow-none transition-colors data-[state=active]:bg-transparent data-[state=active]:shadow-none", children: "Chat" })] })] }), _jsxs("div", { className: "mt-1 flex items-center gap-2", children: [data.repositoryPath ? (_jsx("p", { className: "text-muted-foreground min-w-0 truncate font-mono text-xs", children: data.repositoryPath })) : null, featureFlags.envDeploy && data.repositoryPath ? (_jsxs("div", { className: "ml-auto flex shrink-0 items-center gap-2", children: [_jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { children: _jsx(ActionButton, { label: isDeployActive ? 'Stop Dev Server' : 'Start Dev Server', onClick: isDeployActive ? deployAction.stop : deployAction.deploy, loading: deployAction.deployLoading || deployAction.stopLoading, error: !!deployAction.deployError, icon: isDeployActive ? Square : Play, iconOnly: true, variant: "outline", size: "icon-sm" }) }) }), _jsx(TooltipContent, { children: isDeployActive ? 'Stop Dev Server' : 'Start Dev Server' })] }) }), isDeployActive ? (_jsx(DeploymentStatusBadge, { status: deployAction.status, url: deployAction.url, targetId: data.repositoryPath })) : null] })) : null] })] }), _jsx(Separator, {}), _jsx(TabsContent, { value: "overview", className: "mt-0 flex-1 overflow-y-auto", children: data.repositoryPath ? (_jsxs("div", { className: "flex-1 overflow-y-auto", children: [_jsxs("div", { className: "flex flex-col gap-3 p-4", children: [_jsx("div", { className: "text-muted-foreground text-xs font-semibold tracking-wider", children: "OPEN WITH" }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(ActionButton, { label: "Open in IDE", onClick: repoActions.openInIde, loading: repoActions.ideLoading, error: !!repoActions.ideError, icon: Code2, variant: "outline", size: "sm" }), _jsx(ActionButton, { label: "Open in Shell", onClick: repoActions.openInShell, loading: repoActions.shellLoading, error: !!repoActions.shellError, icon: Terminal, variant: "outline", size: "sm" }), _jsx(ActionButton, { label: "Open Folder", onClick: repoActions.openFolder, loading: repoActions.folderLoading, error: !!repoActions.folderError, icon: FolderOpen, variant: "outline", size: "sm" })] })] }), data.id && featureFlags.gitRebaseSync ? (_jsxs(_Fragment, { children: [_jsx(Separator, {}), _jsxs("div", { className: "flex flex-col gap-3 p-4", children: [_jsx("div", { className: "text-muted-foreground text-xs font-semibold tracking-wider", children: "GIT OPERATIONS" }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(ActionButton, { label: "Sync Main", onClick: repoActions.syncMain, loading: repoActions.syncLoading, error: !!repoActions.syncError, icon: RefreshCw, variant: "outline", size: "sm" }), repoActions.syncError ? (_jsx("p", { className: "text-destructive text-xs", children: repoActions.syncError })) : null] })] })] })) : null] })) : null }), _jsx(TabsContent, { value: "chat", className: "mt-0 flex min-h-0 flex-1 flex-col overflow-hidden", children: _jsx(ChatTab, { featureId: repoSessionId, worktreePath: data.repositoryPath }) })] }) }));
36
+ return (_jsx(BaseDrawer, { open: isOpen, onClose: onClose, size: "lg", modal: false, "data-testid": "repository-drawer", children: _jsxs(Tabs, { value: activeTab, onValueChange: setActiveTab, className: "flex min-h-0 flex-1 flex-col", children: [_jsxs("div", { className: "shrink-0 px-4 pt-4 pb-3", "data-testid": "repository-drawer-header", children: [_jsxs("div", { className: "flex items-baseline gap-4 pr-6", children: [_jsx("h2", { className: "text-foreground min-w-0 shrink truncate text-base font-semibold tracking-tight", children: data.name }), _jsxs(TabsList, { className: "h-auto shrink-0 gap-0.5 rounded-none border-0 bg-transparent p-0", children: [_jsx(TabsTrigger, { value: "overview", className: "text-muted-foreground hover:text-foreground data-[state=active]:text-foreground data-[state=active]:border-primary h-auto rounded-none border-b-2 border-transparent bg-transparent px-2 py-0.5 text-[12px] font-medium shadow-none transition-colors data-[state=active]:bg-transparent data-[state=active]:shadow-none", children: "Overview" }), _jsx(TabsTrigger, { value: "chat", className: "text-muted-foreground hover:text-foreground data-[state=active]:text-foreground data-[state=active]:border-primary h-auto rounded-none border-b-2 border-transparent bg-transparent px-2 py-0.5 text-[12px] font-medium shadow-none transition-colors data-[state=active]:bg-transparent data-[state=active]:shadow-none", children: "Chat" })] })] }), _jsxs("div", { className: "mt-1 flex items-center gap-2", children: [data.repositoryPath ? (_jsx("p", { className: "text-muted-foreground min-w-0 truncate font-mono text-xs", children: data.repositoryPath })) : null, featureFlags.envDeploy && data.repositoryPath ? (_jsxs("div", { className: "ml-auto flex shrink-0 items-center gap-2", children: [_jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { children: _jsx(ActionButton, { label: isDeployActive ? 'Stop Dev Server' : 'Start Dev Server', onClick: isDeployActive ? deployAction.stop : deployAction.deploy, loading: deployAction.deployLoading || deployAction.stopLoading, error: !!deployAction.deployError, icon: isDeployActive ? Square : Play, iconOnly: true, variant: "outline", size: "icon-sm" }) }) }), _jsx(TooltipContent, { children: isDeployActive ? 'Stop Dev Server' : 'Start Dev Server' })] }) }), isDeployActive ? (_jsx(DeploymentStatusBadge, { status: deployAction.status, url: deployAction.url, targetId: data.repositoryPath })) : null] })) : null] })] }), _jsx(Separator, {}), _jsx(TabsContent, { value: "overview", className: "mt-0 flex-1 overflow-y-auto", children: data.repositoryPath ? (_jsxs("div", { className: "flex-1 overflow-y-auto", children: [_jsxs("div", { className: "flex flex-col gap-3 p-4", children: [_jsx("div", { className: "text-muted-foreground text-xs font-semibold tracking-wider", children: "OPEN WITH" }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(ActionButton, { label: "Open in IDE", onClick: repoActions.openInIde, loading: repoActions.ideLoading, error: !!repoActions.ideError, icon: Code2, variant: "outline", size: "sm" }), _jsx(ActionButton, { label: "Open in Shell", onClick: repoActions.openInShell, loading: repoActions.shellLoading, error: !!repoActions.shellError, icon: Terminal, variant: "outline", size: "sm" }), _jsx(ActionButton, { label: "Open Folder", onClick: repoActions.openFolder, loading: repoActions.folderLoading, error: !!repoActions.folderError, icon: FolderOpen, variant: "outline", size: "sm" })] })] }), data.id && featureFlags.gitRebaseSync ? (_jsxs(_Fragment, { children: [_jsx(Separator, {}), _jsxs("div", { className: "flex flex-col gap-3 p-4", children: [_jsx("div", { className: "text-muted-foreground text-xs font-semibold tracking-wider", children: "GIT OPERATIONS" }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsx(ActionButton, { label: "Sync Main", onClick: repoActions.syncMain, loading: repoActions.syncLoading, error: !!repoActions.syncError, icon: RefreshCw, variant: "outline", size: "sm" }), repoActions.syncError ? (_jsx("p", { className: "text-destructive text-xs", children: repoActions.syncError })) : null] })] })] })) : null] })) : null }), _jsx(TabsContent, { value: "chat", className: "mt-0 flex min-h-0 flex-1 flex-col overflow-hidden", children: _jsx(ChatTab, { featureId: repoSessionId, worktreePath: data.repositoryPath }) })] }) }));
37
37
  }
@@ -1 +1 @@
1
- {"version":3,"file":"delete-feature-dialog.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/delete-feature-dialog/delete-feature-dialog.tsx"],"names":[],"mappings":"AAiBA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;AAE/E,wBAAgB,mBAAmB,CAAC,EAClC,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,UAAU,EACV,WAAW,EACX,SAAS,EACT,WAAW,EACX,SAAS,GACV,EAAE,wBAAwB,2CAoG1B"}
1
+ {"version":3,"file":"delete-feature-dialog.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/delete-feature-dialog/delete-feature-dialog.tsx"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;AAE/E,wBAAgB,mBAAmB,CAAC,EAClC,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,UAAU,EACV,WAAW,EACX,SAAS,EACT,WAAW,EACX,SAAS,GACV,EAAE,wBAAwB,2CA+F1B"}
@@ -2,12 +2,10 @@
2
2
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
3
  import { useEffect, useState } from 'react';
4
4
  import { Loader2 } from 'lucide-react';
5
- import { Trans, useTranslation } from 'react-i18next';
6
5
  import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, } from '../../ui/alert-dialog.js';
7
6
  import { Checkbox } from '../../ui/checkbox.js';
8
7
  import { Label } from '../../ui/label.js';
9
8
  export function DeleteFeatureDialog({ open, onOpenChange, onConfirm, isDeleting, featureName, featureId, hasChildren, hasOpenPr, }) {
10
- const { t } = useTranslation('web');
11
9
  const [cleanup, setCleanup] = useState(true);
12
10
  const [cascadeDelete, setCascadeDelete] = useState(false);
13
11
  const [closePr, setClosePr] = useState(true);
@@ -26,5 +24,5 @@ export function DeleteFeatureDialog({ open, onOpenChange, onConfirm, isDeleting,
26
24
  setClosePr(false);
27
25
  }
28
26
  }, [cleanup]);
29
- return (_jsx(AlertDialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(AlertDialogContent, { onCloseAutoFocus: (e) => e.preventDefault(), children: [_jsxs(AlertDialogHeader, { children: [_jsx(AlertDialogTitle, { children: t('deleteFeature.title') }), _jsx(AlertDialogDescription, { children: _jsx(Trans, { t: t, i18nKey: "deleteFeature.description", values: { featureName, featureId }, components: { strong: _jsx("strong", {}) } }) })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Checkbox, { id: "cleanup-checkbox", checked: cleanup, onCheckedChange: (checked) => setCleanup(checked === true), disabled: isDeleting, "aria-label": t('deleteFeature.cleanupLabel') }), _jsx(Label, { htmlFor: "cleanup-checkbox", className: "cursor-pointer text-sm", children: t('deleteFeature.cleanupLabel') })] }), hasChildren ? (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Checkbox, { id: "cascade-delete-checkbox", checked: cascadeDelete, onCheckedChange: (checked) => setCascadeDelete(checked === true), disabled: isDeleting, "aria-label": t('deleteFeature.deleteSubFeatures') }), _jsx(Label, { htmlFor: "cascade-delete-checkbox", className: "cursor-pointer text-sm", children: t('deleteFeature.deleteSubFeatures') })] })) : null, hasOpenPr ? (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Checkbox, { id: "close-pr-checkbox", checked: closePr, onCheckedChange: (checked) => setClosePr(checked === true), disabled: isDeleting || !cleanup, "aria-label": t('deleteFeature.closePullRequest') }), _jsx(Label, { htmlFor: "close-pr-checkbox", className: "cursor-pointer text-sm", children: t('deleteFeature.closePullRequest') })] })) : null] }), _jsxs(AlertDialogFooter, { children: [_jsx(AlertDialogCancel, { disabled: isDeleting, onClick: () => onOpenChange(false), children: t('deleteFeature.cancel') }), _jsx(AlertDialogAction, { variant: "destructive", disabled: isDeleting, onClick: () => onConfirm(cleanup, cascadeDelete, hasOpenPr ? closePr : false), children: isDeleting ? (_jsxs(_Fragment, { children: [_jsx(Loader2, { className: "me-2 h-4 w-4 animate-spin" }), t('deleteFeature.deleting')] })) : (t('deleteFeature.delete')) })] })] }) }));
27
+ return (_jsx(AlertDialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(AlertDialogContent, { onCloseAutoFocus: (e) => e.preventDefault(), children: [_jsxs(AlertDialogHeader, { children: [_jsx(AlertDialogTitle, { children: "Delete feature?" }), _jsxs(AlertDialogDescription, { children: ["This will permanently delete ", _jsx("strong", { children: featureName }), " (", featureId, "). This action cannot be undone."] })] }), _jsxs("div", { className: "flex flex-col gap-2", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Checkbox, { id: "cleanup-checkbox", checked: cleanup, onCheckedChange: (checked) => setCleanup(checked === true), disabled: isDeleting, "aria-label": "Clean up worktree and branches" }), _jsx(Label, { htmlFor: "cleanup-checkbox", className: "cursor-pointer text-sm", children: "Clean up worktree and branches" })] }), hasChildren ? (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Checkbox, { id: "cascade-delete-checkbox", checked: cascadeDelete, onCheckedChange: (checked) => setCascadeDelete(checked === true), disabled: isDeleting, "aria-label": "Delete sub-features" }), _jsx(Label, { htmlFor: "cascade-delete-checkbox", className: "cursor-pointer text-sm", children: "Delete sub-features" })] })) : null, hasOpenPr ? (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Checkbox, { id: "close-pr-checkbox", checked: closePr, onCheckedChange: (checked) => setClosePr(checked === true), disabled: isDeleting || !cleanup, "aria-label": "Close pull request" }), _jsx(Label, { htmlFor: "close-pr-checkbox", className: "cursor-pointer text-sm", children: "Close pull request" })] })) : null] }), _jsxs(AlertDialogFooter, { children: [_jsx(AlertDialogCancel, { disabled: isDeleting, onClick: () => onOpenChange(false), children: "Cancel" }), _jsx(AlertDialogAction, { variant: "destructive", disabled: isDeleting, onClick: () => onConfirm(cleanup, cascadeDelete, hasOpenPr ? closePr : false), children: isDeleting ? (_jsxs(_Fragment, { children: [_jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), "Deleting\u2026"] })) : ('Delete') })] })] }) }));
30
28
  }
@@ -10,12 +10,12 @@ export function DeploymentStatusBadge({ status, url, targetId }) {
10
10
  const showLogButton = targetId && (status === DeploymentState.Booting || status === DeploymentState.Ready);
11
11
  switch (status) {
12
12
  case DeploymentState.Booting:
13
- return (_jsxs(_Fragment, { children: [_jsxs(Badge, { className: "border-transparent bg-blue-50 text-blue-700 hover:bg-blue-50", children: [_jsx(Loader2, { className: "me-1 h-3.5 w-3.5 animate-spin" }), "Starting...", showLogButton ? (_jsx("button", { type: "button", "aria-label": "View server logs", className: "ms-1.5 inline-flex items-center rounded-sm p-0.5 hover:bg-blue-100", onClick: (e) => {
13
+ return (_jsxs(_Fragment, { children: [_jsxs(Badge, { className: "border-transparent bg-blue-50 text-blue-700 hover:bg-blue-50", children: [_jsx(Loader2, { className: "mr-1 h-3.5 w-3.5 animate-spin" }), "Starting...", showLogButton ? (_jsx("button", { type: "button", "aria-label": "View server logs", className: "ml-1.5 inline-flex items-center rounded-sm p-0.5 hover:bg-blue-100", onClick: (e) => {
14
14
  e.stopPropagation();
15
15
  setLogViewerOpen(true);
16
16
  }, children: _jsx(Terminal, { className: "h-3 w-3" }) })) : null] }), showLogButton ? (_jsx(ServerLogViewer, { open: logViewerOpen, onOpenChange: setLogViewerOpen, targetId: targetId })) : null] }));
17
17
  case DeploymentState.Ready:
18
- return (_jsxs(_Fragment, { children: [_jsxs(Badge, { className: "border-transparent bg-green-50 text-green-700 hover:bg-green-50", children: [_jsx("span", { className: "me-1 inline-block h-2 w-2 rounded-full bg-green-500" }), url ? (_jsxs("a", { href: url, target: "_blank", rel: "noopener noreferrer", className: "inline-flex items-center gap-1 hover:underline", onClick: (e) => e.stopPropagation(), children: [url, _jsx(ExternalLink, { className: "h-3 w-3" })] })) : ('Ready'), showLogButton ? (_jsx("button", { type: "button", "aria-label": "View server logs", className: "ms-1.5 inline-flex items-center rounded-sm p-0.5 hover:bg-green-100", onClick: (e) => {
18
+ return (_jsxs(_Fragment, { children: [_jsxs(Badge, { className: "border-transparent bg-green-50 text-green-700 hover:bg-green-50", children: [_jsx("span", { className: "mr-1 inline-block h-2 w-2 rounded-full bg-green-500" }), url ? (_jsxs("a", { href: url, target: "_blank", rel: "noopener noreferrer", className: "inline-flex items-center gap-1 hover:underline", onClick: (e) => e.stopPropagation(), children: [url, _jsx(ExternalLink, { className: "h-3 w-3" })] })) : ('Ready'), showLogButton ? (_jsx("button", { type: "button", "aria-label": "View server logs", className: "ml-1.5 inline-flex items-center rounded-sm p-0.5 hover:bg-green-100", onClick: (e) => {
19
19
  e.stopPropagation();
20
20
  setLogViewerOpen(true);
21
21
  }, children: _jsx(Terminal, { className: "h-3 w-3" }) })) : null] }), showLogButton ? (_jsx(ServerLogViewer, { open: logViewerOpen, onOpenChange: setLogViewerOpen, targetId: targetId })) : null] }));
@@ -277,13 +277,13 @@ export function DrawerActionBar({ onReject, onApprove, approveLabel, approveVari
277
277
  }
278
278
  }, []);
279
279
  const modKey = typeof navigator !== 'undefined' && /Mac/i.test(navigator.userAgent) ? '⌘' : 'Ctrl';
280
- return (_jsxs("div", { className: "border-border shrink-0 border-t", children: [children, onReject ? (_jsx(TooltipProvider, { delayDuration: 400, children: _jsx("form", { ref: formRef, onSubmit: handleFormSubmit, className: "p-3", children: _jsx("div", { role: "region", "aria-label": "File drop zone", "data-drag-over": isDragOver ? 'true' : 'false', onDragEnter: handleDragEnter, onDragLeave: handleDragLeave, onDragOver: handleDragOver, onDrop: handleDrop, className: cn('rounded-md border-2 border-transparent transition-colors', isDragOver && 'border-primary/50 bg-primary/5'), children: _jsxs("div", { className: "border-input focus-within:ring-ring/50 focus-within:border-ring flex flex-col overflow-hidden rounded-md border shadow-xs transition-[color,box-shadow] focus-within:ring-[3px]", children: [_jsx(Textarea, { placeholder: revisionPlaceholder ?? 'Ask AI to revise...', "aria-label": revisionPlaceholder ?? 'Ask AI to revise...', disabled: disabled, value: chatInput, onChange: (e) => setChatInput(e.target.value), onKeyDown: handleKeyDown, onPaste: handlePaste, rows: 1, className: "max-h-[35dvh] min-h-9 flex-1 resize-none overflow-y-auto rounded-none border-0 py-2 shadow-none focus-visible:ring-0", "data-testid": "drawer-chat-input" }), attachments.length > 0 && (_jsx("div", { className: "flex flex-wrap items-center gap-1.5 px-3 py-2", children: attachments.map((file) => (_jsx(AttachmentChip, { name: file.name, size: file.size, mimeType: file.mimeType, path: file.path, onRemove: () => handleRemoveFile(file.id), disabled: disabled, loading: file.loading, notes: file.notes, onNotesChange: (notes) => handleNotesChange(file.id, notes) }, file.id))) })), uploadError ? (_jsx("p", { className: "text-destructive px-3 pb-2 text-xs", children: uploadError })) : null, _jsxs("div", { className: "border-input flex items-center gap-2 border-t px-3 py-1.5", children: [_jsxs("span", { className: "text-muted-foreground flex-1 truncate text-[11px]", children: [_jsxs("kbd", { className: "bg-muted rounded px-1 py-0.5 font-mono text-[10px]", children: [modKey, "+Enter"] }), ' ', hasText ? 'reject' : 'approve'] }), _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("button", { type: "button", onClick: handleAddFiles, disabled: disabled, "aria-label": "Attach files", className: "text-muted-foreground hover:text-foreground cursor-pointer rounded p-1 transition-colors", children: _jsx(PaperclipIcon, { className: "h-4 w-4" }) }) }), _jsx(TooltipContent, { side: "top", children: "Attach files" })] }), _jsx("div", { onMouseLeave: () => setHoverExpanded(false), children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs("button", { type: "submit", disabled: disabled, "data-testid": "drawer-action-submit", className: cn('relative flex h-9 min-w-[12rem] cursor-pointer items-center overflow-hidden rounded-md border ps-4 pe-10 text-sm font-medium whitespace-nowrap transition-colors', 'disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50', approveExpanded
280
+ return (_jsxs("div", { className: "border-border shrink-0 border-t", children: [children, onReject ? (_jsx(TooltipProvider, { delayDuration: 400, children: _jsx("form", { ref: formRef, onSubmit: handleFormSubmit, className: "p-3", children: _jsx("div", { role: "region", "aria-label": "File drop zone", "data-drag-over": isDragOver ? 'true' : 'false', onDragEnter: handleDragEnter, onDragLeave: handleDragLeave, onDragOver: handleDragOver, onDrop: handleDrop, className: cn('rounded-md border-2 border-transparent transition-colors', isDragOver && 'border-primary/50 bg-primary/5'), children: _jsxs("div", { className: "border-input focus-within:ring-ring/50 focus-within:border-ring flex flex-col overflow-hidden rounded-md border shadow-xs transition-[color,box-shadow] focus-within:ring-[3px]", children: [_jsx(Textarea, { placeholder: revisionPlaceholder ?? 'Ask AI to revise...', "aria-label": revisionPlaceholder ?? 'Ask AI to revise...', disabled: disabled, value: chatInput, onChange: (e) => setChatInput(e.target.value), onKeyDown: handleKeyDown, onPaste: handlePaste, rows: 1, className: "max-h-[35dvh] min-h-9 flex-1 resize-none overflow-y-auto rounded-none border-0 py-2 shadow-none focus-visible:ring-0", "data-testid": "drawer-chat-input" }), attachments.length > 0 && (_jsx("div", { className: "flex flex-wrap items-center gap-1.5 px-3 py-2", children: attachments.map((file) => (_jsx(AttachmentChip, { name: file.name, size: file.size, mimeType: file.mimeType, path: file.path, onRemove: () => handleRemoveFile(file.id), disabled: disabled, loading: file.loading, notes: file.notes, onNotesChange: (notes) => handleNotesChange(file.id, notes) }, file.id))) })), uploadError ? (_jsx("p", { className: "text-destructive px-3 pb-2 text-xs", children: uploadError })) : null, _jsxs("div", { className: "border-input flex items-center gap-2 border-t px-3 py-1.5", children: [_jsxs("span", { className: "text-muted-foreground flex-1 truncate text-[11px]", children: [_jsxs("kbd", { className: "bg-muted rounded px-1 py-0.5 font-mono text-[10px]", children: [modKey, "+Enter"] }), ' ', hasText ? 'reject' : 'approve'] }), _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("button", { type: "button", onClick: handleAddFiles, disabled: disabled, "aria-label": "Attach files", className: "text-muted-foreground hover:text-foreground cursor-pointer rounded p-1 transition-colors", children: _jsx(PaperclipIcon, { className: "h-4 w-4" }) }) }), _jsx(TooltipContent, { side: "top", children: "Attach files" })] }), _jsx("div", { onMouseLeave: () => setHoverExpanded(false), children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs("button", { type: "submit", disabled: disabled, "data-testid": "drawer-action-submit", className: cn('relative flex h-9 min-w-[12rem] cursor-pointer items-center overflow-hidden rounded-md border pr-10 pl-4 text-sm font-medium whitespace-nowrap transition-colors', 'disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50', approveExpanded
281
281
  ? `${accentBorder} text-white`
282
282
  : rejectHighlighted
283
283
  ? 'border-primary bg-muted ring-primary/30 shadow-sm ring-1'
284
284
  : 'border-border bg-muted/50 hover:bg-muted shadow-sm'), children: [_jsx("div", { className: cn('pointer-events-none absolute inset-0 transition-transform duration-300 ease-in-out', accentBg), style: {
285
285
  transform: approveExpanded ? 'translateX(0)' : 'translateX(100%)',
286
- } }), _jsxs("span", { className: cn('absolute inset-0 z-10 flex items-center justify-center gap-2 pe-8 transition-opacity duration-300', approveExpanded ? 'opacity-0' : 'opacity-100'), children: [_jsx(Send, { className: "h-4 w-4 shrink-0" }), "Reject"] }), _jsxs("span", { className: cn('absolute inset-0 z-10 flex items-center justify-center gap-2 text-white transition-opacity duration-300', approveExpanded ? 'opacity-100' : 'opacity-0'), children: [_jsx(ApproveIcon, { className: "h-4 w-4 shrink-0" }), approveLabel] }), _jsx("span", { className: cn(`border-input/60 absolute inset-y-0 right-0 z-20 flex w-8 cursor-pointer items-center justify-center rounded-e-[5px] border-s ${accentBg} transition-opacity duration-300`, !hasText && !hoverExpanded && 'pointer-events-none opacity-0'), onMouseEnter: () => setHoverExpanded(true), children: _jsx(ChevronLeft, { className: "h-4 w-4 text-white" }) })] }) }), !isWarning ? (_jsx(TooltipContent, { side: "top", children: approveExpanded ? approveLabel : 'Send revision feedback' })) : null] }) })] })] }) }) }) })) : (_jsx("div", { className: "flex items-center gap-2 px-4 pb-4", children: _jsx(Button, { type: "button", className: "flex-1", disabled: disabled, onClick: () => {
286
+ } }), _jsxs("span", { className: cn('absolute inset-0 z-10 flex items-center justify-center gap-2 pr-8 transition-opacity duration-300', approveExpanded ? 'opacity-0' : 'opacity-100'), children: [_jsx(Send, { className: "h-4 w-4 shrink-0" }), "Reject"] }), _jsxs("span", { className: cn('absolute inset-0 z-10 flex items-center justify-center gap-2 text-white transition-opacity duration-300', approveExpanded ? 'opacity-100' : 'opacity-0'), children: [_jsx(ApproveIcon, { className: "h-4 w-4 shrink-0" }), approveLabel] }), _jsx("span", { className: cn(`border-input/60 absolute inset-y-0 right-0 z-20 flex w-8 cursor-pointer items-center justify-center rounded-r-[5px] border-l ${accentBg} transition-opacity duration-300`, !hasText && !hoverExpanded && 'pointer-events-none opacity-0'), onMouseEnter: () => setHoverExpanded(true), children: _jsx(ChevronLeft, { className: "h-4 w-4 text-white" }) })] }) }), !isWarning ? (_jsx(TooltipContent, { side: "top", children: approveExpanded ? approveLabel : 'Send revision feedback' })) : null] }) })] })] }) }) }) })) : (_jsx("div", { className: "flex items-center gap-2 px-4 pb-4", children: _jsx(Button, { type: "button", className: "flex-1", disabled: disabled, onClick: () => {
287
287
  approveSound.play();
288
288
  onApprove();
289
289
  }, children: approveLabel }) }))] }));