@shepai/cli 1.156.0 → 1.157.0-pr496.7e3ce96

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 (648) hide show
  1. package/README.md +253 -142
  2. package/apis/json-schema/Language.yaml +13 -0
  3. package/apis/json-schema/UserProfile.yaml +3 -0
  4. package/apis/json-schema/WorkflowConfig.yaml +5 -0
  5. package/dist/packages/core/src/application/use-cases/agents/approve-agent-run.use-case.d.ts.map +1 -1
  6. package/dist/packages/core/src/application/use-cases/agents/approve-agent-run.use-case.js +5 -0
  7. package/dist/packages/core/src/application/use-cases/agents/reject-agent-run.use-case.d.ts.map +1 -1
  8. package/dist/packages/core/src/application/use-cases/agents/reject-agent-run.use-case.js +7 -0
  9. package/dist/packages/core/src/application/use-cases/features/auto-archive-completed.use-case.d.ts +30 -0
  10. package/dist/packages/core/src/application/use-cases/features/auto-archive-completed.use-case.d.ts.map +1 -0
  11. package/dist/packages/core/src/application/use-cases/features/auto-archive-completed.use-case.js +75 -0
  12. package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.d.ts.map +1 -1
  13. package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.js +11 -1
  14. package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.d.ts.map +1 -1
  15. package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.js +3 -0
  16. package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.d.ts.map +1 -1
  17. package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.js +5 -0
  18. package/dist/packages/core/src/domain/factories/settings-defaults.factory.d.ts.map +1 -1
  19. package/dist/packages/core/src/domain/factories/settings-defaults.factory.js +1 -0
  20. package/dist/packages/core/src/domain/generated/output.d.ts +18 -0
  21. package/dist/packages/core/src/domain/generated/output.d.ts.map +1 -1
  22. package/dist/packages/core/src/domain/generated/output.js +11 -0
  23. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts +2 -0
  24. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts.map +1 -1
  25. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.js +7 -2
  26. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-auto-archive-delay-minutes.d.ts +15 -0
  27. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-auto-archive-delay-minutes.d.ts.map +1 -0
  28. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-auto-archive-delay-minutes.js +20 -0
  29. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.d.ts +14 -0
  30. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.d.ts.map +1 -0
  31. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/049-add-language-preference.js +19 -0
  32. package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.d.ts.map +1 -1
  33. package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.js +9 -5
  34. package/dist/packages/core/src/infrastructure/services/auto-archive/auto-archive-watcher.service.d.ts +48 -0
  35. package/dist/packages/core/src/infrastructure/services/auto-archive/auto-archive-watcher.service.d.ts.map +1 -0
  36. package/dist/packages/core/src/infrastructure/services/auto-archive/auto-archive-watcher.service.js +101 -0
  37. package/dist/packages/core/src/infrastructure/services/git/pr-branding.d.ts +1 -1
  38. package/dist/packages/core/src/infrastructure/services/git/pr-branding.d.ts.map +1 -1
  39. package/dist/packages/core/src/infrastructure/services/git/pr-branding.js +1 -1
  40. package/dist/packages/core/src/infrastructure/services/tool-installer/tool-installer.service.d.ts.map +1 -1
  41. package/dist/packages/core/src/infrastructure/services/tool-installer/tool-installer.service.js +3 -1
  42. package/dist/packages/core/src/infrastructure/services/tool-installer/tools/claude-code.json +3 -4
  43. package/dist/src/presentation/cli/commands/_serve.command.d.ts.map +1 -1
  44. package/dist/src/presentation/cli/commands/_serve.command.js +10 -3
  45. package/dist/src/presentation/cli/commands/agent/approve.command.d.ts.map +1 -1
  46. package/dist/src/presentation/cli/commands/agent/approve.command.js +9 -4
  47. package/dist/src/presentation/cli/commands/agent/delete.command.d.ts.map +1 -1
  48. package/dist/src/presentation/cli/commands/agent/delete.command.js +9 -5
  49. package/dist/src/presentation/cli/commands/agent/index.d.ts.map +1 -1
  50. package/dist/src/presentation/cli/commands/agent/index.js +3 -1
  51. package/dist/src/presentation/cli/commands/agent/logs.command.d.ts.map +1 -1
  52. package/dist/src/presentation/cli/commands/agent/logs.command.js +7 -5
  53. package/dist/src/presentation/cli/commands/agent/ls.command.d.ts.map +1 -1
  54. package/dist/src/presentation/cli/commands/agent/ls.command.js +12 -10
  55. package/dist/src/presentation/cli/commands/agent/reject.command.d.ts.map +1 -1
  56. package/dist/src/presentation/cli/commands/agent/reject.command.js +10 -5
  57. package/dist/src/presentation/cli/commands/agent/resolve-run.d.ts.map +1 -1
  58. package/dist/src/presentation/cli/commands/agent/resolve-run.js +7 -2
  59. package/dist/src/presentation/cli/commands/agent/show.command.d.ts.map +1 -1
  60. package/dist/src/presentation/cli/commands/agent/show.command.js +8 -6
  61. package/dist/src/presentation/cli/commands/agent/stop.command.d.ts.map +1 -1
  62. package/dist/src/presentation/cli/commands/agent/stop.command.js +9 -4
  63. package/dist/src/presentation/cli/commands/daemon/start-daemon.d.ts.map +1 -1
  64. package/dist/src/presentation/cli/commands/daemon/start-daemon.js +10 -8
  65. package/dist/src/presentation/cli/commands/daemon/stop-daemon.d.ts.map +1 -1
  66. package/dist/src/presentation/cli/commands/daemon/stop-daemon.js +5 -3
  67. package/dist/src/presentation/cli/commands/feat/adopt.command.d.ts.map +1 -1
  68. package/dist/src/presentation/cli/commands/feat/adopt.command.js +14 -12
  69. package/dist/src/presentation/cli/commands/feat/approve.command.d.ts.map +1 -1
  70. package/dist/src/presentation/cli/commands/feat/approve.command.js +8 -6
  71. package/dist/src/presentation/cli/commands/feat/archive.command.d.ts.map +1 -1
  72. package/dist/src/presentation/cli/commands/feat/archive.command.js +10 -8
  73. package/dist/src/presentation/cli/commands/feat/del.command.d.ts.map +1 -1
  74. package/dist/src/presentation/cli/commands/feat/del.command.js +17 -15
  75. package/dist/src/presentation/cli/commands/feat/index.d.ts.map +1 -1
  76. package/dist/src/presentation/cli/commands/feat/index.js +2 -1
  77. package/dist/src/presentation/cli/commands/feat/logs.command.d.ts.map +1 -1
  78. package/dist/src/presentation/cli/commands/feat/logs.command.js +8 -6
  79. package/dist/src/presentation/cli/commands/feat/ls.command.d.ts.map +1 -1
  80. package/dist/src/presentation/cli/commands/feat/ls.command.js +14 -12
  81. package/dist/src/presentation/cli/commands/feat/new.command.d.ts.map +1 -1
  82. package/dist/src/presentation/cli/commands/feat/new.command.js +43 -37
  83. package/dist/src/presentation/cli/commands/feat/reject.command.d.ts.map +1 -1
  84. package/dist/src/presentation/cli/commands/feat/reject.command.js +11 -9
  85. package/dist/src/presentation/cli/commands/feat/resolve-waiting-feature.d.ts.map +1 -1
  86. package/dist/src/presentation/cli/commands/feat/resolve-waiting-feature.js +12 -5
  87. package/dist/src/presentation/cli/commands/feat/resume.command.d.ts.map +1 -1
  88. package/dist/src/presentation/cli/commands/feat/resume.command.js +8 -6
  89. package/dist/src/presentation/cli/commands/feat/review.command.d.ts.map +1 -1
  90. package/dist/src/presentation/cli/commands/feat/review.command.js +17 -15
  91. package/dist/src/presentation/cli/commands/feat/show.command.d.ts.map +1 -1
  92. package/dist/src/presentation/cli/commands/feat/show.command.js +89 -45
  93. package/dist/src/presentation/cli/commands/feat/start.command.d.ts.map +1 -1
  94. package/dist/src/presentation/cli/commands/feat/start.command.js +12 -10
  95. package/dist/src/presentation/cli/commands/feat/unarchive.command.d.ts.map +1 -1
  96. package/dist/src/presentation/cli/commands/feat/unarchive.command.js +8 -6
  97. package/dist/src/presentation/cli/commands/ide-open.command.d.ts.map +1 -1
  98. package/dist/src/presentation/cli/commands/ide-open.command.js +10 -5
  99. package/dist/src/presentation/cli/commands/install.command.d.ts.map +1 -1
  100. package/dist/src/presentation/cli/commands/install.command.js +29 -21
  101. package/dist/src/presentation/cli/commands/log-viewer.d.ts.map +1 -1
  102. package/dist/src/presentation/cli/commands/log-viewer.js +6 -3
  103. package/dist/src/presentation/cli/commands/repo/add.command.d.ts.map +1 -1
  104. package/dist/src/presentation/cli/commands/repo/add.command.js +12 -10
  105. package/dist/src/presentation/cli/commands/repo/index.d.ts.map +1 -1
  106. package/dist/src/presentation/cli/commands/repo/index.js +3 -1
  107. package/dist/src/presentation/cli/commands/repo/ls.command.d.ts.map +1 -1
  108. package/dist/src/presentation/cli/commands/repo/ls.command.js +11 -9
  109. package/dist/src/presentation/cli/commands/repo/resolve-repository.d.ts.map +1 -1
  110. package/dist/src/presentation/cli/commands/repo/resolve-repository.js +7 -2
  111. package/dist/src/presentation/cli/commands/repo/show.command.d.ts.map +1 -1
  112. package/dist/src/presentation/cli/commands/repo/show.command.js +21 -10
  113. package/dist/src/presentation/cli/commands/restart.command.d.ts.map +1 -1
  114. package/dist/src/presentation/cli/commands/restart.command.js +6 -4
  115. package/dist/src/presentation/cli/commands/run.command.d.ts.map +1 -1
  116. package/dist/src/presentation/cli/commands/run.command.js +21 -17
  117. package/dist/src/presentation/cli/commands/session/index.d.ts.map +1 -1
  118. package/dist/src/presentation/cli/commands/session/index.js +3 -1
  119. package/dist/src/presentation/cli/commands/session/ls.command.d.ts.map +1 -1
  120. package/dist/src/presentation/cli/commands/session/ls.command.js +11 -9
  121. package/dist/src/presentation/cli/commands/session/show.command.d.ts.map +1 -1
  122. package/dist/src/presentation/cli/commands/session/show.command.js +26 -18
  123. package/dist/src/presentation/cli/commands/settings/agent.command.d.ts.map +1 -1
  124. package/dist/src/presentation/cli/commands/settings/agent.command.js +12 -8
  125. package/dist/src/presentation/cli/commands/settings/ide.command.d.ts.map +1 -1
  126. package/dist/src/presentation/cli/commands/settings/ide.command.js +13 -7
  127. package/dist/src/presentation/cli/commands/settings/index.d.ts +1 -0
  128. package/dist/src/presentation/cli/commands/settings/index.d.ts.map +1 -1
  129. package/dist/src/presentation/cli/commands/settings/index.js +7 -3
  130. package/dist/src/presentation/cli/commands/settings/init.command.d.ts.map +1 -1
  131. package/dist/src/presentation/cli/commands/settings/init.command.js +8 -7
  132. package/dist/src/presentation/cli/commands/settings/language.command.d.ts +14 -0
  133. package/dist/src/presentation/cli/commands/settings/language.command.d.ts.map +1 -0
  134. package/dist/src/presentation/cli/commands/settings/language.command.js +79 -0
  135. package/dist/src/presentation/cli/commands/settings/model.command.d.ts.map +1 -1
  136. package/dist/src/presentation/cli/commands/settings/model.command.js +7 -6
  137. package/dist/src/presentation/cli/commands/settings/show.command.d.ts.map +1 -1
  138. package/dist/src/presentation/cli/commands/settings/show.command.js +4 -3
  139. package/dist/src/presentation/cli/commands/settings/workflow.command.d.ts.map +1 -1
  140. package/dist/src/presentation/cli/commands/settings/workflow.command.js +20 -18
  141. package/dist/src/presentation/cli/commands/start.command.d.ts.map +1 -1
  142. package/dist/src/presentation/cli/commands/start.command.js +5 -3
  143. package/dist/src/presentation/cli/commands/status.command.d.ts.map +1 -1
  144. package/dist/src/presentation/cli/commands/status.command.js +32 -24
  145. package/dist/src/presentation/cli/commands/stop.command.d.ts.map +1 -1
  146. package/dist/src/presentation/cli/commands/stop.command.js +4 -2
  147. package/dist/src/presentation/cli/commands/tools.command.d.ts.map +1 -1
  148. package/dist/src/presentation/cli/commands/tools.command.js +8 -4
  149. package/dist/src/presentation/cli/commands/ui.command.d.ts.map +1 -1
  150. package/dist/src/presentation/cli/commands/ui.command.js +17 -10
  151. package/dist/src/presentation/cli/commands/upgrade.command.d.ts.map +1 -1
  152. package/dist/src/presentation/cli/commands/upgrade.command.js +18 -13
  153. package/dist/src/presentation/cli/commands/version.command.d.ts.map +1 -1
  154. package/dist/src/presentation/cli/commands/version.command.js +5 -3
  155. package/dist/src/presentation/cli/i18n.d.ts +41 -0
  156. package/dist/src/presentation/cli/i18n.d.ts.map +1 -0
  157. package/dist/src/presentation/cli/i18n.js +100 -0
  158. package/dist/src/presentation/cli/index.js +13 -1
  159. package/dist/src/presentation/cli/ui/install-messages.d.ts.map +1 -1
  160. package/dist/src/presentation/cli/ui/install-messages.js +16 -6
  161. package/dist/src/presentation/tui/i18n.d.ts +24 -0
  162. package/dist/src/presentation/tui/i18n.d.ts.map +1 -0
  163. package/dist/src/presentation/tui/i18n.js +48 -0
  164. package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts +13 -31
  165. package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts.map +1 -1
  166. package/dist/src/presentation/tui/prompts/agent-select.prompt.js +17 -15
  167. package/dist/src/presentation/tui/prompts/auth-method.prompt.d.ts +7 -11
  168. package/dist/src/presentation/tui/prompts/auth-method.prompt.d.ts.map +1 -1
  169. package/dist/src/presentation/tui/prompts/auth-method.prompt.js +7 -5
  170. package/dist/src/presentation/tui/prompts/ide-select.prompt.d.ts.map +1 -1
  171. package/dist/src/presentation/tui/prompts/ide-select.prompt.js +2 -1
  172. package/dist/src/presentation/tui/prompts/prd-review-summary.prompt.d.ts.map +1 -1
  173. package/dist/src/presentation/tui/prompts/prd-review-summary.prompt.js +8 -6
  174. package/dist/src/presentation/tui/wizards/agent-config.wizard.d.ts.map +1 -1
  175. package/dist/src/presentation/tui/wizards/agent-config.wizard.js +2 -1
  176. package/dist/src/presentation/tui/wizards/github-import.wizard.d.ts.map +1 -1
  177. package/dist/src/presentation/tui/wizards/github-import.wizard.js +15 -11
  178. package/dist/src/presentation/tui/wizards/merge-review.wizard.d.ts.map +1 -1
  179. package/dist/src/presentation/tui/wizards/merge-review.wizard.js +10 -8
  180. package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.d.ts.map +1 -1
  181. package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.js +10 -7
  182. package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.d.ts +0 -41
  183. package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.d.ts.map +1 -1
  184. package/dist/src/presentation/tui/wizards/onboarding/steps/workflow-defaults.step.js +15 -15
  185. package/dist/src/presentation/tui/wizards/plan-review.wizard.d.ts.map +1 -1
  186. package/dist/src/presentation/tui/wizards/plan-review.wizard.js +10 -8
  187. package/dist/src/presentation/tui/wizards/prd-review.wizard.d.ts.map +1 -1
  188. package/dist/src/presentation/tui/wizards/prd-review.wizard.js +3 -2
  189. package/dist/src/presentation/web/app/(dashboard)/get-graph-data.d.ts.map +1 -1
  190. package/dist/src/presentation/web/app/(dashboard)/get-graph-data.js +4 -2
  191. package/dist/src/presentation/web/app/actions/create-feature.d.ts.map +1 -1
  192. package/dist/src/presentation/web/app/actions/create-feature.js +3 -0
  193. package/dist/src/presentation/web/app/layout.d.ts.map +1 -1
  194. package/dist/src/presentation/web/app/layout.js +5 -2
  195. package/dist/src/presentation/web/components/assistant-ui/thread.d.ts.map +1 -1
  196. package/dist/src/presentation/web/components/assistant-ui/thread.js +13 -10
  197. package/dist/src/presentation/web/components/common/add-repository-button/add-repository-button.d.ts.map +1 -1
  198. package/dist/src/presentation/web/components/common/add-repository-button/add-repository-button.js +3 -1
  199. package/dist/src/presentation/web/components/common/attachment-chip/attachment-chip.js +1 -1
  200. package/dist/src/presentation/web/components/common/base-drawer/base-drawer.d.ts.map +1 -1
  201. package/dist/src/presentation/web/components/common/base-drawer/base-drawer.js +5 -2
  202. package/dist/src/presentation/web/components/common/ci-status-badge/ci-status-badge.js +3 -3
  203. package/dist/src/presentation/web/components/common/control-center-drawer/adopt-branch-drawer.js +4 -4
  204. package/dist/src/presentation/web/components/common/control-center-drawer/feature-drawer-client.d.ts.map +1 -1
  205. package/dist/src/presentation/web/components/common/control-center-drawer/feature-drawer-client.js +7 -1
  206. package/dist/src/presentation/web/components/common/control-center-drawer/repository-drawer-client.js +1 -1
  207. package/dist/src/presentation/web/components/common/delete-feature-dialog/delete-feature-dialog.d.ts.map +1 -1
  208. package/dist/src/presentation/web/components/common/delete-feature-dialog/delete-feature-dialog.js +3 -1
  209. package/dist/src/presentation/web/components/common/deployment-status-badge/deployment-status-badge.js +2 -2
  210. package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.d.ts.map +1 -1
  211. package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.js +6 -2
  212. package/dist/src/presentation/web/components/common/empty-state/empty-state.stories.js +2 -2
  213. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts.map +1 -1
  214. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.js +34 -22
  215. package/dist/src/presentation/web/components/common/feature-drawer-tabs/activity-tab.d.ts.map +1 -1
  216. package/dist/src/presentation/web/components/common/feature-drawer-tabs/activity-tab.js +11 -7
  217. package/dist/src/presentation/web/components/common/feature-drawer-tabs/activity-tab.stories.js +1 -1
  218. package/dist/src/presentation/web/components/common/feature-drawer-tabs/branch-sync-status.d.ts.map +1 -1
  219. package/dist/src/presentation/web/components/common/feature-drawer-tabs/branch-sync-status.js +3 -1
  220. package/dist/src/presentation/web/components/common/feature-drawer-tabs/feature-drawer-tabs.d.ts.map +1 -1
  221. package/dist/src/presentation/web/components/common/feature-drawer-tabs/feature-drawer-tabs.js +4 -2
  222. package/dist/src/presentation/web/components/common/feature-drawer-tabs/feature-drawer-tabs.stories.js +2 -2
  223. package/dist/src/presentation/web/components/common/feature-drawer-tabs/log-tab.d.ts.map +1 -1
  224. package/dist/src/presentation/web/components/common/feature-drawer-tabs/log-tab.js +5 -3
  225. package/dist/src/presentation/web/components/common/feature-drawer-tabs/overview-tab.d.ts.map +1 -1
  226. package/dist/src/presentation/web/components/common/feature-drawer-tabs/overview-tab.js +9 -5
  227. package/dist/src/presentation/web/components/common/feature-list-item/feature-list-item.js +1 -1
  228. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts +2 -2
  229. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts.map +1 -1
  230. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.js +22 -22
  231. package/dist/src/presentation/web/components/common/feature-node/feature-node.d.ts.map +1 -1
  232. package/dist/src/presentation/web/components/common/feature-node/feature-node.js +49 -36
  233. package/dist/src/presentation/web/components/common/feature-node/feature-sessions-dropdown.d.ts.map +1 -1
  234. package/dist/src/presentation/web/components/common/feature-node/feature-sessions-dropdown.js +7 -3
  235. package/dist/src/presentation/web/components/common/feature-status-badges/feature-status-badges.d.ts.map +1 -1
  236. package/dist/src/presentation/web/components/common/feature-status-badges/feature-status-badges.js +4 -2
  237. package/dist/src/presentation/web/components/common/feature-status-config.d.ts +2 -1
  238. package/dist/src/presentation/web/components/common/feature-status-config.d.ts.map +1 -1
  239. package/dist/src/presentation/web/components/common/feature-status-config.js +6 -6
  240. package/dist/src/presentation/web/components/common/feature-status-group/feature-status-group.js +1 -1
  241. package/dist/src/presentation/web/components/common/floating-action-button/floating-action-button.d.ts.map +1 -1
  242. package/dist/src/presentation/web/components/common/floating-action-button/floating-action-button.js +4 -2
  243. package/dist/src/presentation/web/components/common/github-import-dialog/github-repo-browser.js +1 -1
  244. package/dist/src/presentation/web/components/common/merge-review/diff-view.js +2 -2
  245. package/dist/src/presentation/web/components/common/merge-review/merge-review.js +2 -2
  246. package/dist/src/presentation/web/components/common/merge-review/merge-review.stories.js +1 -1
  247. package/dist/src/presentation/web/components/common/prd-questionnaire/prd-questionnaire.js +3 -3
  248. package/dist/src/presentation/web/components/common/reject-feedback-dialog/reject-feedback-dialog.d.ts.map +1 -1
  249. package/dist/src/presentation/web/components/common/reject-feedback-dialog/reject-feedback-dialog.js +6 -4
  250. package/dist/src/presentation/web/components/common/repository-node/repository-drawer.stories.js +3 -3
  251. package/dist/src/presentation/web/components/common/repository-node/repository-node-config.d.ts +1 -1
  252. package/dist/src/presentation/web/components/common/repository-node/repository-node-config.d.ts.map +1 -1
  253. package/dist/src/presentation/web/components/common/repository-node/repository-node.d.ts.map +1 -1
  254. package/dist/src/presentation/web/components/common/repository-node/repository-node.js +18 -11
  255. package/dist/src/presentation/web/components/common/repository-node/repository-node.stories.js +12 -12
  256. package/dist/src/presentation/web/components/common/server-log-viewer/server-log-viewer.js +1 -1
  257. package/dist/src/presentation/web/components/common/task-progress-view/task-progress-view.d.ts.map +1 -1
  258. package/dist/src/presentation/web/components/common/task-progress-view/task-progress-view.js +7 -4
  259. package/dist/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.js +2 -2
  260. package/dist/src/presentation/web/components/common/version-badge/version-badge.d.ts.map +1 -1
  261. package/dist/src/presentation/web/components/common/version-badge/version-badge.js +3 -1
  262. package/dist/src/presentation/web/components/features/chat/ChatComposer.d.ts.map +1 -1
  263. package/dist/src/presentation/web/components/features/chat/ChatComposer.js +3 -1
  264. package/dist/src/presentation/web/components/features/chat/ChatMessageBubble.d.ts.map +1 -1
  265. package/dist/src/presentation/web/components/features/chat/ChatMessageBubble.js +7 -5
  266. package/dist/src/presentation/web/components/features/chat/ChatMessageList.js +1 -1
  267. package/dist/src/presentation/web/components/features/chat/ChatSheet.d.ts.map +1 -1
  268. package/dist/src/presentation/web/components/features/chat/ChatSheet.js +5 -3
  269. package/dist/src/presentation/web/components/features/chat/ChatTab.d.ts.map +1 -1
  270. package/dist/src/presentation/web/components/features/chat/ChatTab.js +5 -3
  271. package/dist/src/presentation/web/components/features/control-center/control-center-empty-state.d.ts.map +1 -1
  272. package/dist/src/presentation/web/components/features/control-center/control-center-empty-state.js +15 -11
  273. package/dist/src/presentation/web/components/features/control-center/control-center-inner.d.ts.map +1 -1
  274. package/dist/src/presentation/web/components/features/control-center/control-center-inner.js +14 -6
  275. package/dist/src/presentation/web/components/features/control-center/control-center.stories.js +1 -1
  276. package/dist/src/presentation/web/components/features/control-center/use-control-center-state.js +2 -2
  277. package/dist/src/presentation/web/components/features/control-center/welcome-agent-setup.d.ts.map +1 -1
  278. package/dist/src/presentation/web/components/features/control-center/welcome-agent-setup.js +8 -6
  279. package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.d.ts.map +1 -1
  280. package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.js +3 -1
  281. package/dist/src/presentation/web/components/features/features-canvas/features-canvas.d.ts.map +1 -1
  282. package/dist/src/presentation/web/components/features/features-canvas/features-canvas.js +4 -2
  283. package/dist/src/presentation/web/components/features/features-canvas/features-canvas.stories.js +6 -6
  284. package/dist/src/presentation/web/components/features/settings/AgentModelPicker/index.js +2 -2
  285. package/dist/src/presentation/web/components/features/settings/ModelPicker/index.js +2 -2
  286. package/dist/src/presentation/web/components/features/settings/agent-settings-section.js +1 -1
  287. package/dist/src/presentation/web/components/features/settings/language-settings-section.d.ts +5 -0
  288. package/dist/src/presentation/web/components/features/settings/language-settings-section.d.ts.map +1 -0
  289. package/dist/src/presentation/web/components/features/settings/language-settings-section.js +54 -0
  290. package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.d.ts +18 -0
  291. package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.d.ts.map +1 -0
  292. package/dist/src/presentation/web/components/features/settings/language-settings-section.stories.js +36 -0
  293. package/dist/src/presentation/web/components/features/settings/settings-page-client.d.ts.map +1 -1
  294. package/dist/src/presentation/web/components/features/settings/settings-page-client.js +100 -88
  295. package/dist/src/presentation/web/components/features/settings/timeout-slider.js +1 -1
  296. package/dist/src/presentation/web/components/features/skills/category-filter.js +1 -1
  297. package/dist/src/presentation/web/components/features/skills/skills-page-client.js +1 -1
  298. package/dist/src/presentation/web/components/features/tools/tool-card.js +1 -1
  299. package/dist/src/presentation/web/components/features/tools/tool-detail-drawer.js +2 -2
  300. package/dist/src/presentation/web/components/features/version/version-page-client.js +1 -1
  301. package/dist/src/presentation/web/components/layouts/app-shell/app-shell.d.ts.map +1 -1
  302. package/dist/src/presentation/web/components/layouts/app-shell/app-shell.js +5 -1
  303. package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.d.ts.map +1 -1
  304. package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.js +13 -7
  305. package/dist/src/presentation/web/components/providers/i18n-provider.d.ts +17 -0
  306. package/dist/src/presentation/web/components/providers/i18n-provider.d.ts.map +1 -0
  307. package/dist/src/presentation/web/components/providers/i18n-provider.js +36 -0
  308. package/dist/src/presentation/web/components/ui/alert-dialog.js +1 -1
  309. package/dist/src/presentation/web/components/ui/alert.js +1 -1
  310. package/dist/src/presentation/web/components/ui/checkbox-group.js +1 -1
  311. package/dist/src/presentation/web/components/ui/command.js +1 -1
  312. package/dist/src/presentation/web/components/ui/dialog.d.ts.map +1 -1
  313. package/dist/src/presentation/web/components/ui/dialog.js +2 -2
  314. package/dist/src/presentation/web/components/ui/dialog.stories.js +1 -1
  315. package/dist/src/presentation/web/components/ui/drawer.d.ts.map +1 -1
  316. package/dist/src/presentation/web/components/ui/drawer.js +2 -8
  317. package/dist/src/presentation/web/components/ui/dropdown-menu.js +6 -6
  318. package/dist/src/presentation/web/components/ui/scroll-area.js +1 -1
  319. package/dist/src/presentation/web/components/ui/select.js +1 -1
  320. package/dist/src/presentation/web/components/ui/sheet.js +3 -3
  321. package/dist/src/presentation/web/components/ui/sidebar.d.ts.map +1 -1
  322. package/dist/src/presentation/web/components/ui/sidebar.js +15 -15
  323. package/dist/src/presentation/web/components/ui/switch.js +1 -1
  324. package/dist/src/presentation/web/dev-server.js +10 -0
  325. package/dist/src/presentation/web/hooks/use-graph-state.d.ts.map +1 -1
  326. package/dist/src/presentation/web/hooks/use-graph-state.js +7 -4
  327. package/dist/src/presentation/web/hooks/use-sound-action.stories.js +1 -1
  328. package/dist/src/presentation/web/lib/i18n.d.ts +15 -0
  329. package/dist/src/presentation/web/lib/i18n.d.ts.map +1 -0
  330. package/dist/src/presentation/web/lib/i18n.js +64 -0
  331. package/dist/src/presentation/web/lib/language.d.ts +23 -0
  332. package/dist/src/presentation/web/lib/language.d.ts.map +1 -0
  333. package/dist/src/presentation/web/lib/language.js +37 -0
  334. package/dist/src/presentation/web/lib/layout-with-dagre.d.ts +2 -0
  335. package/dist/src/presentation/web/lib/layout-with-dagre.d.ts.map +1 -1
  336. package/dist/src/presentation/web/lib/layout-with-dagre.js +4 -0
  337. package/dist/src/presentation/web/lib/rtl-fonts.d.ts +19 -0
  338. package/dist/src/presentation/web/lib/rtl-fonts.d.ts.map +1 -0
  339. package/dist/src/presentation/web/lib/rtl-fonts.js +51 -0
  340. package/dist/translations/ar/cli.json +613 -0
  341. package/dist/translations/ar/common.json +55 -0
  342. package/dist/translations/ar/tui.json +130 -0
  343. package/dist/translations/ar/web.json +594 -0
  344. package/dist/translations/de/cli.json +613 -0
  345. package/dist/translations/de/common.json +55 -0
  346. package/dist/translations/de/tui.json +109 -0
  347. package/dist/translations/de/web.json +580 -0
  348. package/dist/translations/en/cli.json +613 -0
  349. package/dist/translations/en/common.json +55 -0
  350. package/dist/translations/en/tui.json +130 -0
  351. package/dist/translations/en/web.json +594 -0
  352. package/dist/translations/es/cli.json +613 -0
  353. package/dist/translations/es/common.json +55 -0
  354. package/dist/translations/es/tui.json +130 -0
  355. package/dist/translations/es/web.json +594 -0
  356. package/dist/translations/fr/cli.json +613 -0
  357. package/dist/translations/fr/common.json +55 -0
  358. package/dist/translations/fr/tui.json +130 -0
  359. package/dist/translations/fr/web.json +594 -0
  360. package/dist/translations/he/cli.json +613 -0
  361. package/dist/translations/he/common.json +55 -0
  362. package/dist/translations/he/tui.json +130 -0
  363. package/dist/translations/he/web.json +594 -0
  364. package/dist/translations/pt/cli.json +613 -0
  365. package/dist/translations/pt/common.json +55 -0
  366. package/dist/translations/pt/tui.json +130 -0
  367. package/dist/translations/pt/web.json +594 -0
  368. package/dist/translations/ru/cli.json +613 -0
  369. package/dist/translations/ru/common.json +55 -0
  370. package/dist/translations/ru/tui.json +130 -0
  371. package/dist/translations/ru/web.json +594 -0
  372. package/dist/tsconfig.build.tsbuildinfo +1 -1
  373. package/package.json +5 -3
  374. package/web/.next/BUILD_ID +1 -1
  375. package/web/.next/build-manifest.json +2 -2
  376. package/web/.next/fallback-build-manifest.json +2 -2
  377. package/web/.next/prerender-manifest.json +3 -3
  378. package/web/.next/required-server-files.js +7 -7
  379. package/web/.next/required-server-files.json +7 -7
  380. package/web/.next/server/app/(dashboard)/@drawer/adopt/page/server-reference-manifest.json +28 -28
  381. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js +3 -3
  382. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js.nft.json +1 -1
  383. package/web/.next/server/app/(dashboard)/@drawer/adopt/page_client-reference-manifest.js +1 -1
  384. package/web/.next/server/app/(dashboard)/@drawer/chat/page/server-reference-manifest.json +26 -26
  385. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js +3 -3
  386. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js.nft.json +1 -1
  387. package/web/.next/server/app/(dashboard)/@drawer/chat/page_client-reference-manifest.js +1 -1
  388. package/web/.next/server/app/(dashboard)/@drawer/create/page/server-reference-manifest.json +29 -29
  389. package/web/.next/server/app/(dashboard)/@drawer/create/page.js +3 -3
  390. package/web/.next/server/app/(dashboard)/@drawer/create/page.js.nft.json +1 -1
  391. package/web/.next/server/app/(dashboard)/@drawer/create/page_client-reference-manifest.js +1 -1
  392. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page/server-reference-manifest.json +36 -36
  393. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js +4 -4
  394. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  395. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  396. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page/server-reference-manifest.json +36 -36
  397. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js +4 -4
  398. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js.nft.json +1 -1
  399. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page_client-reference-manifest.js +1 -1
  400. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +26 -26
  401. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js +3 -3
  402. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  403. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  404. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page/server-reference-manifest.json +26 -26
  405. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js +3 -3
  406. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js.nft.json +1 -1
  407. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  408. package/web/.next/server/app/(dashboard)/chat/page/server-reference-manifest.json +26 -26
  409. package/web/.next/server/app/(dashboard)/chat/page.js +3 -3
  410. package/web/.next/server/app/(dashboard)/chat/page.js.nft.json +1 -1
  411. package/web/.next/server/app/(dashboard)/chat/page_client-reference-manifest.js +1 -1
  412. package/web/.next/server/app/(dashboard)/create/page/server-reference-manifest.json +29 -29
  413. package/web/.next/server/app/(dashboard)/create/page.js +3 -3
  414. package/web/.next/server/app/(dashboard)/create/page.js.nft.json +1 -1
  415. package/web/.next/server/app/(dashboard)/create/page_client-reference-manifest.js +1 -1
  416. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page/server-reference-manifest.json +36 -36
  417. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js +4 -4
  418. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  419. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  420. package/web/.next/server/app/(dashboard)/feature/[featureId]/page/server-reference-manifest.json +36 -36
  421. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js +4 -4
  422. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js.nft.json +1 -1
  423. package/web/.next/server/app/(dashboard)/feature/[featureId]/page_client-reference-manifest.js +1 -1
  424. package/web/.next/server/app/(dashboard)/page/server-reference-manifest.json +26 -26
  425. package/web/.next/server/app/(dashboard)/page.js +3 -3
  426. package/web/.next/server/app/(dashboard)/page.js.nft.json +1 -1
  427. package/web/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
  428. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +26 -26
  429. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js +3 -3
  430. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  431. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  432. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page/server-reference-manifest.json +26 -26
  433. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js +3 -3
  434. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js.nft.json +1 -1
  435. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  436. package/web/.next/server/app/_global-error.html +2 -2
  437. package/web/.next/server/app/_global-error.rsc +1 -1
  438. package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  439. package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  440. package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  441. package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  442. package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  443. package/web/.next/server/app/_not-found/page/server-reference-manifest.json +5 -5
  444. package/web/.next/server/app/_not-found/page.js +2 -2
  445. package/web/.next/server/app/_not-found/page.js.nft.json +1 -1
  446. package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  447. package/web/.next/server/app/api/attachments/preview/route.js.nft.json +1 -1
  448. package/web/.next/server/app/api/evidence/route.js.nft.json +1 -1
  449. package/web/.next/server/app/api/graph-data/route.js.nft.json +1 -1
  450. package/web/.next/server/app/api/interactive/chat/[featureId]/messages/route.js.nft.json +1 -1
  451. package/web/.next/server/app/settings/page/server-reference-manifest.json +8 -8
  452. package/web/.next/server/app/settings/page.js +2 -2
  453. package/web/.next/server/app/settings/page.js.nft.json +1 -1
  454. package/web/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  455. package/web/.next/server/app/skills/page/server-reference-manifest.json +10 -10
  456. package/web/.next/server/app/skills/page.js +3 -4
  457. package/web/.next/server/app/skills/page.js.nft.json +1 -1
  458. package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
  459. package/web/.next/server/app/tools/page/server-reference-manifest.json +10 -10
  460. package/web/.next/server/app/tools/page.js +3 -4
  461. package/web/.next/server/app/tools/page.js.nft.json +1 -1
  462. package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
  463. package/web/.next/server/app/version/page/server-reference-manifest.json +5 -5
  464. package/web/.next/server/app/version/page.js +2 -2
  465. package/web/.next/server/app/version/page.js.nft.json +1 -1
  466. package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
  467. package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_370c43b1.js +1 -1
  468. package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_370c43b1.js.map +1 -1
  469. package/web/.next/server/chunks/[root-of-the-server]__a402b567._.js +1 -1
  470. package/web/.next/server/chunks/[root-of-the-server]__a402b567._.js.map +1 -1
  471. package/web/.next/server/chunks/[root-of-the-server]__b4102cc7._.js +1 -1
  472. package/web/.next/server/chunks/[root-of-the-server]__b4102cc7._.js.map +1 -1
  473. package/web/.next/server/chunks/[root-of-the-server]__beda892a._.js +1 -1
  474. package/web/.next/server/chunks/[root-of-the-server]__beda892a._.js.map +1 -1
  475. package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js +1 -1
  476. package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js.map +1 -1
  477. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js +1 -1
  478. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js.map +1 -1
  479. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js +3 -3
  480. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js.map +1 -1
  481. package/web/.next/server/chunks/ssr/[root-of-the-server]__209c9597._.js +4 -0
  482. package/web/.next/server/chunks/ssr/{[root-of-the-server]__88f7e8e6._.js.map → [root-of-the-server]__209c9597._.js.map} +1 -1
  483. package/web/.next/server/chunks/ssr/[root-of-the-server]__27301e38._.js +4 -0
  484. package/web/.next/server/chunks/ssr/{[root-of-the-server]__17ed7ed1._.js.map → [root-of-the-server]__27301e38._.js.map} +1 -1
  485. package/web/.next/server/chunks/ssr/[root-of-the-server]__357d99f9._.js +1 -1
  486. package/web/.next/server/chunks/ssr/[root-of-the-server]__56b70465._.js +1 -1
  487. package/web/.next/server/chunks/ssr/[root-of-the-server]__56b70465._.js.map +1 -1
  488. package/web/.next/server/chunks/ssr/[root-of-the-server]__6fecf886._.js +4 -0
  489. package/web/.next/server/chunks/ssr/{[root-of-the-server]__42bf1807._.js.map → [root-of-the-server]__6fecf886._.js.map} +1 -1
  490. package/web/.next/server/chunks/ssr/[root-of-the-server]__8b0aac03._.js +1 -1
  491. package/web/.next/server/chunks/ssr/[root-of-the-server]__8d27866c._.js +4 -0
  492. package/web/.next/server/chunks/ssr/[root-of-the-server]__8d27866c._.js.map +1 -0
  493. package/web/.next/server/chunks/ssr/[root-of-the-server]__9f3504c7._.js +4 -0
  494. package/web/.next/server/chunks/ssr/{[root-of-the-server]__f80bfc75._.js.map → [root-of-the-server]__9f3504c7._.js.map} +1 -1
  495. package/web/.next/server/chunks/ssr/[root-of-the-server]__bd6ed91a._.js +4 -0
  496. package/web/.next/server/chunks/ssr/[root-of-the-server]__bd6ed91a._.js.map +1 -0
  497. package/web/.next/server/chunks/ssr/[root-of-the-server]__c30f1f82._.js +1 -1
  498. package/web/.next/server/chunks/ssr/[root-of-the-server]__c30f1f82._.js.map +1 -1
  499. package/web/.next/server/chunks/ssr/[root-of-the-server]__dffa13c5._.js +3 -0
  500. package/web/.next/server/chunks/ssr/[root-of-the-server]__dffa13c5._.js.map +1 -0
  501. package/web/.next/server/chunks/ssr/[root-of-the-server]__e91ffd5e._.js +2 -2
  502. package/web/.next/server/chunks/ssr/[root-of-the-server]__e91ffd5e._.js.map +1 -1
  503. package/web/.next/server/chunks/ssr/[root-of-the-server]__f8dd4422._.js +1 -1
  504. package/web/.next/server/chunks/ssr/[root-of-the-server]__f8dd4422._.js.map +1 -1
  505. package/web/.next/server/chunks/ssr/_05c23ad9._.js +1 -1
  506. package/web/.next/server/chunks/ssr/_05c23ad9._.js.map +1 -1
  507. package/web/.next/server/chunks/ssr/_0dc06d07._.js +3 -0
  508. package/web/.next/server/chunks/ssr/_0dc06d07._.js.map +1 -0
  509. package/web/.next/server/chunks/ssr/_16eb4fec._.js +1 -1
  510. package/web/.next/server/chunks/ssr/_16eb4fec._.js.map +1 -1
  511. package/web/.next/server/chunks/ssr/_3a0b989f._.js +2 -2
  512. package/web/.next/server/chunks/ssr/_3a0b989f._.js.map +1 -1
  513. package/web/.next/server/chunks/ssr/{_67104d9e._.js → _3bcda5d7._.js} +2 -2
  514. package/web/.next/server/chunks/ssr/{_67104d9e._.js.map → _3bcda5d7._.js.map} +1 -1
  515. package/web/.next/server/chunks/ssr/_5119a3df._.js +3 -0
  516. package/web/.next/server/chunks/ssr/_5119a3df._.js.map +1 -0
  517. package/web/.next/server/chunks/ssr/{_b354e40a._.js → _54af0d8c._.js} +2 -2
  518. package/web/.next/server/chunks/ssr/{_b354e40a._.js.map → _54af0d8c._.js.map} +1 -1
  519. package/web/.next/server/chunks/ssr/_56b9d60f._.js +1 -1
  520. package/web/.next/server/chunks/ssr/_56b9d60f._.js.map +1 -1
  521. package/web/.next/server/chunks/ssr/_5d73b993._.js +4 -0
  522. package/web/.next/server/chunks/ssr/_5d73b993._.js.map +1 -0
  523. package/web/.next/server/chunks/ssr/_5f69c13f._.js +1 -1
  524. package/web/.next/server/chunks/ssr/_5f69c13f._.js.map +1 -1
  525. package/web/.next/server/chunks/ssr/_7c5b97c6._.js +1 -1
  526. package/web/.next/server/chunks/ssr/_7c5b97c6._.js.map +1 -1
  527. package/web/.next/server/chunks/ssr/_82c57f10._.js +1 -1
  528. package/web/.next/server/chunks/ssr/_82c57f10._.js.map +1 -1
  529. package/web/.next/server/chunks/ssr/_8b57edb8._.js +1 -1
  530. package/web/.next/server/chunks/ssr/_8b57edb8._.js.map +1 -1
  531. package/web/.next/server/chunks/ssr/_8d733ce4._.js +1 -1
  532. package/web/.next/server/chunks/ssr/_8d733ce4._.js.map +1 -1
  533. package/web/.next/server/chunks/ssr/_8e3fa3c7._.js +3 -0
  534. package/web/.next/server/chunks/ssr/{_08dc06df._.js.map → _8e3fa3c7._.js.map} +1 -1
  535. package/web/.next/server/chunks/ssr/_9495d50b._.js +1 -1
  536. package/web/.next/server/chunks/ssr/_9495d50b._.js.map +1 -1
  537. package/web/.next/server/chunks/ssr/_a0e3f7e4._.js +1 -1
  538. package/web/.next/server/chunks/ssr/_a0e3f7e4._.js.map +1 -1
  539. package/web/.next/server/chunks/ssr/_ac4a3873._.js +1 -1
  540. package/web/.next/server/chunks/ssr/_ac4a3873._.js.map +1 -1
  541. package/web/.next/server/chunks/ssr/{_507a8382._.js → _b9ba2473._.js} +2 -2
  542. package/web/.next/server/chunks/ssr/_b9ba2473._.js.map +1 -0
  543. package/web/.next/server/chunks/ssr/_bcaea66b._.js +3 -0
  544. package/web/.next/server/chunks/ssr/_bcaea66b._.js.map +1 -0
  545. package/web/.next/server/chunks/ssr/_bcfa8457._.js +9 -0
  546. package/web/.next/server/chunks/ssr/_bcfa8457._.js.map +1 -0
  547. package/web/.next/server/chunks/ssr/_ca0aa7f0._.js +1 -1
  548. package/web/.next/server/chunks/ssr/_ca0aa7f0._.js.map +1 -1
  549. package/web/.next/server/chunks/ssr/_cb5a021e._.js +1 -1
  550. package/web/.next/server/chunks/ssr/_cb5a021e._.js.map +1 -1
  551. package/web/.next/server/chunks/ssr/_cfbd1d7e._.js +1 -1
  552. package/web/.next/server/chunks/ssr/_cfbd1d7e._.js.map +1 -1
  553. package/web/.next/server/chunks/ssr/_d86175ae._.js +1 -1
  554. package/web/.next/server/chunks/ssr/_d86175ae._.js.map +1 -1
  555. package/web/.next/server/chunks/ssr/_d8bedf13._.js +1 -1
  556. package/web/.next/server/chunks/ssr/_d8bedf13._.js.map +1 -1
  557. package/web/.next/server/chunks/ssr/_d90b0a06._.js +3 -0
  558. package/web/.next/server/chunks/ssr/_d90b0a06._.js.map +1 -0
  559. package/web/.next/server/chunks/ssr/_fa7efce3._.js +2 -2
  560. package/web/.next/server/chunks/ssr/_fa7efce3._.js.map +1 -1
  561. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js +1 -1
  562. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js.map +1 -1
  563. package/web/.next/server/chunks/ssr/node_modules__pnpm_8ec2c790._.js +1 -1
  564. package/web/.next/server/chunks/ssr/node_modules__pnpm_8ec2c790._.js.map +1 -1
  565. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_baaca5d5._.js +1 -1
  566. package/web/.next/server/chunks/ssr/src_presentation_web_ca99d62d._.js +1 -1
  567. package/web/.next/server/chunks/ssr/src_presentation_web_ca99d62d._.js.map +1 -1
  568. package/web/.next/server/chunks/ssr/src_presentation_web_components_895e5bfa._.js +3 -0
  569. package/web/.next/server/chunks/ssr/src_presentation_web_components_895e5bfa._.js.map +1 -0
  570. package/web/.next/server/chunks/ssr/src_presentation_web_components_a5e6c910._.js +1 -1
  571. package/web/.next/server/chunks/ssr/src_presentation_web_components_a5e6c910._.js.map +1 -1
  572. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js +1 -1
  573. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js.map +1 -1
  574. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_tools_tools-page-client_tsx_3d0aa70c._.js +1 -1
  575. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_tools_tools-page-client_tsx_3d0aa70c._.js.map +1 -1
  576. package/web/.next/server/chunks/ssr/src_presentation_web_db9fa0c2._.js +1 -1
  577. package/web/.next/server/chunks/ssr/src_presentation_web_db9fa0c2._.js.map +1 -1
  578. package/web/.next/server/chunks/ssr/translations_23dd5e7e._.js +3 -0
  579. package/web/.next/server/chunks/ssr/translations_23dd5e7e._.js.map +1 -0
  580. package/web/.next/server/pages/500.html +2 -2
  581. package/web/.next/server/server-reference-manifest.js +1 -1
  582. package/web/.next/server/server-reference-manifest.json +45 -45
  583. package/web/.next/static/chunks/{5064470ab185e453.js → 02eb9809370f1b44.js} +2 -2
  584. package/web/.next/static/chunks/{3e1e0f9bde3530d2.js → 08ff9ace090d2691.js} +1 -1
  585. package/web/.next/static/chunks/{b4cde06eff374c59.js → 0a79dfbb8486b66e.js} +2 -2
  586. package/web/.next/static/chunks/0b1c2bbc0169229f.js +1 -0
  587. package/web/.next/static/chunks/18d0ec4f7b848983.js +1 -0
  588. package/web/.next/static/chunks/2273b81cd7c7d2af.css +1 -0
  589. package/web/.next/static/chunks/36768c59216eeaf9.js +1 -0
  590. package/web/.next/static/chunks/{688971d5bad5dc7c.js → 3deefc76ea55047c.js} +1 -1
  591. package/web/.next/static/chunks/{11091b676d1b3bd4.js → 47477ed4c5871747.js} +1 -1
  592. package/web/.next/static/chunks/4864ff06a738d58b.js +1 -0
  593. package/web/.next/static/chunks/504d1bd34e9f7dd8.js +7 -0
  594. package/web/.next/static/chunks/{22c459f1877b1e4f.js → 74db65fa7bfb80bd.js} +1 -1
  595. package/web/.next/static/chunks/7b9ed1c6d9eea406.js +2 -0
  596. package/web/.next/static/chunks/{f98f811478ff3d9e.js → 7e2465210c64ed91.js} +1 -1
  597. package/web/.next/static/chunks/9061f08ab7e537a8.js +1 -0
  598. package/web/.next/static/chunks/{37156b1c0646309f.js → 9d314b2b855bc050.js} +1 -1
  599. package/web/.next/static/chunks/a272e115fd5ca5a0.js +5 -0
  600. package/web/.next/static/chunks/{baa593a4681fc66e.js → b8196a574b97e029.js} +1 -1
  601. package/web/.next/static/chunks/d2cbeefbc8967b16.js +1 -0
  602. package/web/.next/static/chunks/d5366257d6b9f855.js +1 -0
  603. package/web/.next/static/chunks/{5ae60a052ab5f437.js → d6e702c209c413ce.js} +2 -2
  604. package/web/.next/static/chunks/ec99e6be5b32ecc9.js +1 -0
  605. package/web/.next/static/chunks/ed078ae150b9499a.js +1 -0
  606. package/web/.next/server/chunks/ssr/[root-of-the-server]__0b150ddf._.js +0 -3
  607. package/web/.next/server/chunks/ssr/[root-of-the-server]__0b150ddf._.js.map +0 -1
  608. package/web/.next/server/chunks/ssr/[root-of-the-server]__17ed7ed1._.js +0 -4
  609. package/web/.next/server/chunks/ssr/[root-of-the-server]__28d0d265._.js +0 -4
  610. package/web/.next/server/chunks/ssr/[root-of-the-server]__28d0d265._.js.map +0 -1
  611. package/web/.next/server/chunks/ssr/[root-of-the-server]__42bf1807._.js +0 -4
  612. package/web/.next/server/chunks/ssr/[root-of-the-server]__88f7e8e6._.js +0 -4
  613. package/web/.next/server/chunks/ssr/[root-of-the-server]__f80bfc75._.js +0 -4
  614. package/web/.next/server/chunks/ssr/_08dc06df._.js +0 -3
  615. package/web/.next/server/chunks/ssr/_140901ed._.js +0 -4
  616. package/web/.next/server/chunks/ssr/_140901ed._.js.map +0 -1
  617. package/web/.next/server/chunks/ssr/_4b432739._.js +0 -3
  618. package/web/.next/server/chunks/ssr/_4b432739._.js.map +0 -1
  619. package/web/.next/server/chunks/ssr/_507a8382._.js.map +0 -1
  620. package/web/.next/server/chunks/ssr/_8219712a._.js +0 -3
  621. package/web/.next/server/chunks/ssr/_8219712a._.js.map +0 -1
  622. package/web/.next/server/chunks/ssr/_d4b20e29._.js +0 -3
  623. package/web/.next/server/chunks/ssr/_d4b20e29._.js.map +0 -1
  624. package/web/.next/server/chunks/ssr/_e9a73a63._.js +0 -9
  625. package/web/.next/server/chunks/ssr/_e9a73a63._.js.map +0 -1
  626. package/web/.next/server/chunks/ssr/src_presentation_web_324a47da._.js +0 -3
  627. package/web/.next/server/chunks/ssr/src_presentation_web_324a47da._.js.map +0 -1
  628. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_cdc632e3.js +0 -3
  629. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_cdc632e3.js.map +0 -1
  630. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_39ca0924.js +0 -3
  631. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_39ca0924.js.map +0 -1
  632. package/web/.next/server/chunks/ssr/src_presentation_web_components_357e3eb0._.js +0 -3
  633. package/web/.next/server/chunks/ssr/src_presentation_web_components_357e3eb0._.js.map +0 -1
  634. package/web/.next/static/chunks/0104ee32c0b12767.js +0 -7
  635. package/web/.next/static/chunks/1555e75b3393cfe1.js +0 -1
  636. package/web/.next/static/chunks/4b2c4a5c35ebb70d.js +0 -1
  637. package/web/.next/static/chunks/697bbb4ddfc7aed8.js +0 -1
  638. package/web/.next/static/chunks/8590bd2e69b24b9e.css +0 -1
  639. package/web/.next/static/chunks/88a729f218d9628b.js +0 -5
  640. package/web/.next/static/chunks/88ffe4a8760a3559.js +0 -1
  641. package/web/.next/static/chunks/8ba1c07ef18b15a9.js +0 -1
  642. package/web/.next/static/chunks/92629ccb27a1bdb9.js +0 -2
  643. package/web/.next/static/chunks/ae30b66927c676ff.js +0 -1
  644. package/web/.next/static/chunks/cd54b758f58061d0.js +0 -1
  645. package/web/.next/static/chunks/f5c527d3f8699035.js +0 -1
  646. /package/web/.next/static/{N3SkMLMrYUFai4W2zwMGS → jBQpz78BQ7UsAMcJbVOPf}/_buildManifest.js +0 -0
  647. /package/web/.next/static/{N3SkMLMrYUFai4W2zwMGS → jBQpz78BQ7UsAMcJbVOPf}/_clientMiddlewareManifest.json +0 -0
  648. /package/web/.next/static/{N3SkMLMrYUFai4W2zwMGS → jBQpz78BQ7UsAMcJbVOPf}/_ssgManifest.js +0 -0
@@ -1,13 +1,15 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useTranslation } from 'react-i18next';
2
3
  import { Tooltip, TooltipContent, TooltipTrigger } from '../../ui/tooltip.js';
3
4
  import { cn } from '../../../lib/utils.js';
4
5
  import { featureStatusConfig, featureStatusOrder, } from '../../common/feature-status-config.js';
5
6
  export function FeatureStatusBadges({ counts, className }) {
7
+ const { t } = useTranslation('web');
6
8
  const visibleStatuses = featureStatusOrder.filter((s) => counts[s] > 0);
7
9
  if (visibleStatuses.length === 0)
8
10
  return null;
9
11
  return (_jsx("div", { "data-testid": "feature-status-badges", className: cn('flex flex-col items-center gap-1.5 py-1', className), children: visibleStatuses.map((status) => {
10
- const { icon: Icon, iconClass, bgClass, label } = featureStatusConfig[status];
11
- return (_jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs("div", { "data-testid": `feature-status-badge-${status}`, className: cn('flex size-8 items-center justify-center gap-0.5 rounded-md', bgClass), children: [_jsx(Icon, { className: cn('size-3.5 shrink-0', iconClass) }), _jsx("span", { className: "text-[0.6rem] font-semibold tabular-nums", children: counts[status] })] }) }), _jsxs(TooltipContent, { side: "right", children: [label, ": ", counts[status]] })] }, status));
12
+ const { icon: Icon, iconClass, bgClass, labelKey } = featureStatusConfig[status];
13
+ return (_jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs("div", { "data-testid": `feature-status-badge-${status}`, className: cn('flex size-8 items-center justify-center gap-0.5 rounded-md', bgClass), children: [_jsx(Icon, { className: cn('size-3.5 shrink-0', iconClass) }), _jsx("span", { className: "text-[0.6rem] font-semibold tabular-nums", children: counts[status] })] }) }), _jsxs(TooltipContent, { side: "right", children: [t(labelKey), ": ", counts[status]] })] }, status));
12
14
  }) }));
13
15
  }
@@ -4,7 +4,8 @@ export interface FeatureStatusConfig {
4
4
  icon: LucideIcon;
5
5
  iconClass: string;
6
6
  bgClass: string;
7
- label: string;
7
+ /** i18n translation key under the `web` namespace (e.g. `sidebar.statusActionNeeded`). */
8
+ labelKey: string;
8
9
  }
9
10
  export declare const featureStatusConfig: Record<FeatureStatus, FeatureStatusConfig>;
10
11
  export declare const featureStatusOrder: FeatureStatus[];
@@ -1 +1 @@
1
- {"version":3,"file":"feature-status-config.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/web/components/common/feature-status-config.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE/C,MAAM,MAAM,aAAa,GACrB,eAAe,GACf,aAAa,GACb,SAAS,GACT,SAAS,GACT,OAAO,GACP,MAAM,CAAC;AAEX,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,UAAU,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,aAAa,EAAE,mBAAmB,CAqC1E,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,aAAa,EAO7C,CAAC"}
1
+ {"version":3,"file":"feature-status-config.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/web/components/common/feature-status-config.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE/C,MAAM,MAAM,aAAa,GACrB,eAAe,GACf,aAAa,GACb,SAAS,GACT,SAAS,GACT,OAAO,GACP,MAAM,CAAC;AAEX,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,UAAU,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,0FAA0F;IAC1F,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,aAAa,EAAE,mBAAmB,CAqC1E,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,aAAa,EAO7C,CAAC"}
@@ -4,37 +4,37 @@ export const featureStatusConfig = {
4
4
  icon: CircleAlert,
5
5
  iconClass: 'text-amber-500',
6
6
  bgClass: 'bg-amber-500/10',
7
- label: 'Action Needed',
7
+ labelKey: 'sidebar.statusActionNeeded',
8
8
  },
9
9
  'in-progress': {
10
10
  icon: Loader2,
11
11
  iconClass: 'text-blue-500 animate-spin',
12
12
  bgClass: 'bg-blue-500/10',
13
- label: 'In Progress',
13
+ labelKey: 'sidebar.statusInProgress',
14
14
  },
15
15
  pending: {
16
16
  icon: Clock,
17
17
  iconClass: 'text-slate-400',
18
18
  bgClass: 'bg-slate-400/10',
19
- label: 'Pending',
19
+ labelKey: 'sidebar.statusPending',
20
20
  },
21
21
  blocked: {
22
22
  icon: Ban,
23
23
  iconClass: 'text-gray-400',
24
24
  bgClass: 'bg-gray-400/10',
25
- label: 'Blocked',
25
+ labelKey: 'sidebar.statusBlocked',
26
26
  },
27
27
  error: {
28
28
  icon: CircleX,
29
29
  iconClass: 'text-red-500',
30
30
  bgClass: 'bg-red-500/10',
31
- label: 'Error',
31
+ labelKey: 'sidebar.statusError',
32
32
  },
33
33
  done: {
34
34
  icon: CircleCheck,
35
35
  iconClass: 'text-emerald-500',
36
36
  bgClass: 'bg-emerald-500/10',
37
- label: 'Done',
37
+ labelKey: 'sidebar.statusDone',
38
38
  },
39
39
  };
40
40
  export const featureStatusOrder = [
@@ -1,5 +1,5 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { SidebarGroup, SidebarGroupLabel, SidebarGroupContent, SidebarMenu, } from '../../ui/sidebar.js';
3
3
  export function FeatureStatusGroup({ label, count, children }) {
4
- return (_jsxs(SidebarGroup, { "data-testid": "feature-status-group", className: "px-2 py-1", children: [_jsxs(SidebarGroupLabel, { className: "text-muted-foreground h-6 px-2 text-[0.65rem] font-semibold tracking-wider uppercase", children: [label, _jsx("span", { "aria-label": `${count} items`, className: "bg-sidebar-accent text-sidebar-accent-foreground ml-1.5 inline-flex h-4 min-w-4 items-center justify-center rounded-full px-1 text-[0.6rem] font-medium tabular-nums", role: "img", children: count })] }), _jsx(SidebarGroupContent, { children: _jsx(SidebarMenu, { className: "gap-0.5", children: children }) })] }));
4
+ return (_jsxs(SidebarGroup, { "data-testid": "feature-status-group", className: "px-2 py-1", children: [_jsxs(SidebarGroupLabel, { className: "text-muted-foreground h-6 px-2 text-[0.65rem] font-semibold tracking-wider uppercase", children: [label, _jsx("span", { "aria-label": `${count} items`, className: "bg-sidebar-accent text-sidebar-accent-foreground ms-1.5 inline-flex h-4 min-w-4 items-center justify-center rounded-full px-1 text-[0.6rem] font-medium tabular-nums", role: "img", children: count })] }), _jsx(SidebarGroupContent, { children: _jsx(SidebarMenu, { className: "gap-0.5", children: children }) })] }));
5
5
  }
@@ -1 +1 @@
1
- {"version":3,"file":"floating-action-button.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/floating-action-button/floating-action-button.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAKnD,MAAM,WAAW,0BAA0B;IACzC,iCAAiC;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,+CAA+C;IAC/C,KAAK,EAAE,MAAM,CAAC;IACd,6BAA6B;IAC7B,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC;IACtB,yCAAyC;IACzC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,+CAA+C;IAC/C,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,sCAAsC;IACtC,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,yBAAyB;IACxC,mDAAmD;IACnD,OAAO,EAAE,0BAA0B,EAAE,CAAC;IACtC,8CAA8C;IAC9C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gEAAgE;IAChE,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;CAC7B;AAQD;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,yBAAyB,2CAyG5F"}
1
+ {"version":3,"file":"floating-action-button.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/floating-action-button/floating-action-button.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAMnD,MAAM,WAAW,0BAA0B;IACzC,iCAAiC;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,+CAA+C;IAC/C,KAAK,EAAE,MAAM,CAAC;IACd,6BAA6B;IAC7B,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC;IACtB,yCAAyC;IACzC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,+CAA+C;IAC/C,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,sCAAsC;IACtC,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,yBAAyB;IACxC,mDAAmD;IACnD,OAAO,EAAE,0BAA0B,EAAE,CAAC;IACtC,8CAA8C;IAC9C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gEAAgE;IAChE,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;CAC7B;AAQD;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,yBAAyB,2CA0G5F"}
@@ -2,6 +2,7 @@
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 { Plus, Loader2, X } from 'lucide-react';
5
+ import { useTranslation } from 'react-i18next';
5
6
  import { cn } from '../../../lib/utils.js';
6
7
  import { Button } from '../../ui/button.js';
7
8
  /** Stagger delay between each item animation in ms. */
@@ -13,6 +14,7 @@ const DURATION_MS = 250;
13
14
  * Renders inline — parent controls positioning.
14
15
  */
15
16
  export function FloatingActionButton({ actions, className, style }) {
17
+ const { t } = useTranslation('web');
16
18
  const [open, setOpen] = useState(false);
17
19
  // Close on Escape key
18
20
  useEffect(() => {
@@ -26,7 +28,7 @@ export function FloatingActionButton({ actions, className, style }) {
26
28
  document.addEventListener('keydown', handleKeyDown);
27
29
  return () => document.removeEventListener('keydown', handleKeyDown);
28
30
  }, [open]);
29
- return (_jsxs(_Fragment, { children: [open ? (_jsx("div", { "data-testid": "fab-overlay", className: "fixed inset-0 z-40", onClick: () => setOpen(false), "aria-hidden": "true" })) : null, _jsxs("div", { "data-testid": "floating-action-button", className: cn('relative z-50', className), style: style, children: [_jsx("div", { className: cn('absolute bottom-[calc(100%+24px)] left-0 flex flex-col items-start gap-2', !open && 'pointer-events-none'), "data-testid": "fab-actions", children: actions.map((action, i) => {
31
+ return (_jsxs(_Fragment, { children: [open ? (_jsx("div", { "data-testid": "fab-overlay", className: "fixed inset-0 z-40", onClick: () => setOpen(false), "aria-hidden": "true" })) : null, _jsxs("div", { "data-testid": "floating-action-button", className: cn('relative z-50', className), style: style, children: [_jsx("div", { className: cn('absolute start-0 bottom-[calc(100%+24px)] flex flex-col items-start gap-2', !open && 'pointer-events-none'), "data-testid": "fab-actions", children: actions.map((action, i) => {
30
32
  const openDelay = (actions.length - 1 - i) * STAGGER_MS;
31
33
  return (_jsxs("button", { "data-testid": `fab-action-${action.id}`, "aria-label": action.label, disabled: action.disabled ?? action.loading, className: cn('flex h-10 items-center gap-2.5 rounded-full px-4', 'bg-background text-foreground shadow-md', 'border-border border', 'hover:bg-accent hover:text-accent-foreground', 'disabled:pointer-events-none disabled:opacity-50', 'text-sm font-medium whitespace-nowrap', open ? 'translate-y-0 opacity-100' : 'pointer-events-none translate-y-0 opacity-0'), style: {
32
34
  transition: `opacity ${open ? DURATION_MS : 120}ms ease-out ${open ? openDelay : 0}ms, transform ${open ? DURATION_MS : 120}ms ease-out ${open ? openDelay : 0}ms`,
@@ -34,5 +36,5 @@ export function FloatingActionButton({ actions, className, style }) {
34
36
  action.onClick();
35
37
  setOpen(false);
36
38
  }, children: [_jsx("span", { className: "flex h-5 w-5 shrink-0 items-center justify-center", children: action.loading ? _jsx(Loader2, { className: "h-4 w-4 animate-spin" }) : action.icon }), _jsx("span", { children: action.label })] }, action.id));
37
- }) }), _jsxs(Button, { size: "icon", "data-testid": "fab-trigger", "aria-label": open ? 'Close actions' : 'Create new', className: cn('relative h-14 w-14 rounded-full shadow-lg', 'bg-indigo-500 text-white hover:bg-indigo-400 dark:bg-indigo-500 dark:hover:bg-indigo-400', 'transition-all duration-200 hover:scale-105 hover:shadow-xl active:scale-95'), onClick: () => setOpen((prev) => !prev), children: [_jsx(Plus, { className: cn('absolute h-7 w-7 stroke-[2.5] transition-all', open ? 'scale-0 rotate-90 opacity-0' : 'scale-100 rotate-0 opacity-100'), style: { transitionDuration: `${DURATION_MS}ms` } }), _jsx(X, { className: cn('absolute h-6 w-6 stroke-[2.5] transition-all', open ? 'scale-100 rotate-0 opacity-100' : 'scale-0 -rotate-90 opacity-0'), style: { transitionDuration: `${DURATION_MS}ms` } })] })] })] }));
39
+ }) }), _jsxs(Button, { size: "icon", "data-testid": "fab-trigger", "aria-label": open ? t('fab.closeActions') : t('fab.createNew'), className: cn('relative h-14 w-14 rounded-full shadow-lg', 'bg-indigo-500 text-white hover:bg-indigo-400 dark:bg-indigo-500 dark:hover:bg-indigo-400', 'transition-all duration-200 hover:scale-105 hover:shadow-xl active:scale-95'), onClick: () => setOpen((prev) => !prev), children: [_jsx(Plus, { className: cn('absolute h-7 w-7 stroke-[2.5] transition-all', open ? 'scale-0 rotate-90 opacity-0' : 'scale-100 rotate-0 opacity-100'), style: { transitionDuration: `${DURATION_MS}ms` } }), _jsx(X, { className: cn('absolute h-6 w-6 stroke-[2.5] transition-all', open ? 'scale-100 rotate-0 opacity-100' : 'scale-0 -rotate-90 opacity-0'), style: { transitionDuration: `${DURATION_MS}ms` } })] })] })] }));
38
40
  }
@@ -48,5 +48,5 @@ export function GitHubRepoBrowser({ onSelect, loading: externalLoading = false,
48
48
  if (error && !fetching) {
49
49
  return (_jsxs("div", { className: "flex flex-col items-center gap-2 py-8 text-center", "data-testid": "repo-browser-error", children: [_jsx(AlertCircle, { className: "text-destructive h-8 w-8" }), _jsx("p", { className: "text-destructive text-sm", children: error })] }));
50
50
  }
51
- return (_jsxs("div", { className: "flex flex-col gap-3", children: [_jsxs("div", { className: "relative", children: [_jsx(Search, { className: "text-muted-foreground absolute top-1/2 left-3 h-4 w-4 -translate-y-1/2" }), _jsx(Input, { placeholder: "Search repositories...", value: search, onChange: (e) => handleSearchChange(e.target.value), className: "pl-9", disabled: disabled, "aria-label": "Search repositories" })] }), _jsx("div", { className: "max-h-64 overflow-x-hidden overflow-y-auto rounded-md border", role: "listbox", "aria-label": "GitHub repositories", children: fetching ? (_jsx("div", { className: "flex flex-col gap-2 p-3", "data-testid": "repo-browser-loading", children: Array.from({ length: 5 }).map((_, i) => (_jsxs("div", { className: "flex flex-col gap-1", children: [_jsx(Skeleton, { className: "h-4 w-48" }), _jsx(Skeleton, { className: "h-3 w-72" })] }, `skeleton-${String(i)}`))) })) : repos.length === 0 ? (_jsx("div", { className: "text-muted-foreground py-8 text-center text-sm", "data-testid": "repo-browser-empty", children: "No repositories found" })) : (repos.map((repo) => (_jsxs("button", { type: "button", role: "option", "aria-selected": false, className: "hover:bg-accent flex w-full items-start gap-2 border-b px-3 py-2.5 text-left last:border-b-0 disabled:opacity-50", onClick: () => onSelect(repo.nameWithOwner), disabled: disabled, children: [_jsxs("div", { className: "min-w-0 flex-1", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "truncate text-sm font-medium", children: repo.nameWithOwner }), _jsx(Badge, { variant: repo.isPrivate ? 'secondary' : 'outline', className: "shrink-0 text-xs", children: repo.isPrivate ? (_jsxs(_Fragment, { children: [_jsx(Lock, { className: "mr-1 h-3 w-3" }), "Private"] })) : (_jsxs(_Fragment, { children: [_jsx(Globe, { className: "mr-1 h-3 w-3" }), "Public"] })) })] }), repo.description ? (_jsx("p", { className: "text-muted-foreground mt-0.5 truncate text-xs", children: repo.description })) : null] }), disabled ? _jsx(Loader2, { className: "mt-0.5 h-4 w-4 shrink-0 animate-spin" }) : null] }, repo.nameWithOwner)))) })] }));
51
+ return (_jsxs("div", { className: "flex flex-col gap-3", children: [_jsxs("div", { className: "relative", children: [_jsx(Search, { className: "text-muted-foreground absolute top-1/2 left-3 h-4 w-4 -translate-y-1/2" }), _jsx(Input, { placeholder: "Search repositories...", value: search, onChange: (e) => handleSearchChange(e.target.value), className: "ps-9", disabled: disabled, "aria-label": "Search repositories" })] }), _jsx("div", { className: "max-h-64 overflow-x-hidden overflow-y-auto rounded-md border", role: "listbox", "aria-label": "GitHub repositories", children: fetching ? (_jsx("div", { className: "flex flex-col gap-2 p-3", "data-testid": "repo-browser-loading", children: Array.from({ length: 5 }).map((_, i) => (_jsxs("div", { className: "flex flex-col gap-1", children: [_jsx(Skeleton, { className: "h-4 w-48" }), _jsx(Skeleton, { className: "h-3 w-72" })] }, `skeleton-${String(i)}`))) })) : repos.length === 0 ? (_jsx("div", { className: "text-muted-foreground py-8 text-center text-sm", "data-testid": "repo-browser-empty", children: "No repositories found" })) : (repos.map((repo) => (_jsxs("button", { type: "button", role: "option", "aria-selected": false, className: "hover:bg-accent flex w-full items-start gap-2 border-b px-3 py-2.5 text-start last:border-b-0 disabled:opacity-50", onClick: () => onSelect(repo.nameWithOwner), disabled: disabled, children: [_jsxs("div", { className: "min-w-0 flex-1", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "truncate text-sm font-medium", children: repo.nameWithOwner }), _jsx(Badge, { variant: repo.isPrivate ? 'secondary' : 'outline', className: "shrink-0 text-xs", children: repo.isPrivate ? (_jsxs(_Fragment, { children: [_jsx(Lock, { className: "me-1 h-3 w-3" }), "Private"] })) : (_jsxs(_Fragment, { children: [_jsx(Globe, { className: "me-1 h-3 w-3" }), "Public"] })) })] }), repo.description ? (_jsx("p", { className: "text-muted-foreground mt-0.5 truncate text-xs", children: repo.description })) : null] }), disabled ? _jsx(Loader2, { className: "mt-0.5 h-4 w-4 shrink-0 animate-spin" }) : null] }, repo.nameWithOwner)))) })] }));
52
52
  }
@@ -15,13 +15,13 @@ function FileStatusIcon({ status }) {
15
15
  return _jsx(Icon, { className: cn('h-3.5 w-3.5 shrink-0', config.className) });
16
16
  }
17
17
  function HunkView({ hunk }) {
18
- return (_jsxs("div", { className: "border-border border-t first:border-t-0", children: [_jsx("div", { className: "bg-muted/50 text-muted-foreground px-3 py-1 font-mono text-[10px]", children: hunk.header }), _jsx("div", { className: "font-mono text-[11px] leading-[18px]", children: hunk.lines.map((line) => (_jsxs("div", { className: cn('flex', line.type === 'added' && 'bg-green-50 dark:bg-green-950/30', line.type === 'removed' && 'bg-red-50 dark:bg-red-950/30'), children: [_jsx("span", { className: "text-muted-foreground w-10 shrink-0 px-1 text-right text-[10px] select-none", children: line.oldNumber ?? '' }), _jsx("span", { className: "text-muted-foreground w-10 shrink-0 px-1 text-right text-[10px] select-none", children: line.newNumber ?? '' }), _jsx("span", { className: cn('w-4 shrink-0 text-center select-none', line.type === 'added' && 'text-green-700 dark:text-green-400', line.type === 'removed' && 'text-red-700 dark:text-red-400'), children: line.type === 'added' ? '+' : line.type === 'removed' ? '-' : ' ' }), _jsx("span", { className: "min-w-0 flex-1 pr-2 break-all whitespace-pre-wrap", children: line.content })] }, `${line.type}-${line.oldNumber ?? ''}-${line.newNumber ?? ''}`))) })] }));
18
+ return (_jsxs("div", { className: "border-border border-t first:border-t-0", children: [_jsx("div", { className: "bg-muted/50 text-muted-foreground px-3 py-1 font-mono text-[10px]", children: hunk.header }), _jsx("div", { className: "font-mono text-[11px] leading-[18px]", children: hunk.lines.map((line) => (_jsxs("div", { className: cn('flex', line.type === 'added' && 'bg-green-50 dark:bg-green-950/30', line.type === 'removed' && 'bg-red-50 dark:bg-red-950/30'), children: [_jsx("span", { className: "text-muted-foreground w-10 shrink-0 px-1 text-end text-[10px] select-none", children: line.oldNumber ?? '' }), _jsx("span", { className: "text-muted-foreground w-10 shrink-0 px-1 text-end text-[10px] select-none", children: line.newNumber ?? '' }), _jsx("span", { className: cn('w-4 shrink-0 text-center select-none', line.type === 'added' && 'text-green-700 dark:text-green-400', line.type === 'removed' && 'text-red-700 dark:text-red-400'), children: line.type === 'added' ? '+' : line.type === 'removed' ? '-' : ' ' }), _jsx("span", { className: "min-w-0 flex-1 pe-2 break-all whitespace-pre-wrap", children: line.content })] }, `${line.type}-${line.oldNumber ?? ''}-${line.newNumber ?? ''}`))) })] }));
19
19
  }
20
20
  function FileDiffItem({ file }) {
21
21
  const [isOpen, setIsOpen] = useState(false);
22
22
  const fileName = file.path.split('/').pop() ?? file.path;
23
23
  const dirPath = file.path.includes('/') ? file.path.slice(0, file.path.lastIndexOf('/')) : '';
24
- return (_jsxs("div", { className: "border-border border-b last:border-b-0", children: [_jsxs("button", { type: "button", onClick: () => setIsOpen(!isOpen), className: "hover:bg-muted/50 flex w-full items-center gap-2 px-3 py-2 text-left", children: [_jsx(ChevronRight, { className: cn('text-muted-foreground h-3 w-3 shrink-0 transition-transform duration-150', isOpen && 'rotate-90') }), _jsx(FileStatusIcon, { status: file.status }), _jsx("span", { className: "text-foreground min-w-0 flex-1 truncate text-xs", children: dirPath ? (_jsxs(_Fragment, { children: [_jsxs("span", { className: "text-muted-foreground", children: [dirPath, "/"] }), fileName] })) : (fileName) }), file.oldPath ? (_jsxs("span", { className: "text-muted-foreground truncate text-[10px]", children: ["\u2190 ", file.oldPath.split('/').pop()] })) : null, _jsxs("span", { className: "shrink-0 text-[10px]", children: [file.additions > 0 ? _jsxs("span", { className: "text-green-600", children: ["+", file.additions] }) : null, file.additions > 0 && file.deletions > 0 ? ' ' : null, file.deletions > 0 ? _jsxs("span", { className: "text-red-600", children: ["-", file.deletions] }) : null] })] }), isOpen && file.hunks.length > 0 ? (_jsx("div", { className: "border-border overflow-x-auto border-t", children: file.hunks.map((hunk) => (_jsx(HunkView, { hunk: hunk }, hunk.header))) })) : null] }));
24
+ return (_jsxs("div", { className: "border-border border-b last:border-b-0", children: [_jsxs("button", { type: "button", onClick: () => setIsOpen(!isOpen), className: "hover:bg-muted/50 flex w-full items-center gap-2 px-3 py-2 text-start", children: [_jsx(ChevronRight, { className: cn('text-muted-foreground h-3 w-3 shrink-0 transition-transform duration-150', isOpen && 'rotate-90') }), _jsx(FileStatusIcon, { status: file.status }), _jsx("span", { className: "text-foreground min-w-0 flex-1 truncate text-xs", children: dirPath ? (_jsxs(_Fragment, { children: [_jsxs("span", { className: "text-muted-foreground", children: [dirPath, "/"] }), fileName] })) : (fileName) }), file.oldPath ? (_jsxs("span", { className: "text-muted-foreground truncate text-[10px]", children: ["\u2190 ", file.oldPath.split('/').pop()] })) : null, _jsxs("span", { className: "shrink-0 text-[10px]", children: [file.additions > 0 ? _jsxs("span", { className: "text-green-600", children: ["+", file.additions] }) : null, file.additions > 0 && file.deletions > 0 ? ' ' : null, file.deletions > 0 ? _jsxs("span", { className: "text-red-600", children: ["-", file.deletions] }) : null] })] }), isOpen && file.hunks.length > 0 ? (_jsx("div", { className: "border-border overflow-x-auto border-t", children: file.hunks.map((hunk) => (_jsx(HunkView, { hunk: hunk }, hunk.header))) })) : null] }));
25
25
  }
26
26
  export function DiffView({ fileDiffs }) {
27
27
  if (fileDiffs.length === 0)
@@ -30,7 +30,7 @@ function EvidenceItem({ evidence }) {
30
30
  const isImage = evidence.type === 'Screenshot' || IMAGE_EXTENSIONS.has(ext);
31
31
  const isVideo = evidence.type === 'Video' || VIDEO_EXTENSIONS.has(ext);
32
32
  const isText = evidence.type === 'TestOutput' || evidence.type === 'TerminalRecording';
33
- return (_jsxs("li", { className: "border-border rounded-md border", children: [_jsxs("button", { type: "button", onClick: () => setExpanded(!expanded), className: "flex w-full cursor-pointer items-center gap-2.5 px-3 py-2.5 text-left", children: [expanded ? (_jsx(ChevronDown, { className: "text-muted-foreground h-3 w-3 shrink-0" })) : (_jsx(ChevronRight, { className: "text-muted-foreground h-3 w-3 shrink-0" })), _jsx(Icon, { className: "text-muted-foreground h-3.5 w-3.5 shrink-0" }), _jsxs("div", { className: "min-w-0 flex-1", children: [_jsx("span", { className: "text-foreground text-xs font-medium", children: evidence.description }), evidence.taskRef ? (_jsxs("span", { className: "text-muted-foreground ml-1.5 text-[10px]", children: ["(", evidence.taskRef, ")"] })) : null] }), url ? (_jsx("a", { href: url, download: true, onClick: (e) => e.stopPropagation(), className: "text-muted-foreground hover:text-foreground shrink-0 rounded p-1 transition-colors", "aria-label": "Download", children: _jsx(Download, { className: "h-3 w-3" }) })) : null] }), expanded && url ? (_jsx("div", { className: "border-border border-t px-3 py-2.5", children: isImage ? (
33
+ return (_jsxs("li", { className: "border-border rounded-md border", children: [_jsxs("button", { type: "button", onClick: () => setExpanded(!expanded), className: "flex w-full cursor-pointer items-center gap-2.5 px-3 py-2.5 text-start", children: [expanded ? (_jsx(ChevronDown, { className: "text-muted-foreground h-3 w-3 shrink-0" })) : (_jsx(ChevronRight, { className: "text-muted-foreground h-3 w-3 shrink-0" })), _jsx(Icon, { className: "text-muted-foreground h-3.5 w-3.5 shrink-0" }), _jsxs("div", { className: "min-w-0 flex-1", children: [_jsx("span", { className: "text-foreground text-xs font-medium", children: evidence.description }), evidence.taskRef ? (_jsxs("span", { className: "text-muted-foreground ms-1.5 text-[10px]", children: ["(", evidence.taskRef, ")"] })) : null] }), url ? (_jsx("a", { href: url, download: true, onClick: (e) => e.stopPropagation(), className: "text-muted-foreground hover:text-foreground shrink-0 rounded p-1 transition-colors", "aria-label": "Download", children: _jsx(Download, { className: "h-3 w-3" }) })) : null] }), expanded && url ? (_jsx("div", { className: "border-border border-t px-3 py-2.5", children: isImage ? (
34
34
  /* eslint-disable-next-line @next/next/no-img-element */
35
35
  _jsx("img", { src: url, alt: evidence.description, className: "max-h-80 w-full rounded-md border object-contain", loading: "lazy" })) : isVideo ? (_jsx("video", { src: url, controls: true, className: "max-h-80 w-full rounded-md border", preload: "metadata", children: _jsx("track", { kind: "captions" }) })) : isText ? (_jsx(EvidenceTextPreview, { url: url })) : (_jsx("p", { className: "text-muted-foreground truncate font-mono text-[10px]", children: evidence.relativePath })) })) : null, expanded && !url ? (_jsx("div", { className: "border-border border-t px-3 py-2.5", children: _jsx("p", { className: "text-muted-foreground truncate font-mono text-[10px]", children: evidence.relativePath }) })) : null] }));
36
36
  }
@@ -65,5 +65,5 @@ export function MergeReview({ data, readOnly = false, onApprove, onReject, isPro
65
65
  ? 'This feature was merged. Review the pull request details and evidence below.'
66
66
  : pr
67
67
  ? 'Review the pull request details and approve to merge.'
68
- : 'Review the changes and approve to merge.' })] })] }), branch ? (_jsx("div", { className: "border-border rounded-lg border", children: _jsxs("div", { className: "flex items-center gap-2 px-4 py-3", children: [_jsx(GitBranch, { className: "text-muted-foreground h-4 w-4 shrink-0" }), _jsx(Badge, { variant: "secondary", className: "font-mono text-[11px]", children: branch.source }), _jsx(ArrowRight, { className: "text-muted-foreground h-3.5 w-3.5 shrink-0" }), _jsx(Badge, { variant: "outline", className: "font-mono text-[11px]", children: branch.target })] }) })) : null, pr ? (_jsx("div", { className: "border-border rounded-lg border", children: _jsxs("div", { className: "space-y-3 px-4 py-3", children: [_jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("a", { href: pr.url, target: "_blank", rel: "noopener noreferrer", className: "text-primary flex items-center gap-1.5 text-sm font-semibold underline underline-offset-2", children: ["PR #", pr.number, _jsx(ExternalLink, { className: "h-3.5 w-3.5" })] }), _jsx(Badge, { variant: "outline", className: "text-xs", children: pr.status })] }), pr.mergeable === false ? (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-muted-foreground text-xs font-medium", children: "Merge Status" }), _jsxs(Badge, { className: "border-transparent bg-orange-50 text-orange-700 hover:bg-orange-50", children: [_jsx(AlertTriangle, { className: "mr-1 h-3.5 w-3.5" }), "Conflicts"] })] })) : null, pr.ciStatus && hideCiStatus !== true ? (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-muted-foreground text-xs font-medium", children: "CI Status" }), _jsx(CiStatusBadge, { status: pr.ciStatus })] })) : null, pr.commitHash ? (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-muted-foreground text-xs font-medium", children: "Commit" }), _jsxs("div", { className: "flex items-center gap-1.5", children: [_jsx(GitCommitHorizontal, { className: "text-muted-foreground h-3.5 w-3.5" }), _jsx("code", { className: "bg-muted text-foreground rounded-md px-1.5 py-0.5 font-mono text-[11px]", children: pr.commitHash.slice(0, 7) })] })] })) : null] }) })) : null, diffSummary ? (_jsx("div", { className: "border-border rounded-lg border", children: _jsxs("div", { className: "px-4 py-3", children: [_jsxs("div", { className: "mb-3 flex items-center gap-2", children: [_jsx(FileDiff, { className: "text-muted-foreground h-4 w-4" }), _jsx("span", { className: "text-foreground text-xs font-semibold", children: "Changes" })] }), _jsxs("div", { className: "grid grid-cols-4 gap-3", children: [_jsxs("div", { className: "text-center", children: [_jsx("div", { className: "text-foreground text-sm font-bold", children: diffSummary.filesChanged }), _jsx("div", { className: "text-muted-foreground text-[10px]", children: "files" })] }), _jsxs("div", { className: "text-center", children: [_jsxs("div", { className: "text-sm font-bold text-green-600", children: ["+", diffSummary.additions] }), _jsx("div", { className: "text-muted-foreground text-[10px]", children: "additions" })] }), _jsxs("div", { className: "text-center", children: [_jsxs("div", { className: "text-sm font-bold text-red-600", children: ["-", diffSummary.deletions] }), _jsx("div", { className: "text-muted-foreground text-[10px]", children: "deletions" })] }), _jsxs("div", { className: "text-center", children: [_jsx("div", { className: "text-foreground text-sm font-bold", children: diffSummary.commitCount }), _jsx("div", { className: "text-muted-foreground text-[10px]", children: "commits" })] })] })] }) })) : warning ? (_jsx("div", { className: "border-border rounded-lg border", children: _jsxs("div", { className: "flex items-center gap-2 px-4 py-3", children: [_jsx(AlertTriangle, { className: "text-muted-foreground h-4 w-4 shrink-0" }), _jsx("span", { className: "text-muted-foreground text-xs", children: warning })] }) })) : null, evidence && evidence.length > 0 ? _jsx(EvidenceList, { evidence: evidence }) : null, fileDiffs && fileDiffs.length > 0 ? _jsx(DiffView, { fileDiffs: fileDiffs }) : null] }), !readOnly && (_jsx(DrawerActionBar, { onReject: onReject, onApprove: handleApproveOrResolve, approveLabel: hasConflicts ? 'Resolve Conflicts' : 'Approve Merge', approveVariant: hasConflicts ? 'warning' : 'default', revisionPlaceholder: "Ask AI to revise before merging...", isProcessing: isProcessing, isRejecting: isRejecting, chatInput: chatInput, onChatInputChange: onChatInputChange }))] }));
68
+ : 'Review the changes and approve to merge.' })] })] }), branch ? (_jsx("div", { className: "border-border rounded-lg border", children: _jsxs("div", { className: "flex items-center gap-2 px-4 py-3", children: [_jsx(GitBranch, { className: "text-muted-foreground h-4 w-4 shrink-0" }), _jsx(Badge, { variant: "secondary", className: "font-mono text-[11px]", children: branch.source }), _jsx(ArrowRight, { className: "text-muted-foreground h-3.5 w-3.5 shrink-0" }), _jsx(Badge, { variant: "outline", className: "font-mono text-[11px]", children: branch.target })] }) })) : null, pr ? (_jsx("div", { className: "border-border rounded-lg border", children: _jsxs("div", { className: "space-y-3 px-4 py-3", children: [_jsxs("div", { className: "flex items-center justify-between", children: [_jsxs("a", { href: pr.url, target: "_blank", rel: "noopener noreferrer", className: "text-primary flex items-center gap-1.5 text-sm font-semibold underline underline-offset-2", children: ["PR #", pr.number, _jsx(ExternalLink, { className: "h-3.5 w-3.5" })] }), _jsx(Badge, { variant: "outline", className: "text-xs", children: pr.status })] }), pr.mergeable === false ? (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-muted-foreground text-xs font-medium", children: "Merge Status" }), _jsxs(Badge, { className: "border-transparent bg-orange-50 text-orange-700 hover:bg-orange-50", children: [_jsx(AlertTriangle, { className: "me-1 h-3.5 w-3.5" }), "Conflicts"] })] })) : null, pr.ciStatus && hideCiStatus !== true ? (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-muted-foreground text-xs font-medium", children: "CI Status" }), _jsx(CiStatusBadge, { status: pr.ciStatus })] })) : null, pr.commitHash ? (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-muted-foreground text-xs font-medium", children: "Commit" }), _jsxs("div", { className: "flex items-center gap-1.5", children: [_jsx(GitCommitHorizontal, { className: "text-muted-foreground h-3.5 w-3.5" }), _jsx("code", { className: "bg-muted text-foreground rounded-md px-1.5 py-0.5 font-mono text-[11px]", children: pr.commitHash.slice(0, 7) })] })] })) : null] }) })) : null, diffSummary ? (_jsx("div", { className: "border-border rounded-lg border", children: _jsxs("div", { className: "px-4 py-3", children: [_jsxs("div", { className: "mb-3 flex items-center gap-2", children: [_jsx(FileDiff, { className: "text-muted-foreground h-4 w-4" }), _jsx("span", { className: "text-foreground text-xs font-semibold", children: "Changes" })] }), _jsxs("div", { className: "grid grid-cols-4 gap-3", children: [_jsxs("div", { className: "text-center", children: [_jsx("div", { className: "text-foreground text-sm font-bold", children: diffSummary.filesChanged }), _jsx("div", { className: "text-muted-foreground text-[10px]", children: "files" })] }), _jsxs("div", { className: "text-center", children: [_jsxs("div", { className: "text-sm font-bold text-green-600", children: ["+", diffSummary.additions] }), _jsx("div", { className: "text-muted-foreground text-[10px]", children: "additions" })] }), _jsxs("div", { className: "text-center", children: [_jsxs("div", { className: "text-sm font-bold text-red-600", children: ["-", diffSummary.deletions] }), _jsx("div", { className: "text-muted-foreground text-[10px]", children: "deletions" })] }), _jsxs("div", { className: "text-center", children: [_jsx("div", { className: "text-foreground text-sm font-bold", children: diffSummary.commitCount }), _jsx("div", { className: "text-muted-foreground text-[10px]", children: "commits" })] })] })] }) })) : warning ? (_jsx("div", { className: "border-border rounded-lg border", children: _jsxs("div", { className: "flex items-center gap-2 px-4 py-3", children: [_jsx(AlertTriangle, { className: "text-muted-foreground h-4 w-4 shrink-0" }), _jsx("span", { className: "text-muted-foreground text-xs", children: warning })] }) })) : null, evidence && evidence.length > 0 ? _jsx(EvidenceList, { evidence: evidence }) : null, fileDiffs && fileDiffs.length > 0 ? _jsx(DiffView, { fileDiffs: fileDiffs }) : null] }), !readOnly && (_jsx(DrawerActionBar, { onReject: onReject, onApprove: handleApproveOrResolve, approveLabel: hasConflicts ? 'Resolve Conflicts' : 'Approve Merge', approveVariant: hasConflicts ? 'warning' : 'default', revisionPlaceholder: "Ask AI to revise before merging...", isProcessing: isProcessing, isRejecting: isRejecting, chatInput: chatInput, onChatInputChange: onChatInputChange }))] }));
69
69
  }
@@ -3,7 +3,7 @@ import { fn } from '@storybook/test';
3
3
  import { PrStatus, CiStatus } from '../../../../../../packages/core/src/domain/generated/output.js';
4
4
  import { MergeReview } from './merge-review.js';
5
5
  const fullPr = {
6
- url: 'https://github.com/shep-ai/cli/pull/42',
6
+ url: 'https://github.com/shep-ai/shep/pull/42',
7
7
  number: 42,
8
8
  status: PrStatus.Open,
9
9
  commitHash: 'a1b2c3d4e5f6789',
@@ -33,14 +33,14 @@ export function PrdQuestionnaire({ data, selections, onSelect, onApprove, onReje
33
33
  } }, q.id))) })] }), _jsx("div", { className: "space-y-2", children: currentQuestion.options.map((opt, optIdx) => {
34
34
  const selected = selections[currentQuestion.id] === opt.id;
35
35
  const letter = String.fromCharCode(65 + optIdx);
36
- return (_jsx("button", { type: "button", className: cn('border-border w-full overflow-hidden rounded-md border px-3 py-3 text-left text-xs transition-all', 'hover:border-primary/70 hover:bg-primary/5 group', selected && 'border-primary bg-primary/5', opt.isNew && 'animate-option-highlight'), disabled: isProcessing, onClick: () => handleSelect(currentQuestion.id, opt.id), children: _jsxs("div", { className: "flex items-start gap-2", children: [_jsxs("span", { className: "text-muted-foreground mt-0.5 font-mono text-xs", children: [letter, "."] }), _jsxs("div", { className: "min-w-0 flex-1", children: [_jsx("div", { className: "text-foreground mb-0.5 text-xs font-semibold wrap-break-word", children: opt.label }), _jsx("div", { className: "text-muted-foreground text-xs leading-snug", children: opt.rationale })] }), opt.recommended || opt.isNew ? (_jsx("div", { className: "shrink-0 pt-0.5", children: opt.recommended ? (_jsx(Badge, { className: "px-1.5 py-0 text-[10px] whitespace-nowrap", children: "AI Recommended" })) : (_jsx(Badge, { className: "border-transparent bg-emerald-600 px-1.5 py-0 text-[10px] whitespace-nowrap text-white hover:bg-emerald-600/80", children: "New" })) })) : null] }) }, opt.id));
36
+ return (_jsx("button", { type: "button", className: cn('border-border w-full overflow-hidden rounded-md border px-3 py-3 text-start text-xs transition-all', 'hover:border-primary/70 hover:bg-primary/5 group', selected && 'border-primary bg-primary/5', opt.isNew && 'animate-option-highlight'), disabled: isProcessing, onClick: () => handleSelect(currentQuestion.id, opt.id), children: _jsxs("div", { className: "flex items-start gap-2", children: [_jsxs("span", { className: "text-muted-foreground mt-0.5 font-mono text-xs", children: [letter, "."] }), _jsxs("div", { className: "min-w-0 flex-1", children: [_jsx("div", { className: "text-foreground mb-0.5 text-xs font-semibold wrap-break-word", children: opt.label }), _jsx("div", { className: "text-muted-foreground text-xs leading-snug", children: opt.rationale })] }), opt.recommended || opt.isNew ? (_jsx("div", { className: "shrink-0 pt-0.5", children: opt.recommended ? (_jsx(Badge, { className: "px-1.5 py-0 text-[10px] whitespace-nowrap", children: "AI Recommended" })) : (_jsx(Badge, { className: "border-transparent bg-emerald-600 px-1.5 py-0 text-[10px] whitespace-nowrap text-white hover:bg-emerald-600/80", children: "New" })) })) : null] }) }, opt.id));
37
37
  }) })] }), _jsxs("div", { className: "flex items-center justify-between pt-2", children: [_jsxs(Button, { type: "button", variant: "ghost", size: "sm", disabled: isFirstStep || isProcessing, onClick: () => {
38
38
  navigateSound.play();
39
39
  setCurrentStep((s) => s - 1);
40
- }, children: [_jsx(ChevronLeft, { className: "mr-1 h-4 w-4" }), "Previous"] }), !isLastStep ? (_jsxs(Button, { type: "button", variant: "ghost", size: "sm", disabled: isProcessing, onClick: () => {
40
+ }, children: [_jsx(ChevronLeft, { className: "me-1 h-4 w-4" }), "Previous"] }), !isLastStep ? (_jsxs(Button, { type: "button", variant: "ghost", size: "sm", disabled: isProcessing, onClick: () => {
41
41
  navigateSound.play();
42
42
  setCurrentStep((s) => s + 1);
43
- }, children: [selections[currentQuestion.id] ? 'Next' : 'Skip', _jsx(ChevronRight, { className: "ml-1 h-4 w-4" })] })) : null] })] }), _jsx(DrawerActionBar, { onReject: onReject, onApprove: () => onApprove(finalAction.id), approveLabel: finalAction.label, revisionPlaceholder: "Ask AI to refine requirements...", isProcessing: isProcessing, isRejecting: isRejecting, chatInput: chatInput, onChatInputChange: onChatInputChange, children: _jsx("div", { className: cn('bg-muted h-1.5 overflow-hidden', (answeredCount > 0 && answeredCount < total) || isProcessing
43
+ }, children: [selections[currentQuestion.id] ? 'Next' : 'Skip', _jsx(ChevronRight, { className: "ms-1 h-4 w-4" })] })) : null] })] }), _jsx(DrawerActionBar, { onReject: onReject, onApprove: () => onApprove(finalAction.id), approveLabel: finalAction.label, revisionPlaceholder: "Ask AI to refine requirements...", isProcessing: isProcessing, isRejecting: isRejecting, chatInput: chatInput, onChatInputChange: onChatInputChange, children: _jsx("div", { className: cn('bg-muted h-1.5 overflow-hidden', (answeredCount > 0 && answeredCount < total) || isProcessing
44
44
  ? 'opacity-100'
45
45
  : 'opacity-0', 'transition-opacity duration-200'), "data-testid": "progress-bar-container", children: isProcessing ? (_jsx("div", { className: "bg-primary animate-indeterminate-progress h-full w-1/3" })) : (_jsx("div", { className: "bg-primary h-full transition-all duration-300", style: { width: `${total > 0 ? (answeredCount / total) * 100 : 0}%` }, "data-testid": "progress-bar" })) }) })] }));
46
46
  }
@@ -1 +1 @@
1
- {"version":3,"file":"reject-feedback-dialog.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/reject-feedback-dialog/reject-feedback-dialog.tsx"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAMjF,wBAAgB,oBAAoB,CAAC,EACnC,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,KAAqB,EACrB,WAAiC,GAClC,EAAE,yBAAyB,2CAkD3B"}
1
+ {"version":3,"file":"reject-feedback-dialog.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/reject-feedback-dialog/reject-feedback-dialog.tsx"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAEjF,wBAAgB,oBAAoB,CAAC,EACnC,IAAI,EACJ,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,KAAK,EACL,WAAW,GACZ,EAAE,yBAAyB,2CAqD3B"}
@@ -2,11 +2,13 @@
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';
5
6
  import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, } from '../../ui/alert-dialog.js';
6
7
  import { Textarea } from '../../ui/textarea.js';
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, }) {
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');
10
12
  const [feedback, setFeedback] = useState('');
11
13
  // Reset feedback when dialog opens
12
14
  useEffect(() => {
@@ -15,5 +17,5 @@ export function RejectFeedbackDialog({ open, onOpenChange, onConfirm, isSubmitti
15
17
  }
16
18
  }, [open]);
17
19
  const isFeedbackEmpty = feedback.trim().length === 0;
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') })] })] }) }));
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')) })] })] }) }));
19
21
  }
@@ -14,8 +14,8 @@ const meta = {
14
14
  export default meta;
15
15
  const repoData = {
16
16
  id: 'repo-1',
17
- name: 'shep-ai/cli',
18
- repositoryPath: '/home/user/shep-ai/cli',
17
+ name: 'shep-ai/shep',
18
+ repositoryPath: '/home/user/shep-ai/shep',
19
19
  };
20
20
  function DrawerTrigger({ data, label }) {
21
21
  const [selected, setSelected] = useState(null);
@@ -27,7 +27,7 @@ export const Default = {
27
27
  export const LongPath = {
28
28
  render: () => (_jsx(DrawerTrigger, { data: {
29
29
  ...repoData,
30
- repositoryPath: '/home/user/projects/company/some-very-long-path/shep-ai/cli',
30
+ repositoryPath: '/home/user/projects/company/some-very-long-path/shep-ai/shep',
31
31
  }, label: "Open Long Path" })),
32
32
  };
33
33
  export const WithoutPath = {
@@ -3,7 +3,7 @@ export interface RepositoryNodeData {
3
3
  [key: string]: unknown;
4
4
  /** Repository domain entity ID (UUID), used for delete operations */
5
5
  id?: string;
6
- /** Repository name, e.g. "shep-ai/cli" */
6
+ /** Repository name, e.g. "shep-ai/shep" */
7
7
  name: string;
8
8
  /** Absolute path to the repository root, used for IDE/shell actions */
9
9
  repositoryPath?: string;
@@ -1 +1 @@
1
- {"version":3,"file":"repository-node-config.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/repository-node/repository-node-config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,WAAW,kBAAkB;IACjC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;IACvB,qEAAqE;IACrE,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,0CAA0C;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,uEAAuE;IACvE,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,yEAAyE;IACzE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,+DAA+D;IAC/D,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,0DAA0D;IAC1D,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,oDAAoD;IACpD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,+GAA+G;IAC/G,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,oHAAoH;IACpH,aAAa,CAAC,EAAE,SAAS,GAAG,OAAO,GAAG,YAAY,CAAC;IACnD,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,IAAI,CAAC;IACnB,QAAQ,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,+EAA+E;IAC/E,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,MAAM,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAC"}
1
+ {"version":3,"file":"repository-node-config.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/repository-node/repository-node-config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,WAAW,kBAAkB;IACjC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;IACvB,qEAAqE;IACrE,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,2CAA2C;IAC3C,IAAI,EAAE,MAAM,CAAC;IACb,uEAAuE;IACvE,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,yEAAyE;IACzE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,+DAA+D;IAC/D,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,0DAA0D;IAC1D,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,oDAAoD;IACpD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,+GAA+G;IAC/G,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,oHAAoH;IACpH,aAAa,CAAC,EAAE,SAAS,GAAG,OAAO,GAAG,YAAY,CAAC;IACnD,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,IAAI,CAAC;IACnB,QAAQ,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,+EAA+E;IAC/E,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,MAAM,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"repository-node.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/repository-node/repository-node.tsx"],"names":[],"mappings":"AAoCA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AASnE,wBAAgB,cAAc,CAAC,EAC7B,IAAI,EACJ,QAAQ,GACT,EAAE;IACD,IAAI,EAAE,kBAAkB,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB,2CAgcA"}
1
+ {"version":3,"file":"repository-node.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/repository-node/repository-node.tsx"],"names":[],"mappings":"AAqCA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AASnE,wBAAgB,cAAc,CAAC,EAC7B,IAAI,EACJ,QAAQ,GACT,EAAE;IACD,IAAI,EAAE,kBAAkB,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB,2CAwcA"}
@@ -4,6 +4,7 @@ import { useState, useCallback } from 'react';
4
4
  import { Handle, Position } from '@xyflow/react';
5
5
  import { useRouter } from 'next/navigation';
6
6
  import { Github, Plus, Code2, Terminal, FolderOpen, Trash2, Play, Square, GitBranch, GitCommitHorizontal, ArrowDown, User, RotateCcw, MessageSquare, } from 'lucide-react';
7
+ import { useTranslation } from 'react-i18next';
7
8
  import { cn } from '../../../lib/utils.js';
8
9
  import { ActionButton } from '../../common/action-button/index.js';
9
10
  import { Dialog, DialogClose, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, } from '../../ui/dialog.js';
@@ -16,7 +17,11 @@ import { ChatDotIndicator } from '../../features/chat/ChatDotIndicator.js';
16
17
  import { useTurnStatus } from '../../../hooks/turn-statuses-provider.js';
17
18
  import { FeatureSessionsDropdown, } from '../../common/feature-node/feature-sessions-dropdown.js';
18
19
  export function RepositoryNode({ data, selected, }) {
20
+ const { t, i18n } = useTranslation('web');
19
21
  const router = useRouter();
22
+ const isRtl = i18n.dir() === 'rtl';
23
+ const targetHandlePos = isRtl ? Position.Right : Position.Left;
24
+ const sourceHandlePos = isRtl ? Position.Left : Position.Right;
20
25
  const featureFlags = useFeatureFlags();
21
26
  const [confirmOpen, setConfirmOpen] = useState(false);
22
27
  const repoScopeId = data.id ? `repo-${data.id}` : `repo-${data.name}`;
@@ -60,13 +65,13 @@ export function RepositoryNode({ data, selected, }) {
60
65
  });
61
66
  router.push(`/create?${params.toString()}`);
62
67
  }, [data.repositoryPath, router]);
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) => {
68
+ return (_jsxs("div", { className: cn('group relative', data.onDelete && data.id && 'ps-10'), style: { direction: isRtl ? 'rtl' : 'ltr' }, children: [data.showHandles ? (_jsx(Handle, { type: "target", position: targetHandlePos, isConnectable: false, className: "opacity-0!", style: { top: 70 } })) : null, data.onDelete && data.id ? (_jsxs(_Fragment, { children: [_jsx("div", { className: "absolute -start-3 top-1/2 -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": t('repositoryNode.removeRepository'), "data-testid": "repository-node-delete-button", onClick: (e) => {
64
69
  e.stopPropagation();
65
70
  setConfirmOpen(true);
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: () => {
71
+ }, 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: t('repositoryNode.removeRepository') })] }) }) }), _jsx(Dialog, { open: confirmOpen, onOpenChange: setConfirmOpen, children: _jsxs(DialogContent, { className: "max-w-xs", children: [_jsxs(DialogHeader, { children: [_jsx(DialogTitle, { children: t('repositoryNode.removeConfirmTitle') }), _jsx(DialogDescription, { children: t('repositoryNode.removeConfirmDescription', { name: data.name }) })] }), _jsxs(DialogFooter, { className: "grid grid-cols-2 gap-2 sm:flex-none", children: [_jsx(DialogClose, { asChild: true, children: _jsx(Button, { variant: "outline", children: t('repositoryNode.cancel') }) }), _jsx(Button, { variant: "destructive", onClick: () => {
67
72
  setConfirmOpen(false);
68
73
  data.onDelete?.(data.id);
69
- }, children: "Remove" })] })] }) })] })) : null, _jsxs("div", { role: "button", tabIndex: 0, "data-testid": "repository-node-card", "data-repo-name": data.name, onClick: (e) => {
74
+ }, children: t('repositoryNode.remove') })] })] }) })] })) : null, _jsxs("div", { role: "button", tabIndex: 0, "data-testid": "repository-node-card", "data-repo-name": data.name, onClick: (e) => {
70
75
  e.stopPropagation();
71
76
  data.onClick?.();
72
77
  }, onKeyDown: (e) => {
@@ -75,22 +80,24 @@ export function RepositoryNode({ data, selected, }) {
75
80
  e.stopPropagation();
76
81
  data.onClick?.();
77
82
  }
78
- }, className: cn('nodrag bg-card flex w-[26rem] cursor-pointer flex-col overflow-hidden rounded-xl border shadow-sm transition-[border-color,box-shadow] duration-200 dark:bg-neutral-800/80', selected && 'border-blue-400 dark:border-amber-500/60'), children: [_jsxs("div", { className: "flex items-center gap-3 px-4 py-3", children: [_jsx(Github, { className: "text-muted-foreground h-5 w-5 shrink-0" }), _jsx("span", { "data-testid": "repository-node-name", className: "min-w-0 truncate text-sm font-medium", children: data.name }), _jsxs("div", { className: cn('flex shrink-0 items-center gap-2', (data.repositoryPath ?? data.onAdd) && 'ml-auto'), onClick: (e) => e.stopPropagation(), children: [data.repositoryPath ? (_jsxs(_Fragment, { children: [_jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: "flex items-center", children: _jsx(ActionButton, { label: "Open in IDE", onClick: actions.openInIde, loading: actions.ideLoading, error: !!actions.ideError, icon: Code2, iconOnly: true, variant: "ghost", size: "icon-xs" }) }) }), _jsx(TooltipContent, { children: "Open in IDE" })] }) }), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: "flex items-center", children: _jsx(ActionButton, { label: "Open in Shell", onClick: actions.openInShell, loading: actions.shellLoading, error: !!actions.shellError, icon: Terminal, iconOnly: true, variant: "ghost", size: "icon-xs" }) }) }), _jsx(TooltipContent, { children: "Open in Shell" })] }) }), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: "flex items-center", children: _jsx(ActionButton, { label: "Open Folder", onClick: actions.openFolder, loading: actions.folderLoading, error: !!actions.folderError, icon: FolderOpen, iconOnly: true, variant: "ghost", size: "icon-xs" }) }) }), _jsx(TooltipContent, { children: "Open Folder" })] }) }), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs(Button, { variant: "ghost", size: "icon-xs", "aria-label": "Chat with agent", onClick: (e) => {
83
+ }, className: cn('nodrag bg-card flex w-[26rem] cursor-pointer flex-col overflow-hidden rounded-xl border shadow-sm transition-[border-color,box-shadow] duration-200 dark:bg-neutral-800/80', selected && 'border-blue-400 dark:border-amber-500/60'), children: [_jsxs("div", { className: "flex items-center gap-3 px-4 py-3", children: [_jsx(Github, { className: "text-muted-foreground h-5 w-5 shrink-0" }), _jsx("span", { "data-testid": "repository-node-name", className: "min-w-0 truncate text-sm font-medium", children: data.name }), _jsxs("div", { className: cn('flex shrink-0 items-center gap-2', (data.repositoryPath ?? data.onAdd) && 'ms-auto'), onClick: (e) => e.stopPropagation(), children: [data.repositoryPath ? (_jsxs(_Fragment, { children: [_jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: "flex items-center", children: _jsx(ActionButton, { label: t('repositoryNode.openInIde'), onClick: actions.openInIde, loading: actions.ideLoading, error: !!actions.ideError, icon: Code2, iconOnly: true, variant: "ghost", size: "icon-xs" }) }) }), _jsx(TooltipContent, { children: t('repositoryNode.openInIde') })] }) }), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: "flex items-center", children: _jsx(ActionButton, { label: t('repositoryNode.openInShell'), onClick: actions.openInShell, loading: actions.shellLoading, error: !!actions.shellError, icon: Terminal, iconOnly: true, variant: "ghost", size: "icon-xs" }) }) }), _jsx(TooltipContent, { children: t('repositoryNode.openInShell') })] }) }), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: "flex items-center", children: _jsx(ActionButton, { label: t('repositoryNode.openFolder'), onClick: actions.openFolder, loading: actions.folderLoading, error: !!actions.folderError, icon: FolderOpen, iconOnly: true, variant: "ghost", size: "icon-xs" }) }) }), _jsx(TooltipContent, { children: t('repositoryNode.openFolder') })] }) }), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsxs(Button, { variant: "ghost", size: "icon-xs", "aria-label": t('repositoryNode.chatWithAgent'), onClick: (e) => {
79
84
  e.stopPropagation();
80
85
  if (data.id)
81
86
  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: "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) => {
87
+ }, 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: t('repositoryNode.chatWithAgent') })] }) }), _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": t('repositoryNode.newFeature'), "data-testid": "repository-node-add-button", onClick: (e) => {
83
88
  e.stopPropagation();
84
89
  data.onAdd?.();
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' ? (
90
+ }, 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: t('repositoryNode.new') })] }) }), _jsx(TooltipContent, { side: "top", children: t('repositoryNode.newFeature') })] }) })) : 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" }), t('repositoryNode.behind', { count: data.behindCount })] })) : 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 ms-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
91
  /* Not a git repo — two rows for consistency with loading/ready states */
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' ? (
92
+ _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: t('repositoryNode.notAGitRepository') })] }) })] })) : data.gitInfoStatus !== 'ready' ? (
88
93
  /* 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: "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 &&
94
+ _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: t('repositoryNode.starting') }))] })) : (_jsxs("span", { className: "text-muted-foreground inline-flex items-baseline gap-2", children: [_jsx("span", { children: t('repositoryNode.run') }), _jsx("span", { className: "text-muted-foreground/50 text-[10px]", children: t('repositoryNode.startLocalEnvironment') })] })), _jsx(TooltipProvider, { children: _jsxs(Tooltip, { children: [_jsx(TooltipTrigger, { asChild: true, children: _jsx("span", { className: cn('ms-auto flex items-center', !isDeploymentActive &&
90
95
  !deployAction.deployError &&
91
96
  '[&_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
- ? 'Retry'
97
+ ? t('repositoryNode.retry')
93
98
  : isDeploymentActive
94
- ? 'Stop Dev Server'
95
- : 'Start Dev Server', onClick: isDeploymentActive ? deployAction.stop : deployAction.deploy, loading: deployAction.deployLoading || deployAction.stopLoading, error: false, icon: deployAction.deployError ? RotateCcw : isDeploymentActive ? Square : Play, iconOnly: true, variant: "ghost", size: "icon-xs" }) }) }), _jsx(TooltipContent, { children: isDeploymentActive ? 'Stop Dev Server' : 'Start Dev Server' })] }) })] }) })) : null] }), data.onAdd || data.showHandles ? (_jsx(Handle, { type: "source", position: Position.Right, isConnectable: !data.showHandles, className: "opacity-0!", style: { top: 70 } })) : null] }));
99
+ ? t('repositoryNode.stopDevServer')
100
+ : t('repositoryNode.startDevServer'), onClick: isDeploymentActive ? deployAction.stop : deployAction.deploy, loading: deployAction.deployLoading || deployAction.stopLoading, error: false, icon: deployAction.deployError ? RotateCcw : isDeploymentActive ? Square : Play, iconOnly: true, variant: "ghost", size: "icon-xs" }) }) }), _jsx(TooltipContent, { children: isDeploymentActive
101
+ ? t('repositoryNode.stopDevServer')
102
+ : t('repositoryNode.startDevServer') })] }) })] }) })) : null] }), data.onAdd || data.showHandles ? (_jsx(Handle, { type: "source", position: sourceHandlePos, isConnectable: !data.showHandles, className: "opacity-0!", style: { top: 70 } })) : null] }));
96
103
  }
@@ -14,7 +14,7 @@ const meta = {
14
14
  layout: 'centered',
15
15
  },
16
16
  args: {
17
- name: 'shep-ai/cli',
17
+ name: 'shep-ai/shep',
18
18
  branch: 'main',
19
19
  commitMessage: 'feat: add dark mode toggle',
20
20
  committer: 'Jane Doe',
@@ -45,7 +45,7 @@ export const LongName = {
45
45
  const onAdd = () => undefined;
46
46
  const multipleRepos = [
47
47
  {
48
- name: 'shep-ai/cli',
48
+ name: 'shep-ai/shep',
49
49
  branch: 'main',
50
50
  commitMessage: 'feat: add dark mode toggle',
51
51
  committer: 'Jane Doe',
@@ -84,7 +84,7 @@ export const Multiple = {
84
84
  };
85
85
  const multipleReposWithButton = [
86
86
  {
87
- name: 'shep-ai/cli',
87
+ name: 'shep-ai/shep',
88
88
  onAdd,
89
89
  branch: 'main',
90
90
  commitMessage: 'feat: add dark mode toggle',
@@ -126,7 +126,7 @@ export const MultipleWithButton = {
126
126
  };
127
127
  export const WithPulseAdd = {
128
128
  args: {
129
- repositoryPath: '/home/user/shep-ai/cli',
129
+ repositoryPath: '/home/user/shep-ai/shep',
130
130
  pulseAdd: true,
131
131
  },
132
132
  argTypes: {
@@ -136,13 +136,13 @@ export const WithPulseAdd = {
136
136
  };
137
137
  export const WithActions = {
138
138
  args: {
139
- repositoryPath: '/home/user/shep-ai/cli',
139
+ repositoryPath: '/home/user/shep-ai/shep',
140
140
  },
141
141
  render: (args) => _jsx(RepositoryNodeCanvas, { data: args }),
142
142
  };
143
143
  export const WithActionsAndAddButton = {
144
144
  args: {
145
- repositoryPath: '/home/user/shep-ai/cli',
145
+ repositoryPath: '/home/user/shep-ai/shep',
146
146
  },
147
147
  argTypes: {
148
148
  onAdd: { action: 'onAdd' },
@@ -153,7 +153,7 @@ const onDelete = () => undefined;
153
153
  export const WithDeleteButton = {
154
154
  args: {
155
155
  id: 'repo-abc-123',
156
- repositoryPath: '/home/user/shep-ai/cli',
156
+ repositoryPath: '/home/user/shep-ai/shep',
157
157
  },
158
158
  argTypes: {
159
159
  onDelete: { action: 'onDelete' },
@@ -163,8 +163,8 @@ export const WithDeleteButton = {
163
163
  const multipleReposWithActions = [
164
164
  {
165
165
  id: 'r1',
166
- name: 'shep-ai/cli',
167
- repositoryPath: '/home/user/shep-ai/cli',
166
+ name: 'shep-ai/shep',
167
+ repositoryPath: '/home/user/shep-ai/shep',
168
168
  onAdd,
169
169
  onDelete,
170
170
  branch: 'main',
@@ -217,7 +217,7 @@ export const MultipleWithActions = {
217
217
  };
218
218
  export const WithGitInfo = {
219
219
  args: {
220
- repositoryPath: '/home/user/shep-ai/cli',
220
+ repositoryPath: '/home/user/shep-ai/shep',
221
221
  branch: 'feat/repo-node-enrichment',
222
222
  commitMessage: 'feat(web): enrich repository node with branch and commit info',
223
223
  committer: 'Ariel Shadkhan',
@@ -227,7 +227,7 @@ export const WithGitInfo = {
227
227
  };
228
228
  export const WithGitInfoBehind = {
229
229
  args: {
230
- repositoryPath: '/home/user/shep-ai/cli',
230
+ repositoryPath: '/home/user/shep-ai/shep',
231
231
  branch: 'feat/old-feature-branch',
232
232
  commitMessage: 'fix: resolve merge conflict in auth module',
233
233
  committer: 'Jane Doe',
@@ -237,7 +237,7 @@ export const WithGitInfoBehind = {
237
237
  };
238
238
  export const GitInfoLoading = {
239
239
  args: {
240
- repositoryPath: '/home/user/shep-ai/cli',
240
+ repositoryPath: '/home/user/shep-ai/shep',
241
241
  gitInfoStatus: 'loading',
242
242
  },
243
243
  render: (args) => _jsx(RepositoryNodeCanvas, { data: args }),
@@ -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 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]" }))] })] }) }));
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]" }))] })] }) }));
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 }) }));