@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
@@ -2,13 +2,11 @@
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 { useTranslation } from 'react-i18next';
6
5
  import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, } from '../../ui/alert-dialog.js';
7
6
  import { Textarea } from '../../ui/textarea.js';
8
- export function RejectFeedbackDialog({ open, onOpenChange, onConfirm, isSubmitting, title, description, }) {
9
- const { t } = useTranslation('web');
10
- const resolvedTitle = title ?? t('rejectFeedback.defaultTitle');
11
- const resolvedDescription = description ?? t('rejectFeedback.defaultDescription');
7
+ const DEFAULT_TITLE = 'Reject Requirements';
8
+ const DEFAULT_DESCRIPTION = 'Provide feedback for the agent to address in the next iteration. Feedback is required.';
9
+ export function RejectFeedbackDialog({ open, onOpenChange, onConfirm, isSubmitting, title = DEFAULT_TITLE, description = DEFAULT_DESCRIPTION, }) {
12
10
  const [feedback, setFeedback] = useState('');
13
11
  // Reset feedback when dialog opens
14
12
  useEffect(() => {
@@ -17,5 +15,5 @@ export function RejectFeedbackDialog({ open, onOpenChange, onConfirm, isSubmitti
17
15
  }
18
16
  }, [open]);
19
17
  const isFeedbackEmpty = feedback.trim().length === 0;
20
- return (_jsx(AlertDialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(AlertDialogContent, { children: [_jsxs(AlertDialogHeader, { children: [_jsx(AlertDialogTitle, { children: resolvedTitle }), _jsx(AlertDialogDescription, { children: resolvedDescription })] }), _jsx(Textarea, { "aria-label": t('rejectFeedback.ariaLabel'), placeholder: t('rejectFeedback.placeholder'), value: feedback, onChange: (e) => setFeedback(e.target.value), disabled: isSubmitting, rows: 4, className: "max-h-[35dvh] overflow-y-auto" }), _jsxs(AlertDialogFooter, { children: [_jsx(AlertDialogCancel, { disabled: isSubmitting, onClick: () => onOpenChange(false), children: t('rejectFeedback.cancel') }), _jsx(AlertDialogAction, { variant: "destructive", disabled: isFeedbackEmpty || isSubmitting, onClick: () => onConfirm(feedback.trim()), children: isSubmitting ? (_jsxs(_Fragment, { children: [_jsx(Loader2, { className: "me-2 h-4 w-4 animate-spin" }), t('rejectFeedback.rejecting')] })) : (t('rejectFeedback.confirmReject')) })] })] }) }));
18
+ return (_jsx(AlertDialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(AlertDialogContent, { children: [_jsxs(AlertDialogHeader, { children: [_jsx(AlertDialogTitle, { children: title }), _jsx(AlertDialogDescription, { children: description })] }), _jsx(Textarea, { "aria-label": "Rejection feedback", placeholder: "Describe what needs to change...", value: feedback, onChange: (e) => setFeedback(e.target.value), disabled: isSubmitting, rows: 4, className: "max-h-[35dvh] overflow-y-auto" }), _jsxs(AlertDialogFooter, { children: [_jsx(AlertDialogCancel, { disabled: isSubmitting, onClick: () => onOpenChange(false), children: "Cancel" }), _jsx(AlertDialogAction, { variant: "destructive", disabled: isFeedbackEmpty || isSubmitting, onClick: () => onConfirm(feedback.trim()), children: isSubmitting ? (_jsxs(_Fragment, { children: [_jsx(Loader2, { className: "mr-2 h-4 w-4 animate-spin" }), "Rejecting\u2026"] })) : ('Confirm Reject') })] })] }) }));
21
19
  }
@@ -60,7 +60,7 @@ export function RepositoryNode({ data, selected, }) {
60
60
  });
61
61
  router.push(`/create?${params.toString()}`);
62
62
  }, [data.repositoryPath, router]);
63
- return (_jsxs("div", { className: cn('group relative', data.onDelete && data.id && 'ps-10'), children: [data.showHandles ? (_jsx(Handle, { type: "target", position: Position.Left, isConnectable: false, className: "opacity-0!", style: { top: 70 } })) : null, data.onDelete && data.id ? (_jsxs(_Fragment, { children: [_jsx("div", { className: "absolute top-1/2 left-0 -translate-y-1/2 opacity-0 transition-opacity group-hover:opacity-100", children: _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("button", { "aria-label": "Remove repository", "data-testid": "repository-node-delete-button", onClick: (e) => {
63
+ return (_jsxs("div", { className: cn('group relative', data.onDelete && data.id && 'pl-10'), children: [data.showHandles ? (_jsx(Handle, { type: "target", position: Position.Left, isConnectable: false, className: "opacity-0!", style: { top: 70 } })) : null, data.onDelete && data.id ? (_jsxs(_Fragment, { children: [_jsx("div", { className: "absolute top-1/2 left-0 -translate-y-1/2 opacity-0 transition-opacity group-hover:opacity-100", children: _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("button", { "aria-label": "Remove repository", "data-testid": "repository-node-delete-button", onClick: (e) => {
64
64
  e.stopPropagation();
65
65
  setConfirmOpen(true);
66
66
  }, className: "bg-card text-muted-foreground hover:border-destructive hover:text-destructive flex h-7 w-7 cursor-pointer items-center justify-center rounded-full border shadow-sm transition-colors", children: _jsx(Trash2, { className: "h-3.5 w-3.5" }) }) }), _jsx(TooltipContent, { children: "Remove repository" })] }) }) }), _jsx(Dialog, { open: confirmOpen, onOpenChange: setConfirmOpen, children: _jsxs(DialogContent, { className: "max-w-xs", children: [_jsxs(DialogHeader, { children: [_jsx(DialogTitle, { children: "Remove repository?" }), _jsxs(DialogDescription, { children: ["This will remove ", _jsx("strong", { children: data.name }), " and all its features from your workspace. The repository files on disk won't be affected."] })] }), _jsxs(DialogFooter, { className: "grid grid-cols-2 gap-2 sm:flex-none", children: [_jsx(DialogClose, { asChild: true, children: _jsx(Button, { variant: "outline", children: "Cancel" }) }), _jsx(Button, { variant: "destructive", onClick: () => {
@@ -79,14 +79,14 @@ export function RepositoryNode({ data, selected, }) {
79
79
  e.stopPropagation();
80
80
  if (data.id)
81
81
  router.push(`/repository/${data.id}/chat`);
82
- }, className: "nodrag relative cursor-pointer text-violet-500 hover:text-violet-600 dark:text-violet-400 dark:hover:text-violet-300", children: [_jsx(MessageSquare, { className: "h-3 w-3" }), _jsx(ChatDotIndicator, { status: chatTurnStatus })] }) }), _jsx(TooltipContent, { children: "Chat with agent" })] }) }), _jsx(FeatureSessionsDropdown, { repositoryPath: data.repositoryPath, includeWorktrees: true, onCreateFromSession: handleCreateFromSession })] })) : null, data.onAdd ? _jsx("div", { className: "ms-1.5" }) : null, data.onAdd ? (_jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs("button", { "aria-label": "New feature", "data-testid": "repository-node-add-button", onClick: (e) => {
82
+ }, className: "nodrag relative cursor-pointer text-violet-500 hover:text-violet-600 dark:text-violet-400 dark:hover:text-violet-300", children: [_jsx(MessageSquare, { className: "h-3 w-3" }), _jsx(ChatDotIndicator, { status: chatTurnStatus })] }) }), _jsx(TooltipContent, { children: "Chat with agent" })] }) }), _jsx(FeatureSessionsDropdown, { repositoryPath: data.repositoryPath, includeWorktrees: true, onCreateFromSession: handleCreateFromSession })] })) : null, data.onAdd ? _jsx("div", { className: "ml-1.5" }) : null, data.onAdd ? (_jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs("button", { "aria-label": "New feature", "data-testid": "repository-node-add-button", onClick: (e) => {
83
83
  e.stopPropagation();
84
84
  data.onAdd?.();
85
85
  }, className: cn('flex h-6 shrink-0 cursor-pointer items-center gap-0.5 rounded bg-blue-500 px-1.5 text-[11px] font-bold text-white transition-colors hover:bg-blue-600 dark:bg-amber-500 dark:hover:bg-amber-400', data.pulseAdd && 'animate-pulse-cta'), children: [_jsx(Plus, { className: "h-3 w-3" }), _jsx("span", { className: "translate-y-px", children: "New" })] }) }), _jsx(TooltipContent, { side: "top", children: "New feature" })] }) })) : null] })] }), data.branch ? (_jsxs(_Fragment, { children: [_jsx("div", { "data-testid": "repository-node-git-info", className: "text-muted-foreground border-border/50 border-t px-4 py-2", children: _jsxs("div", { className: "flex items-center gap-3 text-xs", children: [_jsxs("span", { className: "flex items-center gap-1 truncate", "data-testid": "repository-node-branch", children: [_jsx(GitBranch, { className: "h-3 w-3 shrink-0" }), _jsx("span", { className: "truncate", children: data.branch })] }), data.behindCount != null && data.behindCount > 0 ? (_jsxs("span", { className: "flex shrink-0 items-center gap-1 whitespace-nowrap text-amber-500", "data-testid": "repository-node-behind", children: [_jsx(ArrowDown, { className: "h-3 w-3 shrink-0" }), data.behindCount, " behind"] })) : null] }) }), data.commitMessage ? (_jsx("div", { "data-testid": "repository-node-commit-info", className: "text-muted-foreground border-border/50 border-t px-4 py-2", children: _jsxs("div", { className: "flex items-center gap-2 text-xs", children: [_jsx(GitCommitHorizontal, { className: "h-3 w-3 shrink-0" }), _jsx("span", { className: "min-w-0 truncate", "data-testid": "repository-node-commit-message", children: data.commitMessage }), data.committer ? (_jsxs("span", { className: "text-muted-foreground/70 ml-auto flex shrink-0 items-center gap-1", "data-testid": "repository-node-committer", children: [_jsx(User, { className: "h-3 w-3 shrink-0" }), _jsx("span", { children: data.committer })] })) : null] }) })) : null] })) : data.gitInfoStatus === 'not-a-repo' ? (
86
86
  /* Not a git repo — two rows for consistency with loading/ready states */
87
87
  _jsxs(_Fragment, { children: [_jsx("div", { "data-testid": "repository-node-not-repo", className: "text-muted-foreground border-border/50 border-t px-4 py-2", children: _jsxs("div", { className: "flex items-center gap-2 text-xs", children: [_jsx(FolderOpen, { className: "h-3 w-3 shrink-0" }), _jsx("span", { className: "min-w-0 truncate opacity-60", children: data.repositoryPath ?? 'Unknown path' })] }) }), _jsx("div", { className: "text-muted-foreground border-border/50 border-t px-4 py-2", children: _jsxs("div", { className: "flex items-center gap-2 text-xs opacity-40", children: [_jsx(GitBranch, { className: "h-3 w-3 shrink-0" }), _jsx("span", { children: "Not a git repository" })] }) })] })) : data.gitInfoStatus !== 'ready' ? (
88
88
  /* Loading — show skeleton placeholders for both rows */
89
- _jsxs(_Fragment, { children: [_jsx("div", { "data-testid": "repository-node-git-loading", className: "border-border/50 border-t px-4 py-2", children: _jsxs("div", { className: "flex h-4 items-center gap-2 text-xs", children: [_jsx(GitBranch, { className: "text-muted-foreground h-3 w-3 shrink-0" }), _jsx("span", { className: "bg-muted h-3 w-20 animate-pulse rounded" })] }) }), _jsx("div", { className: "border-border/50 border-t px-4 py-2", children: _jsxs("div", { className: "flex h-4 items-center gap-2 text-xs", children: [_jsx(GitCommitHorizontal, { className: "text-muted-foreground h-3 w-3 shrink-0" }), _jsx("span", { className: "bg-muted h-3 w-36 animate-pulse rounded" })] }) })] })) : null, featureFlags.envDeploy && data.repositoryPath ? (_jsx("div", { "data-testid": "repository-node-dev-preview", className: "border-border/50 border-t px-4 py-2", onClick: (e) => e.stopPropagation(), children: _jsxs("div", { className: "flex items-center gap-2 text-xs", children: [deployAction.deployError ? (_jsx("span", { className: "truncate text-xs text-red-500", children: deployAction.deployError })) : isDeploymentActive ? (_jsxs(_Fragment, { children: [_jsx("span", { className: "me-0.5 inline-block h-2 w-2 shrink-0 rounded-full bg-green-500" }), deployAction.url ? (_jsx("a", { href: deployAction.url, target: "_blank", rel: "noopener noreferrer", className: "truncate text-green-700 hover:underline dark:text-green-400", children: deployAction.url })) : (_jsx("span", { className: "text-muted-foreground", children: "Starting..." }))] })) : (_jsxs("span", { className: "text-muted-foreground", children: ["Run", _jsx("span", { className: "text-muted-foreground/50 ms-2 text-[10px]", children: "start local environment" })] })), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: cn('ml-auto flex items-center', !isDeploymentActive &&
89
+ _jsxs(_Fragment, { children: [_jsx("div", { "data-testid": "repository-node-git-loading", className: "border-border/50 border-t px-4 py-2", children: _jsxs("div", { className: "flex h-4 items-center gap-2 text-xs", children: [_jsx(GitBranch, { className: "text-muted-foreground h-3 w-3 shrink-0" }), _jsx("span", { className: "bg-muted h-3 w-20 animate-pulse rounded" })] }) }), _jsx("div", { className: "border-border/50 border-t px-4 py-2", children: _jsxs("div", { className: "flex h-4 items-center gap-2 text-xs", children: [_jsx(GitCommitHorizontal, { className: "text-muted-foreground h-3 w-3 shrink-0" }), _jsx("span", { className: "bg-muted h-3 w-36 animate-pulse rounded" })] }) })] })) : null, featureFlags.envDeploy && data.repositoryPath ? (_jsx("div", { "data-testid": "repository-node-dev-preview", className: "border-border/50 border-t px-4 py-2", onClick: (e) => e.stopPropagation(), children: _jsxs("div", { className: "flex items-center gap-2 text-xs", children: [deployAction.deployError ? (_jsx("span", { className: "truncate text-xs text-red-500", children: deployAction.deployError })) : isDeploymentActive ? (_jsxs(_Fragment, { children: [_jsx("span", { className: "mr-0.5 inline-block h-2 w-2 shrink-0 rounded-full bg-green-500" }), deployAction.url ? (_jsx("a", { href: deployAction.url, target: "_blank", rel: "noopener noreferrer", className: "truncate text-green-700 hover:underline dark:text-green-400", children: deployAction.url })) : (_jsx("span", { className: "text-muted-foreground", children: "Starting..." }))] })) : (_jsxs("span", { className: "text-muted-foreground", children: ["Run", _jsx("span", { className: "text-muted-foreground/50 ml-2 text-[10px]", children: "start local environment" })] })), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: cn('ml-auto flex items-center', !isDeploymentActive &&
90
90
  !deployAction.deployError &&
91
91
  '[&_button]:text-green-600 [&_button]:hover:text-green-700 dark:[&_button]:text-green-400 dark:[&_button]:hover:text-green-300'), children: _jsx(ActionButton, { label: deployAction.deployError
92
92
  ? 'Retry'
@@ -24,7 +24,7 @@ export function ServerLogViewerContent({ open, onOpenChange, logs, isConnected,
24
24
  scrollRef.current.scrollTop = scrollRef.current.scrollHeight;
25
25
  }
26
26
  }, [logs]);
27
- return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { className: "flex h-[calc(100vh-48px)] max-h-[calc(100vh-48px)] w-full max-w-[calc(100vw-48px)] flex-col gap-0 bg-zinc-950 p-0 text-zinc-100 sm:rounded-lg", "aria-describedby": undefined, children: [_jsxs(DialogHeader, { className: "flex flex-row items-center justify-between border-b border-zinc-800 px-4 py-3", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Terminal, { className: "h-4 w-4 text-zinc-400" }), _jsx(DialogTitle, { className: "text-sm font-medium text-zinc-100", children: "Server Logs" })] }), _jsxs("div", { className: "flex items-center gap-2 pe-8", children: [_jsx("span", { className: `inline-block h-2 w-2 rounded-full ${isConnected ? 'bg-green-500' : 'bg-zinc-500'}` }), _jsx("span", { className: "text-xs text-zinc-400", children: isConnected ? 'Connected' : 'Disconnected' })] })] }), _jsxs("div", { ref: scrollRef, onScroll: handleScroll, className: "flex-1 overflow-auto p-4 font-mono text-sm leading-relaxed", children: [logs.length === 0 ? (_jsx("p", { className: "text-zinc-500", children: "Waiting for log output..." })) : (logs.map((entry) => (_jsx(LogLine, { entry: entry }, `${entry.timestamp}-${entry.stream}-${entry.line}`)))), !isConnected && logs.length > 0 && (_jsx("div", { className: "mt-2 border-t border-zinc-800 pt-2 text-zinc-500", children: "[Server stopped]" }))] })] }) }));
27
+ return (_jsx(Dialog, { open: open, onOpenChange: onOpenChange, children: _jsxs(DialogContent, { className: "flex h-[calc(100vh-48px)] max-h-[calc(100vh-48px)] w-full max-w-[calc(100vw-48px)] flex-col gap-0 bg-zinc-950 p-0 text-zinc-100 sm:rounded-lg", "aria-describedby": undefined, children: [_jsxs(DialogHeader, { className: "flex flex-row items-center justify-between border-b border-zinc-800 px-4 py-3", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Terminal, { className: "h-4 w-4 text-zinc-400" }), _jsx(DialogTitle, { className: "text-sm font-medium text-zinc-100", children: "Server Logs" })] }), _jsxs("div", { className: "flex items-center gap-2 pr-8", children: [_jsx("span", { className: `inline-block h-2 w-2 rounded-full ${isConnected ? 'bg-green-500' : 'bg-zinc-500'}` }), _jsx("span", { className: "text-xs text-zinc-400", children: isConnected ? 'Connected' : 'Disconnected' })] })] }), _jsxs("div", { ref: scrollRef, onScroll: handleScroll, className: "flex-1 overflow-auto p-4 font-mono text-sm leading-relaxed", children: [logs.length === 0 ? (_jsx("p", { className: "text-zinc-500", children: "Waiting for log output..." })) : (logs.map((entry) => (_jsx(LogLine, { entry: entry }, `${entry.timestamp}-${entry.stream}-${entry.line}`)))), !isConnected && logs.length > 0 && (_jsx("div", { className: "mt-2 border-t border-zinc-800 pt-2 text-zinc-500", children: "[Server stopped]" }))] })] }) }));
28
28
  }
29
29
  function LogLine({ entry }) {
30
30
  return (_jsx("div", { "data-stream": entry.stream, className: entry.stream === 'stderr' ? 'text-red-400' : 'text-zinc-200', children: _jsx("span", { className: "break-all whitespace-pre-wrap", children: entry.line }) }));
@@ -69,14 +69,14 @@ function TaskCard({ task, index }) {
69
69
  setExpanded((prev) => !prev);
70
70
  }
71
71
  }, [hasDetails]);
72
- return (_jsxs("div", { "data-testid": `task-card-${index}`, className: cn('rounded-lg border', config.borderClass), children: [_jsxs("button", { type: "button", onClick: handleToggle, disabled: !hasDetails, className: cn('flex w-full items-start gap-2 px-3 py-2.5 text-start', hasDetails && 'hover:bg-muted/50 cursor-pointer transition-colors'), children: [_jsx(Icon, { className: cn('mt-0.5 h-4 w-4 shrink-0', config.colorClass, config.spinning && 'animate-spin') }), _jsxs("div", { className: "flex min-w-0 flex-1 flex-col gap-0.5", children: [_jsx("span", { className: cn('text-sm font-medium', config.colorClass), children: task.title }), task.description ? (_jsx("span", { className: "text-muted-foreground text-xs", children: task.description })) : null] }), hasDetails ? (_jsx(ChevronRight, { className: cn('text-muted-foreground mt-0.5 h-4 w-4 shrink-0 transition-transform', expanded && 'rotate-90') })) : null] }), expanded && hasDetails ? (_jsx("div", { className: "border-t px-3 py-2.5", children: _jsx("div", { className: "flex flex-col gap-2", children: task.actionItems.map((item, aiIndex) => (_jsx(ActionItemRow, { item: item }, item.name || `ai-${aiIndex}`))) }) })) : null] }));
72
+ return (_jsxs("div", { "data-testid": `task-card-${index}`, className: cn('rounded-lg border', config.borderClass), children: [_jsxs("button", { type: "button", onClick: handleToggle, disabled: !hasDetails, className: cn('flex w-full items-start gap-2 px-3 py-2.5 text-left', hasDetails && 'hover:bg-muted/50 cursor-pointer transition-colors'), children: [_jsx(Icon, { className: cn('mt-0.5 h-4 w-4 shrink-0', config.colorClass, config.spinning && 'animate-spin') }), _jsxs("div", { className: "flex min-w-0 flex-1 flex-col gap-0.5", children: [_jsx("span", { className: cn('text-sm font-medium', config.colorClass), children: task.title }), task.description ? (_jsx("span", { className: "text-muted-foreground text-xs", children: task.description })) : null] }), hasDetails ? (_jsx(ChevronRight, { className: cn('text-muted-foreground mt-0.5 h-4 w-4 shrink-0 transition-transform', expanded && 'rotate-90') })) : null] }), expanded && hasDetails ? (_jsx("div", { className: "border-t px-3 py-2.5", children: _jsx("div", { className: "flex flex-col gap-2", children: task.actionItems.map((item, aiIndex) => (_jsx(ActionItemRow, { item: item }, item.name || `ai-${aiIndex}`))) }) })) : null] }));
73
73
  }
74
74
  // ── Action Item Row ──────────────────────────────────────────────────
75
75
  function ActionItemRow({ item }) {
76
76
  const totalCriteria = item.acceptanceCriteria.length;
77
77
  const verifiedCriteria = item.acceptanceCriteria.filter((ac) => ac.verified).length;
78
78
  const allVerified = totalCriteria > 0 && verifiedCriteria === totalCriteria;
79
- return (_jsxs("div", { "data-testid": "action-item", className: "flex flex-col gap-1.5", children: [_jsxs("div", { className: "flex items-start gap-2", children: [allVerified ? (_jsx(CheckCircle2, { className: "mt-0.5 h-3.5 w-3.5 shrink-0 text-emerald-600" })) : (_jsx(CircleDashed, { className: "text-muted-foreground mt-0.5 h-3.5 w-3.5 shrink-0" })), _jsxs("div", { className: "flex min-w-0 flex-col gap-0.5", children: [_jsx("span", { className: "text-xs font-medium", children: item.name }), item.description ? (_jsx("span", { className: "text-muted-foreground text-[11px]", children: item.description })) : null] }), totalCriteria > 0 ? (_jsxs("span", { className: "text-muted-foreground ml-auto shrink-0 text-[11px]", children: [verifiedCriteria, "/", totalCriteria] })) : null] }), totalCriteria > 0 ? (_jsx("div", { className: "ms-5.5 flex flex-col gap-1", children: item.acceptanceCriteria.map((ac, acIndex) => (_jsx(AcceptanceCriterionRow, { criterion: ac }, ac.description || `ac-${acIndex}`))) })) : null] }));
79
+ return (_jsxs("div", { "data-testid": "action-item", className: "flex flex-col gap-1.5", children: [_jsxs("div", { className: "flex items-start gap-2", children: [allVerified ? (_jsx(CheckCircle2, { className: "mt-0.5 h-3.5 w-3.5 shrink-0 text-emerald-600" })) : (_jsx(CircleDashed, { className: "text-muted-foreground mt-0.5 h-3.5 w-3.5 shrink-0" })), _jsxs("div", { className: "flex min-w-0 flex-col gap-0.5", children: [_jsx("span", { className: "text-xs font-medium", children: item.name }), item.description ? (_jsx("span", { className: "text-muted-foreground text-[11px]", children: item.description })) : null] }), totalCriteria > 0 ? (_jsxs("span", { className: "text-muted-foreground ml-auto shrink-0 text-[11px]", children: [verifiedCriteria, "/", totalCriteria] })) : null] }), totalCriteria > 0 ? (_jsx("div", { className: "ml-5.5 flex flex-col gap-1", children: item.acceptanceCriteria.map((ac, acIndex) => (_jsx(AcceptanceCriterionRow, { criterion: ac }, ac.description || `ac-${acIndex}`))) })) : null] }));
80
80
  }
81
81
  // ── Acceptance Criterion Row ─────────────────────────────────────────
82
82
  function AcceptanceCriterionRow({ criterion, }) {
@@ -12,8 +12,8 @@ const markdownComponents = {
12
12
  em: ({ children }) => _jsx("em", { className: "italic", children: children }),
13
13
  code: ({ children, className }) => className ? (_jsx("code", { className: `${className} text-[11px]`, children: children })) : (_jsx("code", { className: "bg-muted text-foreground rounded-md px-1.5 py-0.5 font-mono text-[11px]", children: children })),
14
14
  pre: ({ children }) => (_jsx("pre", { className: "bg-muted my-2 overflow-x-auto rounded-lg border p-3", children: children })),
15
- ul: ({ children }) => (_jsx("ul", { className: "text-muted-foreground mb-2 list-disc space-y-1 ps-4 text-xs", children: children })),
16
- ol: ({ children }) => (_jsx("ol", { className: "text-muted-foreground mb-2 list-decimal space-y-1 ps-4 text-xs", children: children })),
15
+ ul: ({ children }) => (_jsx("ul", { className: "text-muted-foreground mb-2 list-disc space-y-1 pl-4 text-xs", children: children })),
16
+ ol: ({ children }) => (_jsx("ol", { className: "text-muted-foreground mb-2 list-decimal space-y-1 pl-4 text-xs", children: children })),
17
17
  li: ({ children }) => _jsx("li", { className: "leading-relaxed", children: children }),
18
18
  a: ({ children, href }) => (_jsx("a", { href: href, className: "text-primary underline underline-offset-2", target: "_blank", rel: "noopener noreferrer", children: children })),
19
19
  };
@@ -13,7 +13,7 @@ export function VersionBadge({ version, branch, commitHash, isDev = false, packa
13
13
  const isRestarting = upgradeStatus === 'restarting';
14
14
  const didUpgrade = upgradeStatus === 'upgraded';
15
15
  const upgradeError = upgradeStatus === 'error';
16
- return (_jsx(TooltipProvider, { delayDuration: 200, children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs("span", { className: "text-muted-foreground/80 hover:text-muted-foreground relative cursor-default text-[11px] leading-tight transition-colors", "data-testid": "version-label", children: [displayVersion, updateAvailable && !didUpgrade && !isRestarting ? (_jsx("span", { className: "absolute -top-0.5 -right-1.5 size-1.5 rounded-full bg-emerald-400", "data-testid": "update-dot" })) : null] }) }), _jsxs(TooltipContent, { side: "right", className: "max-w-[280px] space-y-1 p-3 text-start", children: [_jsx("div", { className: "mb-1.5 text-xs font-semibold", children: packageName }), description ? (_jsx("div", { className: "text-[10px] leading-snug opacity-70", children: description })) : null, _jsxs("div", { className: "border-t border-white/10 pt-1.5", children: [_jsx(Row, { label: "Version", value: displayVersion }), isDev && branch ? _jsx(Row, { label: "Branch", value: branch }) : null, isDev && shortHash ? _jsx(Row, { label: "Commit", value: shortHash, mono: true }) : null, isDev && instancePath ? _jsx(Row, { label: "Path", value: instancePath, mono: true }) : null, latest ? (_jsx(Row, { label: "Latest", value: `v${latest}`, highlight: updateAvailable })) : null] }), isRestarting ? (_jsx("div", { className: "border-t border-white/10 pt-1.5", children: _jsx("span", { className: "text-[10px] font-medium text-emerald-400", "data-testid": "upgrade-restarting", children: "Restarting..." }) })) : didUpgrade ? (_jsx("div", { className: "border-t border-white/10 pt-1.5", children: _jsx("span", { className: "text-[10px] font-medium text-emerald-400", "data-testid": "upgrade-success", children: "Upgraded successfully" }) })) : upgradeError ? (_jsx("div", { className: "border-t border-white/10 pt-1.5", children: _jsx("span", { className: "text-[10px] font-medium text-red-400", "data-testid": "upgrade-error", children: "Upgrade failed" }) })) : updateAvailable ? (_jsx("div", { className: "border-t border-white/10 pt-1.5", children: _jsx("button", { type: "button", onClick: startUpgrade, disabled: isUpgrading || isRestarting, className: "inline-flex items-center gap-1 text-[10px] font-medium text-emerald-400 transition-colors hover:text-emerald-300 disabled:opacity-50", "data-testid": "upgrade-button", children: isUpgrading
16
+ return (_jsx(TooltipProvider, { delayDuration: 200, children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs("span", { className: "text-muted-foreground/80 hover:text-muted-foreground relative cursor-default text-[11px] leading-tight transition-colors", "data-testid": "version-label", children: [displayVersion, updateAvailable && !didUpgrade && !isRestarting ? (_jsx("span", { className: "absolute -top-0.5 -right-1.5 size-1.5 rounded-full bg-emerald-400", "data-testid": "update-dot" })) : null] }) }), _jsxs(TooltipContent, { side: "right", className: "max-w-[280px] space-y-1 p-3 text-left", children: [_jsx("div", { className: "mb-1.5 text-xs font-semibold", children: packageName }), description ? (_jsx("div", { className: "text-[10px] leading-snug opacity-70", children: description })) : null, _jsxs("div", { className: "border-t border-white/10 pt-1.5", children: [_jsx(Row, { label: "Version", value: displayVersion }), isDev && branch ? _jsx(Row, { label: "Branch", value: branch }) : null, isDev && shortHash ? _jsx(Row, { label: "Commit", value: shortHash, mono: true }) : null, isDev && instancePath ? _jsx(Row, { label: "Path", value: instancePath, mono: true }) : null, latest ? (_jsx(Row, { label: "Latest", value: `v${latest}`, highlight: updateAvailable })) : null] }), isRestarting ? (_jsx("div", { className: "border-t border-white/10 pt-1.5", children: _jsx("span", { className: "text-[10px] font-medium text-emerald-400", "data-testid": "upgrade-restarting", children: "Restarting..." }) })) : didUpgrade ? (_jsx("div", { className: "border-t border-white/10 pt-1.5", children: _jsx("span", { className: "text-[10px] font-medium text-emerald-400", "data-testid": "upgrade-success", children: "Upgraded successfully" }) })) : upgradeError ? (_jsx("div", { className: "border-t border-white/10 pt-1.5", children: _jsx("span", { className: "text-[10px] font-medium text-red-400", "data-testid": "upgrade-error", children: "Upgrade failed" }) })) : updateAvailable ? (_jsx("div", { className: "border-t border-white/10 pt-1.5", children: _jsx("button", { type: "button", onClick: startUpgrade, disabled: isUpgrading || isRestarting, className: "inline-flex items-center gap-1 text-[10px] font-medium text-emerald-400 transition-colors hover:text-emerald-300 disabled:opacity-50", "data-testid": "upgrade-button", children: isUpgrading
17
17
  ? 'Upgrading...'
18
18
  : isRestarting
19
19
  ? 'Restarting...'
@@ -9,14 +9,14 @@ const markdownComponents = {
9
9
  em: ({ children }) => _jsx("em", { className: "italic", children: children }),
10
10
  code: ({ children, className }) => className ? (_jsx("code", { className: `${className} text-[11px]`, children: children })) : (_jsx("code", { className: "bg-background/50 rounded-md px-1.5 py-0.5 font-mono text-xs", children: children })),
11
11
  pre: ({ children }) => (_jsx("pre", { className: "bg-background/50 my-2 overflow-x-auto rounded-md p-3 font-mono text-xs leading-relaxed", children: children })),
12
- ul: ({ children }) => _jsx("ul", { className: "mb-2 list-disc ps-4 last:mb-0", children: children }),
13
- ol: ({ children }) => _jsx("ol", { className: "mb-2 list-decimal ps-4 last:mb-0", children: children }),
12
+ ul: ({ children }) => _jsx("ul", { className: "mb-2 list-disc pl-4 last:mb-0", children: children }),
13
+ ol: ({ children }) => _jsx("ol", { className: "mb-2 list-decimal pl-4 last:mb-0", children: children }),
14
14
  li: ({ children }) => _jsx("li", { className: "mb-0.5", children: children }),
15
15
  h1: ({ children }) => _jsx("h1", { className: "mb-1 text-base font-bold", children: children }),
16
16
  h2: ({ children }) => _jsx("h2", { className: "mb-1 text-sm font-bold", children: children }),
17
17
  h3: ({ children }) => _jsx("h3", { className: "mb-1 text-sm font-semibold", children: children }),
18
18
  a: ({ children, href }) => (_jsx("a", { href: href, className: "text-blue-500 underline", target: "_blank", rel: "noopener noreferrer", children: children })),
19
- blockquote: ({ children }) => (_jsx("blockquote", { className: "border-muted-foreground/30 my-1 border-s-2 ps-3 italic opacity-80", children: children })),
19
+ blockquote: ({ children }) => (_jsx("blockquote", { className: "border-muted-foreground/30 my-1 border-l-2 pl-3 italic opacity-80", children: children })),
20
20
  };
21
21
  function formatTime(ts) {
22
22
  try {
@@ -39,5 +39,5 @@ export function ChatMessageBubble({ role, content, timestamp, streaming = false,
39
39
  const timeStr = timestamp ? formatTime(timestamp) : null;
40
40
  return (_jsxs("div", { className: cn('flex w-full flex-col', isUser ? 'items-end' : 'items-start', className), "aria-label": isUser ? 'Your message' : 'Agent message', children: [_jsxs("div", { className: cn('max-w-[85%] rounded-2xl px-4 py-2.5 text-sm leading-relaxed', isUser
41
41
  ? 'bg-primary text-primary-foreground rounded-br-sm'
42
- : 'bg-muted text-foreground rounded-bl-sm'), children: [isUser ? (_jsx("span", { className: "whitespace-pre-wrap", children: content })) : (_jsx(Markdown, { components: markdownComponents, children: content })), streaming && !isUser ? (_jsx("span", { "aria-label": "Agent is typing", className: "ms-0.5 inline-block h-3.5 w-0.5 animate-pulse bg-current align-middle opacity-75" })) : null] }), timeStr && !streaming ? (_jsx("span", { className: "text-muted-foreground mt-0.5 px-1 text-[10px]", children: timeStr })) : null] }));
42
+ : 'bg-muted text-foreground rounded-bl-sm'), children: [isUser ? (_jsx("span", { className: "whitespace-pre-wrap", children: content })) : (_jsx(Markdown, { components: markdownComponents, children: content })), streaming && !isUser ? (_jsx("span", { "aria-label": "Agent is typing", className: "ml-0.5 inline-block h-3.5 w-0.5 animate-pulse bg-current align-middle opacity-75" })) : null] }), timeStr && !streaming ? (_jsx("span", { className: "text-muted-foreground mt-0.5 px-1 text-[10px]", children: timeStr })) : null] }));
43
43
  }
@@ -32,5 +32,5 @@ function ThinkingIndicator({ activityLog }) {
32
32
  /** Collapsible activity log shown above streaming content. */
33
33
  function ActivityLogCollapsible({ entries }) {
34
34
  const [expanded, setExpanded] = useState(false);
35
- return (_jsxs("div", { className: "flex w-full justify-start", children: [_jsxs("button", { onClick: () => setExpanded(!expanded), className: "text-muted-foreground hover:text-foreground flex items-center gap-1.5 rounded-md px-2 py-1 text-[11px] transition-colors", children: [_jsx(Activity, { className: "size-3 opacity-50" }), expanded ? _jsx(ChevronDown, { className: "size-3" }) : _jsx(ChevronRight, { className: "size-3" }), entries.length, " agent actions"] }), expanded ? (_jsx("div", { className: "bg-muted/50 ms-2 rounded-md px-3 py-2", children: entries.map((entry, i) => (_jsxs("div", { className: "text-muted-foreground flex items-center gap-1.5 py-0.5 text-[11px]", children: [_jsx(Activity, { className: "size-2.5 shrink-0 opacity-50" }), _jsx("span", { children: entry })] }, `${entry.slice(0, 20)}-${i}`))) })) : null] }));
35
+ return (_jsxs("div", { className: "flex w-full justify-start", children: [_jsxs("button", { onClick: () => setExpanded(!expanded), className: "text-muted-foreground hover:text-foreground flex items-center gap-1.5 rounded-md px-2 py-1 text-[11px] transition-colors", children: [_jsx(Activity, { className: "size-3 opacity-50" }), expanded ? _jsx(ChevronDown, { className: "size-3" }) : _jsx(ChevronRight, { className: "size-3" }), entries.length, " agent actions"] }), expanded ? (_jsx("div", { className: "bg-muted/50 ml-2 rounded-md px-3 py-2", children: entries.map((entry, i) => (_jsxs("div", { className: "text-muted-foreground flex items-center gap-1.5 py-0.5 text-[11px]", children: [_jsx(Activity, { className: "size-2.5 shrink-0 opacity-50" }), _jsx("span", { children: entry })] }, `${entry.slice(0, 20)}-${i}`))) })) : null] }));
36
36
  }
@@ -53,7 +53,7 @@ function ChatSkeleton() {
53
53
  }
54
54
  // ── Chat header — compact session info + actions ─────────────────────────────
55
55
  function ChatHeader({ sessionInfo, isAgentActive, onClear, onStop, }) {
56
- return (_jsxs("div", { className: "flex h-8 shrink-0 items-center border-b px-3", children: [_jsx("div", { className: "flex min-w-0 flex-1 items-center gap-2", children: sessionInfo ? (_jsxs(_Fragment, { children: [isAgentActive ? (_jsx("span", { className: "h-1.5 w-1.5 shrink-0 animate-pulse rounded-full bg-emerald-500" })) : (_jsx(Cpu, { className: "text-muted-foreground/40 h-3 w-3 shrink-0" })), _jsxs("span", { className: "text-muted-foreground font-mono text-[10px]", children: [sessionInfo.model ?? 'agent', sessionInfo.sessionId ? ` · ${sessionInfo.sessionId.slice(0, 8)}` : ''] })] })) : (_jsx("span", { className: "text-muted-foreground/40 text-[11px]", children: "No session" })) }), _jsxs("div", { className: "flex items-center gap-1 ps-2", children: [sessionInfo ? (_jsxs(_Fragment, { children: [_jsxs(ToolbarButton, { onClick: () => {
56
+ return (_jsxs("div", { className: "flex h-8 shrink-0 items-center border-b px-3", children: [_jsx("div", { className: "flex min-w-0 flex-1 items-center gap-2", children: sessionInfo ? (_jsxs(_Fragment, { children: [isAgentActive ? (_jsx("span", { className: "h-1.5 w-1.5 shrink-0 animate-pulse rounded-full bg-emerald-500" })) : (_jsx(Cpu, { className: "text-muted-foreground/40 h-3 w-3 shrink-0" })), _jsxs("span", { className: "text-muted-foreground font-mono text-[10px]", children: [sessionInfo.model ?? 'agent', sessionInfo.sessionId ? ` · ${sessionInfo.sessionId.slice(0, 8)}` : ''] })] })) : (_jsx("span", { className: "text-muted-foreground/40 text-[11px]", children: "No session" })) }), _jsxs("div", { className: "flex items-center gap-1 pl-2", children: [sessionInfo ? (_jsxs(_Fragment, { children: [_jsxs(ToolbarButton, { onClick: () => {
57
57
  void onStop();
58
58
  }, title: "Force stop agent process", variant: "danger", children: [_jsx(Square, { className: "h-2.5 w-2.5 fill-current" }), _jsx("span", { children: "Stop" })] }), _jsx("span", { className: "text-border mx-0.5", children: "|" })] })) : null, _jsxs(ToolbarButton, { onClick: () => {
59
59
  void onClear();
@@ -1 +1 @@
1
- {"version":3,"file":"control-center-empty-state.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/control-center/control-center-empty-state.tsx"],"names":[],"mappings":"AA0BA,MAAM,WAAW,4BAA4B;IAC3C,kBAAkB,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5C,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAID,wBAAgB,uBAAuB,CAAC,EACtC,kBAAkB,EAClB,SAAS,GACV,EAAE,4BAA4B,kDAoM9B"}
1
+ {"version":3,"file":"control-center-empty-state.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/control-center/control-center-empty-state.tsx"],"names":[],"mappings":"AAyBA,MAAM,WAAW,4BAA4B;IAC3C,kBAAkB,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5C,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAID,wBAAgB,uBAAuB,CAAC,EACtC,kBAAkB,EAClB,SAAS,GACV,EAAE,4BAA4B,kDAmM9B"}
@@ -2,7 +2,6 @@
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useState, useCallback, useEffect } from 'react';
4
4
  import { FolderOpen, Copy, Check, Loader2, CheckCircle2, AlertCircle, Terminal, ChevronDown, ExternalLink, } from 'lucide-react';
5
- import { useTranslation } from 'react-i18next';
6
5
  import { cn } from '../../../lib/utils.js';
7
6
  import { pickFolder } from '../../common/add-repository-button/pick-folder.js';
8
7
  import { ReactFileManagerDialog } from '../../common/react-file-manager-dialog/index.js';
@@ -13,7 +12,6 @@ import { checkToolStatus } from '../../../app/actions/check-tool-status.js';
13
12
  import { WelcomeAgentSetup } from './welcome-agent-setup.js';
14
13
  const commands = ['cd ~/my-repo', 'shep feat new "sleek dashboard"'];
15
14
  export function ControlCenterEmptyState({ onRepositorySelect, className, }) {
16
- const { t } = useTranslation('web');
17
15
  const [copied, setCopied] = useState(false);
18
16
  const [loading, setLoading] = useState(false);
19
17
  const [showReactPicker, setShowReactPicker] = useState(false);
@@ -79,28 +77,27 @@ export function ControlCenterEmptyState({ onRepositorySelect, className, }) {
79
77
  /* Agent setup wizard — owns its own hero */
80
78
  _jsx(WelcomeAgentSetup, { onComplete: handleAgentSetupComplete })) : (
81
79
  /* Repository step — fade in to match wizard transitions */
82
- _jsxs("div", { className: "animate-in fade-in flex w-full max-w-md flex-col items-center duration-300", children: [_jsx("h1", { className: "text-foreground/90 text-center text-5xl font-extralight tracking-tight", children: t('emptyState.addProject') }), _jsxs("p", { className: "text-muted-foreground mt-3 text-center text-lg leading-relaxed font-light", children: [t('emptyState.addProjectDescription'), _jsx("br", {}), t('emptyState.addProjectDescriptionLine2')] }), _jsxs("div", { className: "mt-8 flex w-full flex-col gap-3", children: [_jsx(AgentAuthBanner, { status: authStatus, onRetry: handleRetryAuth }), _jsx(ToolStatusRow, { label: t('emptyState.git'), status: toolStatus?.git ?? null, missingHint: t('emptyState.gitRequired') }), _jsx(ToolStatusRow, { label: t('emptyState.githubCli'), status: toolStatus?.gh ?? null, missingHint: t('emptyState.githubCliRequired') })] }), _jsxs("button", { type: "button", "data-testid": "empty-state-add-repository", onClick: handlePickerClick, disabled: loading, className: "bg-foreground text-background hover:bg-foreground/90 mt-10 flex w-full cursor-pointer items-center justify-center gap-2.5 rounded-xl px-6 py-4 text-base font-medium shadow-lg transition-all duration-200 hover:shadow-xl active:scale-[0.98] disabled:cursor-wait disabled:opacity-50", children: [loading ? (_jsx(Loader2, { className: "h-5 w-5 animate-spin" })) : (_jsx(FolderOpen, { className: "h-5 w-5" })), loading ? t('emptyState.opening') : t('emptyState.chooseFolder')] }), _jsx("p", { className: "text-muted-foreground/60 mt-3 text-center text-sm", children: t('emptyState.folderHint') })] })), agentReady ? (_jsxs("div", { className: "absolute bottom-8 flex flex-col items-center", style: {
80
+ _jsxs("div", { className: "animate-in fade-in flex w-full max-w-md flex-col items-center duration-300", children: [_jsx("h1", { className: "text-foreground/90 text-center text-5xl font-extralight tracking-tight", children: "Add a project" }), _jsxs("p", { className: "text-muted-foreground mt-3 text-center text-lg leading-relaxed font-light", children: ["Add your project folder to unlock feature creation.", _jsx("br", {}), "Describe what you need \u2014 Shep handles the rest."] }), _jsxs("div", { className: "mt-8 flex w-full flex-col gap-3", children: [_jsx(AgentAuthBanner, { status: authStatus, onRetry: handleRetryAuth }), _jsx(ToolStatusRow, { label: "Git", status: toolStatus?.git ?? null, missingHint: "Required for all phases" }), _jsx(ToolStatusRow, { label: "GitHub CLI", status: toolStatus?.gh ?? null, missingHint: "Required for pull requests" })] }), _jsxs("button", { type: "button", "data-testid": "empty-state-add-repository", onClick: handlePickerClick, disabled: loading, className: "bg-foreground text-background hover:bg-foreground/90 mt-10 flex w-full cursor-pointer items-center justify-center gap-2.5 rounded-xl px-6 py-4 text-base font-medium shadow-lg transition-all duration-200 hover:shadow-xl active:scale-[0.98] disabled:cursor-wait disabled:opacity-50", children: [loading ? (_jsx(Loader2, { className: "h-5 w-5 animate-spin" })) : (_jsx(FolderOpen, { className: "h-5 w-5" })), loading ? 'Opening…' : 'Choose a Folder'] }), _jsx("p", { className: "text-muted-foreground/60 mt-3 text-center text-sm", children: "Any folder works \u2014 git will be initialized automatically if needed." })] })), agentReady ? (_jsxs("div", { className: "absolute bottom-8 flex flex-col items-center", style: {
83
81
  animationDelay: '400ms',
84
82
  animationDuration: '600ms',
85
83
  animationFillMode: 'both',
86
- }, children: [_jsxs("button", { type: "button", onClick: () => setCliExpanded(!cliExpanded), className: "text-muted-foreground hover:text-foreground flex cursor-pointer items-center gap-1.5 transition-colors duration-200", children: [_jsx(Terminal, { className: "h-3.5 w-3.5" }), _jsx("span", { className: "text-sm", children: t('emptyState.orUseCli') }), _jsx(ChevronDown, { className: cn('h-3.5 w-3.5 transition-transform duration-200', cliExpanded ? '' : 'rotate-180') })] }), cliExpanded ? (_jsx("div", { className: "animate-in fade-in slide-in-from-top-1 mt-3 w-80 duration-200", children: _jsxs("div", { "data-testid": "cli-code-block", className: "relative rounded-xl bg-zinc-900 px-5 py-4 font-mono text-[13px] leading-relaxed text-zinc-400", children: [_jsx("button", { type: "button", "data-testid": "cli-code-block-copy", onClick: handleCopy, className: "absolute top-3 right-3 cursor-pointer rounded-md p-1.5 text-zinc-600 transition-colors hover:bg-zinc-800 hover:text-zinc-300", "aria-label": t('emptyState.copyCommands'), children: copied ? (_jsx(Check, { className: "h-3.5 w-3.5 text-emerald-400" })) : (_jsx(Copy, { className: "h-3.5 w-3.5" })) }), _jsx("div", { className: "space-y-1", children: commands.map((cmd) => (_jsxs("div", { className: "whitespace-nowrap", children: [_jsx("span", { className: "text-zinc-600 select-none", children: "$ " }), _jsx("span", { className: "text-zinc-300", children: cmd })] }, cmd))) })] }) })) : null] })) : null, _jsx(ReactFileManagerDialog, { open: showReactPicker, onOpenChange: (open) => {
84
+ }, children: [_jsxs("button", { type: "button", onClick: () => setCliExpanded(!cliExpanded), className: "text-muted-foreground hover:text-foreground flex cursor-pointer items-center gap-1.5 transition-colors duration-200", children: [_jsx(Terminal, { className: "h-3.5 w-3.5" }), _jsx("span", { className: "text-sm", children: "or use the CLI" }), _jsx(ChevronDown, { className: cn('h-3.5 w-3.5 transition-transform duration-200', cliExpanded ? '' : 'rotate-180') })] }), cliExpanded ? (_jsx("div", { className: "animate-in fade-in slide-in-from-top-1 mt-3 w-80 duration-200", children: _jsxs("div", { "data-testid": "cli-code-block", className: "relative rounded-xl bg-zinc-900 px-5 py-4 font-mono text-[13px] leading-relaxed text-zinc-400", children: [_jsx("button", { type: "button", "data-testid": "cli-code-block-copy", onClick: handleCopy, className: "absolute top-3 right-3 cursor-pointer rounded-md p-1.5 text-zinc-600 transition-colors hover:bg-zinc-800 hover:text-zinc-300", "aria-label": "Copy commands", children: copied ? (_jsx(Check, { className: "h-3.5 w-3.5 text-emerald-400" })) : (_jsx(Copy, { className: "h-3.5 w-3.5" })) }), _jsx("div", { className: "space-y-1", children: commands.map((cmd) => (_jsxs("div", { className: "whitespace-nowrap", children: [_jsx("span", { className: "text-zinc-600 select-none", children: "$ " }), _jsx("span", { className: "text-zinc-300", children: cmd })] }, cmd))) })] }) })) : null] })) : null, _jsx(ReactFileManagerDialog, { open: showReactPicker, onOpenChange: (open) => {
87
85
  if (!open)
88
86
  setShowReactPicker(false);
89
87
  }, onSelect: handleReactPickerSelect })] }));
90
88
  }
91
89
  /** Status row for the AI agent (Claude Code, etc.) */
92
90
  function AgentAuthBanner({ status, onRetry, }) {
93
- const { t } = useTranslation('web');
94
91
  if (!status) {
95
- return (_jsx(ChecklistRow, { icon: _jsx(Loader2, { className: "text-muted-foreground/50 h-4 w-4 animate-spin" }), children: _jsx("span", { className: "text-muted-foreground/50 text-sm", children: t('emptyState.checkingSetup') }) }));
92
+ return (_jsx(ChecklistRow, { icon: _jsx(Loader2, { className: "text-muted-foreground/50 h-4 w-4 animate-spin" }), children: _jsx("span", { className: "text-muted-foreground/50 text-sm", children: "Checking setup\u2026" }) }));
96
93
  }
97
94
  if (status.installed && status.authenticated) {
98
- return (_jsx(ChecklistRow, { icon: _jsx(CheckCircle2, { className: "h-4 w-4 text-emerald-500" }), children: _jsx("span", { className: "text-sm text-emerald-600 dark:text-emerald-400", children: t('emptyState.ready', { label: status.label }) }) }));
95
+ return (_jsx(ChecklistRow, { icon: _jsx(CheckCircle2, { className: "h-4 w-4 text-emerald-500" }), children: _jsxs("span", { className: "text-sm text-emerald-600 dark:text-emerald-400", children: [status.label, " ready"] }) }));
99
96
  }
100
97
  if (!status.installed) {
101
- return (_jsxs(ChecklistRow, { icon: _jsx(AlertCircle, { className: "h-4 w-4 text-amber-500" }), children: [_jsx("span", { className: "text-sm font-medium text-amber-600 dark:text-amber-400", children: t('emptyState.notInstalled', { label: status.label }) }), status.installCommand ? _jsx(CopyableCommand, { command: status.installCommand }) : null, _jsx("button", { type: "button", onClick: onRetry, className: "text-xs text-amber-600 underline underline-offset-2 hover:text-amber-800 dark:text-amber-400", children: t('emptyState.reCheck') })] }));
98
+ return (_jsxs(ChecklistRow, { icon: _jsx(AlertCircle, { className: "h-4 w-4 text-amber-500" }), children: [_jsxs("span", { className: "text-sm font-medium text-amber-600 dark:text-amber-400", children: [status.label, " not installed"] }), status.installCommand ? _jsx(CopyableCommand, { command: status.installCommand }) : null, _jsx("button", { type: "button", onClick: onRetry, className: "text-xs text-amber-600 underline underline-offset-2 hover:text-amber-800 dark:text-amber-400", children: "Re-check" })] }));
102
99
  }
103
- return (_jsxs(ChecklistRow, { icon: _jsx(AlertCircle, { className: "h-4 w-4 text-amber-500" }), children: [_jsx("span", { className: "text-sm font-medium text-amber-600 dark:text-amber-400", children: t('emptyState.needsAuth', { label: status.label }) }), status.authCommand ? _jsx(CopyableCommand, { command: status.authCommand }) : null, _jsxs("div", { className: "flex items-center gap-3", children: [status.binaryName ? (_jsxs("button", { type: "button", "data-testid": "auth-banner-open-terminal", onClick: async () => {
100
+ return (_jsxs(ChecklistRow, { icon: _jsx(AlertCircle, { className: "h-4 w-4 text-amber-500" }), children: [_jsxs("span", { className: "text-sm font-medium text-amber-600 dark:text-amber-400", children: [status.label, " needs authentication"] }), status.authCommand ? _jsx(CopyableCommand, { command: status.authCommand }) : null, _jsxs("div", { className: "flex items-center gap-3", children: [status.binaryName ? (_jsxs("button", { type: "button", "data-testid": "auth-banner-open-terminal", onClick: async () => {
104
101
  try {
105
102
  const toolId = status.agentType === 'claude-code' ? 'claude-code' : status.agentType;
106
103
  await fetch(`/api/tools/${toolId}/launch`, { method: 'POST' });
@@ -108,18 +105,17 @@ function AgentAuthBanner({ status, onRetry, }) {
108
105
  catch {
109
106
  /* best effort */
110
107
  }
111
- }, className: "flex items-center gap-1 text-xs font-medium text-amber-600 underline underline-offset-2 hover:text-amber-800 dark:text-amber-400", children: [_jsx(Terminal, { className: "h-3 w-3" }), t('emptyState.open', { label: status.label })] })) : null, _jsx("button", { type: "button", onClick: onRetry, className: "text-xs text-amber-600 underline underline-offset-2 hover:text-amber-800 dark:text-amber-400", children: t('emptyState.reCheck') })] })] }));
108
+ }, className: "flex items-center gap-1 text-xs font-medium text-amber-600 underline underline-offset-2 hover:text-amber-800 dark:text-amber-400", children: [_jsx(Terminal, { className: "h-3 w-3" }), "Open ", status.label] })) : null, _jsx("button", { type: "button", onClick: onRetry, className: "text-xs text-amber-600 underline underline-offset-2 hover:text-amber-800 dark:text-amber-400", children: "Re-check" })] })] }));
112
109
  }
113
110
  /** Status row for system tools (git, gh) */
114
111
  function ToolStatusRow({ label, status, missingHint, }) {
115
- const { t } = useTranslation('web');
116
112
  if (!status) {
117
- return (_jsx(ChecklistRow, { icon: _jsx(Loader2, { className: "text-muted-foreground/50 h-4 w-4 animate-spin" }), children: _jsx("span", { className: "text-muted-foreground/50 text-sm", children: t('emptyState.checking', { label }) }) }));
113
+ return (_jsx(ChecklistRow, { icon: _jsx(Loader2, { className: "text-muted-foreground/50 h-4 w-4 animate-spin" }), children: _jsxs("span", { className: "text-muted-foreground/50 text-sm", children: ["Checking ", label, "\u2026"] }) }));
118
114
  }
119
115
  if (status.installed) {
120
- return (_jsx(ChecklistRow, { icon: _jsx(CheckCircle2, { className: "h-4 w-4 text-emerald-500" }), children: _jsxs("span", { className: "flex items-baseline gap-2", children: [_jsx("span", { className: "text-sm text-emerald-600 dark:text-emerald-400", children: t('emptyState.ready', { label }) }), status.version ? (_jsxs("span", { className: "text-muted-foreground/40 text-xs", children: ["v", status.version] })) : null] }) }));
116
+ return (_jsx(ChecklistRow, { icon: _jsx(CheckCircle2, { className: "h-4 w-4 text-emerald-500" }), children: _jsxs("span", { className: "flex items-baseline gap-2", children: [_jsxs("span", { className: "text-sm text-emerald-600 dark:text-emerald-400", children: [label, " ready"] }), status.version ? (_jsxs("span", { className: "text-muted-foreground/40 text-xs", children: ["v", status.version] })) : null] }) }));
121
117
  }
122
- return (_jsxs(ChecklistRow, { icon: _jsx(AlertCircle, { className: "h-4 w-4 text-amber-500" }), children: [_jsx("span", { className: "text-sm font-medium text-amber-600 dark:text-amber-400", children: t('emptyState.notFound', { label }) }), _jsx("span", { className: "text-muted-foreground/50 text-xs", children: missingHint }), status.installCommand ? _jsx(CopyableCommand, { command: status.installCommand }) : null, status.installUrl ? (_jsxs("a", { href: status.installUrl, target: "_blank", rel: "noopener noreferrer", className: "inline-flex items-center gap-1 text-xs text-amber-600 underline underline-offset-2 hover:text-amber-800 dark:text-amber-400", children: [t('emptyState.docs'), " ", _jsx(ExternalLink, { className: "h-3 w-3" })] })) : null] }));
118
+ return (_jsxs(ChecklistRow, { icon: _jsx(AlertCircle, { className: "h-4 w-4 text-amber-500" }), children: [_jsxs("span", { className: "text-sm font-medium text-amber-600 dark:text-amber-400", children: [label, " not found"] }), _jsx("span", { className: "text-muted-foreground/50 text-xs", children: missingHint }), status.installCommand ? _jsx(CopyableCommand, { command: status.installCommand }) : null, status.installUrl ? (_jsxs("a", { href: status.installUrl, target: "_blank", rel: "noopener noreferrer", className: "inline-flex items-center gap-1 text-xs text-amber-600 underline underline-offset-2 hover:text-amber-800 dark:text-amber-400", children: ["Docs ", _jsx(ExternalLink, { className: "h-3 w-3" })] })) : null] }));
123
119
  }
124
120
  /** Checklist row: icon pinned left, children stacked vertically and fill width */
125
121
  function ChecklistRow({ icon, children }) {
@@ -132,5 +128,5 @@ function CopyableCommand({ command }) {
132
128
  await navigator.clipboard.writeText(command);
133
129
  setCopied(true);
134
130
  setTimeout(() => setCopied(false), 2000);
135
- }, className: "group/cmd flex cursor-pointer items-center justify-between gap-2 rounded-md bg-zinc-100 py-1 ps-2.5 pe-2 text-start transition-colors hover:bg-zinc-200 dark:bg-zinc-800 dark:hover:bg-zinc-700", children: [_jsx("code", { className: "min-w-0 truncate text-[11px] leading-relaxed text-zinc-600 dark:text-zinc-300", children: command }), copied ? (_jsx(Check, { className: "h-3 w-3 shrink-0 text-emerald-500" })) : (_jsx(Copy, { className: "h-3 w-3 shrink-0 text-zinc-400 opacity-0 transition-opacity group-hover/cmd:opacity-100" }))] }));
131
+ }, className: "group/cmd flex cursor-pointer items-center justify-between gap-2 rounded-md bg-zinc-100 py-1 pr-2 pl-2.5 text-left transition-colors hover:bg-zinc-200 dark:bg-zinc-800 dark:hover:bg-zinc-700", children: [_jsx("code", { className: "min-w-0 truncate text-[11px] leading-relaxed text-zinc-600 dark:text-zinc-300", children: command }), copied ? (_jsx(Check, { className: "h-3 w-3 shrink-0 text-emerald-500" })) : (_jsx(Copy, { className: "h-3 w-3 shrink-0 text-zinc-400 opacity-0 transition-opacity group-hover/cmd:opacity-100" }))] }));
136
132
  }
@@ -1 +1 @@
1
- {"version":3,"file":"welcome-agent-setup.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/control-center/welcome-agent-setup.tsx"],"names":[],"mappings":"AAYA,MAAM,WAAW,sBAAsB;IACrC,UAAU,EAAE,MAAM,IAAI,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAMD,wBAAgB,iBAAiB,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,EAAE,sBAAsB,2CAkPlF"}
1
+ {"version":3,"file":"welcome-agent-setup.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/control-center/welcome-agent-setup.tsx"],"names":[],"mappings":"AAWA,MAAM,WAAW,sBAAsB;IACrC,UAAU,EAAE,MAAM,IAAI,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAMD,wBAAgB,iBAAiB,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,EAAE,sBAAsB,2CAkPlF"}
@@ -2,7 +2,6 @@
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useState, useEffect, useCallback, useRef } from 'react';
4
4
  import { ChevronLeft, Loader2, AlertTriangle } from 'lucide-react';
5
- import { useTranslation } from 'react-i18next';
6
5
  import { getAllAgentModels } from '../../../app/actions/get-all-agent-models.js';
7
6
  import { updateAgentAndModel } from '../../../app/actions/update-agent-and-model.js';
8
7
  import { getAgentTypeIcon } from '../../common/feature-node/agent-type-icons.js';
@@ -10,7 +9,6 @@ import { getModelMeta } from '../../../lib/model-metadata.js';
10
9
  import { cn } from '../../../lib/utils.js';
11
10
  const STEPS = ['select-agent', 'select-model'];
12
11
  export function WelcomeAgentSetup({ onComplete, className }) {
13
- const { t } = useTranslation('web');
14
12
  const [groups, setGroups] = useState([]);
15
13
  const [loading, setLoading] = useState(true);
16
14
  const [step, setStep] = useState('select-agent');
@@ -85,22 +83,22 @@ export function WelcomeAgentSetup({ onComplete, className }) {
85
83
  }
86
84
  }, [step, transitionTo]);
87
85
  if (loading) {
88
- return (_jsxs("div", { "data-testid": "welcome-agent-setup", className: cn('flex flex-col items-center justify-center gap-4', className), children: [_jsx(Loader2, { className: "text-muted-foreground h-5 w-5 animate-spin" }), _jsx("p", { className: "text-muted-foreground text-sm", children: t('welcome.loadingAgents') })] }));
86
+ return (_jsxs("div", { "data-testid": "welcome-agent-setup", className: cn('flex flex-col items-center justify-center gap-4', className), children: [_jsx(Loader2, { className: "text-muted-foreground h-5 w-5 animate-spin" }), _jsx("p", { className: "text-muted-foreground text-sm", children: "Loading agents\u2026" })] }));
89
87
  }
90
88
  const stepIndex = STEPS.indexOf(step);
91
89
  // Dynamic hero text per step
92
- const heroTitle = step === 'select-agent' ? t('welcome.chooseAgent') : t('welcome.pickModel');
90
+ const heroTitle = step === 'select-agent' ? 'Choose your agent' : activeGroup ? `Pick a model` : 'Pick a model';
93
91
  const heroSubtitle = step === 'select-agent'
94
- ? t('welcome.selectAgentSubtitle')
92
+ ? 'Select the AI coding agent you want Shep to use.'
95
93
  : activeGroup
96
- ? t('welcome.chooseModelSubtitle', { label: activeGroup.label })
94
+ ? `Choose which ${activeGroup.label} model to run.`
97
95
  : '';
98
- return (_jsxs("div", { "data-testid": "welcome-agent-setup", className: cn('flex w-full flex-col items-center', className), children: [_jsx("div", { className: "mb-8 flex w-full max-w-xs items-center gap-1.5", children: STEPS.map((s, i) => (_jsx("div", { className: cn('h-[3px] flex-1 rounded-full transition-colors duration-300', i <= stepIndex ? 'bg-foreground/60' : 'bg-muted') }, s))) }), _jsxs("div", { className: cn('flex w-full flex-col items-center transition-opacity duration-200', visible && !transitioning ? 'opacity-100' : 'opacity-0'), children: [_jsx("h1", { className: "text-foreground/90 text-center text-5xl font-extralight tracking-tight", children: heroTitle }), _jsx("p", { className: "text-muted-foreground mt-3 text-center text-lg leading-relaxed font-light", children: heroSubtitle }), step === 'select-agent' && (_jsxs("div", { "data-testid": "gh-cli-notice", className: "mt-5 flex items-start gap-2 rounded-lg border border-amber-200 bg-amber-50 px-4 py-3 dark:border-amber-900 dark:bg-amber-950/40", children: [_jsx(AlertTriangle, { className: "mt-0.5 h-4 w-4 shrink-0 text-amber-500" }), _jsxs("p", { className: "text-sm leading-relaxed text-amber-800 dark:text-amber-300", children: [_jsx("span", { className: "font-medium", children: t('welcome.ghCliRequired') }), ' ', t('welcome.ghCliRequiredText'), ' ', _jsx("a", { href: "https://cli.github.com/", target: "_blank", rel: "noopener noreferrer", className: "underline underline-offset-2 hover:text-amber-900 dark:hover:text-amber-200", children: t('welcome.installHere') }), "."] })] })), _jsxs("div", { className: "mt-8 flex w-full flex-col items-center", children: [step === 'select-agent' && (_jsx("div", { "data-testid": "agent-list", className: "grid w-full max-w-lg gap-3", style: {
96
+ return (_jsxs("div", { "data-testid": "welcome-agent-setup", className: cn('flex w-full flex-col items-center', className), children: [_jsx("div", { className: "mb-8 flex w-full max-w-xs items-center gap-1.5", children: STEPS.map((s, i) => (_jsx("div", { className: cn('h-[3px] flex-1 rounded-full transition-colors duration-300', i <= stepIndex ? 'bg-foreground/60' : 'bg-muted') }, s))) }), _jsxs("div", { className: cn('flex w-full flex-col items-center transition-opacity duration-200', visible && !transitioning ? 'opacity-100' : 'opacity-0'), children: [_jsx("h1", { className: "text-foreground/90 text-center text-5xl font-extralight tracking-tight", children: heroTitle }), _jsx("p", { className: "text-muted-foreground mt-3 text-center text-lg leading-relaxed font-light", children: heroSubtitle }), step === 'select-agent' && (_jsxs("div", { "data-testid": "gh-cli-notice", className: "mt-5 flex items-start gap-2 rounded-lg border border-amber-200 bg-amber-50 px-4 py-3 dark:border-amber-900 dark:bg-amber-950/40", children: [_jsx(AlertTriangle, { className: "mt-0.5 h-4 w-4 shrink-0 text-amber-500" }), _jsxs("p", { className: "text-sm leading-relaxed text-amber-800 dark:text-amber-300", children: [_jsx("span", { className: "font-medium", children: "GitHub CLI (gh)" }), " is required for full CI/CD self-healing capabilities.", ' ', _jsx("a", { href: "https://cli.github.com/", target: "_blank", rel: "noopener noreferrer", className: "underline underline-offset-2 hover:text-amber-900 dark:hover:text-amber-200", children: "Install it here" }), "."] })] })), _jsxs("div", { className: "mt-8 flex w-full flex-col items-center", children: [step === 'select-agent' && (_jsx("div", { "data-testid": "agent-list", className: "grid w-full max-w-lg gap-3", style: {
99
97
  gridTemplateColumns: `repeat(${Math.min(groups.length, 4)}, minmax(0, 1fr))`,
100
98
  }, children: groups.map((group) => {
101
99
  const GroupIcon = getAgentTypeIcon(group.agentType);
102
100
  return (_jsxs("button", { type: "button", disabled: saving, "data-testid": `agent-option-${group.agentType}`, className: "border-border hover:bg-accent hover:border-foreground/20 flex cursor-pointer flex-col items-center gap-3 rounded-2xl border px-4 py-5 transition-all duration-150 active:scale-[0.97] disabled:opacity-50", onClick: () => handleAgentSelect(group.agentType), children: [_jsx(GroupIcon, { className: "text-foreground/70 h-7 w-7" }), _jsx("span", { className: "text-sm font-medium", children: group.label })] }, group.agentType));
103
- }) })), step === 'select-model' && activeGroup ? (_jsxs("div", { "data-testid": "model-list", className: "flex w-full max-w-lg flex-col items-center gap-4", children: [_jsxs("button", { type: "button", disabled: saving, className: "text-muted-foreground hover:text-foreground flex cursor-pointer items-center gap-1.5 self-start text-sm transition-colors", onClick: handleBack, children: [_jsx(ChevronLeft, { className: "h-4 w-4" }), t('welcome.back')] }), _jsx("div", { className: "grid w-full gap-3", style: {
101
+ }) })), step === 'select-model' && activeGroup ? (_jsxs("div", { "data-testid": "model-list", className: "flex w-full max-w-lg flex-col items-center gap-4", children: [_jsxs("button", { type: "button", disabled: saving, className: "text-muted-foreground hover:text-foreground flex cursor-pointer items-center gap-1.5 self-start text-sm transition-colors", onClick: handleBack, children: [_jsx(ChevronLeft, { className: "h-4 w-4" }), "Back"] }), _jsx("div", { className: "grid w-full gap-3", style: {
104
102
  gridTemplateColumns: `repeat(${Math.min(activeGroup.models.length, 3)}, minmax(0, 1fr))`,
105
103
  }, children: activeGroup.models.map((m) => {
106
104
  const meta = getModelMeta(m.id);
@@ -1 +1 @@
1
- {"version":3,"file":"canvas-toolbar.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/features-canvas/canvas-toolbar.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAK9C,MAAM,WAAW,kBAAkB;IACjC,YAAY,EAAE,OAAO,CAAC;IACtB,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,eAAe,CAAC,EAAE,MAAM,QAAQ,CAAC;CAClC;AAED,wBAAgB,aAAa,CAAC,EAC5B,YAAY,EACZ,gBAAgB,EAChB,eAAe,GAChB,EAAE,kBAAkB,2CAsDpB"}
1
+ {"version":3,"file":"canvas-toolbar.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/features-canvas/canvas-toolbar.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAI9C,MAAM,WAAW,kBAAkB;IACjC,YAAY,EAAE,OAAO,CAAC;IACtB,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,eAAe,CAAC,EAAE,MAAM,QAAQ,CAAC;CAClC;AAED,wBAAgB,aAAa,CAAC,EAC5B,YAAY,EACZ,gBAAgB,EAChB,eAAe,GAChB,EAAE,kBAAkB,2CAqDpB"}
@@ -3,10 +3,8 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useCallback } from 'react';
4
4
  import { useReactFlow } from '@xyflow/react';
5
5
  import { Eye, EyeOff, ZoomIn, ZoomOut, Maximize, RotateCcw } from 'lucide-react';
6
- import { useTranslation } from 'react-i18next';
7
6
  import { cn } from '../../../lib/utils.js';
8
7
  export function CanvasToolbar({ showArchived, onToggleArchived, onResetViewport, }) {
9
- const { t } = useTranslation('web');
10
8
  const { zoomIn, zoomOut, fitView, setViewport } = useReactFlow();
11
9
  const handleZoomIn = useCallback(() => {
12
10
  zoomIn({ duration: 200 });
@@ -23,7 +21,7 @@ export function CanvasToolbar({ showArchived, onToggleArchived, onResetViewport,
23
21
  setViewport(viewport, { duration: 400 });
24
22
  }
25
23
  }, [onResetViewport, setViewport]);
26
- return (_jsxs("div", { className: "bg-background flex items-center gap-1 rounded-xl border px-2 py-1.5 shadow-md dark:bg-neutral-900", children: [_jsx(ToolbarButton, { onClick: onToggleArchived, title: showArchived ? t('canvas.hideArchived') : t('canvas.showArchived'), active: showArchived, label: showArchived ? t('canvas.hideArchivedLabel') : t('canvas.showArchivedLabel'), children: showArchived ? _jsx(Eye, { className: "h-4 w-4" }) : _jsx(EyeOff, { className: "h-4 w-4" }) }), _jsx("div", { className: "bg-border mx-1 h-5 w-px" }), _jsx(ToolbarButton, { onClick: handleZoomOut, title: t('canvas.zoomOut'), children: _jsx(ZoomOut, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: handleZoomIn, title: t('canvas.zoomIn'), children: _jsx(ZoomIn, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: handleFitView, title: t('canvas.fitView'), children: _jsx(Maximize, { className: "h-4 w-4" }) }), onResetViewport ? (_jsx(ToolbarButton, { onClick: handleReset, title: t('canvas.resetView'), children: _jsx(RotateCcw, { className: "h-4 w-4" }) })) : null] }));
24
+ return (_jsxs("div", { className: "bg-background flex items-center gap-1 rounded-xl border px-2 py-1.5 shadow-md dark:bg-neutral-900", children: [_jsx(ToolbarButton, { onClick: onToggleArchived, title: showArchived ? 'Hide archived' : 'Show archived', active: showArchived, label: showArchived ? 'Hide Archived' : 'Show Archived', children: showArchived ? _jsx(Eye, { className: "h-4 w-4" }) : _jsx(EyeOff, { className: "h-4 w-4" }) }), _jsx("div", { className: "bg-border mx-1 h-5 w-px" }), _jsx(ToolbarButton, { onClick: handleZoomOut, title: "Zoom out", children: _jsx(ZoomOut, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: handleZoomIn, title: "Zoom in", children: _jsx(ZoomIn, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: handleFitView, title: "Fit view", children: _jsx(Maximize, { className: "h-4 w-4" }) }), onResetViewport ? (_jsx(ToolbarButton, { onClick: handleReset, title: "Reset view", children: _jsx(RotateCcw, { className: "h-4 w-4" }) })) : null] }));
27
25
  }
28
26
  // ── Internal button ──────────────────────────────────────────────────────
29
27
  function ToolbarButton({ children, onClick, title, label, active, }) {
@@ -1 +1 @@
1
- {"version":3,"file":"features-canvas.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/features-canvas/features-canvas.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAOvF,OAAO,KAAK,EAAE,eAAe,EAAmB,MAAM,kCAAkC,CAAC;AAEzF,OAAO,KAAK,EAAE,kBAAkB,EAAsB,MAAM,qCAAqC,CAAC;AAGlG,MAAM,MAAM,cAAc,GAAG,eAAe,GAAG,kBAAkB,CAAC;AAElE,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,iBAAiB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,kBAAkB,CAAC,EAAE;QAAE,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;QAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE,CAAC;IAChE,eAAe,CAAC,EAAE,QAAQ,CAAC;IAC3B,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,cAAc,CAAC,EAAE,KAAK,IAAI,CAAC;IAChE,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,cAAc,KAAK,IAAI,CAAC;IACtE,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,KAAK,IAAI,CAAC;IAChD,SAAS,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,IAAI,CAAC;IAC7C,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,UAAU,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC9B;AAID,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EACL,KAAK,EACL,iBAAiB,EACjB,kBAAkB,EAClB,eAAe,EACf,aAAa,EACb,YAAY,EACZ,SAAS,EACT,WAAW,EACX,WAAW,EACX,YAAY,EACZ,SAAS,EACT,OAAO,EACP,UAAU,GACX,EAAE,mBAAmB,2CA0IrB"}
1
+ {"version":3,"file":"features-canvas.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/features-canvas/features-canvas.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAMvF,OAAO,KAAK,EAAE,eAAe,EAAmB,MAAM,kCAAkC,CAAC;AAEzF,OAAO,KAAK,EAAE,kBAAkB,EAAsB,MAAM,qCAAqC,CAAC;AAGlG,MAAM,MAAM,cAAc,GAAG,eAAe,GAAG,kBAAkB,CAAC;AAElE,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,iBAAiB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,kBAAkB,CAAC,EAAE;QAAE,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;QAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE,CAAC;IAChE,eAAe,CAAC,EAAE,QAAQ,CAAC;IAC3B,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,cAAc,CAAC,EAAE,KAAK,IAAI,CAAC;IAChE,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,cAAc,KAAK,IAAI,CAAC;IACtE,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,KAAK,IAAI,CAAC;IAChD,SAAS,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,IAAI,CAAC;IAC7C,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,UAAU,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC9B;AAID,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EACL,KAAK,EACL,iBAAiB,EACjB,kBAAkB,EAClB,eAAe,EACf,aAAa,EACb,YAAY,EACZ,SAAS,EACT,WAAW,EACX,WAAW,EACX,YAAY,EACZ,SAAS,EACT,OAAO,EACP,UAAU,GACX,EAAE,mBAAmB,2CAyIrB"}
@@ -3,7 +3,6 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useEffect, useMemo, useRef, useState } from 'react';
4
4
  import { ReactFlow, Background, BackgroundVariant, Panel } from '@xyflow/react';
5
5
  import { Plus } from 'lucide-react';
6
- import { useTranslation } from 'react-i18next';
7
6
  import { cn } from '../../../lib/utils.js';
8
7
  import { Button } from '../../ui/button.js';
9
8
  import { EmptyState } from '../../common/empty-state/index.js';
@@ -12,7 +11,6 @@ import { RepositoryNode } from '../../common/repository-node/index.js';
12
11
  import { DependencyEdge } from './dependency-edge.js';
13
12
  const FALLBACK_VIEWPORT = { x: 30, y: 30, zoom: 0.85 };
14
13
  export function FeaturesCanvas({ nodes, edges, selectedFeatureId, selectedRepository, defaultViewport, onNodesChange, onAddFeature, onConnect, onNodeClick, onPaneClick, onCanvasDrag, onMoveEnd, toolbar, emptyState, }) {
15
- const { t } = useTranslation('web');
16
14
  const nodeTypes = useMemo(() => ({
17
15
  featureNode: FeatureNode,
18
16
  repositoryNode: RepositoryNode,
@@ -69,7 +67,7 @@ export function FeaturesCanvas({ nodes, edges, selectedFeatureId, selectedReposi
69
67
  }
70
68
  prevEmptyRef.current = isEmpty;
71
69
  }, [isEmpty]);
72
- const fallbackEmptyState = isEmpty && !emptyState ? (_jsx(EmptyState, { title: t('canvas.noFeatures'), description: t('canvas.noFeaturesDescription'), action: _jsxs(Button, { onClick: onAddFeature, children: [_jsx(Plus, { className: "me-2 h-4 w-4" }), t('canvas.newFeature')] }) })) : null;
70
+ const fallbackEmptyState = isEmpty && !emptyState ? (_jsx(EmptyState, { title: "No features yet", description: "Get started by creating your first feature.", action: _jsxs(Button, { onClick: onAddFeature, children: [_jsx(Plus, { className: "mr-2 h-4 w-4" }), "New Feature"] }) })) : null;
73
71
  const overlayContent = emptyState ?? fallbackEmptyState;
74
- return (_jsxs("div", { "data-testid": isEmpty ? 'features-canvas-empty' : 'features-canvas', "data-no-drawer-close": true, className: "dark:bg-background pointer-events-auto relative h-full w-full bg-[#f6f7f8]", children: [_jsxs(ReactFlow, { nodes: enrichedNodes, edges: edges, nodeTypes: nodeTypes, edgeTypes: edgeTypes, onConnect: onConnect, onNodesChange: onNodesChange, onNodeClick: onNodeClick, onPaneClick: onPaneClick, onMoveStart: onCanvasDrag, onMoveEnd: onMoveEnd, defaultViewport: defaultViewport ?? FALLBACK_VIEWPORT, nodesDraggable: false, nodesConnectable: false, elementsSelectable: false, proOptions: { hideAttribution: true }, className: "[&_.react-flow__pane]:!cursor-default", children: [_jsx(Background, { variant: BackgroundVariant.Dots, gap: 24, size: 1, color: "#b8bcc4", className: "dark:[&_circle]:!fill-white/[0.1]" }), !isEmpty && toolbar ? (_jsx(Panel, { position: "top-right", className: "!me-3 !mt-3", children: toolbar })) : null] }), showOverlay && overlayContent ? (_jsx("div", { className: cn('pointer-events-none absolute inset-0 z-10 flex items-center justify-center transition-opacity duration-300', overlayExiting ? 'opacity-0' : 'animate-in fade-in opacity-100 duration-200'), children: _jsx("div", { className: "pointer-events-auto h-full w-full", children: overlayContent }) })) : null] }));
72
+ return (_jsxs("div", { "data-testid": isEmpty ? 'features-canvas-empty' : 'features-canvas', "data-no-drawer-close": true, className: "dark:bg-background pointer-events-auto relative h-full w-full bg-[#f6f7f8]", children: [_jsxs(ReactFlow, { nodes: enrichedNodes, edges: edges, nodeTypes: nodeTypes, edgeTypes: edgeTypes, onConnect: onConnect, onNodesChange: onNodesChange, onNodeClick: onNodeClick, onPaneClick: onPaneClick, onMoveStart: onCanvasDrag, onMoveEnd: onMoveEnd, defaultViewport: defaultViewport ?? FALLBACK_VIEWPORT, nodesDraggable: false, nodesConnectable: false, elementsSelectable: false, proOptions: { hideAttribution: true }, className: "[&_.react-flow__pane]:!cursor-default", children: [_jsx(Background, { variant: BackgroundVariant.Dots, gap: 24, size: 1, color: "#b8bcc4", className: "dark:[&_circle]:!fill-white/[0.1]" }), !isEmpty && toolbar ? (_jsx(Panel, { position: "top-right", className: "!mt-3 !mr-3", children: toolbar })) : null] }), showOverlay && overlayContent ? (_jsx("div", { className: cn('pointer-events-none absolute inset-0 z-10 flex items-center justify-center transition-opacity duration-300', overlayExiting ? 'opacity-0' : 'animate-in fade-in opacity-100 duration-200'), children: _jsx("div", { className: "pointer-events-auto h-full w-full", children: overlayContent }) })) : null] }));
75
73
  }
@@ -95,9 +95,9 @@ export function AgentModelPicker({ initialAgentType, initialModel, onAgentModelC
95
95
  else {
96
96
  handleSelect(group.agentType, '');
97
97
  }
98
- }, children: [_jsx(GroupIcon, { className: "h-4 w-4 shrink-0" }), _jsx("span", { className: "flex-1 text-start", children: group.label }), isActive && !hasModels ? (_jsx(Check, { className: "text-primary h-3.5 w-3.5 shrink-0" })) : null, hasModels ? (_jsx(ChevronRight, { className: "text-muted-foreground h-3.5 w-3.5 shrink-0" })) : null] }, group.agentType));
98
+ }, children: [_jsx(GroupIcon, { className: "h-4 w-4 shrink-0" }), _jsx("span", { className: "flex-1 text-left", children: group.label }), isActive && !hasModels ? (_jsx(Check, { className: "text-primary h-3.5 w-3.5 shrink-0" })) : null, hasModels ? (_jsx(ChevronRight, { className: "text-muted-foreground h-3.5 w-3.5 shrink-0" })) : null] }, group.agentType));
99
99
  })] }), _jsx("div", { className: "w-1/2 shrink-0", children: activeGroup ? (_jsxs(_Fragment, { children: [_jsxs("button", { type: "button", className: "text-muted-foreground hover:text-foreground flex w-full cursor-pointer items-center gap-1.5 border-b px-3 py-2 text-xs font-medium transition-colors", onClick: drillBack, children: [_jsx(ChevronLeft, { className: "h-3.5 w-3.5" }), activeGroup.label] }), activeGroup.models.map((m) => {
100
100
  const isSelected = agentType === activeGroup.agentType && model === m.id;
101
- return (_jsxs("button", { type: "button", className: cn('flex w-full cursor-pointer items-center gap-3 px-3 py-2 text-start transition-colors', 'hover:bg-accent hover:text-accent-foreground', isSelected && 'bg-accent/50'), onClick: () => handleSelect(activeGroup.agentType, m.id), children: [_jsxs("div", { className: "flex min-w-0 flex-1 flex-col", children: [_jsx("span", { className: "text-xs font-medium", children: m.displayName }), _jsx("span", { className: "text-muted-foreground text-xs", children: m.description })] }), isSelected ? (_jsx(Check, { className: "text-primary h-3.5 w-3.5 shrink-0" })) : null] }, m.id));
101
+ return (_jsxs("button", { type: "button", className: cn('flex w-full cursor-pointer items-center gap-3 px-3 py-2 text-left transition-colors', 'hover:bg-accent hover:text-accent-foreground', isSelected && 'bg-accent/50'), onClick: () => handleSelect(activeGroup.agentType, m.id), children: [_jsxs("div", { className: "flex min-w-0 flex-1 flex-col", children: [_jsx("span", { className: "text-xs font-medium", children: m.displayName }), _jsx("span", { className: "text-muted-foreground text-xs", children: m.description })] }), isSelected ? (_jsx(Check, { className: "text-primary h-3.5 w-3.5 shrink-0" })) : null] }, m.id));
102
102
  })] })) : null })] }) })] }), Boolean(error) && _jsx("p", { className: "text-destructive text-sm", children: error })] }));
103
103
  }
@@ -78,7 +78,7 @@ export function ModelPicker({ initialModel, onModelChange, disabled, className,
78
78
  }
79
79
  };
80
80
  const isDisabled = (disabled ?? false) || loading || saving;
81
- return (_jsxs("div", { className: cn('flex flex-col gap-1', className), children: [_jsxs(Popover, { open: open, onOpenChange: setOpen, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs(Button, { variant: "outline", role: "combobox", "aria-expanded": open, disabled: isDisabled, className: "w-full justify-between font-normal", children: [_jsx("span", { className: "truncate", children: loading ? 'Loading models…' : saving ? 'Saving…' : (value ?? 'Select model…') }), _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, { placeholder: "Search or type a model ID\u2026", value: inputValue, onChange: handleInputChange, onKeyDown: handleInputKeyDown }), _jsxs(CommandList, { children: [!loading && filteredModels.length === 0 && (_jsx(CommandEmpty, { children: models.length === 0
81
+ return (_jsxs("div", { className: cn('flex flex-col gap-1', className), children: [_jsxs(Popover, { open: open, onOpenChange: setOpen, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs(Button, { variant: "outline", role: "combobox", "aria-expanded": open, disabled: isDisabled, className: "w-full justify-between font-normal", children: [_jsx("span", { className: "truncate", children: loading ? 'Loading models…' : saving ? 'Saving…' : (value ?? 'Select model…') }), _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, { placeholder: "Search or type a model ID\u2026", value: inputValue, onChange: handleInputChange, onKeyDown: handleInputKeyDown }), _jsxs(CommandList, { children: [!loading && filteredModels.length === 0 && (_jsx(CommandEmpty, { children: models.length === 0
82
82
  ? 'No models advertised for this agent.'
83
- : 'No match — press Enter to use this value.' })), filteredModels.length > 0 && (_jsx(CommandGroup, { children: filteredModels.map((model) => (_jsxs(CommandItem, { selected: model === value, onClick: () => handleSelect(model), children: [_jsx(Check, { className: cn('me-2 h-4 w-4', model === value ? 'opacity-100' : 'opacity-0') }), model] }, model))) }))] })] }) })] }), Boolean(error) && _jsx("p", { className: "text-destructive text-sm", children: error })] }));
83
+ : 'No match — press Enter to use this value.' })), filteredModels.length > 0 && (_jsx(CommandGroup, { children: filteredModels.map((model) => (_jsxs(CommandItem, { selected: model === value, onClick: () => handleSelect(model), children: [_jsx(Check, { className: cn('mr-2 h-4 w-4', model === value ? 'opacity-100' : 'opacity-0') }), model] }, model))) }))] })] }) })] }), Boolean(error) && _jsx("p", { className: "text-destructive text-sm", children: error })] }));
84
84
  }
@@ -72,5 +72,5 @@ export function AgentSettingsSection({ agent }) {
72
72
  return (_jsxs(Card, { id: "agent", className: "scroll-mt-6", "data-testid": "agent-settings-section", children: [_jsxs(CardHeader, { children: [_jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Bot, { className: "text-muted-foreground h-4 w-4" }), _jsx(CardTitle, { children: "Preferred Agent" })] }), isPending ? _jsx("span", { className: "text-muted-foreground text-xs", children: "Saving..." }) : null, showSaved && !isPending ? (_jsxs("span", { className: "flex items-center gap-1 text-xs text-green-600", children: [_jsx(Check, { className: "h-3 w-3" }), "Saved"] })) : null] }), _jsx(CardDescription, { children: "Choose your AI coding agent and authentication method" })] }), _jsxs(CardContent, { className: "space-y-4", children: [_jsxs("div", { className: "space-y-2", children: [_jsx(Label, { htmlFor: "agent-type", children: "Agent Type" }), _jsxs(Select, { value: agentType, onValueChange: handleAgentTypeChange, children: [_jsx(SelectTrigger, { id: "agent-type", "data-testid": "agent-type-select", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: AGENT_TYPE_OPTIONS.map((opt) => {
73
73
  const Icon = getAgentTypeIcon(opt.value);
74
74
  return (_jsx(SelectItem, { value: opt.value, children: _jsxs("span", { className: "flex items-center gap-2", children: [_jsx(Icon, { className: "h-4 w-4 shrink-0" }), opt.label] }) }, opt.value));
75
- }) })] })] }), _jsxs("div", { className: "space-y-2", children: [_jsx(Label, { htmlFor: "auth-method", children: "Authentication Method" }), _jsxs(Select, { value: authMethod, onValueChange: handleAuthMethodChange, children: [_jsx(SelectTrigger, { id: "auth-method", "data-testid": "auth-method-select", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: AUTH_METHOD_OPTIONS.map((opt) => (_jsx(SelectItem, { value: opt.value, children: opt.label }, opt.value))) })] })] }), authMethod === AgentAuthMethod.Token && (_jsxs("div", { className: "space-y-2", children: [_jsx(Label, { htmlFor: "agent-token", children: "API Token" }), _jsxs("div", { className: "relative", children: [_jsx(Input, { id: "agent-token", "data-testid": "agent-token-input", type: showToken ? 'text' : 'password', value: token, onChange: (e) => setToken(e.target.value), onBlur: handleTokenBlur, placeholder: "Enter your API token", className: "pe-10" }), _jsx(Button, { type: "button", variant: "ghost", size: "sm", className: "absolute top-0 right-0 h-full px-3 hover:bg-transparent", onClick: () => setShowToken(!showToken), "data-testid": "toggle-token-visibility", "aria-label": showToken ? 'Hide token' : 'Show token', children: showToken ? _jsx(EyeOff, { className: "h-4 w-4" }) : _jsx(Eye, { className: "h-4 w-4" }) })] }), _jsx("p", { className: "text-muted-foreground text-xs", children: "Saves automatically when you leave the field" })] }))] })] }));
75
+ }) })] })] }), _jsxs("div", { className: "space-y-2", children: [_jsx(Label, { htmlFor: "auth-method", children: "Authentication Method" }), _jsxs(Select, { value: authMethod, onValueChange: handleAuthMethodChange, children: [_jsx(SelectTrigger, { id: "auth-method", "data-testid": "auth-method-select", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: AUTH_METHOD_OPTIONS.map((opt) => (_jsx(SelectItem, { value: opt.value, children: opt.label }, opt.value))) })] })] }), authMethod === AgentAuthMethod.Token && (_jsxs("div", { className: "space-y-2", children: [_jsx(Label, { htmlFor: "agent-token", children: "API Token" }), _jsxs("div", { className: "relative", children: [_jsx(Input, { id: "agent-token", "data-testid": "agent-token-input", type: showToken ? 'text' : 'password', value: token, onChange: (e) => setToken(e.target.value), onBlur: handleTokenBlur, placeholder: "Enter your API token", className: "pr-10" }), _jsx(Button, { type: "button", variant: "ghost", size: "sm", className: "absolute top-0 right-0 h-full px-3 hover:bg-transparent", onClick: () => setShowToken(!showToken), "data-testid": "toggle-token-visibility", "aria-label": showToken ? 'Hide token' : 'Show token', children: showToken ? _jsx(EyeOff, { className: "h-4 w-4" }) : _jsx(Eye, { className: "h-4 w-4" }) })] }), _jsx("p", { className: "text-muted-foreground text-xs", children: "Saves automatically when you leave the field" })] }))] })] }));
76
76
  }
@@ -1 +1 @@
1
- {"version":3,"file":"settings-page-client.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/settings-page-client.tsx"],"names":[],"mappings":"AA2CA,OAAO,KAAK,EACV,QAAQ,EAIT,MAAM,sCAAsC,CAAC;AAC9C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AA6B/E,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,QAAQ,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,iBAAiB,EAAE,CAAC;CAC1C;AA+QD,wBAAgB,kBAAkB,CAAC,EACjC,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,kBAAkB,GACnB,EAAE,uBAAuB,2CA8wCzB"}
1
+ {"version":3,"file":"settings-page-client.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/settings-page-client.tsx"],"names":[],"mappings":"AAmCA,OAAO,KAAK,EACV,QAAQ,EAIT,MAAM,sCAAsC,CAAC;AAC9C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AA4B/E,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,QAAQ,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,iBAAiB,EAAE,CAAC;CAC1C;AA6QD,wBAAgB,kBAAkB,CAAC,EACjC,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,kBAAkB,GACnB,EAAE,uBAAuB,2CAwwCzB"}