@shepai/cli 1.145.0 → 1.146.0-pr437.aa23c1e

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 (349) hide show
  1. package/apis/json-schema/Feature.yaml +25 -0
  2. package/apis/json-schema/FeatureFlags.yaml +5 -0
  3. package/apis/json-schema/PullRequest.yaml +11 -0
  4. package/apis/json-schema/SdlcLifecycle.yaml +1 -0
  5. package/dist/packages/core/src/application/ports/output/agents/feature-agent-process.interface.d.ts +5 -0
  6. package/dist/packages/core/src/application/ports/output/agents/feature-agent-process.interface.d.ts.map +1 -1
  7. package/dist/packages/core/src/application/ports/output/services/coasts-service.interface.d.ts +132 -0
  8. package/dist/packages/core/src/application/ports/output/services/coasts-service.interface.d.ts.map +1 -0
  9. package/dist/packages/core/src/application/ports/output/services/coasts-service.interface.js +12 -0
  10. package/dist/packages/core/src/application/ports/output/services/git-fork-service.interface.d.ts +79 -0
  11. package/dist/packages/core/src/application/ports/output/services/git-fork-service.interface.d.ts.map +1 -0
  12. package/dist/packages/core/src/application/ports/output/services/git-fork-service.interface.js +31 -0
  13. package/dist/packages/core/src/application/ports/output/services/index.d.ts +1 -0
  14. package/dist/packages/core/src/application/ports/output/services/index.d.ts.map +1 -1
  15. package/dist/packages/core/src/application/use-cases/features/adopt-branch.use-case.d.ts.map +1 -1
  16. package/dist/packages/core/src/application/use-cases/features/adopt-branch.use-case.js +5 -0
  17. package/dist/packages/core/src/application/use-cases/features/create/create-feature.use-case.d.ts.map +1 -1
  18. package/dist/packages/core/src/application/use-cases/features/create/create-feature.use-case.js +10 -0
  19. package/dist/packages/core/src/application/use-cases/features/create/types.d.ts +10 -0
  20. package/dist/packages/core/src/application/use-cases/features/create/types.d.ts.map +1 -1
  21. package/dist/packages/core/src/application/use-cases/features/poll-upstream-pr.use-case.d.ts +23 -0
  22. package/dist/packages/core/src/application/use-cases/features/poll-upstream-pr.use-case.d.ts.map +1 -0
  23. package/dist/packages/core/src/application/use-cases/features/poll-upstream-pr.use-case.js +84 -0
  24. package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.d.ts.map +1 -1
  25. package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.js +2 -0
  26. package/dist/packages/core/src/domain/factories/settings-defaults.factory.d.ts.map +1 -1
  27. package/dist/packages/core/src/domain/factories/settings-defaults.factory.js +1 -0
  28. package/dist/packages/core/src/domain/generated/output.d.ts +37 -0
  29. package/dist/packages/core/src/domain/generated/output.d.ts.map +1 -1
  30. package/dist/packages/core/src/domain/generated/output.js +1 -0
  31. package/dist/packages/core/src/infrastructure/di/container.d.ts.map +1 -1
  32. package/dist/packages/core/src/infrastructure/di/container.js +12 -0
  33. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.d.ts +8 -0
  34. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.d.ts.map +1 -1
  35. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.js +18 -0
  36. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts +1 -0
  37. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts.map +1 -1
  38. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.js +2 -0
  39. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/044-add-feature-flag-coasts-dev-server.d.ts +11 -0
  40. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/044-add-feature-flag-coasts-dev-server.d.ts.map +1 -0
  41. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/044-add-feature-flag-coasts-dev-server.js +17 -0
  42. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/045-add-fork-and-pr-columns.d.ts +13 -0
  43. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/045-add-fork-and-pr-columns.d.ts.map +1 -0
  44. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/045-add-fork-and-pr-columns.js +30 -0
  45. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/046-add-per-feature-workflow-columns.d.ts +12 -0
  46. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/046-add-per-feature-workflow-columns.d.ts.map +1 -0
  47. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/046-add-per-feature-workflow-columns.js +23 -0
  48. package/dist/packages/core/src/infrastructure/repositories/sqlite-feature.repository.d.ts.map +1 -1
  49. package/dist/packages/core/src/infrastructure/repositories/sqlite-feature.repository.js +23 -4
  50. package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.d.ts.map +1 -1
  51. package/dist/packages/core/src/infrastructure/repositories/sqlite-settings.repository.js +3 -2
  52. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/fast-feature-agent-graph.d.ts +25 -0
  53. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/fast-feature-agent-graph.d.ts.map +1 -1
  54. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-graph.d.ts +85 -0
  55. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-graph.d.ts.map +1 -1
  56. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.d.ts +5 -0
  57. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.d.ts.map +1 -1
  58. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.js +15 -0
  59. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.d.ts +5 -0
  60. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.d.ts.map +1 -1
  61. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.js +23 -0
  62. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.d.ts +2 -0
  63. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.d.ts.map +1 -1
  64. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.js +50 -0
  65. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.d.ts +8 -0
  66. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.d.ts.map +1 -1
  67. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.js +40 -1
  68. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/analyze.prompt.d.ts.map +1 -1
  69. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/analyze.prompt.js +11 -9
  70. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/merge-prompts.d.ts.map +1 -1
  71. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/merge-prompts.js +5 -1
  72. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/plan.prompt.d.ts.map +1 -1
  73. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/plan.prompt.js +8 -6
  74. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/requirements.prompt.d.ts.map +1 -1
  75. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/requirements.prompt.js +11 -9
  76. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/research.prompt.d.ts.map +1 -1
  77. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/prompts/research.prompt.js +8 -6
  78. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/schemas/spec.schema.d.ts.map +1 -1
  79. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/schemas/spec.schema.js +3 -1
  80. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/schemas/validation.d.ts +1 -0
  81. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/schemas/validation.d.ts.map +1 -1
  82. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/schemas/validation.js +9 -0
  83. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.d.ts +5 -0
  84. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.d.ts.map +1 -1
  85. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.js +20 -0
  86. package/dist/packages/core/src/infrastructure/services/coasts.service.d.ts +42 -0
  87. package/dist/packages/core/src/infrastructure/services/coasts.service.d.ts.map +1 -0
  88. package/dist/packages/core/src/infrastructure/services/coasts.service.js +185 -0
  89. package/dist/packages/core/src/infrastructure/services/git/git-fork.service.d.ts +25 -0
  90. package/dist/packages/core/src/infrastructure/services/git/git-fork.service.d.ts.map +1 -0
  91. package/dist/packages/core/src/infrastructure/services/git/git-fork.service.js +145 -0
  92. package/dist/packages/core/src/infrastructure/services/pr-sync/pr-sync-watcher.service.d.ts +17 -3
  93. package/dist/packages/core/src/infrastructure/services/pr-sync/pr-sync-watcher.service.d.ts.map +1 -1
  94. package/dist/packages/core/src/infrastructure/services/pr-sync/pr-sync-watcher.service.js +98 -15
  95. package/dist/src/presentation/cli/commands/coasts/index.d.ts +3 -0
  96. package/dist/src/presentation/cli/commands/coasts/index.d.ts.map +1 -0
  97. package/dist/src/presentation/cli/commands/coasts/index.js +7 -0
  98. package/dist/src/presentation/cli/commands/coasts/init.command.d.ts +3 -0
  99. package/dist/src/presentation/cli/commands/coasts/init.command.d.ts.map +1 -0
  100. package/dist/src/presentation/cli/commands/coasts/init.command.js +40 -0
  101. package/dist/src/presentation/cli/commands/ui.command.d.ts.map +1 -1
  102. package/dist/src/presentation/cli/commands/ui.command.js +2 -1
  103. package/dist/src/presentation/cli/index.js +2 -0
  104. package/dist/src/presentation/web/app/actions/check-coastfile.d.ts +5 -0
  105. package/dist/src/presentation/web/app/actions/check-coastfile.d.ts.map +1 -0
  106. package/dist/src/presentation/web/app/actions/check-coastfile.js +16 -0
  107. package/dist/src/presentation/web/app/actions/create-feature.d.ts +10 -0
  108. package/dist/src/presentation/web/app/actions/create-feature.d.ts.map +1 -1
  109. package/dist/src/presentation/web/app/actions/create-feature.js +8 -1
  110. package/dist/src/presentation/web/app/actions/generate-coastfile.d.ts +7 -0
  111. package/dist/src/presentation/web/app/actions/generate-coastfile.d.ts.map +1 -0
  112. package/dist/src/presentation/web/app/actions/generate-coastfile.js +22 -0
  113. package/dist/src/presentation/web/app/api/agent-events/route.d.ts.map +1 -1
  114. package/dist/src/presentation/web/app/api/agent-events/route.js +1 -0
  115. package/dist/src/presentation/web/app/build-feature-node-data.d.ts.map +1 -1
  116. package/dist/src/presentation/web/app/build-feature-node-data.js +5 -3
  117. package/dist/src/presentation/web/app/build-graph-nodes.js +5 -3
  118. package/dist/src/presentation/web/coasts-dev-server.d.ts +34 -0
  119. package/dist/src/presentation/web/coasts-dev-server.d.ts.map +1 -0
  120. package/dist/src/presentation/web/coasts-dev-server.js +69 -0
  121. package/dist/src/presentation/web/components/common/base-drawer/base-drawer.js +1 -1
  122. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts +4 -0
  123. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts.map +1 -1
  124. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.js +24 -7
  125. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.stories.d.ts +12 -0
  126. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.stories.d.ts.map +1 -1
  127. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.stories.js +35 -0
  128. package/dist/src/presentation/web/components/common/feature-drawer-tabs/overview-tab.js +7 -1
  129. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts +5 -1
  130. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts.map +1 -1
  131. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.js +12 -0
  132. package/dist/src/presentation/web/components/common/feature-node/feature-node.stories.d.ts.map +1 -1
  133. package/dist/src/presentation/web/components/common/feature-node/feature-node.stories.js +1 -0
  134. package/dist/src/presentation/web/components/common/repository-node/repository-drawer.stories.d.ts.map +1 -1
  135. package/dist/src/presentation/web/components/common/repository-node/repository-drawer.stories.js +1 -0
  136. package/dist/src/presentation/web/components/common/repository-node/repository-node.d.ts.map +1 -1
  137. package/dist/src/presentation/web/components/common/repository-node/repository-node.js +9 -2
  138. package/dist/src/presentation/web/components/common/repository-node/use-coasts-actions.d.ts +12 -0
  139. package/dist/src/presentation/web/components/common/repository-node/use-coasts-actions.d.ts.map +1 -0
  140. package/dist/src/presentation/web/components/common/repository-node/use-coasts-actions.js +76 -0
  141. package/dist/src/presentation/web/components/features/settings/feature-flags-settings-section.d.ts.map +1 -1
  142. package/dist/src/presentation/web/components/features/settings/feature-flags-settings-section.js +3 -0
  143. package/dist/src/presentation/web/components/features/settings/feature-flags-settings-section.stories.d.ts.map +1 -1
  144. package/dist/src/presentation/web/components/features/settings/feature-flags-settings-section.stories.js +3 -0
  145. package/dist/src/presentation/web/components/features/settings/settings-page-client.d.ts.map +1 -1
  146. package/dist/src/presentation/web/components/features/settings/settings-page-client.js +5 -0
  147. package/dist/src/presentation/web/components/features/settings/settings-page-client.stories.d.ts.map +1 -1
  148. package/dist/src/presentation/web/components/features/settings/settings-page-client.stories.js +1 -0
  149. package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.stories.d.ts.map +1 -1
  150. package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.stories.js +1 -0
  151. package/dist/src/presentation/web/dev-server.js +64 -2
  152. package/dist/src/presentation/web/hooks/feature-flags-context.d.ts.map +1 -1
  153. package/dist/src/presentation/web/hooks/feature-flags-context.js +1 -0
  154. package/dist/src/presentation/web/lib/feature-flags.d.ts +2 -0
  155. package/dist/src/presentation/web/lib/feature-flags.d.ts.map +1 -1
  156. package/dist/src/presentation/web/lib/feature-flags.js +5 -0
  157. package/dist/tsconfig.build.tsbuildinfo +1 -1
  158. package/package.json +2 -1
  159. package/web/.next/BUILD_ID +1 -1
  160. package/web/.next/build-manifest.json +2 -2
  161. package/web/.next/fallback-build-manifest.json +2 -2
  162. package/web/.next/prerender-manifest.json +3 -3
  163. package/web/.next/required-server-files.js +3 -3
  164. package/web/.next/required-server-files.json +3 -3
  165. package/web/.next/server/app/(dashboard)/@drawer/adopt/page/server-reference-manifest.json +86 -56
  166. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js +1 -1
  167. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js.nft.json +1 -1
  168. package/web/.next/server/app/(dashboard)/@drawer/adopt/page_client-reference-manifest.js +1 -1
  169. package/web/.next/server/app/(dashboard)/@drawer/create/page/server-reference-manifest.json +86 -56
  170. package/web/.next/server/app/(dashboard)/@drawer/create/page.js +1 -1
  171. package/web/.next/server/app/(dashboard)/@drawer/create/page.js.nft.json +1 -1
  172. package/web/.next/server/app/(dashboard)/@drawer/create/page_client-reference-manifest.js +1 -1
  173. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page/server-reference-manifest.json +102 -72
  174. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js +1 -1
  175. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  176. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  177. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page/server-reference-manifest.json +102 -72
  178. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js +1 -1
  179. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js.nft.json +1 -1
  180. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page_client-reference-manifest.js +1 -1
  181. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page/server-reference-manifest.json +82 -52
  182. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js +1 -1
  183. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js.nft.json +1 -1
  184. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  185. package/web/.next/server/app/(dashboard)/create/page/server-reference-manifest.json +86 -56
  186. package/web/.next/server/app/(dashboard)/create/page.js +1 -1
  187. package/web/.next/server/app/(dashboard)/create/page.js.nft.json +1 -1
  188. package/web/.next/server/app/(dashboard)/create/page_client-reference-manifest.js +1 -1
  189. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page/server-reference-manifest.json +102 -72
  190. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js +1 -1
  191. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  192. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  193. package/web/.next/server/app/(dashboard)/feature/[featureId]/page/server-reference-manifest.json +102 -72
  194. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js +1 -1
  195. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js.nft.json +1 -1
  196. package/web/.next/server/app/(dashboard)/feature/[featureId]/page_client-reference-manifest.js +1 -1
  197. package/web/.next/server/app/(dashboard)/page/server-reference-manifest.json +82 -52
  198. package/web/.next/server/app/(dashboard)/page.js +1 -1
  199. package/web/.next/server/app/(dashboard)/page.js.nft.json +1 -1
  200. package/web/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
  201. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page/server-reference-manifest.json +82 -52
  202. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js +1 -1
  203. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js.nft.json +1 -1
  204. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  205. package/web/.next/server/app/_global-error.html +2 -2
  206. package/web/.next/server/app/_global-error.rsc +1 -1
  207. package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  208. package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  209. package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  210. package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  211. package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  212. package/web/.next/server/app/_not-found/page/server-reference-manifest.json +3 -3
  213. package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  214. package/web/.next/server/app/api/attachments/preview/route.js.nft.json +1 -1
  215. package/web/.next/server/app/api/evidence/route.js.nft.json +1 -1
  216. package/web/.next/server/app/api/graph-data/route.js.nft.json +1 -1
  217. package/web/.next/server/app/api/sessions/route.js.nft.json +1 -1
  218. package/web/.next/server/app/settings/page/server-reference-manifest.json +8 -8
  219. package/web/.next/server/app/settings/page.js.nft.json +1 -1
  220. package/web/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  221. package/web/.next/server/app/skills/page/server-reference-manifest.json +8 -8
  222. package/web/.next/server/app/skills/page.js.nft.json +1 -1
  223. package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
  224. package/web/.next/server/app/tools/page/server-reference-manifest.json +8 -8
  225. package/web/.next/server/app/tools/page.js.nft.json +1 -1
  226. package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
  227. package/web/.next/server/app/version/page/server-reference-manifest.json +3 -3
  228. package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
  229. package/web/.next/server/chunks/403f9_next_567de315._.js +2 -2
  230. package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_370c43b1.js +1 -1
  231. package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_370c43b1.js.map +1 -1
  232. package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_4d623b8e.js +2 -2
  233. package/web/.next/server/chunks/403f9_next_dist_esm_build_templates_app-route_4d623b8e.js.map +1 -1
  234. package/web/.next/server/chunks/[root-of-the-server]__a402b567._.js +1 -1
  235. package/web/.next/server/chunks/[root-of-the-server]__c6e32a23._.js +1 -1
  236. package/web/.next/server/chunks/[root-of-the-server]__c6e32a23._.js.map +1 -1
  237. package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js +1 -1
  238. package/web/.next/server/chunks/[root-of-the-server]__cd67a84c._.js.map +1 -1
  239. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js +1 -1
  240. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js.map +1 -1
  241. package/web/.next/server/chunks/ssr/[root-of-the-server]__0b150ddf._.js +1 -1
  242. package/web/.next/server/chunks/ssr/[root-of-the-server]__0b150ddf._.js.map +1 -1
  243. package/web/.next/server/chunks/ssr/[root-of-the-server]__2138fa7e._.js +2 -2
  244. package/web/.next/server/chunks/ssr/[root-of-the-server]__2138fa7e._.js.map +1 -1
  245. package/web/.next/server/chunks/ssr/[root-of-the-server]__357d99f9._.js +1 -1
  246. package/web/.next/server/chunks/ssr/[root-of-the-server]__3ef34e4c._.js +1 -1
  247. package/web/.next/server/chunks/ssr/[root-of-the-server]__43f51aa6._.js +1 -1
  248. package/web/.next/server/chunks/ssr/[root-of-the-server]__43f51aa6._.js.map +1 -1
  249. package/web/.next/server/chunks/ssr/[root-of-the-server]__581769f7._.js +4 -0
  250. package/web/.next/server/chunks/ssr/[root-of-the-server]__581769f7._.js.map +1 -0
  251. package/web/.next/server/chunks/ssr/[root-of-the-server]__6df523d1._.js +4 -0
  252. package/web/.next/server/chunks/ssr/[root-of-the-server]__6df523d1._.js.map +1 -0
  253. package/web/.next/server/chunks/ssr/[root-of-the-server]__8004c676._.js +4 -0
  254. package/web/.next/server/chunks/ssr/[root-of-the-server]__8004c676._.js.map +1 -0
  255. package/web/.next/server/chunks/ssr/[root-of-the-server]__815546bd._.js +1 -1
  256. package/web/.next/server/chunks/ssr/[root-of-the-server]__815546bd._.js.map +1 -1
  257. package/web/.next/server/chunks/ssr/[root-of-the-server]__815f85e7._.js +4 -0
  258. package/web/.next/server/chunks/ssr/[root-of-the-server]__815f85e7._.js.map +1 -0
  259. package/web/.next/server/chunks/ssr/[root-of-the-server]__aad040c0._.js +2 -2
  260. package/web/.next/server/chunks/ssr/[root-of-the-server]__aad040c0._.js.map +1 -1
  261. package/web/.next/server/chunks/ssr/[root-of-the-server]__d48c5b11._.js +1 -1
  262. package/web/.next/server/chunks/ssr/[root-of-the-server]__d48c5b11._.js.map +1 -1
  263. package/web/.next/server/chunks/ssr/[root-of-the-server]__df7c1cd3._.js +3 -0
  264. package/web/.next/server/chunks/ssr/[root-of-the-server]__df7c1cd3._.js.map +1 -0
  265. package/web/.next/server/chunks/ssr/_0020fddd._.js +1 -1
  266. package/web/.next/server/chunks/ssr/_0020fddd._.js.map +1 -1
  267. package/web/.next/server/chunks/ssr/{_0c5f56e3._.js → _45117016._.js} +3 -3
  268. package/web/.next/server/chunks/ssr/{_0c5f56e3._.js.map → _45117016._.js.map} +1 -1
  269. package/web/.next/server/chunks/ssr/_4b432739._.js +1 -1
  270. package/web/.next/server/chunks/ssr/_4b432739._.js.map +1 -1
  271. package/web/.next/server/chunks/ssr/_6256a985._.js +1 -1
  272. package/web/.next/server/chunks/ssr/_6256a985._.js.map +1 -1
  273. package/web/.next/server/chunks/ssr/{_1fa6f5f0._.js → _7b12d338._.js} +2 -2
  274. package/web/.next/server/chunks/ssr/{_1fa6f5f0._.js.map → _7b12d338._.js.map} +1 -1
  275. package/web/.next/server/chunks/ssr/_7dca1882._.js +1 -1
  276. package/web/.next/server/chunks/ssr/_7dca1882._.js.map +1 -1
  277. package/web/.next/server/chunks/ssr/_8fcc39d4._.js +3 -0
  278. package/web/.next/server/chunks/ssr/_8fcc39d4._.js.map +1 -0
  279. package/web/.next/server/chunks/ssr/{_b71645b4._.js → _9133ca98._.js} +2 -2
  280. package/web/.next/server/chunks/ssr/{_b71645b4._.js.map → _9133ca98._.js.map} +1 -1
  281. package/web/.next/server/chunks/ssr/{_1b719e7f._.js → _913a6589._.js} +2 -2
  282. package/web/.next/server/chunks/ssr/{_1b719e7f._.js.map → _913a6589._.js.map} +1 -1
  283. package/web/.next/server/chunks/ssr/_a93b44aa._.js +3 -0
  284. package/web/.next/server/chunks/ssr/{_2a415784._.js.map → _a93b44aa._.js.map} +1 -1
  285. package/web/.next/server/chunks/ssr/{_64bdfc6f._.js → _c7d0d381._.js} +3 -3
  286. package/web/.next/server/chunks/ssr/{_64bdfc6f._.js.map → _c7d0d381._.js.map} +1 -1
  287. package/web/.next/server/chunks/ssr/_d4b20e29._.js.map +1 -1
  288. package/web/.next/server/chunks/ssr/_d8575088._.js +1 -1
  289. package/web/.next/server/chunks/ssr/_d8575088._.js.map +1 -1
  290. package/web/.next/server/chunks/ssr/{_55d763e2._.js → _e816b997._.js} +2 -2
  291. package/web/.next/server/chunks/ssr/{_37e8548b._.js.map → _e816b997._.js.map} +1 -1
  292. package/web/.next/server/chunks/ssr/_f39a1adb._.js +1 -1
  293. package/web/.next/server/chunks/ssr/_f39a1adb._.js.map +1 -1
  294. package/web/.next/server/chunks/ssr/{_37e8548b._.js → _f483d14b._.js} +2 -2
  295. package/web/.next/server/chunks/ssr/{_55d763e2._.js.map → _f483d14b._.js.map} +1 -1
  296. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js +1 -1
  297. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js.map +1 -1
  298. package/web/.next/server/chunks/ssr/src_presentation_web_0c3330d7._.js +3 -0
  299. package/web/.next/server/chunks/ssr/{src_presentation_web_721fb773._.js.map → src_presentation_web_0c3330d7._.js.map} +1 -1
  300. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_1b176e3c.js +1 -1
  301. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_1b176e3c.js.map +1 -1
  302. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_bd9f0dda.js +1 -1
  303. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_bd9f0dda.js.map +1 -1
  304. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_baaca5d5._.js +1 -1
  305. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_baaca5d5._.js.map +1 -1
  306. package/web/.next/server/chunks/ssr/src_presentation_web_ca99d62d._.js +1 -1
  307. package/web/.next/server/chunks/ssr/src_presentation_web_ca99d62d._.js.map +1 -1
  308. package/web/.next/server/chunks/ssr/src_presentation_web_components_e599bb8c._.js +1 -1
  309. package/web/.next/server/chunks/ssr/src_presentation_web_components_e599bb8c._.js.map +1 -1
  310. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js +1 -1
  311. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js.map +1 -1
  312. package/web/.next/server/pages/500.html +2 -2
  313. package/web/.next/server/server-reference-manifest.js +1 -1
  314. package/web/.next/server/server-reference-manifest.json +506 -350
  315. package/web/.next/static/chunks/{74ee98538b63a4b2.css → 080d853d319c5cc5.css} +1 -1
  316. package/web/.next/static/chunks/{41667f7f505952e6.js → 179c3052fd19c46d.js} +1 -1
  317. package/web/.next/static/chunks/{18c49ba954b15750.js → 1f4814c4adb31418.js} +1 -1
  318. package/web/.next/static/chunks/{149c88eadafaf835.js → 47d12705199052e7.js} +1 -1
  319. package/web/.next/static/chunks/{7559d0ac9e155de8.js → 524add4103e8a3b9.js} +2 -2
  320. package/web/.next/static/chunks/{c0fd9ae3d7b3ebe3.js → 6b7a1e5e9f1b014a.js} +1 -1
  321. package/web/.next/static/chunks/{08baac5434d9528e.js → 7d5e500fab64cfb5.js} +7 -7
  322. package/web/.next/static/chunks/816b98cd7e8330b5.js +1 -0
  323. package/web/.next/static/chunks/{f2a6406394a41d3c.js → 8e26be828072d7f6.js} +1 -1
  324. package/web/.next/static/chunks/9d6689f6cc4f825f.js +1 -0
  325. package/web/.next/static/chunks/{e2e3d8a7d339c110.js → a511514839eda467.js} +1 -1
  326. package/web/.next/static/chunks/{266fe61224d14058.js → d540d45e05b43599.js} +1 -1
  327. package/web/.next/static/chunks/{ed43f5ec24322234.js → ee3fb116e420b158.js} +1 -1
  328. package/web/.next/static/chunks/{37b065777853153c.js → f5a7f4c2313fad01.js} +2 -2
  329. package/web/.next/static/chunks/fa556c575c788679.js +1 -0
  330. package/web/.next/server/chunks/ssr/[root-of-the-server]__29580090._.js +0 -4
  331. package/web/.next/server/chunks/ssr/[root-of-the-server]__29580090._.js.map +0 -1
  332. package/web/.next/server/chunks/ssr/[root-of-the-server]__c094882b._.js +0 -4
  333. package/web/.next/server/chunks/ssr/[root-of-the-server]__c094882b._.js.map +0 -1
  334. package/web/.next/server/chunks/ssr/[root-of-the-server]__cb850066._.js +0 -3
  335. package/web/.next/server/chunks/ssr/[root-of-the-server]__cb850066._.js.map +0 -1
  336. package/web/.next/server/chunks/ssr/[root-of-the-server]__dac5dbf1._.js +0 -4
  337. package/web/.next/server/chunks/ssr/[root-of-the-server]__dac5dbf1._.js.map +0 -1
  338. package/web/.next/server/chunks/ssr/[root-of-the-server]__fae8b355._.js +0 -4
  339. package/web/.next/server/chunks/ssr/[root-of-the-server]__fae8b355._.js.map +0 -1
  340. package/web/.next/server/chunks/ssr/_2a415784._.js +0 -3
  341. package/web/.next/server/chunks/ssr/_a9f57758._.js +0 -3
  342. package/web/.next/server/chunks/ssr/_a9f57758._.js.map +0 -1
  343. package/web/.next/server/chunks/ssr/src_presentation_web_721fb773._.js +0 -3
  344. package/web/.next/static/chunks/6a370f2709c81d83.js +0 -1
  345. package/web/.next/static/chunks/a6f8230f1756f318.js +0 -1
  346. package/web/.next/static/chunks/d1c52a649f1c7704.js +0 -1
  347. /package/web/.next/static/{CrBDjRQwzIQuEXTobFPfK → MsLpLuZsb_IZtZfJuzG81}/_buildManifest.js +0 -0
  348. /package/web/.next/static/{CrBDjRQwzIQuEXTobFPfK → MsLpLuZsb_IZtZfJuzG81}/_clientMiddlewareManifest.json +0 -0
  349. /package/web/.next/static/{CrBDjRQwzIQuEXTobFPfK → MsLpLuZsb_IZtZfJuzG81}/_ssgManifest.js +0 -0
@@ -0,0 +1,76 @@
1
+ 'use client';
2
+ import { useState, useCallback, useRef, useEffect } from 'react';
3
+ import { generateCoastfileAction } from '../../../app/actions/generate-coastfile.js';
4
+ import { checkCoastfileAction } from '../../../app/actions/check-coastfile.js';
5
+ const ERROR_CLEAR_DELAY = 5000;
6
+ export function useCoastsActions(input) {
7
+ const repoPath = input?.repositoryPath ?? null;
8
+ const [coastfileExists, setCoastfileExists] = useState(false);
9
+ const [generating, setGenerating] = useState(false);
10
+ const [checkLoading, setCheckLoading] = useState(!!repoPath);
11
+ const [error, setError] = useState(null);
12
+ const errorTimerRef = useRef(null);
13
+ useEffect(() => {
14
+ const ref = errorTimerRef;
15
+ return () => {
16
+ if (ref.current)
17
+ clearTimeout(ref.current);
18
+ };
19
+ }, []);
20
+ // Check coastfile existence on mount — use repoPath (string) as dep to avoid infinite re-renders
21
+ useEffect(() => {
22
+ if (!repoPath)
23
+ return;
24
+ let cancelled = false;
25
+ setCheckLoading(true);
26
+ checkCoastfileAction(repoPath)
27
+ .then((result) => {
28
+ if (!cancelled) {
29
+ setCoastfileExists(result.exists);
30
+ setCheckLoading(false);
31
+ }
32
+ })
33
+ .catch(() => {
34
+ if (!cancelled) {
35
+ setCoastfileExists(false);
36
+ setCheckLoading(false);
37
+ }
38
+ });
39
+ return () => {
40
+ cancelled = true;
41
+ };
42
+ }, [repoPath]);
43
+ const handleGenerate = useCallback(async () => {
44
+ if (!repoPath || generating)
45
+ return;
46
+ if (errorTimerRef.current)
47
+ clearTimeout(errorTimerRef.current);
48
+ setGenerating(true);
49
+ setError(null);
50
+ try {
51
+ const result = await generateCoastfileAction(repoPath);
52
+ if (result.success) {
53
+ setCoastfileExists(true);
54
+ }
55
+ else {
56
+ setError(result.error ?? 'Failed to generate Coastfile');
57
+ errorTimerRef.current = setTimeout(() => setError(null), ERROR_CLEAR_DELAY);
58
+ }
59
+ }
60
+ catch (err) {
61
+ const message = err instanceof Error ? err.message : 'Failed to generate Coastfile';
62
+ setError(message);
63
+ errorTimerRef.current = setTimeout(() => setError(null), ERROR_CLEAR_DELAY);
64
+ }
65
+ finally {
66
+ setGenerating(false);
67
+ }
68
+ }, [repoPath, generating]);
69
+ return {
70
+ coastfileExists,
71
+ generating,
72
+ checkLoading,
73
+ error,
74
+ generateCoastfile: handleGenerate,
75
+ };
76
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"feature-flags-settings-section.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/feature-flags-settings-section.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAiCzE,MAAM,WAAW,gCAAgC;IAC/C,YAAY,EAAE,YAAY,CAAC;CAC5B;AAED,wBAAgB,2BAA2B,CAAC,EAAE,YAAY,EAAE,EAAE,gCAAgC,2CAgE7F"}
1
+ {"version":3,"file":"feature-flags-settings-section.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/feature-flags-settings-section.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAqCzE,MAAM,WAAW,gCAAgC;IAC/C,YAAY,EAAE,YAAY,CAAC;CAC5B;AAED,wBAAgB,2BAA2B,CAAC,EAAE,YAAY,EAAE,EAAE,gCAAgC,2CAgE7F"}
@@ -15,6 +15,7 @@ const FLAG_DESCRIPTIONS = {
15
15
  adoptBranch: 'Enable the ability to adopt existing branches as tracked features',
16
16
  gitRebaseSync: 'Enable git rebase-on-main and sync-main operations in the web UI',
17
17
  reactFileManager: 'Use the built-in React file manager instead of the native OS folder picker. Also serves as automatic fallback when the native picker is unavailable.',
18
+ coastsDevServer: 'Enable Coasts containerized runtime isolation for the dev server, providing per-worktree isolation via Docker containers',
18
19
  };
19
20
  const FLAG_LABELS = {
20
21
  skills: 'Skills',
@@ -24,6 +25,7 @@ const FLAG_LABELS = {
24
25
  adoptBranch: 'Adopt Branch',
25
26
  gitRebaseSync: 'Git Rebase & Sync',
26
27
  reactFileManager: 'React File Manager',
28
+ coastsDevServer: 'Coasts Dev Server',
27
29
  };
28
30
  const FLAG_KEYS = [
29
31
  'skills',
@@ -33,6 +35,7 @@ const FLAG_KEYS = [
33
35
  'adoptBranch',
34
36
  'gitRebaseSync',
35
37
  'reactFileManager',
38
+ 'coastsDevServer',
36
39
  ];
37
40
  export function FeatureFlagsSettingsSection({ featureFlags }) {
38
41
  const [flags, setFlags] = useState({ ...featureFlags });
@@ -1 +1 @@
1
- {"version":3,"file":"feature-flags-settings-section.stories.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/feature-flags-settings-section.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAE/E,QAAA,MAAM,IAAI;;;;;;;CAO0C,CAAC;AAErD,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAYrB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,KAYxB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAYzB,CAAC"}
1
+ {"version":3,"file":"feature-flags-settings-section.stories.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/feature-flags-settings-section.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAE/E,QAAA,MAAM,IAAI;;;;;;;CAO0C,CAAC;AAErD,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAarB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,KAaxB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAazB,CAAC"}
@@ -18,6 +18,7 @@ export const Default = {
18
18
  adoptBranch: false,
19
19
  gitRebaseSync: false,
20
20
  reactFileManager: false,
21
+ coastsDevServer: false,
21
22
  },
22
23
  },
23
24
  };
@@ -31,6 +32,7 @@ export const AllEnabled = {
31
32
  adoptBranch: true,
32
33
  gitRebaseSync: true,
33
34
  reactFileManager: true,
35
+ coastsDevServer: true,
34
36
  },
35
37
  },
36
38
  };
@@ -44,6 +46,7 @@ export const AllDisabled = {
44
46
  adoptBranch: false,
45
47
  gitRebaseSync: false,
46
48
  reactFileManager: false,
49
+ coastsDevServer: false,
47
50
  },
48
51
  },
49
52
  };
@@ -1 +1 @@
1
- {"version":3,"file":"settings-page-client.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/settings-page-client.tsx"],"names":[],"mappings":"AAkCA,OAAO,KAAK,EACV,QAAQ,EAGT,MAAM,sCAAsC,CAAC;AAC9C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AA2B/E,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,QAAQ,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,iBAAiB,EAAE,CAAC;CAC1C;AA6QD,wBAAgB,kBAAkB,CAAC,EACjC,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,kBAAkB,GACnB,EAAE,uBAAuB,2CA6pCzB"}
1
+ {"version":3,"file":"settings-page-client.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/settings-page-client.tsx"],"names":[],"mappings":"AAkCA,OAAO,KAAK,EACV,QAAQ,EAGT,MAAM,sCAAsC,CAAC;AAC9C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AA2B/E,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,QAAQ,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,iBAAiB,EAAE,CAAC;CAC1C;AA6QD,wBAAgB,kBAAkB,CAAC,EACjC,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,kBAAkB,GACnB,EAAE,uBAAuB,2CA0qCzB"}
@@ -123,6 +123,7 @@ export function SettingsPageClient({ settings, shepHome, dbFileSize, availableTe
123
123
  adoptBranch: false,
124
124
  gitRebaseSync: false,
125
125
  reactFileManager: false,
126
+ coastsDevServer: false,
126
127
  };
127
128
  // Agent state
128
129
  const [agentType, setAgentType] = useState(settings.agent.type);
@@ -506,6 +507,10 @@ export function SettingsPageClient({ settings, shepHome, dbFileSize, availableTe
506
507
  const newFlags = { ...flags, reactFileManager: v };
507
508
  setFlags(newFlags);
508
509
  save({ featureFlags: newFlags });
510
+ } }), _jsx(SwitchRow, { label: "Coasts Dev Server", description: "Enable Coasts containerized runtime isolation for the dev server", id: "flag-coastsDevServer", testId: "switch-flag-coastsDevServer", checked: flags.coastsDevServer, onChange: (v) => {
511
+ const newFlags = { ...flags, coastsDevServer: v };
512
+ setFlags(newFlags);
513
+ save({ featureFlags: newFlags });
509
514
  } })] }), _jsx(SectionHint, { children: "Experimental features that are still under development. Enable at your own risk \u2014 they may change or be removed in future versions. Debug mode adds verbose logging useful for troubleshooting." })] }), _jsxs("div", { id: "section-database", className: "grid scroll-mt-18 grid-cols-1 gap-x-5 rounded-lg lg:grid-cols-[1fr_280px]", children: [_jsxs(SettingsSection, { icon: Database, title: "Database", description: "Local storage information", testId: "database-settings-section", children: [_jsx(SettingsRow, { label: "Location", description: "Path to the local SQLite database", children: _jsx("span", { className: "text-muted-foreground max-w-50 truncate font-mono text-xs", "data-testid": "shep-home-path", children: shepHome }) }), _jsx(SettingsRow, { label: "Size", children: _jsx("span", { className: "text-muted-foreground text-xs", "data-testid": "db-file-size", children: dbFileSize }) })] }), _jsx(SectionHint, { links: [
510
515
  {
511
516
  label: 'Settings service',
@@ -1 +1 @@
1
- {"version":3,"file":"settings-page-client.stories.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/settings-page-client.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAM5D,QAAA,MAAM,IAAI;;;;;;;CAOiC,CAAC;AAE5C,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAMrB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAqBzB,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,KAa7B,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,KAsB5B,CAAC"}
1
+ {"version":3,"file":"settings-page-client.stories.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/settings/settings-page-client.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAM5D,QAAA,MAAM,IAAI;;;;;;;CAOiC,CAAC;AAE5C,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAMrB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAsBzB,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,KAa7B,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,KAsB5B,CAAC"}
@@ -34,6 +34,7 @@ export const AllSections = {
34
34
  adoptBranch: false,
35
35
  gitRebaseSync: false,
36
36
  reactFileManager: false,
37
+ coastsDevServer: false,
37
38
  },
38
39
  },
39
40
  shepHome: '/opt/shep',
@@ -1 +1 @@
1
- {"version":3,"file":"app-sidebar.stories.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/layouts/app-sidebar/app-sidebar.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAgB3C,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,UAAU,CAyBjC,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAmDnC,eAAO,MAAM,OAAO,EAAE,KAIrB,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,KAIlC,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,KAOvB,CAAC;AAEF,eAAO,MAAM,KAAK,EAAE,KAInB,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAiB3B,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,KAQrB,CAAC"}
1
+ {"version":3,"file":"app-sidebar.stories.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/layouts/app-sidebar/app-sidebar.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAiB3C,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,UAAU,CAyBjC,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAmDnC,eAAO,MAAM,OAAO,EAAE,KAIrB,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,KAIlC,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,KAOvB,CAAC;AAEF,eAAO,MAAM,KAAK,EAAE,KAInB,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAiB3B,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,KAQrB,CAAC"}
@@ -9,6 +9,7 @@ const defaultFeatureFlags = {
9
9
  adoptBranch: false,
10
10
  gitRebaseSync: false,
11
11
  reactFileManager: false,
12
+ coastsDevServer: false,
12
13
  };
13
14
  const meta = {
14
15
  title: 'Layout/AppSidebar',
@@ -20,6 +20,8 @@ import { initializeSettings } from '../../../packages/core/src/infrastructure/se
20
20
  import { initializeNotificationWatcher, getNotificationWatcher, } from '../../../packages/core/src/infrastructure/services/notifications/notification-watcher.service.js';
21
21
  import { initializePrSyncWatcher, getPrSyncWatcher, } from '../../../packages/core/src/infrastructure/services/pr-sync/pr-sync-watcher.service.js';
22
22
  import { getExistingConnection } from '../../../packages/core/src/infrastructure/persistence/sqlite/connection.js';
23
+ import { getFeatureFlags } from './lib/feature-flags.js';
24
+ import { startCoastsDevServer, shutdownCoasts } from './coasts-dev-server.js';
23
25
  const DEFAULT_PORT = 3000;
24
26
  async function isPortAvailable(port) {
25
27
  return new Promise((resolve) => {
@@ -47,6 +49,9 @@ async function findAvailablePort(startPort) {
47
49
  async function main() {
48
50
  const basePort = process.env.PORT !== undefined ? parseInt(process.env.PORT, 10) : DEFAULT_PORT;
49
51
  const port = await findAvailablePort(basePort);
52
+ // Track Coasts mode state for shutdown handler
53
+ let coastsService = null;
54
+ let coastsWorkDir = null;
50
55
  // Step 1: Initialize DI container (database + migrations)
51
56
  // Same as CLI bootstrap (src/presentation/cli/index.ts:52-58)
52
57
  try {
@@ -65,14 +70,71 @@ async function main() {
65
70
  getNotificationWatcher().start();
66
71
  // Start PR sync watcher to detect PR/CI status transitions on GitHub
67
72
  const gitPrService = container.resolve('IGitPrService');
73
+ const gitForkService = container.resolve('IGitForkService');
68
74
  const db = getExistingConnection();
69
- initializePrSyncWatcher(featureRepo, runRepo, gitPrService, notificationService, undefined, db);
75
+ initializePrSyncWatcher(featureRepo, runRepo, gitPrService, notificationService, undefined, db, gitForkService);
70
76
  getPrSyncWatcher().start();
71
77
  }
72
78
  catch (error) {
73
79
  console.warn('[dev-server] DI initialization failed — features will be empty:', error);
74
80
  }
75
- // Step 2: Clean up lock file to allow multiple dev instances
81
+ // Step 2: Check coastsDevServer feature flag — branch to Coasts mode or bare Next.js
82
+ const flags = getFeatureFlags();
83
+ if (flags.coastsDevServer) {
84
+ // --- Coasts mode: containerized runtime isolation ---
85
+ const workDir = process.cwd();
86
+ try {
87
+ const service = container.resolve('ICoastsService');
88
+ const instance = await startCoastsDevServer(service, workDir);
89
+ coastsService = service;
90
+ coastsWorkDir = workDir;
91
+ console.log(`[dev-server:coasts] Dev server running in Coasts mode at ${instance.url}`);
92
+ }
93
+ catch (error) {
94
+ console.error('[dev-server:coasts] Failed to start Coasts dev server:', error);
95
+ process.exit(1);
96
+ }
97
+ // Graceful shutdown for Coasts mode
98
+ let isShuttingDown = false;
99
+ const shutdown = async () => {
100
+ if (isShuttingDown)
101
+ return;
102
+ isShuttingDown = true;
103
+ console.log('\n[dev-server:coasts] Shutting down...');
104
+ const forceExit = setTimeout(() => process.exit(0), 2000);
105
+ try {
106
+ await shutdownCoasts(coastsService, coastsWorkDir);
107
+ try {
108
+ const deploymentService = container.resolve('IDeploymentService');
109
+ deploymentService.stopAll();
110
+ }
111
+ catch {
112
+ /* not initialized */
113
+ }
114
+ try {
115
+ getNotificationWatcher().stop();
116
+ }
117
+ catch {
118
+ /* not initialized */
119
+ }
120
+ try {
121
+ getPrSyncWatcher().stop();
122
+ }
123
+ catch {
124
+ /* not initialized */
125
+ }
126
+ }
127
+ finally {
128
+ clearTimeout(forceExit);
129
+ process.exit(0);
130
+ }
131
+ };
132
+ process.on('SIGINT', shutdown);
133
+ process.on('SIGTERM', shutdown);
134
+ return;
135
+ }
136
+ // --- Bare mode: standard Next.js dev server (default, unchanged) ---
137
+ // Clean up lock file to allow multiple dev instances
76
138
  const lockPath = path.join(import.meta.dirname, '.next', 'dev', 'lock');
77
139
  try {
78
140
  fs.rmSync(lockPath, { force: true });
@@ -1 +1 @@
1
- {"version":3,"file":"feature-flags-context.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/hooks/feature-flags-context.tsx"],"names":[],"mappings":"AAEA,OAAO,EAA6B,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAClE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAc7D,UAAU,yBAAyB;IACjC,QAAQ,EAAE,SAAS,CAAC;IACpB,KAAK,EAAE,iBAAiB,CAAC;CAC1B;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,yBAAyB,2CAElF;AAED;;;GAGG;AACH,wBAAgB,eAAe,IAAI,iBAAiB,CAEnD"}
1
+ {"version":3,"file":"feature-flags-context.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/hooks/feature-flags-context.tsx"],"names":[],"mappings":"AAEA,OAAO,EAA6B,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAClE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAe7D,UAAU,yBAAyB;IACjC,QAAQ,EAAE,SAAS,CAAC;IACpB,KAAK,EAAE,iBAAiB,CAAC;CAC1B;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,yBAAyB,2CAElF;AAED;;;GAGG;AACH,wBAAgB,eAAe,IAAI,iBAAiB,CAEnD"}
@@ -9,6 +9,7 @@ const defaultFlags = {
9
9
  adoptBranch: false,
10
10
  gitRebaseSync: false,
11
11
  reactFileManager: false,
12
+ coastsDevServer: false,
12
13
  };
13
14
  const FeatureFlagsContext = createContext(defaultFlags);
14
15
  /**
@@ -13,6 +13,7 @@ export interface FeatureFlagsState {
13
13
  adoptBranch: boolean;
14
14
  gitRebaseSync: boolean;
15
15
  reactFileManager: boolean;
16
+ coastsDevServer: boolean;
16
17
  }
17
18
  export declare function getFeatureFlags(): FeatureFlagsState;
18
19
  /**
@@ -27,5 +28,6 @@ export declare const featureFlags: {
27
28
  readonly adoptBranch: boolean;
28
29
  readonly gitRebaseSync: boolean;
29
30
  readonly reactFileManager: boolean;
31
+ readonly coastsDevServer: boolean;
30
32
  };
31
33
  //# sourceMappingURL=feature-flags.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"feature-flags.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/lib/feature-flags.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAQH,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,OAAO,CAAC;IAChB,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,OAAO,CAAC;IACf,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,OAAO,CAAC;IACrB,aAAa,EAAE,OAAO,CAAC;IACvB,gBAAgB,EAAE,OAAO,CAAC;CAC3B;AAED,wBAAgB,eAAe,IAAI,iBAAiB,CAgCnD;AAED;;;GAGG;AACH,eAAO,MAAM,YAAY;;;;;;;;CAsBf,CAAC"}
1
+ {"version":3,"file":"feature-flags.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/lib/feature-flags.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAQH,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,OAAO,CAAC;IAChB,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,OAAO,CAAC;IACf,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,OAAO,CAAC;IACrB,aAAa,EAAE,OAAO,CAAC;IACvB,gBAAgB,EAAE,OAAO,CAAC;IAC1B,eAAe,EAAE,OAAO,CAAC;CAC1B;AAED,wBAAgB,eAAe,IAAI,iBAAiB,CAkCnD;AAED;;;GAGG;AACH,eAAO,MAAM,YAAY;;;;;;;;;CAyBf,CAAC"}
@@ -22,6 +22,7 @@ export function getFeatureFlags() {
22
22
  adoptBranch: flags.adoptBranch,
23
23
  gitRebaseSync: flags.gitRebaseSync,
24
24
  reactFileManager: flags.reactFileManager,
25
+ coastsDevServer: flags.coastsDevServer,
25
26
  };
26
27
  }
27
28
  }
@@ -39,6 +40,7 @@ export function getFeatureFlags() {
39
40
  adoptBranch: false,
40
41
  gitRebaseSync: false,
41
42
  reactFileManager: isEnabled(process.env.NEXT_PUBLIC_FLAG_REACT_FILE_MANAGER),
43
+ coastsDevServer: isEnabled(process.env.NEXT_PUBLIC_FLAG_COASTS_DEV_SERVER),
42
44
  };
43
45
  }
44
46
  /**
@@ -67,4 +69,7 @@ export const featureFlags = {
67
69
  get reactFileManager() {
68
70
  return getFeatureFlags().reactFileManager;
69
71
  },
72
+ get coastsDevServer() {
73
+ return getFeatureFlags().coastsDevServer;
74
+ },
70
75
  };